react-semaphor 0.0.501 → 0.0.502

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 Ot=s=>{throw TypeError(s)};var Je=(s,a,n)=>a.has(s)||Ot("Cannot "+n);var W=(s,a,n)=>(Je(s,a,"read from private field"),n?n.call(s):a.get(s)),oe=(s,a,n)=>a.has(s)?Ot("Cannot add the same private member more than once"):a instanceof WeakSet?a.add(s):a.set(s,n),te=(s,a,n,r)=>(Je(s,a,"write to private field"),r?r.call(s,n):a.set(s,n),n),ie=(s,a,n)=>(Je(s,a,"access private method"),n);const e=require("react/jsx-runtime"),t=require("./index-_4KUL8lP.js"),L=require("react");require("react-dom");function Os(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 re=Os(L);function Ft(s,a){return s.filter(n=>!a.includes(n))}function Fs(s,a,n){const r=s.slice(0);return r[a]=n,r}var pe,ne,Ce,Ne,ae,he,Ie,De,Te,ee,tt,st,nt,at,rt,Ht,zs=(Ht=class extends t.Subscribable{constructor(a,n,r){super();oe(this,ee);oe(this,pe);oe(this,ne);oe(this,Ce);oe(this,Ne);oe(this,ae);oe(this,he);oe(this,Ie);oe(this,De);oe(this,Te,[]);te(this,pe,a),te(this,Ne,r),te(this,Ce,[]),te(this,ae,[]),te(this,ne,[]),this.setQueries(n)}onSubscribe(){this.listeners.size===1&&W(this,ae).forEach(a=>{a.subscribe(n=>{ie(this,ee,at).call(this,a,n)})})}onUnsubscribe(){this.listeners.size||this.destroy()}destroy(){this.listeners=new Set,W(this,ae).forEach(a=>{a.destroy()})}setQueries(a,n,r){if(te(this,Ce,a),te(this,Ne,n),process.env.NODE_ENV!=="production"){const o=a.map(i=>W(this,pe).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=W(this,ae),i=ie(this,ee,nt).call(this,W(this,Ce));te(this,Te,i),i.forEach(h=>h.observer.setOptions(h.defaultedQueryOptions,r));const l=i.map(h=>h.observer),u=l.map(h=>h.getCurrentResult()),c=l.some((h,d)=>h!==o[d]);o.length===l.length&&!c||(te(this,ae,l),te(this,ne,u),this.hasListeners()&&(Ft(o,l).forEach(h=>{h.destroy()}),Ft(l,o).forEach(h=>{h.subscribe(d=>{ie(this,ee,at).call(this,h,d)})}),ie(this,ee,rt).call(this)))})}getCurrentResult(){return W(this,ne)}getQueries(){return W(this,ae).map(a=>a.getCurrentQuery())}getObservers(){return W(this,ae)}getOptimisticResult(a,n){const r=ie(this,ee,nt).call(this,a),o=r.map(i=>i.observer.getOptimisticResult(i.defaultedQueryOptions));return[o,i=>ie(this,ee,st).call(this,i??o,n),()=>ie(this,ee,tt).call(this,o,r)]}},pe=new WeakMap,ne=new WeakMap,Ce=new WeakMap,Ne=new WeakMap,ae=new WeakMap,he=new WeakMap,Ie=new WeakMap,De=new WeakMap,Te=new WeakMap,ee=new WeakSet,tt=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)})})})},st=function(a,n){return n?((!W(this,he)||W(this,ne)!==W(this,De)||n!==W(this,Ie))&&(te(this,Ie,n),te(this,De,W(this,ne)),te(this,he,t.replaceEqualDeep(W(this,he),n(a)))),W(this,he)):a},nt=function(a){const n=new Map(W(this,ae).map(o=>[o.options.queryHash,o])),r=[];return a.forEach(o=>{const i=W(this,pe).defaultQueryOptions(o),l=n.get(i.queryHash);l?r.push({defaultedQueryOptions:i,observer:l}):r.push({defaultedQueryOptions:i,observer:new t.QueryObserver(W(this,pe),i)})}),r},at=function(a,n){const r=W(this,ae).indexOf(a);r!==-1&&(te(this,ne,Fs(W(this,ne),r,n)),ie(this,ee,rt).call(this))},rt=function(){var a;if(this.hasListeners()){const n=W(this,he),r=ie(this,ee,tt).call(this,W(this,ne),W(this,Te)),o=ie(this,ee,st).call(this,r,(a=W(this,Ne))==null?void 0:a.combine);n!==o&&t.notifyManager.batch(()=>{this.listeners.forEach(i=>{i(W(this,ne))})})}},Ht);function Bs({queries:s,...a},n){const r=t.useQueryClient(),o=t.useIsRestoring(),i=t.useQueryErrorResetBoundary(),l=re.useMemo(()=>s.map(x=>{const b=r.defaultQueryOptions(x);return b._optimisticResults=o?"isRestoring":"optimistic",b}),[s,r,o]);l.forEach(x=>{t.ensureSuspenseTimers(x),t.ensurePreventErrorBoundaryRetry(x,i)}),t.useClearResetErrorBoundary(i);const[u]=re.useState(()=>new zs(r,l,a)),[c,h,d]=u.getOptimisticResult(l,a.combine),m=!o&&a.subscribed!==!1;re.useSyncExternalStore(re.useCallback(x=>m?u.subscribe(t.notifyManager.batchCalls(x)):t.noop,[u,m]),()=>u.getCurrentResult(),()=>u.getCurrentResult()),re.useEffect(()=>{u.setQueries(l,a,{listeners:!1})},[l,a,u]);const p=c.some((x,b)=>t.shouldSuspend(l[b],x))?c.flatMap((x,b)=>{const f=l[b];if(f){const k=new t.QueryObserver(r,f);if(t.shouldSuspend(f,x))return t.fetchOptimistic(f,k,i);t.willFetch(x,o)&&t.fetchOptimistic(f,k,i)}return[]}):[];if(p.length>0)throw Promise.all(p);const j=c.find((x,b)=>{const f=l[b];return f&&t.getHasError({result:x,errorResetBoundary:i,throwOnError:f.throwOnError,query:r.getQueryCache().get(f.queryHash),suspense:f.suspense})});if(j!=null&&j.error)throw j.error;return h(d())}/**
1
+ "use strict";var Ot=s=>{throw TypeError(s)};var Je=(s,a,n)=>a.has(s)||Ot("Cannot "+n);var W=(s,a,n)=>(Je(s,a,"read from private field"),n?n.call(s):a.get(s)),ie=(s,a,n)=>a.has(s)?Ot("Cannot add the same private member more than once"):a instanceof WeakSet?a.add(s):a.set(s,n),te=(s,a,n,r)=>(Je(s,a,"write to private field"),r?r.call(s,n):a.set(s,n),n),oe=(s,a,n)=>(Je(s,a,"access private method"),n);const e=require("react/jsx-runtime"),t=require("./index-B2SUjbFs.js"),L=require("react");require("react-dom");function Os(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 re=Os(L);function Ft(s,a){return s.filter(n=>!a.includes(n))}function Fs(s,a,n){const r=s.slice(0);return r[a]=n,r}var pe,ne,Ne,Ce,ae,he,Ie,De,Te,ee,tt,st,nt,at,rt,Ht,Bs=(Ht=class extends t.Subscribable{constructor(a,n,r){super();ie(this,ee);ie(this,pe);ie(this,ne);ie(this,Ne);ie(this,Ce);ie(this,ae);ie(this,he);ie(this,Ie);ie(this,De);ie(this,Te,[]);te(this,pe,a),te(this,Ce,r),te(this,Ne,[]),te(this,ae,[]),te(this,ne,[]),this.setQueries(n)}onSubscribe(){this.listeners.size===1&&W(this,ae).forEach(a=>{a.subscribe(n=>{oe(this,ee,at).call(this,a,n)})})}onUnsubscribe(){this.listeners.size||this.destroy()}destroy(){this.listeners=new Set,W(this,ae).forEach(a=>{a.destroy()})}setQueries(a,n,r){if(te(this,Ne,a),te(this,Ce,n),process.env.NODE_ENV!=="production"){const i=a.map(o=>W(this,pe).defaultQueryOptions(o).queryHash);new Set(i).size!==i.length&&console.warn("[QueriesObserver]: Duplicate Queries found. This might result in unexpected behavior.")}t.notifyManager.batch(()=>{const i=W(this,ae),o=oe(this,ee,nt).call(this,W(this,Ne));te(this,Te,o),o.forEach(h=>h.observer.setOptions(h.defaultedQueryOptions,r));const l=o.map(h=>h.observer),u=l.map(h=>h.getCurrentResult()),c=l.some((h,d)=>h!==i[d]);i.length===l.length&&!c||(te(this,ae,l),te(this,ne,u),this.hasListeners()&&(Ft(i,l).forEach(h=>{h.destroy()}),Ft(l,i).forEach(h=>{h.subscribe(d=>{oe(this,ee,at).call(this,h,d)})}),oe(this,ee,rt).call(this)))})}getCurrentResult(){return W(this,ne)}getQueries(){return W(this,ae).map(a=>a.getCurrentQuery())}getObservers(){return W(this,ae)}getOptimisticResult(a,n){const r=oe(this,ee,nt).call(this,a),i=r.map(o=>o.observer.getOptimisticResult(o.defaultedQueryOptions));return[i,o=>oe(this,ee,st).call(this,o??i,n),()=>oe(this,ee,tt).call(this,i,r)]}},pe=new WeakMap,ne=new WeakMap,Ne=new WeakMap,Ce=new WeakMap,ae=new WeakMap,he=new WeakMap,Ie=new WeakMap,De=new WeakMap,Te=new WeakMap,ee=new WeakSet,tt=function(a,n){return n.map((r,i)=>{const o=a[i];return r.defaultedQueryOptions.notifyOnChangeProps?o:r.observer.trackResult(o,l=>{n.forEach(u=>{u.observer.trackProp(l)})})})},st=function(a,n){return n?((!W(this,he)||W(this,ne)!==W(this,De)||n!==W(this,Ie))&&(te(this,Ie,n),te(this,De,W(this,ne)),te(this,he,t.replaceEqualDeep(W(this,he),n(a)))),W(this,he)):a},nt=function(a){const n=new Map(W(this,ae).map(i=>[i.options.queryHash,i])),r=[];return a.forEach(i=>{const o=W(this,pe).defaultQueryOptions(i),l=n.get(o.queryHash);l?r.push({defaultedQueryOptions:o,observer:l}):r.push({defaultedQueryOptions:o,observer:new t.QueryObserver(W(this,pe),o)})}),r},at=function(a,n){const r=W(this,ae).indexOf(a);r!==-1&&(te(this,ne,Fs(W(this,ne),r,n)),oe(this,ee,rt).call(this))},rt=function(){var a;if(this.hasListeners()){const n=W(this,he),r=oe(this,ee,tt).call(this,W(this,ne),W(this,Te)),i=oe(this,ee,st).call(this,r,(a=W(this,Ce))==null?void 0:a.combine);n!==i&&t.notifyManager.batch(()=>{this.listeners.forEach(o=>{o(W(this,ne))})})}},Ht);function zs({queries:s,...a},n){const r=t.useQueryClient(),i=t.useIsRestoring(),o=t.useQueryErrorResetBoundary(),l=re.useMemo(()=>s.map(x=>{const b=r.defaultQueryOptions(x);return b._optimisticResults=i?"isRestoring":"optimistic",b}),[s,r,i]);l.forEach(x=>{t.ensureSuspenseTimers(x),t.ensurePreventErrorBoundaryRetry(x,o)}),t.useClearResetErrorBoundary(o);const[u]=re.useState(()=>new Bs(r,l,a)),[c,h,d]=u.getOptimisticResult(l,a.combine),m=!i&&a.subscribed!==!1;re.useSyncExternalStore(re.useCallback(x=>m?u.subscribe(t.notifyManager.batchCalls(x)):t.noop,[u,m]),()=>u.getCurrentResult(),()=>u.getCurrentResult()),re.useEffect(()=>{u.setQueries(l,a,{listeners:!1})},[l,a,u]);const p=c.some((x,b)=>t.shouldSuspend(l[b],x))?c.flatMap((x,b)=>{const f=l[b];if(f){const k=new t.QueryObserver(r,f);if(t.shouldSuspend(f,x))return t.fetchOptimistic(f,k,o);t.willFetch(x,i)&&t.fetchOptimistic(f,k,o)}return[]}):[];if(p.length>0)throw Promise.all(p);const j=c.find((x,b)=>{const f=l[b];return f&&t.getHasError({result:x,errorResetBoundary:o,throwOnError:f.throwOnError,query:r.getQueryCache().get(f.queryHash),suspense:f.suspense})});if(j!=null&&j.error)throw j.error;return h(d())}/**
2
2
  * @license lucide-react v0.453.0 - ISC
3
3
  *
4
4
  * This source code is licensed under the ISC license.
@@ -8,12 +8,12 @@
8
8
  *
9
9
  * This source code is licensed under the ISC license.
10
10
  * See the LICENSE file in the root directory of this source tree.
11
- */const Vs=t.createLucideIcon("AlignLeft",[["path",{d:"M15 12H3",key:"6jk70r"}],["path",{d:"M17 18H3",key:"1amg6g"}],["path",{d:"M21 6H3",key:"1jwq7v"}]]);/**
11
+ */const Ps=t.createLucideIcon("AlignLeft",[["path",{d:"M15 12H3",key:"6jk70r"}],["path",{d:"M17 18H3",key:"1amg6g"}],["path",{d:"M21 6H3",key:"1jwq7v"}]]);/**
12
12
  * @license lucide-react v0.453.0 - ISC
13
13
  *
14
14
  * This source code is licensed under the ISC license.
15
15
  * See the LICENSE file in the root directory of this source tree.
16
- */const Ps=t.createLucideIcon("AlignRight",[["path",{d:"M21 12H9",key:"dn1m92"}],["path",{d:"M21 18H7",key:"1ygte8"}],["path",{d:"M21 6H3",key:"1jwq7v"}]]);/**
16
+ */const Vs=t.createLucideIcon("AlignRight",[["path",{d:"M21 12H9",key:"dn1m92"}],["path",{d:"M21 18H7",key:"1ygte8"}],["path",{d:"M21 6H3",key:"1jwq7v"}]]);/**
17
17
  * @license lucide-react v0.453.0 - ISC
18
18
  *
19
19
  * This source code is licensed under the ISC license.
@@ -268,12 +268,12 @@
268
268
  *
269
269
  * This source code is licensed under the ISC license.
270
270
  * See the LICENSE file in the root directory of this source tree.
271
- */const Cn=t.createLucideIcon("Logs",[["path",{d:"M13 12h8",key:"h98zly"}],["path",{d:"M13 18h8",key:"oe0vm4"}],["path",{d:"M13 6h8",key:"15sg57"}],["path",{d:"M3 12h1",key:"lp3yf2"}],["path",{d:"M3 18h1",key:"1eiwyy"}],["path",{d:"M3 6h1",key:"rgxa97"}],["path",{d:"M8 12h1",key:"1con00"}],["path",{d:"M8 18h1",key:"13wk12"}],["path",{d:"M8 6h1",key:"tn6mkg"}]]);/**
271
+ */const Nn=t.createLucideIcon("Logs",[["path",{d:"M13 12h8",key:"h98zly"}],["path",{d:"M13 18h8",key:"oe0vm4"}],["path",{d:"M13 6h8",key:"15sg57"}],["path",{d:"M3 12h1",key:"lp3yf2"}],["path",{d:"M3 18h1",key:"1eiwyy"}],["path",{d:"M3 6h1",key:"rgxa97"}],["path",{d:"M8 12h1",key:"1con00"}],["path",{d:"M8 18h1",key:"13wk12"}],["path",{d:"M8 6h1",key:"tn6mkg"}]]);/**
272
272
  * @license lucide-react v0.453.0 - ISC
273
273
  *
274
274
  * This source code is licensed under the ISC license.
275
275
  * See the LICENSE file in the root directory of this source tree.
276
- */const Nn=t.createLucideIcon("Mail",[["rect",{width:"20",height:"16",x:"2",y:"4",rx:"2",key:"18n3k1"}],["path",{d:"m22 7-8.97 5.7a1.94 1.94 0 0 1-2.06 0L2 7",key:"1ocrg3"}]]);/**
276
+ */const Cn=t.createLucideIcon("Mail",[["rect",{width:"20",height:"16",x:"2",y:"4",rx:"2",key:"18n3k1"}],["path",{d:"m22 7-8.97 5.7a1.94 1.94 0 0 1-2.06 0L2 7",key:"1ocrg3"}]]);/**
277
277
  * @license lucide-react v0.453.0 - ISC
278
278
  *
279
279
  * This source code is licensed under the ISC license.
@@ -298,12 +298,12 @@
298
298
  *
299
299
  * This source code is licensed under the ISC license.
300
300
  * See the LICENSE file in the root directory of this source tree.
301
- */const zt=t.createLucideIcon("MoveHorizontal",[["path",{d:"m18 8 4 4-4 4",key:"1ak13k"}],["path",{d:"M2 12h20",key:"9i4pu4"}],["path",{d:"m6 8-4 4 4 4",key:"15zrgr"}]]);/**
301
+ */const Bt=t.createLucideIcon("MoveHorizontal",[["path",{d:"m18 8 4 4-4 4",key:"1ak13k"}],["path",{d:"M2 12h20",key:"9i4pu4"}],["path",{d:"m6 8-4 4 4 4",key:"15zrgr"}]]);/**
302
302
  * @license lucide-react v0.453.0 - ISC
303
303
  *
304
304
  * This source code is licensed under the ISC license.
305
305
  * See the LICENSE file in the root directory of this source tree.
306
- */const Bt=t.createLucideIcon("MoveVertical",[["path",{d:"M12 2v20",key:"t6zp3m"}],["path",{d:"m8 18 4 4 4-4",key:"bh5tu3"}],["path",{d:"m8 6 4-4 4 4",key:"ybng9g"}]]);/**
306
+ */const zt=t.createLucideIcon("MoveVertical",[["path",{d:"M12 2v20",key:"t6zp3m"}],["path",{d:"m8 18 4 4 4-4",key:"bh5tu3"}],["path",{d:"m8 6 4-4 4 4",key:"ybng9g"}]]);/**
307
307
  * @license lucide-react v0.453.0 - ISC
308
308
  *
309
309
  * This source code is licensed under the ISC license.
@@ -383,7 +383,7 @@
383
383
  *
384
384
  * This source code is licensed under the ISC license.
385
385
  * See the LICENSE file in the root directory of this source tree.
386
- */const Zt=t.createLucideIcon("Type",[["polyline",{points:"4 7 4 4 20 4 20 7",key:"1nosan"}],["line",{x1:"9",x2:"15",y1:"20",y2:"20",key:"swin9y"}],["line",{x1:"12",x2:"12",y1:"4",y2:"20",key:"1tx1rr"}]]);function Ct(s){var a;return{...s,sheets:(a=s==null?void 0:s.sheets)==null?void 0:a.map(n=>{var r;return{...n,frames:(r=n.frames)==null?void 0:r.map(o=>{var i;return{...o,cards:(i=o.cards)==null?void 0:i.map(l=>es(l))}})}})}}function es(s){return{...s,customCfg:On(s.customCfg),data:[]}}function On(s){var a,n;return s?{...s,data:{...s==null?void 0:s.data,labels:[],datasets:(n=(a=s==null?void 0:s.data)==null?void 0:a.datasets)==null?void 0:n.map(r=>({...r,data:[]}))}}:null}async function Fn(s,a,n,r){if(!r)return null;const o=JSON.stringify(a);return await t.postRequest("https://semaphor.cloud/api/v1/lens",r,{name:s,template:o,filterValues:n,operation:"create"})}async function ot(s,a){if(!a)return null;const{id:n,template:r,filterValues:o,isDefault:i,shared:l}=s;return await t.postRequest("https://semaphor.cloud/api/v1/lens",a,{lensId:n,template:r,filterValues:o,isDefault:i,shared:l,operation:"update"})}async function zn(s,a){return a?await t.postRequest("https://semaphor.cloud/api/v1/lens",a,{operation:"delete",lensId:s}):null}function Bn(){const[s,a]=L.useState(""),[n,r]=L.useState(!1),o=t.useDashboardStore(x=>x.lenses),{setLenses:i,setSelectedLensId:l}=t.useDashboardActions(),[u,c]=L.useState(!1),[h,d]=L.useState(!1),m=t.useDashboardStore(x=>x.dashboard),g=t.useDashboardStore(x=>x.filterValues),{authToken:p}=t.useSemaphorContext();async function j(){c(!0);const x=Ct(m),b=await Fn(s,x,g,p==null?void 0:p.accessToken);b&&(i([...o||[],b]),l(b.id),d(!1)),c(!1)}return e.jsxs(t.Dialog,{open:h,onOpenChange:d,children:[e.jsx(t.DialogTrigger,{asChild:!0,children:e.jsxs(t.Button,{variant:"secondary",className:"h-7 p-2",size:"sm",children:[e.jsx(t.Plus,{className:"mr-2 h-4 w-4"}),"Lens"]})}),e.jsxs(t.DialogContent,{className:"sm:max-w-[425px]",children:[e.jsxs(t.DialogHeader,{children:[e.jsx(t.DialogTitle,{children:"Create Lens"}),e.jsx(t.DialogDescription,{children:"Lenses are private by default and are only visible to you."})]}),e.jsx("div",{className:"grid gap-4 py-4",children:e.jsxs("div",{className:"grid grid-cols-8 items-center gap-4",children:[e.jsx(t.Label,{className:"text-right",children:"Name"}),e.jsx(t.Input,{value:s,onChange:x=>{a(x.target.value)},id:"name",className:"col-span-7 focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0"})]})}),n&&e.jsx("p",{className:"text-sm",children:"The lens name already exists. Use a differnet name."}),e.jsx(t.DialogFooter,{children:e.jsx(t.Button,{size:"sm",variant:"outline",type:"submit",onClick:j,disabled:u,children:u?"Creating...":"Add"})})]})]})}function Rn(){const[s,a]=L.useState(!1),n=t.useDashboardStore(d=>d.lenses),r=t.useDashboardStore(d=>d.selectedLensId),{setLenses:o,setSelectedLensId:i}=t.useDashboardActions(),{authToken:l}=t.useSemaphorContext();async function u(d){i(d)}async function c(d){if(await zn(d,l==null?void 0:l.accessToken)){const g=n==null?void 0:n.filter(p=>p.id!==d);o(g||[]),i("original")}}async function h(d){const m=n==null?void 0:n.map(j=>j.id===d.id?{...j,isDefault:!d.isDefault}:{...j,isDefault:!1});o(m||[]);const g={...d,isDefault:!d.isDefault};await ot(g,l==null?void 0:l.accessToken);const p=n==null?void 0:n.find(j=>j.isDefault);if(p&&p.id!==d.id){const j={...p,isDefault:!1};await ot(j,l==null?void 0:l.accessToken)}}return e.jsxs(t.DropdownMenu,{open:s,onOpenChange:a,children:[e.jsx(t.DropdownMenuTrigger,{asChild:!0,children:e.jsx(t.IconButton,{tooltip:"Lenses",className:"h-7 p-2",children:e.jsx(xn,{className:"h-4 w-4"})})}),e.jsxs(t.DropdownMenuContent,{align:"end",className:"w-60",children:[e.jsx(t.DropdownMenuLabel,{className:"px-3",children:"Lenses"}),e.jsx(t.DropdownMenuSeparator,{}),e.jsxs(t.DropdownMenuRadioGroup,{value:r,onValueChange:u,children:[e.jsx(t.DropdownMenuRadioItem,{value:"original",children:"Original"}),n==null?void 0:n.map(d=>e.jsxs(t.DropdownMenuRadioItem,{className:"group flex justify-between gap-2",value:d.id,children:[e.jsx("p",{children:d.name}),e.jsxs("span",{className:"flex items-center gap-3",children:[e.jsx(gn,{onClick:m=>{m.preventDefault(),h(d)},className:t.cn("size-3.5 text-muted-foreground hover:cursor-pointer hover:text-foreground group-hover:visible",{invisible:!d.isDefault,"text-green-500":d.isDefault}),strokeWidth:1.5}),e.jsx(t.Cross2Icon,{onClick:m=>{m.preventDefault(),c(d.id)},className:"invisible size-3.5 text-muted-foreground hover:cursor-pointer hover:text-foreground group-hover:visible",strokeWidth:1.5})]})]},d.id))]})]})]})}function ts(){var i;const s=t.useDashboardStore.getState().authToken,a=t.useDashboardStore.getState().theme,n=t.useDashboardStore.getState().filterValues,r=(i=t.useDashboardStore.getState().dashboard)==null?void 0:i.title,o=t.useDashboardStore.getState().selectedSheetId;return{authToken:s,theme:a||"light",filterValues:n,dashboardTitle:r||"",selectedSheetId:o||""}}async function ss(){const s=t.useDashboardStore.getState().isDownloadingPdf,{authToken:a,theme:n,filterValues:r,dashboardTitle:o,selectedSheetId:i}=ts();if(s)return;const l=new URLSearchParams;l.set("token",(a==null?void 0:a.accessToken)||""),l.set("theme",n),l.set("filterValues",JSON.stringify(r)),l.set("selectedSheetId",i||"");const u=`https://semaphor.cloud/api/v1/generate-pdf?params=${encodeURIComponent(l.toString())}`;t.useDashboardStore.setState({isDownloadingPdf:!0});const d=(await(await fetch(u,{method:"GET",headers:{Authorization:`Bearer ${a==null?void 0:a.accessToken}`}})).json()).url,m=document.createElement("a");m.href=d;const g=`${o}-${new Date().toISOString()}.pdf`;m.download=g,m.click(),t.useDashboardStore.setState({isDownloadingPdf:!1})}function Vn({iconClassName:s}){const{authToken:a}=t.useSemaphorContext();t.useDashboardStore(o=>{var i;return(i=o.dashboard)==null?void 0:i.title}),t.useDashboardStore(o=>o.theme),t.useDashboardStore(o=>o.filterValues);const n=t.useDashboardStore(o=>o.isDownloadingPdf);async function r(){await ss()}return e.jsx(t.IconButton,{tooltip:"Download PDF",className:"h-7 p-2",onClick:r,children:n?e.jsx(ce,{className:t.cn("size-3.5 animate-spin",s)}):e.jsx(t.Download,{className:t.cn("size-4",s)})})}function le({defaultValue:s,label:a,options:n,value:r,onValueChange:o,className:i,icon:l,showPlaceholderLabel:u=!0}){return e.jsxs(t.Select,{defaultValue:s,value:r,onValueChange:o,children:[e.jsx(t.SelectTrigger,{className:t.cn("w-full focus:ring-0 focus:ring-offset-0",i),children:e.jsxs("div",{className:"flex items-center gap-2",children:[l&&e.jsx("span",{children:l}),u&&e.jsx(t.SelectValue,{placeholder:a})]})}),e.jsx(t.SelectContent,{children:e.jsxs(t.SelectGroup,{children:[e.jsx(t.SelectLabel,{children:a}),n.map(c=>e.jsx(t.SelectItem,{value:c.value,children:c.label},c.value))]})})]})}const Rt=[{value:"daily",label:"Daily"},{value:"weekly",label:"Weekly"},{value:"biweekly",label:"Bi-Weekly"},{value:"monthly",label:"Monthly"}];function ns({triggerButtonClassName:s}){const{data:a,handleScheduleSubscription:n,handleDeleteSubscription:r,status:o,error:i,isDeleting:l}=Pn(),[u,c]=L.useState(""),[h,d]=L.useState(Rt[0].value),[m,g]=L.useState("06:00"),[p,j]=L.useState("");return e.jsx(t.TooltipProvider,{delayDuration:0,children:e.jsxs(t.Popover,{children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsx(t.IconButton,{tooltip:"Schedule Dashboard",className:t.cn("h-7 p-2",s),children:e.jsx(sn,{className:"size-4"})})}),e.jsx(t.PopoverContent,{align:"end",className:"w-80",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:"Schedule Subscription"}),e.jsx("p",{className:"text-sm text-muted-foreground",children:"Subscribe to receive dashboard via email"})]}),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:"email",children:"Email"}),e.jsx(t.Input,{id:"email",value:u,onChange:x=>c(x.target.value),className:`col-span-2 h-8 ${t.removeRing}`})]}),e.jsxs("div",{className:"grid grid-cols-3 items-center gap-4",children:[e.jsx(t.Label,{htmlFor:"subject",children:"Subject"}),e.jsx(t.Input,{id:"subject",placeholder:"Monthly Sales Report",value:p,onChange:x=>{j(x.target.value.replace(/[^a-zA-Z0-9\s-_]/g,""))},className:`col-span-2 h-8 ${t.removeRing}`})]}),e.jsxs("div",{className:"grid grid-cols-3 items-center gap-4",children:[e.jsx(t.Label,{htmlFor:"frequency",children:"Frequency"}),e.jsx(le,{className:"col-span-2 h-8",label:"Select Frequency",options:Rt,value:h,onValueChange:x=>d(x)})]}),e.jsxs("div",{className:"grid grid-cols-3 items-center gap-4",children:[e.jsx(t.Label,{htmlFor:"time",children:"Time"}),e.jsx(t.Input,{id:"time",type:"time",value:m,onChange:x=>g(x.target.value),className:`col-span-2 h-8 ${t.removeRing}`})]}),e.jsx("div",{className:"mt-2 flex justify-end",children:e.jsxs(t.Button,{onClick:async()=>{await n({email:u,frequency:h,time:m,subject:p}),g("00:00"),c(""),j("")},className:"h-8 p-2",disabled:o==="loading"||!u,children:[o==="loading"&&e.jsx(ce,{className:"mr-2 size-4 animate-spin"}),o==="success"&&e.jsx(t.Check,{className:"mr-2 size-4"}),o==="error"&&e.jsxs(t.Tooltip,{children:[e.jsx(t.TooltipTrigger,{children:e.jsx(Ut,{className:"mr-2 size-4 text-destructive"})}),e.jsx(t.TooltipContent,{children:e.jsx("p",{children:i})})]}),"Schedule"]})}),a&&a.length>0&&e.jsxs("div",{className:"space-y-4",children:[e.jsx(t.Separator,{className:"my-2"}),e.jsx("div",{className:"space-y-2",children:e.jsxs("div",{className:"flex items-start justify-between",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx("h4",{className:"font-medium leading-none",children:"Subscriptions"}),e.jsx("p",{className:"text-sm text-muted-foreground",children:"Active email subscriptions"})]}),t.isDevEnv]})}),e.jsx("div",{className:"grid gap-2",children:a==null?void 0:a.map(x=>e.jsxs("div",{className:"group grid grid-cols-5 gap-3",children:[e.jsx("div",{className:"col-span-3 text-sm",children:e.jsxs("div",{className:"flex items-center justify-between gap-2",children:[e.jsxs("div",{className:"boder-border rounded-md border bg-muted px-2 py-1",children:[t.titleCase(x.frequency)," "]}),e.jsx(t.Label,{children:x.time})]})}),e.jsxs("div",{className:"col-span-2 flex items-center justify-end gap-4",children:[e.jsx(Vt,{tooltip:`Next Run: ${new Date(x.nextRun).toLocaleString()} ${x.timezone}`,children:e.jsx(tn,{className:"size-3.5"})}),e.jsx(Vt,{tooltip:`${x.endUserEmail}`,children:e.jsx(Nn,{className:"size-3.5"})}),l===x.id?e.jsx(ce,{className:"size-3.5 animate-spin"}):e.jsx(t.Trash2,{onClick:()=>r(x.id),className:"size-3.5 cursor-pointer"})]})]},x.id))})]})]})]})})]})})}const Vt=({children:s,tooltip:a})=>e.jsx(t.TooltipProvider,{delayDuration:0,children:e.jsxs(t.Tooltip,{children:[e.jsx(t.TooltipTrigger,{asChild:!0,children:s}),e.jsx(t.TooltipContent,{children:a})]})});function Pn(){const[s,a]=L.useState("idle"),[n,r]=L.useState(""),[o,i]=L.useState(null),l=t.useDashboardStore(T=>T.authToken),u=t.useDashboardStore(T=>T.dashboard.id),c=t.useDashboardStore(T=>T.dashboard.title),{endUserId:h}=t.getTenantAndEndUserId((l==null?void 0:l.accessToken)||""),d="https://semaphor.cloud/api/v1/subscriptions/get",m={dashboardId:u,endUserId:h},{data:g,isLoading:p,isError:j,isFetching:x,refetch:b}=t.useQuery({queryKey:["subscriptions",u,h],queryFn:()=>t.getRequest(d,(l==null?void 0:l.accessToken)||"",m),enabled:!!(l!=null&&l.accessToken)&&!!u&&!!h});async function f({email:T,subject:E,frequency:y,time:C}){const{authToken:v,...w}=ts(),I=Intl.DateTimeFormat().resolvedOptions().timeZone,D={email:T,frequency:y,time:C,timezone:I,endUserId:h,endUserEmail:T,subject:E||c||"Scheduled Dashboard",dashboardId:u,dashboardParams:w};a("loading");const N="https://semaphor.cloud/api/v1/subscriptions/create";try{const F=await t.postRequestRegular(N,(v==null?void 0:v.accessToken)||"",{...D});a("success"),r(""),b(),setTimeout(()=>{a("idle")},2e3)}catch(F){console.error(F),a("error"),r(F.message)}}async function k(T){const E="https://semaphor.cloud/api/v1/subscriptions/delete";i(T);try{await t.postRequestRegular(E,(l==null?void 0:l.accessToken)||"",{id:T}),b(),setTimeout(()=>{i(null)},2e3)}catch(y){console.error(y),i(null),a("error"),r(y.message)}}return{data:g,isLoading:p,isFetching:x,isError:j,isDeleting:o,refetch:b,handleScheduleSubscription:f,handleDeleteSubscription:k,status:s,error:n}}function qn(){const{authToken:s}=t.useSemaphorContext();t.useDashboardStore(D=>D.theme);const a=t.useDashboardStore(D=>D.lenses),n=t.useDashboardStore(D=>D.selectedLensId),r=a==null?void 0:a.find(D=>D.id===n),o=t.useDashboardStore(D=>D.dashboard);t.useDashboardStore(D=>D.selectedSheetId);const i=t.useDashboardStore(D=>D.isDashboardEditing),l=t.useEditorStore(D=>D.selectedConnectionId),[u,c]=L.useState(!1),h=t.useDashboardStore(D=>D.filterValues),d=t.useDashboardStore(D=>D.isVisualEditing),m=t.useDashboardStore(D=>D.showFilters);t.useDashboardStore(D=>D.showDashboardJSON);const g=t.useDashboardStore(D=>D.onSaveFunction),p=t.useDashboardStore(D=>D.actions.setShowFilters),{addFrame:j,setSelectedFrameId:x}=t.useDashboardStore(D=>D.actions),{getSelectedSheet:b,setIsDashboardEditing:f,setShowDashboardJSON:k}=t.useDashboardStore(D=>D.actions),T=b(),{tenantId:E,endUserId:y}=L.useMemo(()=>t.getTenantAndEndUserId(s==null?void 0:s.accessToken),[s==null?void 0:s.accessToken]),C=L.useMemo(()=>E||y,[E,y]),v=()=>{if(!i||!T)return;const D={connectionId:l,id:t.v4(),title:"Title",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"",data:[]},N={id:t.v4(),cards:[D],activeCardId:D.id};j(T.id,N),x(N.id)},w=()=>{f(!0)};async function I(){if(c(!0),!n||!r)return;const D=Ct(o),N=JSON.stringify(D),F={...r,template:N,filterValues:h};await ot(F,s==null?void 0:s.accessToken),t.ue.success("Lens saved"),g==null||g(D),c(!1)}return d?null:e.jsxs("div",{className:"flex items-center justify-between gap-2 border-b py-1 pl-3 pr-2",role:"dashboard-controls",children:[!d&&e.jsx("div",{className:"flex items-center gap-3",children:e.jsx(t.Label,{children:r==null?void 0:r.name})}),e.jsxs("div",{className:"flex gap-2",children:[!1,!d&&e.jsx(Vn,{}),!d&&e.jsx(ns,{}),i&&!d&&C&&e.jsx(Bn,{}),!d&&C&&e.jsx(Rn,{}),i&&!d&&e.jsxs(t.Button,{variant:"secondary",className:"h-7 p-2",size:"sm",disabled:!i,onClick:v,children:[e.jsx(t.Plus,{className:"mr-2 h-4 w-4"}),"Frame"]}),!i&&e.jsx(t.Button,{variant:"ghost",className:"h-7 p-2",onClick:w,size:"sm",children:e.jsx(t.Pencil,{className:"h-4 w-4"})}),i&&!d&&e.jsx(t.IconButton,{className:"h-7 p-2",onClick:()=>{f(!1),k(!1)},children:e.jsx(t.Cross2Icon,{className:"h-4 w-4"})}),i&&!d&&C&&e.jsx(t.Button,{className:"h-7 p-2",variant:"ghost",disabled:u,onClick:I,size:"sm",children:e.jsx(Tn,{className:"h-4 w-4"})}),!m&&!d&&i&&e.jsx(t.Button,{className:"h-7 p-2",variant:"ghost",onClick:()=>p(!0),size:"sm",children:e.jsx(ft,{className:"h-4 w-4"})}),!d&&i&&!1,!d&&!1]})]})}function _n({name:s,items:a,value:n,onChange:r,isLoading:o,isError:i,refetch:l,className:u,icon:c,showNone:h=!1}){const d=re.useRef(null),[m,g]=re.useState(!1),[p,j]=re.useState("100%"),x=h?[...a||[],{id:"none",name:"None"}]:a;re.useLayoutEffect(()=>{d.current&&j(d.current.offsetWidth)},[]);function b(){var k;return o?"Loading...":i?"Error":n?(k=a==null?void 0:a.find(T=>T.id===n))==null?void 0:k.name:`Select ${s}`}function f(k,T){r(T),g(!1)}return e.jsxs(t.Popover,{open:m,onOpenChange:g,children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsxs(t.Button,{ref:d,variant:"outline",role:"combobox","aria-expanded":m,className:t.cn("flex h-9 w-full justify-between",u),children:[e.jsxs("div",{className:"flex items-center gap-2",children:[c&&e.jsx("div",{className:"mr-2",children:c}),e.jsx("span",{className:"max-w-[150px] overflow-hidden truncate text-ellipsis whitespace-nowrap",children:b()})]}),e.jsx(t.ChevronDown,{className:"size-4 opacity-50"})]})}),e.jsx(t.PopoverContent,{className:"w-full p-0",style:{minWidth:p},children:e.jsxs(t.Command,{children:[e.jsxs("div",{className:"flex h-9 items-center justify-between border-b pr-1",children:[e.jsx(t.CommandInput,{className:"h-9",placeholder:"Search..."}),e.jsx(t.IconButton,{className:"h-7",onClick:l,children:e.jsx(Kt,{className:t.cn("size-3.5 opacity-50",o&&"animate-spin")})})]}),e.jsxs(t.CommandList,{children:[e.jsxs(t.CommandEmpty,{children:["No ",s==null?void 0:s.toLowerCase()," found."]}),e.jsx(t.CommandGroup,{children:x==null?void 0:x.map(k=>e.jsx(t.CommandItem,{className:"overflow-x-auto",value:k.name,onSelect:T=>f(T,k.id),children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Check,{className:t.cn("size-4",n===k.id?"opacity-100":"opacity-0")}),e.jsx("div",{title:k.name,children:k.name})]})},k.id))})]})]})})]})}function ve({title:s,items:a,value:n,isLoading:r,isError:o,refetch:i,onChange:l,showNone:u=!1,className:c,disabled:h=!1,type:d="combobox"}){const m=r?"Loading...":o?"Error":n;function g(){if(s==="Connection")return e.jsx(In,{className:"size-4"});if(s==="Database")return e.jsx(t.Database,{className:"size-4"});if(s==="Schema")return e.jsx(En,{className:"size-4"});if(s==="Table")return e.jsx(He,{className:"size-4"});if(s==="Model")return e.jsx(Qs,{className:"size-4"})}function p(){return e.jsxs(t.Select,{disabled:h,value:m,onValueChange:l,children:[e.jsx(t.SelectTrigger,{className:t.cn("h-9 w-full border-muted focus:ring-1 focus:ring-offset-0",c),children:e.jsx(t.SelectValue,{placeholder:r?"Loading...":o?"Error":`Select ${s}`})}),e.jsx(t.SelectContent,{children:e.jsxs(t.SelectGroup,{children:[r?e.jsx(t.SelectLabel,{children:"Loading..."}):e.jsxs(t.SelectLabel,{className:"flex items-center justify-between gap-2",children:[s,e.jsx(Kt,{className:t.cn("mr-1 size-3 cursor-pointer text-muted-foreground hover:text-foreground",r&&"animate-spin"),onClick:i})]}),e.jsxs(e.Fragment,{children:[u&&e.jsx(t.SelectItem,{value:"none",children:"None"},"none"),a&&a.map((x,b)=>e.jsx(t.SelectItem,{value:x.id,children:x.name},b))]}),(r||o)&&e.jsx(t.SelectItem,{value:m,children:m})]})})]})}function j(){return e.jsx(_n,{icon:g(),items:a,value:m,onChange:l||(()=>{}),isLoading:r,isError:o,refetch:i,name:s,showNone:u})}return e.jsx(t.TooltipProvider$1,{delayDuration:0,children:e.jsx("div",{className:"flex items-center gap-2",children:d==="select"?p():j()})})}function Gn({column:s}){const[a,n]=L.useState(!1),r=t.useEditorStore(x=>x.selectedTableName),o=t.useEditorStore(x=>x.selectedSchemaName),i=t.useEditorStore(x=>x.selectedDatabaseName),l=t.useEditorStore(x=>x.selectedDatamodelId),u=t.useEditorStore(x=>x.sqlGen),{modelItems:c,connectionType:h}=t.useEditorAside(),d=t.useEditorStore(x=>x.actions.setSqlGen),m=t.useEditorStore(x=>x.actions.setCardSql),g=t.useEditorStore(x=>x.actions.setRunSql);function p(x,b){var E;const f=t.createSqlGenConfig(x,u,b),k=(E=c==null?void 0:c.find(y=>y.id===l))==null?void 0:E.name;d(f);const T=t.getSql(f,t.fmt(o||""),t.fmt(r),k||"",h,i||"");T&&(m(T),g(!0)),n(!1)}function j(){return e.jsxs("ul",{className:"text-xs",children:[e.jsx("li",{onClick:()=>p(s,"COUNT"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Count"}),e.jsx("li",{onClick:()=>p(s,"AVG"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Avg"}),e.jsx("li",{onClick:()=>p(s,"SUM"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Sum"}),e.jsx("li",{onClick:()=>p(s,"MAX"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Max"}),e.jsx("li",{onClick:()=>p(s,"MIN"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Min"})]})}return e.jsxs(t.HoverCard,{openDelay:0,open:a,onOpenChange:n,children:[e.jsx(t.HoverCardTrigger,{asChild:!0,children:e.jsx(t.EllipsisVertical,{className:"invisible size-3.5 cursor-pointer text-foreground/40 group-hover:visible"})}),e.jsx(t.HoverCardContent,{align:"center",className:"w-20 rounded-md p-0 shadow-none",children:j()})]})}function Nt({column:s}){return e.jsxs(t.Tooltip,{children:[e.jsx(t.TooltipTrigger$1,{className:"shrink-0",asChild:!0,children:t.isTextDataType(s.data_type)?e.jsx(t.TextIcon,{className:"size-3 text-muted-foreground"}):t.isNumberDataType(s.data_type)?e.jsx(gt,{className:"size-3 text-muted-foreground"}):t.isDateDataType(s.data_type)?e.jsx(t.Calendar,{className:"size-3 text-muted-foreground"}):t.isBooleanDataType(s.data_type)?e.jsx(Xt,{className:"size-3 text-muted-foreground"}):s.data_type.startsWith("json")?e.jsx(Ws,{className:"size-3 text-muted-foreground"}):e.jsx(t.QuestionMarkIcon,{className:"size-3 text-muted-foreground"})}),e.jsx(t.TooltipContent,{children:e.jsx("p",{className:"text-xs",children:s.data_type})})]})}function Ue({column:s,className:a}){return e.jsxs("div",{className:t.cn("flex min-h-8 grow items-center space-x-2 px-2 text-sm",a),children:[e.jsx(Nt,{column:s}),e.jsx("span",{children:s.column_name})]})}function $n({id:s,children:a,type:n="column"}){const{attributes:r,listeners:o,setNodeRef:i,transform:l}=t.useDraggable({id:s,data:{type:n}}),u=l?{translate:t.CSS.Translate.toString(l),transform:t.CSS.Transform.toString(l)}:void 0;return e.jsx("div",{ref:i,style:u,...o,...r,children:a})}function Hn({onClick:s,column:a}){const n=t.useDndStore(d=>d.activeId),r=t.useEditorStore(d=>{var m;return(m=d.card.queryConfig)==null?void 0:m.groupByColumns}),o=t.useEditorStore(d=>{var m;return(m=d.card.queryConfig)==null?void 0:m.metricColumns}),i=t.useEditorStore(d=>{var m;return(m=d.card.queryConfig)==null?void 0:m.filterColumns});function l(d){return u(d)||c(d)||h(d)}function u(d){return r==null?void 0:r.some(m=>m.name===d.column_name)}function c(d){return o==null?void 0:o.some(m=>m.name===d.column_name)}function h(d){return i==null?void 0:i.some(m=>m.name===d.column_name)}return e.jsxs("div",{onClick:()=>s(a),className:t.cn("relative grow overflow-x-hidden overflow-y-hidden rounded-md active:border active:border-dashed active:border-muted-foreground",{"bg-muted-foreground/10":l(a)}),children:[n===a.column_name&&e.jsx(t.DragOverlay,{children:e.jsx(Ue,{column:a,className:"rounded-md border-2 border-dashed border-muted-foreground bg-muted shadow-md"})}),n===a.column_name&&e.jsx("div",{className:"absolute inset-0",children:n===a.column_name&&e.jsx(Ue,{column:a})}),e.jsx($n,{id:a.column_name,type:"column",children:e.jsx(Ue,{column:a})})]})}const Ye={id:"__placeholder__",role:"groupby",type:"string"},Ke={id:"__placeholder__",role:"groupby",type:"string"},Qe={id:"__placeholder__",role:"metric",type:"number"},We={name:"Filter",id:"__placeholder__",role:"filter",type:"string"},as={id:"__placeholder__"},fe="droppable-group-by",ge="droppable-metrics",je="droppable-pivot-by",ze="sortable-group-by",it="sortable-metrics",Be="sortable-pivot-by",lt="droppable-filters",ct="sortable-filters",St="sortable-order-by";function Jn(){const s=t.useDndStore(A=>A.insertIndex),a=t.useEditorStore(A=>{var S;return((S=A.card.queryConfig)==null?void 0:S.groupByColumns)||[]}),n=t.useEditorStore(A=>{var S;return((S=A.card.queryConfig)==null?void 0:S.metricColumns)||[]}),r=t.useEditorStore(A=>{var S;return((S=A.card.queryConfig)==null?void 0:S.filterColumns)||[]}),o=t.useEditorStore(A=>{var S;return((S=A.card.queryConfig)==null?void 0:S.orderBy)||[]}),i=t.useEditorStore(A=>{var S;return((S=A.card.queryConfig)==null?void 0:S.pivotColumns)||[]}),{setInsertIndex:l,setActiveId:u,setPreviewGroupByColumns:c,setPreviewMetricColumns:h,setPreviewFilterColumns:d,setPreviewPivotColumns:m}=t.useDndActions(),{setGroupByColumns:g,setMetricColumns:p,setFilterColumns:j,setOrderByColumns:x,setPivotByColumns:b}=t.useEditorActions(),{columns:f}=t.useDataColumns(),{formattedTableName:k}=t.useEditorAside(),T=t.useSensors(t.useSensor(t.MouseSensor,{activationConstraint:{distance:1}})),E=A=>{var z;const{active:S,over:M}=A;if(((z=S.data.current)==null?void 0:z.type)==="column"&&M){const R=M.id,V=f.find($=>$.column_name===S.id);if(!V)return;const B=t.isNumberDataType(V.data_type),K=t.isTextDataType(V.data_type),J=t.isDateDataType(V.data_type);if(K||J){if(a.some(U=>U.id===R)){const U=a.findIndex(P=>P.id===R);l(U);const q=a.filter(P=>P.id!==Ye.id);q.splice(U,0,Ye),c(q)}else if(M.id===fe){l(a.length);const U=[...a,Ye];c(U),h(n),d(r)}}if(K||J){if(i.some(U=>U.id===R)){const U=i.findIndex(P=>P.id===R);l(U);const q=i.filter(P=>P.id!==Ke.id);q.splice(U,0,Ke),m(q)}else if(M.id===je){l(i.length);const U=[...i,Ke];m(U),c(a),h(n),d(r)}}if(B||K){if(n.some(U=>U.id===R)){console.log("isOverMetricSortable",R);const U=n.findIndex(P=>P.id===R);l(U);const q=n.filter(P=>P.id!==Qe.id);q.splice(U,0,Qe),h(q)}else if(M.id===ge){l(n.length);const U=[...n,Qe];h(U),d(r),c(a),m(i)}}if(C(V)){if(r.some(U=>U.id===R)){const U=r.findIndex(P=>P.id===R);l(U);const q=r.filter(P=>P.id!==We.id);q.splice(U,0,We),d(q)}else if(M.id===lt){l(r.length);const U=[...r,We];d(U),h(n),c(a),m(i)}}}else c(a),h(n),d(r),m(i)};function y(A){u(A.active.id),l(null),c(a),h(n),d(r),m(i)}function C(A){return!r.some(S=>S.name===A.column_name)}function v(A,S="SUM"){const{column_name:M,data_type:z}=A,R=[...n],V=s!==null?s:n.length,B={...A,id:ue(M),name:M,label:Ee(M,S),type:z,role:"metric",aggregate:S};R.splice(V,0,B),p(R)}function w(A){const S=t.isTextDataType(A.data_type);t.isDateDataType(A.data_type);const M=[...i],z=s!==null?s:i.length;let R;S?R={...A,id:ue(A.column_name),name:A.column_name,type:A.data_type,role:"groupby"}:R={...A,id:ue(A.column_name),name:A.column_name,type:A.data_type,role:"groupby",label:Se(A.column_name,"month"),granularity:"month"},M.splice(z,0,R),b(M)}function I(A){const S=t.isTextDataType(A.data_type);t.isDateDataType(A.data_type);const M=[...a],z=s!==null?s:a.length;let R;S?R={...A,id:ue(A.column_name),name:A.column_name,type:A.data_type,role:"groupby"}:R={...A,id:ue(A.column_name),name:A.column_name,type:A.data_type,role:"groupby",label:Se(A.column_name,"month"),granularity:"month"},M.splice(z,0,R),g(M)}function D(A){const S=[...r],M=s!==null?s:r.length,z={...A,id:ue(A.column_name),name:A.column_name,type:A.data_type,sql:t.getDefaultFilterSql(A.data_type,k,t.fmt(A.column_name)),role:"filter"};S.splice(M,0,z),j(S)}function N(A){var R,V,B,K,J,$,U,q;const{active:S,over:M}=A,z=S.data.current;if((z==null?void 0:z.type)==="column"&&M){const P=f.find(Z=>Z.column_name===S.id);if(!P)return;const _=t.isNumberDataType(P.data_type),H=t.isTextDataType(P.data_type),Y=t.isDateDataType(P.data_type);(H||Y)&&(M.id===fe||((R=M.data.current)==null?void 0:R.type)===ze)&&I(P),(H||Y)&&(M.id===je||((V=M.data.current)==null?void 0:V.type)===Be)?w(P):(_||H)&&(M.id===ge||((B=M.data.current)==null?void 0:B.type)===it)?(_&&v(P),H&&v(P,"COUNT")):C(P)&&(M.id===lt||((K=M.data.current)==null?void 0:K.type)===ct)&&D(P)}if(M&&((J=M.data.current)==null?void 0:J.type)===ze&&a.some(P=>P.id===S.id)){const P=a.findIndex(H=>H.id===S.id),_=a.findIndex(H=>H.id===M.id);if(P!==-1&&_!==-1&&P!==_){const H=[...a],[Y]=H.splice(P,1);H.splice(_,0,Y),g(H)}}if(M&&(($=M.data.current)==null?void 0:$.type)===Be&&i.some(P=>P.id===S.id)){const P=i.findIndex(H=>H.id===S.id),_=i.findIndex(H=>H.id===M.id);if(P!==-1&&_!==-1&&P!==_){const H=[...i],[Y]=H.splice(P,1);H.splice(_,0,Y),b(H)}}if(M&&((U=M.data.current)==null?void 0:U.type)===it&&n.some(P=>P.id===S.id)){const P=n.findIndex(H=>H.id===S.id),_=n.findIndex(H=>H.id===M.id);if(P!==-1&&_!==-1&&P!==_){const H=[...n],[Y]=H.splice(P,1);H.splice(_,0,Y),p(H)}}if(M&&((q=M.data.current)==null?void 0:q.type)===ct&&r.some(P=>P.id===S.id)){const P=r.findIndex(H=>H.id===S.id),_=r.findIndex(H=>H.id===M.id);if(P!==-1&&_!==-1&&P!==_){const H=[...r],[Y]=H.splice(P,1);H.splice(_,0,Y),j(H)}}F(A),u(null),l(null),c(a),h(n),d(r),m(i)}function F(A){const{active:S,over:M}=A,z=S.data.current;if((z==null?void 0:z.type)===St&&M){const R=o.findIndex(B=>ke(B.columnId)===S.id),V=o.findIndex(B=>ke(B.columnId)===M.id);if(R!==-1&&V!==-1&&R!==V){const B=[...o],[K]=B.splice(R,1);B.splice(V,0,K),x(B)}}}function O(){u(null),l(null),c(a),h(n),d(r)}return{handleDragOver:E,handleDragEnd:N,handleDragStart:y,handleDragCancel:O,sensors:T}}function ue(s){return`${s}-${t.v4()}`}function Ee(s,a){const n=t.toTitleCase(s.replace(/_/g," "));switch(a){case"SUM":return`Sum of ${n}`;case"COUNT":return`Count of ${n}`;case"DISTINCT":return`Unique ${n}`;case"AVG":return`Average of ${n}`;case"MIN":return`Min of ${n}`;case"MAX":return`Max of ${n}`;default:return n}}function ke(s){return`${St}-${s}`}function Se(s,a){const n=t.toTitleCase(s.replace(/_/g," "));switch(a){case"day":return`Date of ${n}`;case"week":return`Week of ${n}`;case"month":return`Month of ${n}`;case"year":return`Year of ${n}`;default:return n}}function Un({schemaName:s,tableName:a,columns:n,status:r}){const o=t.useEditorStore(S=>S.sqlGen),i=t.useEditorStore(S=>S.isDevMode),l=t.useEditorStore(S=>S.selectedConnectionId),u=t.useEditorStore(S=>{var M,z;return(z=(M=S.card)==null?void 0:M.queryConfig)==null?void 0:z.metricColumns});t.useEditorStore(S=>{var M,z;return(z=(M=S.card)==null?void 0:M.queryConfig)==null?void 0:z.groupByColumns});const c=t.useEditorStore(S=>S.selectedDatabaseName),h=t.useEditorStore(S=>S.selectedSchemaName),d=t.useEditorStore(S=>S.selectedTableName),m=t.useEditorStore(S=>S.selectedDatamodelId),g=t.useDashboardStore(S=>S.dashboard.aiScopeTables),{addToAIScope:p,removeFromAIScope:j}=t.useDashboardActions(),{addColumnToMetricColumns:x,addColumnToGroupBy:b,setCardSql:f,setRunSql:k,setSqlGen:T,setIsShowingVisual:E}=t.useEditorActions(),{connectionType:y,modelItems:C,selectedDatamodelName:v}=t.useEditorAside();function w(S){var M;if(i){const z=t.createSqlGenConfig(S,o);T(z);const R=(M=C==null?void 0:C.find(B=>B.id===m))==null?void 0:M.name,V=t.getSql(z,t.fmt(s),t.fmt(a),R||"",y,c||"");V&&(f(V),k(!0))}if(!i){if(t.isTextDataType(S.data_type))if(u&&u.length>0){const z={...S,role:"groupby",id:ue(S.column_name),name:S.column_name,type:S.data_type};b(z)}else{const z={...S,role:"metric",id:ue(S.column_name),name:S.column_name,label:Ee(S.column_name,"COUNT"),type:S.data_type,aggregate:"COUNT"};x(z)}if(t.isDateDataType(S.data_type)){const z={...S,role:"groupby",id:ue(S.column_name),name:S.column_name,type:S.data_type,label:Se(S.column_name,"month"),granularity:"month"};b(z)}if(t.isNumberDataType(S.data_type)){const z={...S,role:"metric",id:ue(S.column_name),name:S.column_name,label:Ee(S.column_name,"SUM"),type:S.data_type,aggregate:"SUM"};x(z)}}}function I(S){S===!0&&(d||v)&&l?(p({connectionId:l,connectionType:y==="S3"||y==="API"?"DuckDb":y||"",databaseName:c||"",schemaName:h||"",tableName:d||"",datamodelName:t.resolveDatamodelName(v),datamodelId:m||""}),t.ue.success("Added to Assistant Scope",{position:"top-right",duration:2500,richColors:!0})):(j({connectionId:l||"",connectionType:y||"",tableName:d||"",datamodelName:t.resolveDatamodelName(v),datamodelId:m||"",databaseName:c||"",schemaName:h||""}),t.ue("Removed from Assistant Scope",{position:"top-right",duration:2e3,richColors:!0}))}function D(){const S=t.getFormattedTableNameForQuery({schemaName:s,tableName:a,modelName:v,connectionType:y,databaseName:c||""});E(!1);const M=y==="MSSQL"?`SELECT top 10 * FROM ${S}`:`SELECT * FROM ${S} LIMIT 10`;f(M),k(!0)}function N(){const S=t.getFormattedTableNameForQuery({schemaName:s,tableName:a,modelName:v,connectionType:y,databaseName:c||""});f(`SELECT COUNT(*) as count FROM ${S}`),k(!0)}function F(){return(g==null?void 0:g.find(S=>S.connectionId===l&&(S.tableName===d||S.datamodelName===v)))!==void 0}function O(S){return i?e.jsxs("div",{className:"flex grow items-center justify-between space-x-2 rounded-md px-2 py-1",onClick:()=>w(S),children:[e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(Nt,{column:S}),e.jsx("span",{children:S.column_name})]}),e.jsx("div",{onClick:M=>M.stopPropagation(),className:"flex items-center justify-end",children:t.isNumberDataType(S.data_type)&&e.jsx(Gn,{column:S})})]}):e.jsx(Hn,{onClick:w,column:S})}function A(){return e.jsxs(e.Fragment,{children:[e.jsxs(t.Toggle,{title:`${F()?"Remove from":"Add to"} Assistant Scope`,pressed:F(),onPressedChange:I,variant:"outline",className:t.cn("h-9 px-2",{}),children:[e.jsx(t.Plus,{className:t.cn("mr-1 size-4",{"text-green-400":F(),"text-muted-foreground":!F()})}),"AI"]}),e.jsxs(t.Button,{disabled:r!=="Success",onClick:D,size:"sm",variant:"secondary",className:"flex",children:[r!=="Success"?e.jsx(ce,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsx(Cn,{className:"mr-2 size-4"}),"Top 10"]}),e.jsxs(t.Button,{disabled:r!=="Success",onClick:N,size:"sm",variant:"secondary",className:"w-full",children:[r!=="Success"?e.jsx(ce,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsx(Qt,{className:"mr-2 size-4"}),"Count"]})]})}return r!=="Success"?e.jsx("div",{className:"flex grow flex-col justify-start gap-2 px-6",children:Array.from({length:3}).map((S,M)=>e.jsx(t.Skeleton,{className:"h-7 w-full"},M))}):e.jsxs("div",{className:"flex grow flex-col space-y-4 px-4",children:[i&&e.jsx("div",{className:"mx-2 flex items-center justify-center gap-2",children:A()}),e.jsxs(t.CustomScrollArea,{className:"flex-1 basis-0 overflow-y-auto px-2 py-0",children:[e.jsx("div",{className:"flex flex-col gap-1",children:n==null?void 0:n.map(S=>e.jsx("div",{className:t.cn("mr-2 cursor-pointer rounded-md text-sm transition-colors hover:bg-muted"),children:O(S)},S.column_name))}),e.jsx(t.ScrollBar,{orientation:"vertical"}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function rs({ColumnsComponent:s,type:a}){var Lt;const n=t.useEditorStore(X=>X.card),r=t.useEditorStore(X=>X.selectedConnectionId),o=t.useDashboardStore(X=>X.showFilters),i=t.useEditorStore(X=>X.selectedDatamodelId),l=t.useEditorStore(X=>X.selectedDatabaseName),u=t.useEditorStore(X=>X.selectedSchemaName),c=t.useEditorStore(X=>X.selectedTableName),h=t.useEditorStore(X=>X.isDevMode),{setSelectedTableName:d,setIsDevMode:m,setCardSql:g}=t.useEditorActions(),{connectionItems:p,modelItems:j,schemaItems:x,databaseItems:b,tableItems:f,columns:k,isConnectionsLoading:T,isModelsLoading:E,isConnectionsError:y,isModelsError:C,isDatabasesLoadingOrFetching:v,isDatabaseError:w,isSchemaLoadingOrFetching:I,isSchemaError:D,isColumnsError:N,isColumnsLoadingOrFetching:F,isTableLoadingOrFetching:O,isTableError:A,connectionType:S,isNonDbConnection:M,refetchDatabases:z,refetchModels:R,refetchSchemas:V,refetchTables:B,refetchColumns:K,refetchConnections:J,handleConnectionChange:$,handleDatabaseChange:U,handleSchemaChange:q,handleDatamodelChange:P,handleTableChange:_,tableName:H,schemaName:Y}=t.useEditorAside(),{data:Z,refetch:de}=t.useDashboardCardQuery(n);function G(){return s?s(Y,H,k):e.jsx(Un,{schemaName:Y,tableName:H,columns:k,status:F?"Loading...":N?"Error":"Success"})}function Q(){window.location.href="mailto:support@semaphor.cloud?subject=Help&body=I need help with..."}function se(X){X===!0?Z&&(g(Z.userSql),setTimeout(()=>{de()},100)):g(""),m(X)}function me(){if(!r||S==="S3"||S==="API")return null;if(!i||i==="none")return e.jsx(ve,{refetch:z,showNone:!0,onChange:U,isError:w,isLoading:v,items:b,value:l||"",title:"Database",type:"combobox"})}function Ts(){if(r&&!M&&(!l||l==="none")&&(!i||i==="none"))return e.jsxs("div",{className:"grid grid-cols-3",children:[e.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsx(t.Separator,{})}),e.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsx(t.Label,{children:"OR"})}),e.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsx(t.Separator,{})})]})}function Ms(){if(!r||S==="S3"||S==="API")return null;if(!l||l==="none")return e.jsx(ve,{refetch:R,showNone:!0,onChange:P,isError:C,isLoading:E,items:j,value:i||"",title:"Model",type:"combobox"})}function As(){return!r||S==="S3"||S==="API"||!l||l==="none"?null:e.jsx(ve,{refetch:V,onChange:q,isError:D,isLoading:I,items:x,value:u||"",title:"Schema",type:"combobox"})}function Ls(){function X(){let xe=!1;return S==="API"?(xe=!1,xe):((S==="S3"||r&&l&&l!=="none"&&u)&&(xe=!0),xe)}return X()?e.jsx(ve,{refetch:B,onChange:_,isError:A,items:f,isLoading:O,value:c||"",title:"Table",type:"combobox"}):null}return e.jsxs("aside",{className:t.cn("flex h-full min-w-[310px] max-w-[310px] flex-col justify-between rounded-none",{"border-r-[1px]":!o}),children:[e.jsxs("section",{className:"space-y-3 px-6 py-4",children:[e.jsx(ve,{refetch:J,items:p,title:"Connection",value:r||"",onChange:$,isLoading:T,isError:y,type:"combobox",connectionTooltip:((Lt=p==null?void 0:p.find(X=>X.id===r))==null?void 0:Lt.type)||""}),me(),Ts(),Ms(),As(),Ls()]}),G(),e.jsx("div",{className:"flex items-center justify-between gap-2 px-6 py-4",children:a==="main"&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Switch,{className:"data-[state=checked]:bg-muted-foreground/80",checked:h,onCheckedChange:se,id:"dev-mode"}),e.jsx(t.Label,{htmlFor:"dev-mode",children:"Advanced Mode"})]}),e.jsxs(t.Button,{onClick:Q,size:"sm",variant:"secondary",className:"group flex items-center gap-2 rounded-full",children:[e.jsx(wn,{className:"size-4"}),e.jsx("span",{className:"hidden group-hover:block",children:"Help"})]})]})})]})}function os({sql:s,error:a,onClick:n}){const r=t.useEditorStore(c=>c.isDevMode),{setIsDevMode:o,setCardSql:i,setRunSql:l}=t.useEditorActions();function u(){o(!r),i(s),setTimeout(()=>{l(!0)},100)}return e.jsx("div",{className:"flex justify-between space-x-4",children:e.jsxs("div",{className:"flex grow flex-col space-y-2",children:[e.jsxs(t.ScrollArea,{className:"max-h-[250px] min-h-0 overflow-scroll text-xs leading-relaxed text-foreground/80",children:[a&&a,s&&e.jsx("div",{className:"flex flex-col space-y-1.5",children:e.jsx("div",{className:"rounded-md",children:e.jsx(t.CodeHighlighter,{code:s,language:"sql"})})})]}),!r&&e.jsxs(t.Button,{onClick:u,variant:"secondary",size:"sm",children:[e.jsx(dn,{className:"mr-2 h-4 w-4"}),"View in SQL Editor"]}),a&&n&&e.jsxs(t.Button,{onClick:n,size:"sm",variant:"secondary",children:[e.jsx(fn,{className:"mr-2 h-4 w-4"}),"Debug with Assistant"]})]})})}function is({sql:s,error:a,onClick:n}){return e.jsxs(t.HoverCard,{openDelay:a?0:500,children:[e.jsx(t.HoverCardTrigger,{asChild:!0,children:e.jsx(t.Button,{variant:"link",className:"h-5 p-0",children:a?e.jsx(Ut,{className:"h-4 w-4 text-red-500"}):e.jsx(t.Info,{className:"h-4 w-4 text-muted-foreground"})})}),e.jsx(t.HoverCardContent,{align:"start",className:"w-full min-w-fit max-w-[700px]",children:e.jsx(os,{sql:s,error:a,onClick:n})})]})}var ls={color:void 0,size:void 0,className:void 0,style:void 0,attr:void 0},Pt=L.createContext&&L.createContext(ls),Yn=["attr","size","title"];function Kn(s,a){if(s==null)return{};var n=Qn(s,a),r,o;if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(s);for(o=0;o<i.length;o++)r=i[o],!(a.indexOf(r)>=0)&&Object.prototype.propertyIsEnumerable.call(s,r)&&(n[r]=s[r])}return n}function Qn(s,a){if(s==null)return{};var n={};for(var r in s)if(Object.prototype.hasOwnProperty.call(s,r)){if(a.indexOf(r)>=0)continue;n[r]=s[r]}return n}function Re(){return Re=Object.assign?Object.assign.bind():function(s){for(var a=1;a<arguments.length;a++){var n=arguments[a];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(s[r]=n[r])}return s},Re.apply(this,arguments)}function qt(s,a){var n=Object.keys(s);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(s);a&&(r=r.filter(function(o){return Object.getOwnPropertyDescriptor(s,o).enumerable})),n.push.apply(n,r)}return n}function Ve(s){for(var a=1;a<arguments.length;a++){var n=arguments[a]!=null?arguments[a]:{};a%2?qt(Object(n),!0).forEach(function(r){Wn(s,r,n[r])}):Object.getOwnPropertyDescriptors?Object.defineProperties(s,Object.getOwnPropertyDescriptors(n)):qt(Object(n)).forEach(function(r){Object.defineProperty(s,r,Object.getOwnPropertyDescriptor(n,r))})}return s}function Wn(s,a,n){return a=Xn(a),a in s?Object.defineProperty(s,a,{value:n,enumerable:!0,configurable:!0,writable:!0}):s[a]=n,s}function Xn(s){var a=Zn(s,"string");return typeof a=="symbol"?a:a+""}function Zn(s,a){if(typeof s!="object"||!s)return s;var n=s[Symbol.toPrimitive];if(n!==void 0){var r=n.call(s,a);if(typeof r!="object")return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return(a==="string"?String:Number)(s)}function cs(s){return s&&s.map((a,n)=>L.createElement(a.tag,Ve({key:n},a.attr),cs(a.child)))}function ye(s){return a=>L.createElement(ea,Re({attr:Ve({},s.attr)},a),cs(s.child))}function ea(s){var a=n=>{var{attr:r,size:o,title:i}=s,l=Kn(s,Yn),u=o||n.size||"1em",c;return n.className&&(c=n.className),s.className&&(c=(c?c+" ":"")+s.className),L.createElement("svg",Re({stroke:"currentColor",fill:"currentColor",strokeWidth:"0"},n.attr,r,l,{className:c,style:Ve(Ve({color:s.color||n.color},n.style),s.style),height:u,width:u,xmlns:"http://www.w3.org/2000/svg"}),i&&L.createElement("title",null,i),s.children)};return Pt!==void 0?L.createElement(Pt.Consumer,null,n=>a(n)):a(ls)}function ta(s){return ye({attr:{viewBox:"0 0 448 512"},child:[{tag:"path",attr:{d:"M439.8 200.5c-7.7-30.9-22.3-54.2-53.4-54.2h-40.1v47.4c0 36.8-31.2 67.8-66.8 67.8H172.7c-29.2 0-53.4 25-53.4 54.3v101.8c0 29 25.2 46 53.4 54.3 33.8 9.9 66.3 11.7 106.8 0 26.9-7.8 53.4-23.5 53.4-54.3v-40.7H226.2v-13.6h160.2c31.1 0 42.6-21.7 53.4-54.2 11.2-33.5 10.7-65.7 0-108.6zM286.2 404c11.1 0 20.1 9.1 20.1 20.3 0 11.3-9 20.4-20.1 20.4-11 0-20.1-9.2-20.1-20.4.1-11.3 9.1-20.3 20.1-20.3zM167.8 248.1h106.8c29.7 0 53.4-24.5 53.4-54.3V91.9c0-29-24.4-50.7-53.4-55.6-35.8-5.9-74.7-5.6-106.8.1-45.2 8-53.4 24.7-53.4 55.6v40.7h106.9v13.6h-147c-31.1 0-58.3 18.7-66.8 54.2-9.8 40.7-10.2 66.1 0 108.6 7.6 31.6 25.7 54.2 56.8 54.2H101v-48.8c0-35.3 30.5-66.4 66.8-66.4zm-6.7-142.6c-11.1 0-20.1-9.1-20.1-20.3.1-11.3 9-20.4 20.1-20.4 11 0 20.1 9.2 20.1 20.4s-9 20.3-20.1 20.3z"},child:[]}]})(s)}function ds(s){const{theme:a}=t.useTheme(),n=t.useDashboardStore(x=>x.theme),r=t.useEditorStore(x=>x.frame),o=t.useEditorStore(x=>x.card),i=t.useEditorStore(x=>x.activeTabCardId),l=t.Le(),{refetch:u}=t.useDashboardCardQuery(o),{updateCardTab:c,setRunSql:h}=t.useEditorActions(),d=L.useRef(),m=L.useRef({}),g=r.cards.find(x=>x.id===i),p=L.useCallback(()=>{let x="";return s==="python"&&(x=(g==null?void 0:g.python)||t.PYTHON_DEFAULT_CODE),s==="sql"&&(x=(g==null?void 0:g.sql)||""),x},[s,g]);L.useEffect(()=>{if(i&&o.id&&o.id!==i){if(d.current&&l){const x=d.current.getModel();x&&(m.current[o.id]=x);let b=m.current[i];if(!b){const f=p();b=l.editor.createModel(f,s),m.current[i]=b}d.current.setModel(b)}c(i,o),h(!0)}},[i,o,c,l,h,s,p]),L.useEffect(()=>{if(!l)return;const x=window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light",b=n==="system"?x:n;l.editor.defineTheme("default",{base:b==="light"?"vs":"vs-dark",inherit:!0,rules:[],colors:{"editor.background":b==="light"?"#ffffff":t.hslStringToHex("240 10% 10%")}}),l.editor.setTheme("default")},[a,n,l]),L.useEffect(()=>{const x=d.current;x&&l&&o&&x.addCommand(l.KeyMod.Shift|l.KeyCode.Enter,function(){return u(),!1})},[l,u,o]);function j(x,b){if(d.current=x,!m.current[o.id]){const f=x.getModel(),k=p();m.current[o.id]=f||(b==null?void 0:b.editor.createModel(k,s))||x.getModel()}x.setModel(m.current[o.id])}return{handleEditorDidMount:j}}function sa(){const s=t.useEditorStore(l=>l.card.sql),a=t.useEditorStore(l=>l.sqlGen),{setCardSql:n,setSqlGen:r}=t.useEditorActions(),{handleEditorDidMount:o}=ds("sql");function i(l){n(l),t.isObjectEmpty(a)||r({})}return e.jsxs("div",{className:"relative h-full w-full",children:[!s&&e.jsx("div",{className:"pointer-events-none absolute left-[65px] top-3 z-10 font-mono text-sm text-muted-foreground",children:"Write your SQL here"}),e.jsx(t.Ft,{theme:"default",className:"pt-3",onChange:i,value:s||"",options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:13,renderLineHighlight:"none"},defaultLanguage:"sql",onMount:o})]})}function na(){const s=t.useEditorStore(o=>o.card.python),{setCardPython:a}=t.useEditorActions(),{handleEditorDidMount:n}=ds("python");function r(o){a(o)}return e.jsx(t.Ft,{className:"pt-3",theme:"default",onChange:r,value:s||t.PYTHON_DEFAULT_CODE,options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:13,renderLineHighlight:"none"},defaultLanguage:"python",onMount:n})}function aa({jsonString:s}){return e.jsx(t.Ft,{theme:"default",defaultLanguage:"json",className:"mt-1 min-h-[220px]",value:s,options:{readOnly:!0,minimap:{enabled:!1},lineNumbers:"off",glyphMargin:!1,wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:12,renderLineHighlight:"none"}})}function ra(){const s=t.useQueryClient(),[a,n]=L.useState(!1),[r,o]=L.useState(!1);t.useEditorStore(B=>B.frame);const i=t.useEditorStore(B=>B.card);t.useEditorStore(B=>B.isShowingVisual),t.useEditorStore(B=>B.selectedConnectionId),t.useEditorStore(B=>B.tempQueryData),t.useEditorStore(B=>B.selectedDatabaseName),t.useEditorStore(B=>B.selectedDatamodelId),t.useEditorStore(B=>B.selectedSchemaName);const l=t.useEditorStore(B=>B.showAIDialog);t.useEditorStore(B=>B.selectedTableName);const u=t.useEditorStore(B=>{var K;return(K=B==null?void 0:B.card)==null?void 0:K.sql}),c=t.useEditorStore(B=>{var K;return(K=B==null?void 0:B.card)==null?void 0:K.python}),{sheetFilterValues:h}=t.useSheetFilterValues(),{setCardCustomCfg:d,setQueryResultColumns:m,setCardSql:g,setTempQueryData:p,setPythonStdOut:j,setCardPreferences:x,setCardType:b,setCardPython:f,runAssistant:k,setShowAIDialog:T}=t.useEditorActions();t.useEditorStore(B=>B.onSave),t.useEditorStore(B=>B.onClose),t.useEditorStore(B=>B.actions.setSqlGen);const E=t.useEditorStore(B=>B.runSql),y=t.useEditorStore(B=>B.actions.setRunSql),C=t.useEditorStore(B=>B.actions.setIsSqlRunning),{data:v,isLoading:w,isFetching:I,isSuccess:D,isError:N,error:F,queryKey:O,refetch:A,errorMessage:S}=t.useDashboardCardQuery(i);L.useEffect(()=>{if(v&&(v.rowLimitExceeded&&t.ue.error("Row limit (10,000) exceeded. Refine your query.",{position:"top-center",richColors:!0}),j((v==null?void 0:v.output)||""),v.records.length>0)){const{dimensionKeys:B}=t.getKeys(v.records);m(B)}},[v,m,j]),L.useEffect(()=>{(w||I)&&C(!0),(N||D)&&C(!1),N&&(m([]),j(""))},[w,I,v,j,N,D,C,m,F]),L.useEffect(()=>{E&&(s.getQueryData(O)||A(),y(!1))},[E,A,y,O,s]);async function M(){const B=`Can you help me debug this query in the current table scope?
386
+ */const Zt=t.createLucideIcon("Type",[["polyline",{points:"4 7 4 4 20 4 20 7",key:"1nosan"}],["line",{x1:"9",x2:"15",y1:"20",y2:"20",key:"swin9y"}],["line",{x1:"12",x2:"12",y1:"4",y2:"20",key:"1tx1rr"}]]);function Nt(s){var a;return{...s,sheets:(a=s==null?void 0:s.sheets)==null?void 0:a.map(n=>{var r;return{...n,frames:(r=n.frames)==null?void 0:r.map(i=>{var o;return{...i,cards:(o=i.cards)==null?void 0:o.map(l=>es(l))}})}})}}function es(s){return{...s,customCfg:On(s.customCfg),data:[]}}function On(s){var a,n;return s?{...s,data:{...s==null?void 0:s.data,labels:[],datasets:(n=(a=s==null?void 0:s.data)==null?void 0:a.datasets)==null?void 0:n.map(r=>({...r,data:[]}))}}:null}async function Fn(s,a,n,r){if(!r)return null;const i=JSON.stringify(a);return await t.postRequest("https://semaphor.cloud/api/v1/lens",r,{name:s,template:i,filterValues:n,operation:"create"})}async function it(s,a){if(!a)return null;const{id:n,template:r,filterValues:i,isDefault:o,shared:l}=s;return await t.postRequest("https://semaphor.cloud/api/v1/lens",a,{lensId:n,template:r,filterValues:i,isDefault:o,shared:l,operation:"update"})}async function Bn(s,a){return a?await t.postRequest("https://semaphor.cloud/api/v1/lens",a,{operation:"delete",lensId:s}):null}function zn(){const[s,a]=L.useState(""),[n,r]=L.useState(!1),i=t.useDashboardStore(x=>x.lenses),{setLenses:o,setSelectedLensId:l}=t.useDashboardActions(),[u,c]=L.useState(!1),[h,d]=L.useState(!1),m=t.useDashboardStore(x=>x.dashboard),g=t.useDashboardStore(x=>x.filterValues),{authToken:p}=t.useSemaphorContext();async function j(){c(!0);const x=Nt(m),b=await Fn(s,x,g,p==null?void 0:p.accessToken);b&&(o([...i||[],b]),l(b.id),d(!1)),c(!1)}return e.jsxs(t.Dialog,{open:h,onOpenChange:d,children:[e.jsx(t.DialogTrigger,{asChild:!0,children:e.jsxs(t.Button,{variant:"secondary",className:"h-7 p-2",size:"sm",children:[e.jsx(t.Plus,{className:"mr-2 h-4 w-4"}),"Lens"]})}),e.jsxs(t.DialogContent,{className:"sm:max-w-[425px]",children:[e.jsxs(t.DialogHeader,{children:[e.jsx(t.DialogTitle,{children:"Create Lens"}),e.jsx(t.DialogDescription,{children:"Lenses are private by default and are only visible to you."})]}),e.jsx("div",{className:"grid gap-4 py-4",children:e.jsxs("div",{className:"grid grid-cols-8 items-center gap-4",children:[e.jsx(t.Label,{className:"text-right",children:"Name"}),e.jsx(t.Input,{value:s,onChange:x=>{a(x.target.value)},id:"name",className:"col-span-7 focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0"})]})}),n&&e.jsx("p",{className:"text-sm",children:"The lens name already exists. Use a differnet name."}),e.jsx(t.DialogFooter,{children:e.jsx(t.Button,{size:"sm",variant:"outline",type:"submit",onClick:j,disabled:u,children:u?"Creating...":"Add"})})]})]})}function Rn(){const[s,a]=L.useState(!1),n=t.useDashboardStore(d=>d.lenses),r=t.useDashboardStore(d=>d.selectedLensId),{setLenses:i,setSelectedLensId:o}=t.useDashboardActions(),{authToken:l}=t.useSemaphorContext();async function u(d){o(d)}async function c(d){if(await Bn(d,l==null?void 0:l.accessToken)){const g=n==null?void 0:n.filter(p=>p.id!==d);i(g||[]),o("original")}}async function h(d){const m=n==null?void 0:n.map(j=>j.id===d.id?{...j,isDefault:!d.isDefault}:{...j,isDefault:!1});i(m||[]);const g={...d,isDefault:!d.isDefault};await it(g,l==null?void 0:l.accessToken);const p=n==null?void 0:n.find(j=>j.isDefault);if(p&&p.id!==d.id){const j={...p,isDefault:!1};await it(j,l==null?void 0:l.accessToken)}}return e.jsxs(t.DropdownMenu,{open:s,onOpenChange:a,children:[e.jsx(t.DropdownMenuTrigger,{asChild:!0,children:e.jsx(t.IconButton,{tooltip:"Lenses",className:"h-7 p-2",children:e.jsx(xn,{className:"h-4 w-4"})})}),e.jsxs(t.DropdownMenuContent,{align:"end",className:"w-60",children:[e.jsx(t.DropdownMenuLabel,{className:"px-3",children:"Lenses"}),e.jsx(t.DropdownMenuSeparator,{}),e.jsxs(t.DropdownMenuRadioGroup,{value:r,onValueChange:u,children:[e.jsx(t.DropdownMenuRadioItem,{value:"original",children:"Original"}),n==null?void 0:n.map(d=>e.jsxs(t.DropdownMenuRadioItem,{className:"group flex justify-between gap-2",value:d.id,children:[e.jsx("p",{children:d.name}),e.jsxs("span",{className:"flex items-center gap-3",children:[e.jsx(gn,{onClick:m=>{m.preventDefault(),h(d)},className:t.cn("size-3.5 text-muted-foreground hover:cursor-pointer hover:text-foreground group-hover:visible",{invisible:!d.isDefault,"text-green-500":d.isDefault}),strokeWidth:1.5}),e.jsx(t.Cross2Icon,{onClick:m=>{m.preventDefault(),c(d.id)},className:"invisible size-3.5 text-muted-foreground hover:cursor-pointer hover:text-foreground group-hover:visible",strokeWidth:1.5})]})]},d.id))]})]})]})}function ts(){var o;const s=t.useDashboardStore.getState().authToken,a=t.useDashboardStore.getState().theme,n=t.useDashboardStore.getState().filterValues,r=(o=t.useDashboardStore.getState().dashboard)==null?void 0:o.title,i=t.useDashboardStore.getState().selectedSheetId;return{authToken:s,theme:a||"light",filterValues:n,dashboardTitle:r||"",selectedSheetId:i||""}}async function ss(){const s=t.useDashboardStore.getState().isDownloadingPdf,{authToken:a,theme:n,filterValues:r,dashboardTitle:i,selectedSheetId:o}=ts();if(s)return;const l=new URLSearchParams;l.set("token",(a==null?void 0:a.accessToken)||""),l.set("theme",n),l.set("filterValues",JSON.stringify(r)),l.set("selectedSheetId",o||"");const u=`https://semaphor.cloud/api/v1/generate-pdf?params=${encodeURIComponent(l.toString())}`;t.useDashboardStore.setState({isDownloadingPdf:!0});const d=(await(await fetch(u,{method:"GET",headers:{Authorization:`Bearer ${a==null?void 0:a.accessToken}`}})).json()).url,m=document.createElement("a");m.href=d;const g=`${i}-${new Date().toISOString()}.pdf`;m.download=g,m.click(),t.useDashboardStore.setState({isDownloadingPdf:!1})}function Pn({iconClassName:s}){const{authToken:a}=t.useSemaphorContext();t.useDashboardStore(i=>{var o;return(o=i.dashboard)==null?void 0:o.title}),t.useDashboardStore(i=>i.theme),t.useDashboardStore(i=>i.filterValues);const n=t.useDashboardStore(i=>i.isDownloadingPdf);async function r(){await ss()}return e.jsx(t.IconButton,{tooltip:"Download PDF",className:"h-7 p-2",onClick:r,children:n?e.jsx(ce,{className:t.cn("size-3.5 animate-spin",s)}):e.jsx(t.Download,{className:t.cn("size-4",s)})})}function le({defaultValue:s,label:a,options:n,value:r,onValueChange:i,className:o,icon:l,showPlaceholderLabel:u=!0}){return e.jsxs(t.Select,{defaultValue:s,value:r,onValueChange:i,children:[e.jsx(t.SelectTrigger,{className:t.cn("w-full focus:ring-0 focus:ring-offset-0",o),children:e.jsxs("div",{className:"flex items-center gap-2",children:[l&&e.jsx("span",{children:l}),u&&e.jsx(t.SelectValue,{placeholder:a})]})}),e.jsx(t.SelectContent,{children:e.jsxs(t.SelectGroup,{children:[e.jsx(t.SelectLabel,{children:a}),n.map(c=>e.jsx(t.SelectItem,{value:c.value,children:c.label},c.value))]})})]})}const Rt=[{value:"daily",label:"Daily"},{value:"weekly",label:"Weekly"},{value:"biweekly",label:"Bi-Weekly"},{value:"monthly",label:"Monthly"}];function ns({triggerButtonClassName:s}){const{data:a,handleScheduleSubscription:n,handleDeleteSubscription:r,status:i,error:o,isDeleting:l}=Vn(),[u,c]=L.useState(""),[h,d]=L.useState(Rt[0].value),[m,g]=L.useState("06:00"),[p,j]=L.useState("");return e.jsx(t.TooltipProvider,{delayDuration:0,children:e.jsxs(t.Popover,{children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsx(t.IconButton,{tooltip:"Schedule Dashboard",className:t.cn("h-7 p-2",s),children:e.jsx(sn,{className:"size-4"})})}),e.jsx(t.PopoverContent,{align:"end",className:"w-80",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:"Schedule Subscription"}),e.jsx("p",{className:"text-sm text-muted-foreground",children:"Subscribe to receive dashboard via email"})]}),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:"email",children:"Email"}),e.jsx(t.Input,{id:"email",value:u,onChange:x=>c(x.target.value),className:`col-span-2 h-8 ${t.removeRing}`})]}),e.jsxs("div",{className:"grid grid-cols-3 items-center gap-4",children:[e.jsx(t.Label,{htmlFor:"subject",children:"Subject"}),e.jsx(t.Input,{id:"subject",placeholder:"Monthly Sales Report",value:p,onChange:x=>{j(x.target.value.replace(/[^a-zA-Z0-9\s-_]/g,""))},className:`col-span-2 h-8 ${t.removeRing}`})]}),e.jsxs("div",{className:"grid grid-cols-3 items-center gap-4",children:[e.jsx(t.Label,{htmlFor:"frequency",children:"Frequency"}),e.jsx(le,{className:"col-span-2 h-8",label:"Select Frequency",options:Rt,value:h,onValueChange:x=>d(x)})]}),e.jsxs("div",{className:"grid grid-cols-3 items-center gap-4",children:[e.jsx(t.Label,{htmlFor:"time",children:"Time"}),e.jsx(t.Input,{id:"time",type:"time",value:m,onChange:x=>g(x.target.value),className:`col-span-2 h-8 ${t.removeRing}`})]}),e.jsx("div",{className:"mt-2 flex justify-end",children:e.jsxs(t.Button,{onClick:async()=>{await n({email:u,frequency:h,time:m,subject:p}),g("00:00"),c(""),j("")},className:"h-8 p-2",disabled:i==="loading"||!u,children:[i==="loading"&&e.jsx(ce,{className:"mr-2 size-4 animate-spin"}),i==="success"&&e.jsx(t.Check,{className:"mr-2 size-4"}),i==="error"&&e.jsxs(t.Tooltip,{children:[e.jsx(t.TooltipTrigger,{children:e.jsx(Ut,{className:"mr-2 size-4 text-destructive"})}),e.jsx(t.TooltipContent,{children:e.jsx("p",{children:o})})]}),"Schedule"]})}),a&&a.length>0&&e.jsxs("div",{className:"space-y-4",children:[e.jsx(t.Separator,{className:"my-2"}),e.jsx("div",{className:"space-y-2",children:e.jsxs("div",{className:"flex items-start justify-between",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx("h4",{className:"font-medium leading-none",children:"Subscriptions"}),e.jsx("p",{className:"text-sm text-muted-foreground",children:"Active email subscriptions"})]}),t.isDevEnv]})}),e.jsx("div",{className:"grid gap-2",children:a==null?void 0:a.map(x=>e.jsxs("div",{className:"group grid grid-cols-5 gap-3",children:[e.jsx("div",{className:"col-span-3 text-sm",children:e.jsxs("div",{className:"flex items-center justify-between gap-2",children:[e.jsxs("div",{className:"boder-border rounded-md border bg-muted px-2 py-1",children:[t.titleCase(x.frequency)," "]}),e.jsx(t.Label,{children:x.time})]})}),e.jsxs("div",{className:"col-span-2 flex items-center justify-end gap-4",children:[e.jsx(Pt,{tooltip:`Next Run: ${new Date(x.nextRun).toLocaleString()} ${x.timezone}`,children:e.jsx(tn,{className:"size-3.5"})}),e.jsx(Pt,{tooltip:`${x.endUserEmail}`,children:e.jsx(Cn,{className:"size-3.5"})}),l===x.id?e.jsx(ce,{className:"size-3.5 animate-spin"}):e.jsx(t.Trash2,{onClick:()=>r(x.id),className:"size-3.5 cursor-pointer"})]})]},x.id))})]})]})]})})]})})}const Pt=({children:s,tooltip:a})=>e.jsx(t.TooltipProvider,{delayDuration:0,children:e.jsxs(t.Tooltip,{children:[e.jsx(t.TooltipTrigger,{asChild:!0,children:s}),e.jsx(t.TooltipContent,{children:a})]})});function Vn(){const[s,a]=L.useState("idle"),[n,r]=L.useState(""),[i,o]=L.useState(null),l=t.useDashboardStore(T=>T.authToken),u=t.useDashboardStore(T=>T.dashboard.id),c=t.useDashboardStore(T=>T.dashboard.title),{endUserId:h}=t.getTenantAndEndUserId((l==null?void 0:l.accessToken)||""),d="https://semaphor.cloud/api/v1/subscriptions/get",m={dashboardId:u,endUserId:h},{data:g,isLoading:p,isError:j,isFetching:x,refetch:b}=t.useQuery({queryKey:["subscriptions",u,h],queryFn:()=>t.getRequest(d,(l==null?void 0:l.accessToken)||"",m),enabled:!!(l!=null&&l.accessToken)&&!!u&&!!h});async function f({email:T,subject:E,frequency:y,time:N}){const{authToken:v,...w}=ts(),I=Intl.DateTimeFormat().resolvedOptions().timeZone,D={email:T,frequency:y,time:N,timezone:I,endUserId:h,endUserEmail:T,subject:E||c||"Scheduled Dashboard",dashboardId:u,dashboardParams:w};a("loading");const C="https://semaphor.cloud/api/v1/subscriptions/create";try{const F=await t.postRequestRegular(C,(v==null?void 0:v.accessToken)||"",{...D});a("success"),r(""),b(),setTimeout(()=>{a("idle")},2e3)}catch(F){console.error(F),a("error"),r(F.message)}}async function k(T){const E="https://semaphor.cloud/api/v1/subscriptions/delete";o(T);try{await t.postRequestRegular(E,(l==null?void 0:l.accessToken)||"",{id:T}),b(),setTimeout(()=>{o(null)},2e3)}catch(y){console.error(y),o(null),a("error"),r(y.message)}}return{data:g,isLoading:p,isFetching:x,isError:j,isDeleting:i,refetch:b,handleScheduleSubscription:f,handleDeleteSubscription:k,status:s,error:n}}function qn(){const{authToken:s}=t.useSemaphorContext();t.useDashboardStore(D=>D.theme);const a=t.useDashboardStore(D=>D.lenses),n=t.useDashboardStore(D=>D.selectedLensId),r=a==null?void 0:a.find(D=>D.id===n),i=t.useDashboardStore(D=>D.dashboard);t.useDashboardStore(D=>D.selectedSheetId);const o=t.useDashboardStore(D=>D.isDashboardEditing),l=t.useEditorStore(D=>D.selectedConnectionId),[u,c]=L.useState(!1),h=t.useDashboardStore(D=>D.filterValues),d=t.useDashboardStore(D=>D.isVisualEditing),m=t.useDashboardStore(D=>D.showFilters);t.useDashboardStore(D=>D.showDashboardJSON);const g=t.useDashboardStore(D=>D.onSaveFunction),p=t.useDashboardStore(D=>D.actions.setShowFilters),{addFrame:j,setSelectedFrameId:x}=t.useDashboardStore(D=>D.actions),{getSelectedSheet:b,setIsDashboardEditing:f,setShowDashboardJSON:k}=t.useDashboardStore(D=>D.actions),T=b(),{tenantId:E,endUserId:y}=L.useMemo(()=>t.getTenantAndEndUserId(s==null?void 0:s.accessToken),[s==null?void 0:s.accessToken]),N=L.useMemo(()=>E||y,[E,y]),v=()=>{if(!o||!T)return;const D={connectionId:l,id:t.v4(),title:"Title",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"",data:[]},C={id:t.v4(),cards:[D],activeCardId:D.id};j(T.id,C),x(C.id)},w=()=>{f(!0)};async function I(){if(c(!0),!n||!r)return;const D=Nt(i),C=JSON.stringify(D),F={...r,template:C,filterValues:h};await it(F,s==null?void 0:s.accessToken),t.ue.success("Lens saved"),g==null||g(D),c(!1)}return d?null:e.jsxs("div",{className:"flex items-center justify-between gap-2 border-b py-1 pl-3 pr-2",role:"dashboard-controls",children:[!d&&e.jsx("div",{className:"flex items-center gap-3",children:e.jsx(t.Label,{children:r==null?void 0:r.name})}),e.jsxs("div",{className:"flex gap-2",children:[!1,!d&&e.jsx(Pn,{}),!d&&e.jsx(ns,{}),o&&!d&&N&&e.jsx(zn,{}),!d&&N&&e.jsx(Rn,{}),o&&!d&&e.jsxs(t.Button,{variant:"secondary",className:"h-7 p-2",size:"sm",disabled:!o,onClick:v,children:[e.jsx(t.Plus,{className:"mr-2 h-4 w-4"}),"Frame"]}),!o&&e.jsx(t.Button,{variant:"ghost",className:"h-7 p-2",onClick:w,size:"sm",children:e.jsx(t.Pencil,{className:"h-4 w-4"})}),o&&!d&&e.jsx(t.IconButton,{className:"h-7 p-2",onClick:()=>{f(!1),k(!1)},children:e.jsx(t.Cross2Icon,{className:"h-4 w-4"})}),o&&!d&&N&&e.jsx(t.Button,{className:"h-7 p-2",variant:"ghost",disabled:u,onClick:I,size:"sm",children:e.jsx(Tn,{className:"h-4 w-4"})}),!m&&!d&&o&&e.jsx(t.Button,{className:"h-7 p-2",variant:"ghost",onClick:()=>p(!0),size:"sm",children:e.jsx(ft,{className:"h-4 w-4"})}),!d&&o&&!1,!d&&!1]})]})}function _n({name:s,items:a,value:n,onChange:r,isLoading:i,isError:o,refetch:l,className:u,icon:c,showNone:h=!1}){const d=re.useRef(null),[m,g]=re.useState(!1),[p,j]=re.useState("100%"),x=h?[...a||[],{id:"none",name:"None"}]:a;re.useLayoutEffect(()=>{d.current&&j(d.current.offsetWidth)},[]);function b(){var k;return i?"Loading...":o?"Error":n?(k=a==null?void 0:a.find(T=>T.id===n))==null?void 0:k.name:`Select ${s}`}function f(k,T){r(T),g(!1)}return e.jsxs(t.Popover,{open:m,onOpenChange:g,children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsxs(t.Button,{ref:d,variant:"outline",role:"combobox","aria-expanded":m,className:t.cn("flex h-9 w-full justify-between",u),children:[e.jsxs("div",{className:"flex items-center gap-2",children:[c&&e.jsx("div",{className:"mr-2",children:c}),e.jsx("span",{className:"max-w-[150px] overflow-hidden truncate text-ellipsis whitespace-nowrap",children:b()})]}),e.jsx(t.ChevronDown,{className:"size-4 opacity-50"})]})}),e.jsx(t.PopoverContent,{className:"w-full p-0",style:{minWidth:p},children:e.jsxs(t.Command,{children:[e.jsxs("div",{className:"flex h-9 items-center justify-between border-b pr-1",children:[e.jsx(t.CommandInput,{className:"h-9",placeholder:"Search..."}),e.jsx(t.IconButton,{className:"h-7",onClick:l,children:e.jsx(Kt,{className:t.cn("size-3.5 opacity-50",i&&"animate-spin")})})]}),e.jsxs(t.CommandList,{children:[e.jsxs(t.CommandEmpty,{children:["No ",s==null?void 0:s.toLowerCase()," found."]}),e.jsx(t.CommandGroup,{children:x==null?void 0:x.map(k=>e.jsx(t.CommandItem,{className:"overflow-x-auto",value:k.name,onSelect:T=>f(T,k.id),children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Check,{className:t.cn("size-4",n===k.id?"opacity-100":"opacity-0")}),e.jsx("div",{title:k.name,children:k.name})]})},k.id))})]})]})})]})}function ve({title:s,items:a,value:n,isLoading:r,isError:i,refetch:o,onChange:l,showNone:u=!1,className:c,disabled:h=!1,type:d="combobox"}){const m=r?"Loading...":i?"Error":n;function g(){if(s==="Connection")return e.jsx(In,{className:"size-4"});if(s==="Database")return e.jsx(t.Database,{className:"size-4"});if(s==="Schema")return e.jsx(En,{className:"size-4"});if(s==="Table")return e.jsx(He,{className:"size-4"});if(s==="Model")return e.jsx(Qs,{className:"size-4"})}function p(){return e.jsxs(t.Select,{disabled:h,value:m,onValueChange:l,children:[e.jsx(t.SelectTrigger,{className:t.cn("h-9 w-full border-muted focus:ring-1 focus:ring-offset-0",c),children:e.jsx(t.SelectValue,{placeholder:r?"Loading...":i?"Error":`Select ${s}`})}),e.jsx(t.SelectContent,{children:e.jsxs(t.SelectGroup,{children:[r?e.jsx(t.SelectLabel,{children:"Loading..."}):e.jsxs(t.SelectLabel,{className:"flex items-center justify-between gap-2",children:[s,e.jsx(Kt,{className:t.cn("mr-1 size-3 cursor-pointer text-muted-foreground hover:text-foreground",r&&"animate-spin"),onClick:o})]}),e.jsxs(e.Fragment,{children:[u&&e.jsx(t.SelectItem,{value:"none",children:"None"},"none"),a&&a.map((x,b)=>e.jsx(t.SelectItem,{value:x.id,children:x.name},b))]}),(r||i)&&e.jsx(t.SelectItem,{value:m,children:m})]})})]})}function j(){return e.jsx(_n,{icon:g(),items:a,value:m,onChange:l||(()=>{}),isLoading:r,isError:i,refetch:o,name:s,showNone:u})}return e.jsx(t.TooltipProvider$1,{delayDuration:0,children:e.jsx("div",{className:"flex items-center gap-2",children:d==="select"?p():j()})})}function Gn({column:s}){const[a,n]=L.useState(!1),r=t.useEditorStore(x=>x.selectedTableName),i=t.useEditorStore(x=>x.selectedSchemaName),o=t.useEditorStore(x=>x.selectedDatabaseName),l=t.useEditorStore(x=>x.selectedDatamodelId),u=t.useEditorStore(x=>x.sqlGen),{modelItems:c,connectionType:h}=t.useEditorAside(),d=t.useEditorStore(x=>x.actions.setSqlGen),m=t.useEditorStore(x=>x.actions.setCardSql),g=t.useEditorStore(x=>x.actions.setRunSql);function p(x,b){var E;const f=t.createSqlGenConfig(x,u,b),k=(E=c==null?void 0:c.find(y=>y.id===l))==null?void 0:E.name;d(f);const T=t.getSql(f,t.fmt(i||""),t.fmt(r),k||"",h,o||"");T&&(m(T),g(!0)),n(!1)}function j(){return e.jsxs("ul",{className:"text-xs",children:[e.jsx("li",{onClick:()=>p(s,"COUNT"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Count"}),e.jsx("li",{onClick:()=>p(s,"AVG"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Avg"}),e.jsx("li",{onClick:()=>p(s,"SUM"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Sum"}),e.jsx("li",{onClick:()=>p(s,"MAX"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Max"}),e.jsx("li",{onClick:()=>p(s,"MIN"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Min"})]})}return e.jsxs(t.HoverCard,{openDelay:0,open:a,onOpenChange:n,children:[e.jsx(t.HoverCardTrigger,{asChild:!0,children:e.jsx(t.EllipsisVertical,{className:"invisible size-3.5 cursor-pointer text-foreground/40 group-hover:visible"})}),e.jsx(t.HoverCardContent,{align:"center",className:"w-20 rounded-md p-0 shadow-none",children:j()})]})}function Ct({column:s}){return e.jsxs(t.Tooltip,{children:[e.jsx(t.TooltipTrigger$1,{className:"shrink-0",asChild:!0,children:t.isTextDataType(s.data_type)?e.jsx(t.TextIcon,{className:"size-3 text-muted-foreground"}):t.isNumberDataType(s.data_type)?e.jsx(gt,{className:"size-3 text-muted-foreground"}):t.isDateDataType(s.data_type)?e.jsx(t.Calendar,{className:"size-3 text-muted-foreground"}):t.isBooleanDataType(s.data_type)?e.jsx(Xt,{className:"size-3 text-muted-foreground"}):s.data_type.startsWith("json")?e.jsx(Ws,{className:"size-3 text-muted-foreground"}):e.jsx(t.QuestionMarkIcon,{className:"size-3 text-muted-foreground"})}),e.jsx(t.TooltipContent,{children:e.jsx("p",{className:"text-xs",children:s.data_type})})]})}function Ue({column:s,className:a}){return e.jsxs("div",{className:t.cn("flex min-h-8 grow items-center space-x-2 px-2 text-sm",a),children:[e.jsx(Ct,{column:s}),e.jsx("span",{children:s.column_name})]})}function $n({id:s,children:a,type:n="column"}){const{attributes:r,listeners:i,setNodeRef:o,transform:l}=t.useDraggable({id:s,data:{type:n}}),u=l?{translate:t.CSS.Translate.toString(l),transform:t.CSS.Transform.toString(l)}:void 0;return e.jsx("div",{ref:o,style:u,...i,...r,children:a})}function Hn({onClick:s,column:a}){const n=t.useDndStore(d=>d.activeId),r=t.useEditorStore(d=>{var m;return(m=d.card.queryConfig)==null?void 0:m.groupByColumns}),i=t.useEditorStore(d=>{var m;return(m=d.card.queryConfig)==null?void 0:m.metricColumns}),o=t.useEditorStore(d=>{var m;return(m=d.card.queryConfig)==null?void 0:m.filterColumns});function l(d){return u(d)||c(d)||h(d)}function u(d){return r==null?void 0:r.some(m=>m.name===d.column_name)}function c(d){return i==null?void 0:i.some(m=>m.name===d.column_name)}function h(d){return o==null?void 0:o.some(m=>m.name===d.column_name)}return e.jsxs("div",{onClick:()=>s(a),className:t.cn("relative grow overflow-x-hidden overflow-y-hidden rounded-md active:border active:border-dashed active:border-muted-foreground",{"bg-muted-foreground/10":l(a)}),children:[n===a.column_name&&e.jsx(t.DragOverlay,{children:e.jsx(Ue,{column:a,className:"rounded-md border-2 border-dashed border-muted-foreground bg-muted shadow-md"})}),n===a.column_name&&e.jsx("div",{className:"absolute inset-0",children:n===a.column_name&&e.jsx(Ue,{column:a})}),e.jsx($n,{id:a.column_name,type:"column",children:e.jsx(Ue,{column:a})})]})}const Ye={id:"__placeholder__",role:"groupby",type:"string"},Ke={id:"__placeholder__",role:"groupby",type:"string"},Qe={id:"__placeholder__",role:"metric",type:"number"},We={name:"Filter",id:"__placeholder__",role:"filter",type:"string"},as={id:"__placeholder__"},fe="droppable-group-by",ge="droppable-metrics",je="droppable-pivot-by",Be="sortable-group-by",ot="sortable-metrics",ze="sortable-pivot-by",lt="droppable-filters",ct="sortable-filters",St="sortable-order-by";function Jn(){const s=t.useDndStore(A=>A.insertIndex),a=t.useEditorStore(A=>{var S;return((S=A.card.queryConfig)==null?void 0:S.groupByColumns)||[]}),n=t.useEditorStore(A=>{var S;return((S=A.card.queryConfig)==null?void 0:S.metricColumns)||[]}),r=t.useEditorStore(A=>{var S;return((S=A.card.queryConfig)==null?void 0:S.filterColumns)||[]}),i=t.useEditorStore(A=>{var S;return((S=A.card.queryConfig)==null?void 0:S.orderBy)||[]}),o=t.useEditorStore(A=>{var S;return((S=A.card.queryConfig)==null?void 0:S.pivotColumns)||[]}),{setInsertIndex:l,setActiveId:u,setPreviewGroupByColumns:c,setPreviewMetricColumns:h,setPreviewFilterColumns:d,setPreviewPivotColumns:m}=t.useDndActions(),{setGroupByColumns:g,setMetricColumns:p,setFilterColumns:j,setOrderByColumns:x,setPivotByColumns:b}=t.useEditorActions(),{columns:f}=t.useDataColumns(),{formattedTableName:k}=t.useEditorAside(),T=t.useSensors(t.useSensor(t.MouseSensor,{activationConstraint:{distance:1}})),E=A=>{var B;const{active:S,over:M}=A;if(((B=S.data.current)==null?void 0:B.type)==="column"&&M){const R=M.id,P=f.find($=>$.column_name===S.id);if(!P)return;const z=t.isNumberDataType(P.data_type),K=t.isTextDataType(P.data_type),J=t.isDateDataType(P.data_type);if(K||J){if(a.some(U=>U.id===R)){const U=a.findIndex(V=>V.id===R);l(U);const q=a.filter(V=>V.id!==Ye.id);q.splice(U,0,Ye),c(q)}else if(M.id===fe){l(a.length);const U=[...a,Ye];c(U),h(n),d(r)}}if(K||J){if(o.some(U=>U.id===R)){const U=o.findIndex(V=>V.id===R);l(U);const q=o.filter(V=>V.id!==Ke.id);q.splice(U,0,Ke),m(q)}else if(M.id===je){l(o.length);const U=[...o,Ke];m(U),c(a),h(n),d(r)}}if(z||K){if(n.some(U=>U.id===R)){console.log("isOverMetricSortable",R);const U=n.findIndex(V=>V.id===R);l(U);const q=n.filter(V=>V.id!==Qe.id);q.splice(U,0,Qe),h(q)}else if(M.id===ge){l(n.length);const U=[...n,Qe];h(U),d(r),c(a),m(o)}}if(N(P)){if(r.some(U=>U.id===R)){const U=r.findIndex(V=>V.id===R);l(U);const q=r.filter(V=>V.id!==We.id);q.splice(U,0,We),d(q)}else if(M.id===lt){l(r.length);const U=[...r,We];d(U),h(n),c(a),m(o)}}}else c(a),h(n),d(r),m(o)};function y(A){u(A.active.id),l(null),c(a),h(n),d(r),m(o)}function N(A){return!r.some(S=>S.name===A.column_name)}function v(A,S="SUM"){const{column_name:M,data_type:B}=A,R=[...n],P=s!==null?s:n.length,z={...A,id:ue(M),name:M,label:Ee(M,S),type:B,role:"metric",aggregate:S};R.splice(P,0,z),p(R)}function w(A){const S=t.isTextDataType(A.data_type);t.isDateDataType(A.data_type);const M=[...o],B=s!==null?s:o.length;let R;S?R={...A,id:ue(A.column_name),name:A.column_name,type:A.data_type,role:"groupby"}:R={...A,id:ue(A.column_name),name:A.column_name,type:A.data_type,role:"groupby",label:Se(A.column_name,"month"),granularity:"month"},M.splice(B,0,R),b(M)}function I(A){const S=t.isTextDataType(A.data_type);t.isDateDataType(A.data_type);const M=[...a],B=s!==null?s:a.length;let R;S?R={...A,id:ue(A.column_name),name:A.column_name,type:A.data_type,role:"groupby"}:R={...A,id:ue(A.column_name),name:A.column_name,type:A.data_type,role:"groupby",label:Se(A.column_name,"month"),granularity:"month"},M.splice(B,0,R),g(M)}function D(A){const S=[...r],M=s!==null?s:r.length,B={...A,id:ue(A.column_name),name:A.column_name,type:A.data_type,sql:t.getDefaultFilterSql(A.data_type,k,t.fmt(A.column_name)),role:"filter"};S.splice(M,0,B),j(S)}function C(A){var R,P,z,K,J,$,U,q;const{active:S,over:M}=A,B=S.data.current;if((B==null?void 0:B.type)==="column"&&M){const V=f.find(Z=>Z.column_name===S.id);if(!V)return;const _=t.isNumberDataType(V.data_type),H=t.isTextDataType(V.data_type),Y=t.isDateDataType(V.data_type);(H||Y)&&(M.id===fe||((R=M.data.current)==null?void 0:R.type)===Be)&&I(V),(H||Y)&&(M.id===je||((P=M.data.current)==null?void 0:P.type)===ze)?w(V):(_||H)&&(M.id===ge||((z=M.data.current)==null?void 0:z.type)===ot)?(_&&v(V),H&&v(V,"COUNT")):N(V)&&(M.id===lt||((K=M.data.current)==null?void 0:K.type)===ct)&&D(V)}if(M&&((J=M.data.current)==null?void 0:J.type)===Be&&a.some(V=>V.id===S.id)){const V=a.findIndex(H=>H.id===S.id),_=a.findIndex(H=>H.id===M.id);if(V!==-1&&_!==-1&&V!==_){const H=[...a],[Y]=H.splice(V,1);H.splice(_,0,Y),g(H)}}if(M&&(($=M.data.current)==null?void 0:$.type)===ze&&o.some(V=>V.id===S.id)){const V=o.findIndex(H=>H.id===S.id),_=o.findIndex(H=>H.id===M.id);if(V!==-1&&_!==-1&&V!==_){const H=[...o],[Y]=H.splice(V,1);H.splice(_,0,Y),b(H)}}if(M&&((U=M.data.current)==null?void 0:U.type)===ot&&n.some(V=>V.id===S.id)){const V=n.findIndex(H=>H.id===S.id),_=n.findIndex(H=>H.id===M.id);if(V!==-1&&_!==-1&&V!==_){const H=[...n],[Y]=H.splice(V,1);H.splice(_,0,Y),p(H)}}if(M&&((q=M.data.current)==null?void 0:q.type)===ct&&r.some(V=>V.id===S.id)){const V=r.findIndex(H=>H.id===S.id),_=r.findIndex(H=>H.id===M.id);if(V!==-1&&_!==-1&&V!==_){const H=[...r],[Y]=H.splice(V,1);H.splice(_,0,Y),j(H)}}F(A),u(null),l(null),c(a),h(n),d(r),m(o)}function F(A){const{active:S,over:M}=A,B=S.data.current;if((B==null?void 0:B.type)===St&&M){const R=i.findIndex(z=>ke(z.columnId)===S.id),P=i.findIndex(z=>ke(z.columnId)===M.id);if(R!==-1&&P!==-1&&R!==P){const z=[...i],[K]=z.splice(R,1);z.splice(P,0,K),x(z)}}}function O(){u(null),l(null),c(a),h(n),d(r)}return{handleDragOver:E,handleDragEnd:C,handleDragStart:y,handleDragCancel:O,sensors:T}}function ue(s){return`${s}-${t.v4()}`}function Ee(s,a){const n=t.toTitleCase(s.replace(/_/g," "));switch(a){case"SUM":return`Sum of ${n}`;case"COUNT":return`Count of ${n}`;case"DISTINCT":return`Unique ${n}`;case"AVG":return`Average of ${n}`;case"MIN":return`Min of ${n}`;case"MAX":return`Max of ${n}`;default:return n}}function ke(s){return`${St}-${s}`}function Se(s,a){const n=t.toTitleCase(s.replace(/_/g," "));switch(a){case"day":return`Date of ${n}`;case"week":return`Week of ${n}`;case"month":return`Month of ${n}`;case"year":return`Year of ${n}`;default:return n}}function Un({schemaName:s,tableName:a,columns:n,status:r}){const i=t.useEditorStore(S=>S.sqlGen),o=t.useEditorStore(S=>S.isDevMode),l=t.useEditorStore(S=>S.selectedConnectionId),u=t.useEditorStore(S=>{var M,B;return(B=(M=S.card)==null?void 0:M.queryConfig)==null?void 0:B.metricColumns});t.useEditorStore(S=>{var M,B;return(B=(M=S.card)==null?void 0:M.queryConfig)==null?void 0:B.groupByColumns});const c=t.useEditorStore(S=>S.selectedDatabaseName),h=t.useEditorStore(S=>S.selectedSchemaName),d=t.useEditorStore(S=>S.selectedTableName),m=t.useEditorStore(S=>S.selectedDatamodelId),g=t.useDashboardStore(S=>S.dashboard.aiScopeTables),{addToAIScope:p,removeFromAIScope:j}=t.useDashboardActions(),{addColumnToMetricColumns:x,addColumnToGroupBy:b,setCardSql:f,setRunSql:k,setSqlGen:T,setIsShowingVisual:E}=t.useEditorActions(),{connectionType:y,modelItems:N,selectedDatamodelName:v}=t.useEditorAside();function w(S){var M;if(o){const B=t.createSqlGenConfig(S,i);T(B);const R=(M=N==null?void 0:N.find(z=>z.id===m))==null?void 0:M.name,P=t.getSql(B,t.fmt(s),t.fmt(a),R||"",y,c||"");P&&(f(P),k(!0))}if(!o){if(t.isTextDataType(S.data_type))if(u&&u.length>0){const B={...S,role:"groupby",id:ue(S.column_name),name:S.column_name,type:S.data_type};b(B)}else{const B={...S,role:"metric",id:ue(S.column_name),name:S.column_name,label:Ee(S.column_name,"COUNT"),type:S.data_type,aggregate:"COUNT"};x(B)}if(t.isDateDataType(S.data_type)){const B={...S,role:"groupby",id:ue(S.column_name),name:S.column_name,type:S.data_type,label:Se(S.column_name,"month"),granularity:"month"};b(B)}if(t.isNumberDataType(S.data_type)){const B={...S,role:"metric",id:ue(S.column_name),name:S.column_name,label:Ee(S.column_name,"SUM"),type:S.data_type,aggregate:"SUM"};x(B)}}}function I(S){S===!0&&(d||v)&&l?(p({connectionId:l,connectionType:y==="S3"||y==="API"?"DuckDb":y||"",databaseName:c||"",schemaName:h||"",tableName:d||"",datamodelName:t.resolveDatamodelName(v),datamodelId:m||""}),t.ue.success("Added to Assistant Scope",{position:"top-right",duration:2500,richColors:!0})):(j({connectionId:l||"",connectionType:y||"",tableName:d||"",datamodelName:t.resolveDatamodelName(v),datamodelId:m||"",databaseName:c||"",schemaName:h||""}),t.ue("Removed from Assistant Scope",{position:"top-right",duration:2e3,richColors:!0}))}function D(){const S=t.getFormattedTableNameForQuery({schemaName:s,tableName:a,modelName:v,connectionType:y,databaseName:c||""});E(!1);const M=y==="MSSQL"?`SELECT top 10 * FROM ${S}`:`SELECT * FROM ${S} LIMIT 10`;f(M),k(!0)}function C(){const S=t.getFormattedTableNameForQuery({schemaName:s,tableName:a,modelName:v,connectionType:y,databaseName:c||""});f(`SELECT COUNT(*) as count FROM ${S}`),k(!0)}function F(){return(g==null?void 0:g.find(S=>S.connectionId===l&&(S.tableName===d||S.datamodelName===v)))!==void 0}function O(S){return o?e.jsxs("div",{className:"flex grow items-center justify-between space-x-2 rounded-md px-2 py-1",onClick:()=>w(S),children:[e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(Ct,{column:S}),e.jsx("span",{children:S.column_name})]}),e.jsx("div",{onClick:M=>M.stopPropagation(),className:"flex items-center justify-end",children:t.isNumberDataType(S.data_type)&&e.jsx(Gn,{column:S})})]}):e.jsx(Hn,{onClick:w,column:S})}function A(){return e.jsxs(e.Fragment,{children:[e.jsxs(t.Toggle,{title:`${F()?"Remove from":"Add to"} Assistant Scope`,pressed:F(),onPressedChange:I,variant:"outline",className:t.cn("h-9 px-2",{}),children:[e.jsx(t.Plus,{className:t.cn("mr-1 size-4",{"text-green-400":F(),"text-muted-foreground":!F()})}),"AI"]}),e.jsxs(t.Button,{disabled:r!=="Success",onClick:D,size:"sm",variant:"secondary",className:"flex",children:[r!=="Success"?e.jsx(ce,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsx(Nn,{className:"mr-2 size-4"}),"Top 10"]}),e.jsxs(t.Button,{disabled:r!=="Success",onClick:C,size:"sm",variant:"secondary",className:"w-full",children:[r!=="Success"?e.jsx(ce,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsx(Qt,{className:"mr-2 size-4"}),"Count"]})]})}return r!=="Success"?e.jsx("div",{className:"flex grow flex-col justify-start gap-2 px-6",children:Array.from({length:3}).map((S,M)=>e.jsx(t.Skeleton,{className:"h-7 w-full"},M))}):e.jsxs("div",{className:"flex grow flex-col space-y-4 px-4",children:[o&&e.jsx("div",{className:"mx-2 flex items-center justify-center gap-2",children:A()}),e.jsxs(t.CustomScrollArea,{className:"flex-1 basis-0 overflow-y-auto px-2 py-0",children:[e.jsx("div",{className:"flex flex-col gap-1",children:n==null?void 0:n.map(S=>e.jsx("div",{className:t.cn("mr-2 cursor-pointer rounded-md text-sm transition-colors hover:bg-muted"),children:O(S)},S.column_name))}),e.jsx(t.ScrollBar,{orientation:"vertical"}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function rs({ColumnsComponent:s,type:a}){var Lt;const n=t.useEditorStore(X=>X.card),r=t.useEditorStore(X=>X.selectedConnectionId),i=t.useDashboardStore(X=>X.showFilters),o=t.useEditorStore(X=>X.selectedDatamodelId),l=t.useEditorStore(X=>X.selectedDatabaseName),u=t.useEditorStore(X=>X.selectedSchemaName),c=t.useEditorStore(X=>X.selectedTableName),h=t.useEditorStore(X=>X.isDevMode),{setSelectedTableName:d,setIsDevMode:m,setCardSql:g}=t.useEditorActions(),{connectionItems:p,modelItems:j,schemaItems:x,databaseItems:b,tableItems:f,columns:k,isConnectionsLoading:T,isModelsLoading:E,isConnectionsError:y,isModelsError:N,isDatabasesLoadingOrFetching:v,isDatabaseError:w,isSchemaLoadingOrFetching:I,isSchemaError:D,isColumnsError:C,isColumnsLoadingOrFetching:F,isTableLoadingOrFetching:O,isTableError:A,connectionType:S,isNonDbConnection:M,refetchDatabases:B,refetchModels:R,refetchSchemas:P,refetchTables:z,refetchColumns:K,refetchConnections:J,handleConnectionChange:$,handleDatabaseChange:U,handleSchemaChange:q,handleDatamodelChange:V,handleTableChange:_,tableName:H,schemaName:Y}=t.useEditorAside(),{data:Z,refetch:de}=t.useDashboardCardQuery(n);function G(){return s?s(Y,H,k):e.jsx(Un,{schemaName:Y,tableName:H,columns:k,status:F?"Loading...":C?"Error":"Success"})}function Q(){window.location.href="mailto:support@semaphor.cloud?subject=Help&body=I need help with..."}function se(X){X===!0?Z&&(g(Z.userSql),setTimeout(()=>{de()},100)):g(""),m(X)}function me(){if(!r||S==="S3"||S==="API")return null;if(!o||o==="none")return e.jsx(ve,{refetch:B,showNone:!0,onChange:U,isError:w,isLoading:v,items:b,value:l||"",title:"Database",type:"combobox"})}function Ts(){if(r&&!M&&(!l||l==="none")&&(!o||o==="none"))return e.jsxs("div",{className:"grid grid-cols-3",children:[e.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsx(t.Separator,{})}),e.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsx(t.Label,{children:"OR"})}),e.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsx(t.Separator,{})})]})}function Ms(){if(!r||S==="S3"||S==="API")return null;if(!l||l==="none")return e.jsx(ve,{refetch:R,showNone:!0,onChange:V,isError:N,isLoading:E,items:j,value:o||"",title:"Model",type:"combobox"})}function As(){return!r||S==="S3"||S==="API"||!l||l==="none"?null:e.jsx(ve,{refetch:P,onChange:q,isError:D,isLoading:I,items:x,value:u||"",title:"Schema",type:"combobox"})}function Ls(){function X(){let xe=!1;return S==="API"?(xe=!1,xe):((S==="S3"||r&&l&&l!=="none"&&u)&&(xe=!0),xe)}return X()?e.jsx(ve,{refetch:z,onChange:_,isError:A,items:f,isLoading:O,value:c||"",title:"Table",type:"combobox"}):null}return e.jsxs("aside",{className:t.cn("flex h-full min-w-[310px] max-w-[310px] flex-col justify-between rounded-none",{"border-r-[1px]":!i}),children:[e.jsxs("section",{className:"space-y-3 px-6 py-4",children:[e.jsx(ve,{refetch:J,items:p,title:"Connection",value:r||"",onChange:$,isLoading:T,isError:y,type:"combobox",connectionTooltip:((Lt=p==null?void 0:p.find(X=>X.id===r))==null?void 0:Lt.type)||""}),me(),Ts(),Ms(),As(),Ls()]}),G(),e.jsx("div",{className:"flex items-center justify-between gap-2 px-6 py-4",children:a==="main"&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Switch,{className:"data-[state=checked]:bg-muted-foreground/80",checked:h,onCheckedChange:se,id:"dev-mode"}),e.jsx(t.Label,{htmlFor:"dev-mode",children:"Advanced Mode"})]}),e.jsxs(t.Button,{onClick:Q,size:"sm",variant:"secondary",className:"group flex items-center gap-2 rounded-full",children:[e.jsx(wn,{className:"size-4"}),e.jsx("span",{className:"hidden group-hover:block",children:"Help"})]})]})})]})}function is({sql:s,error:a,onClick:n}){const r=t.useEditorStore(c=>c.isDevMode),{setIsDevMode:i,setCardSql:o,setRunSql:l}=t.useEditorActions();function u(){i(!r),o(s),setTimeout(()=>{l(!0)},100)}return e.jsx("div",{className:"flex justify-between space-x-4",children:e.jsxs("div",{className:"flex grow flex-col space-y-2",children:[e.jsxs(t.ScrollArea,{className:"max-h-[250px] min-h-0 overflow-scroll text-xs leading-relaxed text-foreground/80",children:[a&&a,s&&e.jsx("div",{className:"flex flex-col space-y-1.5",children:e.jsx("div",{className:"rounded-md",children:e.jsx(t.CodeHighlighter,{code:s,language:"sql"})})})]}),!r&&e.jsxs(t.Button,{onClick:u,variant:"secondary",size:"sm",children:[e.jsx(dn,{className:"mr-2 h-4 w-4"}),"View in SQL Editor"]}),a&&n&&e.jsxs(t.Button,{onClick:n,size:"sm",variant:"secondary",children:[e.jsx(fn,{className:"mr-2 h-4 w-4"}),"Debug with Assistant"]})]})})}function os({sql:s,error:a,onClick:n}){return e.jsxs(t.HoverCard,{openDelay:a?0:500,children:[e.jsx(t.HoverCardTrigger,{asChild:!0,children:e.jsx(t.Button,{variant:"link",className:"h-5 p-0",children:a?e.jsx(Ut,{className:"h-4 w-4 text-red-500"}):e.jsx(t.Info,{className:"h-4 w-4 text-muted-foreground"})})}),e.jsx(t.HoverCardContent,{align:"start",className:"w-full min-w-fit max-w-[700px]",children:e.jsx(is,{sql:s,error:a,onClick:n})})]})}var ls={color:void 0,size:void 0,className:void 0,style:void 0,attr:void 0},Vt=L.createContext&&L.createContext(ls),Yn=["attr","size","title"];function Kn(s,a){if(s==null)return{};var n=Qn(s,a),r,i;if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(s);for(i=0;i<o.length;i++)r=o[i],!(a.indexOf(r)>=0)&&Object.prototype.propertyIsEnumerable.call(s,r)&&(n[r]=s[r])}return n}function Qn(s,a){if(s==null)return{};var n={};for(var r in s)if(Object.prototype.hasOwnProperty.call(s,r)){if(a.indexOf(r)>=0)continue;n[r]=s[r]}return n}function Re(){return Re=Object.assign?Object.assign.bind():function(s){for(var a=1;a<arguments.length;a++){var n=arguments[a];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(s[r]=n[r])}return s},Re.apply(this,arguments)}function qt(s,a){var n=Object.keys(s);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(s);a&&(r=r.filter(function(i){return Object.getOwnPropertyDescriptor(s,i).enumerable})),n.push.apply(n,r)}return n}function Pe(s){for(var a=1;a<arguments.length;a++){var n=arguments[a]!=null?arguments[a]:{};a%2?qt(Object(n),!0).forEach(function(r){Wn(s,r,n[r])}):Object.getOwnPropertyDescriptors?Object.defineProperties(s,Object.getOwnPropertyDescriptors(n)):qt(Object(n)).forEach(function(r){Object.defineProperty(s,r,Object.getOwnPropertyDescriptor(n,r))})}return s}function Wn(s,a,n){return a=Xn(a),a in s?Object.defineProperty(s,a,{value:n,enumerable:!0,configurable:!0,writable:!0}):s[a]=n,s}function Xn(s){var a=Zn(s,"string");return typeof a=="symbol"?a:a+""}function Zn(s,a){if(typeof s!="object"||!s)return s;var n=s[Symbol.toPrimitive];if(n!==void 0){var r=n.call(s,a);if(typeof r!="object")return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return(a==="string"?String:Number)(s)}function cs(s){return s&&s.map((a,n)=>L.createElement(a.tag,Pe({key:n},a.attr),cs(a.child)))}function ye(s){return a=>L.createElement(ea,Re({attr:Pe({},s.attr)},a),cs(s.child))}function ea(s){var a=n=>{var{attr:r,size:i,title:o}=s,l=Kn(s,Yn),u=i||n.size||"1em",c;return n.className&&(c=n.className),s.className&&(c=(c?c+" ":"")+s.className),L.createElement("svg",Re({stroke:"currentColor",fill:"currentColor",strokeWidth:"0"},n.attr,r,l,{className:c,style:Pe(Pe({color:s.color||n.color},n.style),s.style),height:u,width:u,xmlns:"http://www.w3.org/2000/svg"}),o&&L.createElement("title",null,o),s.children)};return Vt!==void 0?L.createElement(Vt.Consumer,null,n=>a(n)):a(ls)}function ta(s){return ye({attr:{viewBox:"0 0 448 512"},child:[{tag:"path",attr:{d:"M439.8 200.5c-7.7-30.9-22.3-54.2-53.4-54.2h-40.1v47.4c0 36.8-31.2 67.8-66.8 67.8H172.7c-29.2 0-53.4 25-53.4 54.3v101.8c0 29 25.2 46 53.4 54.3 33.8 9.9 66.3 11.7 106.8 0 26.9-7.8 53.4-23.5 53.4-54.3v-40.7H226.2v-13.6h160.2c31.1 0 42.6-21.7 53.4-54.2 11.2-33.5 10.7-65.7 0-108.6zM286.2 404c11.1 0 20.1 9.1 20.1 20.3 0 11.3-9 20.4-20.1 20.4-11 0-20.1-9.2-20.1-20.4.1-11.3 9.1-20.3 20.1-20.3zM167.8 248.1h106.8c29.7 0 53.4-24.5 53.4-54.3V91.9c0-29-24.4-50.7-53.4-55.6-35.8-5.9-74.7-5.6-106.8.1-45.2 8-53.4 24.7-53.4 55.6v40.7h106.9v13.6h-147c-31.1 0-58.3 18.7-66.8 54.2-9.8 40.7-10.2 66.1 0 108.6 7.6 31.6 25.7 54.2 56.8 54.2H101v-48.8c0-35.3 30.5-66.4 66.8-66.4zm-6.7-142.6c-11.1 0-20.1-9.1-20.1-20.3.1-11.3 9-20.4 20.1-20.4 11 0 20.1 9.2 20.1 20.4s-9 20.3-20.1 20.3z"},child:[]}]})(s)}function ds(s){const{theme:a}=t.useTheme(),n=t.useDashboardStore(x=>x.theme),r=t.useEditorStore(x=>x.frame),i=t.useEditorStore(x=>x.card),o=t.useEditorStore(x=>x.activeTabCardId),l=t.Le(),{refetch:u}=t.useDashboardCardQuery(i),{updateCardTab:c,setRunSql:h}=t.useEditorActions(),d=L.useRef(),m=L.useRef({}),g=r.cards.find(x=>x.id===o),p=L.useCallback(()=>{let x="";return s==="python"&&(x=(g==null?void 0:g.python)||t.PYTHON_DEFAULT_CODE),s==="sql"&&(x=(g==null?void 0:g.sql)||""),x},[s,g]);L.useEffect(()=>{if(o&&i.id&&i.id!==o){if(d.current&&l){const x=d.current.getModel();x&&(m.current[i.id]=x);let b=m.current[o];if(!b){const f=p();b=l.editor.createModel(f,s),m.current[o]=b}d.current.setModel(b)}c(o,i),h(!0)}},[o,i,c,l,h,s,p]),L.useEffect(()=>{if(!l)return;const x=window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light",b=n==="system"?x:n;l.editor.defineTheme("default",{base:b==="light"?"vs":"vs-dark",inherit:!0,rules:[],colors:{"editor.background":b==="light"?"#ffffff":t.hslStringToHex("240 10% 10%")}}),l.editor.setTheme("default")},[a,n,l]),L.useEffect(()=>{const x=d.current;x&&l&&i&&x.addCommand(l.KeyMod.Shift|l.KeyCode.Enter,function(){return u(),!1})},[l,u,i]);function j(x,b){if(d.current=x,!m.current[i.id]){const f=x.getModel(),k=p();m.current[i.id]=f||(b==null?void 0:b.editor.createModel(k,s))||x.getModel()}x.setModel(m.current[i.id])}return{handleEditorDidMount:j}}function sa(){const s=t.useEditorStore(l=>l.card.sql),a=t.useEditorStore(l=>l.sqlGen),{setCardSql:n,setSqlGen:r}=t.useEditorActions(),{handleEditorDidMount:i}=ds("sql");function o(l){n(l),t.isObjectEmpty(a)||r({})}return e.jsxs("div",{className:"relative h-full w-full",children:[!s&&e.jsx("div",{className:"pointer-events-none absolute left-[65px] top-3 z-10 font-mono text-sm text-muted-foreground",children:"Write your SQL here"}),e.jsx(t.Ft,{theme:"default",className:"pt-3",onChange:o,value:s||"",options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:13,renderLineHighlight:"none"},defaultLanguage:"sql",onMount:i})]})}function na(){const s=t.useEditorStore(i=>i.card.python),{setCardPython:a}=t.useEditorActions(),{handleEditorDidMount:n}=ds("python");function r(i){a(i)}return e.jsx(t.Ft,{className:"pt-3",theme:"default",onChange:r,value:s||t.PYTHON_DEFAULT_CODE,options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:13,renderLineHighlight:"none"},defaultLanguage:"python",onMount:n})}function aa({jsonString:s}){return e.jsx(t.Ft,{theme:"default",defaultLanguage:"json",className:"mt-1 min-h-[220px]",value:s,options:{readOnly:!0,minimap:{enabled:!1},lineNumbers:"off",glyphMargin:!1,wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:12,renderLineHighlight:"none"}})}function ra(){const s=t.useQueryClient(),[a,n]=L.useState(!1),[r,i]=L.useState(!1);t.useEditorStore(z=>z.frame);const o=t.useEditorStore(z=>z.card);t.useEditorStore(z=>z.isShowingVisual),t.useEditorStore(z=>z.selectedConnectionId),t.useEditorStore(z=>z.tempQueryData),t.useEditorStore(z=>z.selectedDatabaseName),t.useEditorStore(z=>z.selectedDatamodelId),t.useEditorStore(z=>z.selectedSchemaName);const l=t.useEditorStore(z=>z.showAIDialog);t.useEditorStore(z=>z.selectedTableName);const u=t.useEditorStore(z=>{var K;return(K=z==null?void 0:z.card)==null?void 0:K.sql}),c=t.useEditorStore(z=>{var K;return(K=z==null?void 0:z.card)==null?void 0:K.python}),{sheetFilterValues:h}=t.useSheetFilterValues(),{setCardCustomCfg:d,setQueryResultColumns:m,setCardSql:g,setTempQueryData:p,setPythonStdOut:j,setCardPreferences:x,setCardType:b,setCardPython:f,runAssistant:k,setShowAIDialog:T}=t.useEditorActions();t.useEditorStore(z=>z.onSave),t.useEditorStore(z=>z.onClose),t.useEditorStore(z=>z.actions.setSqlGen);const E=t.useEditorStore(z=>z.runSql),y=t.useEditorStore(z=>z.actions.setRunSql),N=t.useEditorStore(z=>z.actions.setIsSqlRunning),{data:v,isLoading:w,isFetching:I,isSuccess:D,isError:C,error:F,queryKey:O,refetch:A,errorMessage:S}=t.useDashboardCardQuery(o);L.useEffect(()=>{if(v&&(v.rowLimitExceeded&&t.ue.error("Row limit (10,000) exceeded. Refine your query.",{position:"top-center",richColors:!0}),j((v==null?void 0:v.output)||""),v.records.length>0)){const{dimensionKeys:z}=t.getKeys(v.records);m(z)}},[v,m,j]),L.useEffect(()=>{(w||I)&&N(!0),(C||D)&&N(!1),C&&(m([]),j(""))},[w,I,v,j,C,D,N,m,F]),L.useEffect(()=>{E&&(s.getQueryData(O)||A(),y(!1))},[E,A,y,O,s]);async function M(){const z=`Can you help me debug this query in the current table scope?
387
387
 
388
388
  Error:
389
389
 
@@ -395,11 +395,11 @@
395
395
 
396
396
  ${c?`Python:
397
397
  ${c}`:""}
398
- `;k(B)}function z(){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(aa,{jsonString:JSON.stringify(h,null,2)})})}),h&&h.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(ft,{className:"size-3.5 text-muted-foreground"})})]})}function R(){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(sa,{})}),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(na,{})}),e.jsx("code",{className:"absolute right-6 top-3 text-xs text-muted-foreground/70",children:"python"})]})]})]})}function V(){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(ce,{className:"mr-2 h-4 w-4 animate-spin"}):e.jsx(t.Play,{className:"mr-2 h-4 w-4"}),"Run"]}),e.jsx(is,{sql:v==null?void 0:v.sql,error:S,onClick:M}),e.jsx(t.EditorClearButton,{}),e.jsx(t.Toggle,{pressed:a,onPressedChange:B=>n(B),className:"",size:"sm",children:e.jsx(ta,{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:[R(),z()]}),V()]})}function oa({data:s}){var l;const[a,n]=L.useState([]),o=Object.keys(s[0]).map(u=>({accessorKey:u,header:({column:c})=>{const h=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,h==="asc"?e.jsx(t.TriangleUpIcon,{className:"ml-2 h-5 w-5"}):h==="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 ia({card:s}){var k,T,E,y,C,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=(k=u==null?void 0:u.chart)==null?void 0:k.dataset)==null?void 0:T.backgroundColor)||[]};(E=s.customCardPreferences)!=null&&E.inputData;const{getCard:h}=t.useCustomVisual(((y=s.customCardPreferences)==null?void 0:y.url)||""),d=((C=s.customCardPreferences)==null?void 0:C.visualType)||"single",m=t.useEditorStore(O=>O.frame),{setCustomCardPreferences:g}=t.useEditorActions(),{data:p}=t.useDashboardCardQuery(s),j=L.useCallback((O,A)=>{o(S=>({...S,[O]:A}))},[]);if(!((v=s.customCardPreferences)!=null&&v.componentName))return null;const x=h((w=s.customCardPreferences)==null?void 0:w.componentName);function b(O){n(O)}const f=Object.keys(((I=s.customCardPreferences)==null?void 0:I.dataInputCardIds)||{}).map(O=>{var M,z,R;const A=(z=(M=s.customCardPreferences)==null?void 0:M.dataInputCardIds)==null?void 0:z[O].cardId,S=(R=m==null?void 0:m.cards)==null?void 0:R.find(V=>V.id===A);return S||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:j,data:(p==null?void 0:p.records)||[]}),x&&d==="multiple"&&e.jsxs(e.Fragment,{children:[Object.keys(((N=s.customCardPreferences)==null?void 0:N.dataInputCardIds)||{}).map(O=>{var M,z,R;const A=(z=(M=s.customCardPreferences)==null?void 0:M.dataInputCardIds)==null?void 0:z[O].cardId,S=(R=m==null?void 0:m.cards)==null?void 0:R.find(V=>V.id===A);if(S)return e.jsx(t.MultiInputEmptyRenderer,{onLoadingStatus:b,onDataChange:j,dataInputIndex:O,card:S},S.id+O)}),e.jsx("div",{className:"flex flex-col gap-2",children:e.jsx(x,{theme:c,onDataChange:j,settings:f.map(O=>{var A;return(A=O==null?void 0:O.customCardPreferences)==null?void 0:A.settings}),data:f.map(O=>O!=null&&O.id?r==null?void 0:r[O.id]:[])})})]})]},(F=s.customCardPreferences)==null?void 0:F.componentName)})}function us({className:s,...a}){var b;const n=t.useEditorStore(f=>f.card),r=((b=n.customCardPreferences)==null?void 0:b.showCardHeader)??!0,o=t.useEditorStore(f=>f.frame),i=t.useDashboardStore(f=>f.dashboard.filters);t.useEditorStore(f=>f.actions.setRunSql);const{updateFilter:l}=t.useDashboardActions(),u=i==null?void 0:i.find(f=>f.id===o.filterId),{data:c,isLoading:h,isFetching:d}=t.useDashboardCardQuery(n),{setCard:m}=t.useEditorActions(),{data:g}=t.useTopoJson(n),p=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:g}),[n.id,c==null?void 0:c.records,n.type,n.queryConfig,n.customCfg,n.preferences,g]);function j(f){return e.jsx(ia,{card:f})}function x(){if(c!=null&&c.records&&(c==null?void 0:c.records.length)===0&&!h&&!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 j(n);if(!["table","custom"].includes(n.type)&&p)return e.jsx(e.Fragment,{children:h||d?e.jsx(e.Fragment,{}):e.jsx(t.ChartJsVisual,{cfg:p})});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:f=>m({...n,title:f}),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:f=>m({...n,description:f}),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:f=>l({...u,title:f}),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 Xe=({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}),la=()=>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."})]})]}),ca=({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(Xe,{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(Xe,{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(Xe,{language:"javascript",value:s,onChange:o})})]}),da=({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 ua(){const[s,a]=L.useState(!1),[n,r]=L.useState(""),[o,i]=L.useState(""),[l,u]=L.useState(""),[c,h]=L.useState(""),d=t.useEditorStore(y=>y.card),m=t.useEditorStore(y=>y.card.customCfg),g=m?JSON.stringify(m,null,2):"",{data:p}=t.useDashboardCardQuery(d),{data:j}=t.useTopoJson(d),{setCardCustomCfg:x,setCustomVisualCode:b}=t.useEditorActions(),f=y=>{var C,v;return JSON.stringify({...y,data:{...y.data,datasets:(v=(C=y.data)==null?void 0:C.datasets)==null?void 0:v.map(w=>({...w,data:[]}))}},null,2)},k=()=>{var C,v;if(!((C=p==null?void 0:p.records)!=null&&C.length))return;const y=t.createChartConfig({card:d,data:p.records,cardType:d.type,queryConfig:d.queryConfig,preferences:d.preferences,topoJson:j});if(y){r(f(y)),u(((v=d.preferences)==null?void 0:v.customVisualCode)||"");const w=t.merge(y,m);i(f(w))}},T=()=>{try{if(l&&b(l),o){const y=JSON.parse(o),C=t.getObjectDiff(JSON.parse(n),y);x(C),h("")}}catch{h("Invalid JSON configuration")}},E=Object.keys(m||{}).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:k,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(la,{}),e.jsxs("div",{className:"flex grow gap-2",children:[e.jsx(t.ErrorBoundary,{FallbackComponent:t.FallbackEditorCard,children:e.jsx(us,{className:"w-1/2 rounded shadow-none"})}),e.jsx(ca,{customCode:l,cardCustomCfgString:g,mergedConfig:o,onConfigChange:y=>i(y??""),onCodeChange:y=>u(y??"")})]}),e.jsx(da,{error:c,hasCardCustomConfig:!!m,onReset:()=>{i(n),x(null)},onApply:T,onClose:()=>a(!1)})]})]})}function ms(s){const[a,n]=L.useState(null);return a}function hs(){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 ma({onChartTypeChange:s}){const[a,n]=L.useState([]),{setCardCustomCfg:r,setCardPreferences:o,setCardType:i,setCustomCardPreferences:l}=t.useEditorActions(),{data:u}=hs();function c(h,d){r(null),o({}),i(h),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 g=(await Promise.all((d=u==null?void 0:u.plugins)==null?void 0:d.map(async p=>(await t.loadManifest(p.value)).visuals.map(b=>({name:b.name,icon:b.icon,url:p.value}))))).flat();n(g)}})()},[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((h,d)=>e.jsx(ha,{text:h.name,onClick:()=>c("custom",h),icon:h.icon},h.url+h.name+d))})]})}const ha=({text:s,icon:a,onClick:n})=>{const r=ms(),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 wt(s){return ye({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 xa(s){return ye({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 kt(s){return ye({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 Et(s){return ye({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 It(s){return ye({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 Dt(s){return ye({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 xs({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,m){i(null),r({}),n(d),["kpi","custom","text","map"].includes(d)&&(o(!0),u(void 0)),s==null||s()}const h=1e3;return e.jsxs("div",{className:"grid grid-cols-5 place-items-center",children:[e.jsx(t.IconButton,{openDelay:h,tooltip:"Table",onClick:()=>c("table"),className:"h-10 p-4",children:e.jsx(He,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Bar Chart",onClick:()=>c("bar"),className:"h-10 p-4",children:e.jsx(Ge,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Line Chart",onClick:()=>c("line"),className:"h-10 p-4",children:e.jsx($e,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Stacked Bar Chart",onClick:()=>c("stackedBar"),className:"h-10 p-4",children:e.jsx(dt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Stacked Line Chart",onClick:()=>c("stackedLine"),className:"h-10 p-4",children:e.jsx(It,{className:t.cn("size-5",a),strokeWidth:0})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Scatter Chart",onClick:()=>c("scatter"),className:"h-10 p-4",children:e.jsx(xt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Bubble Chart",onClick:()=>c("bubble"),className:"h-10 p-4",children:e.jsx(kt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Pie Chart",onClick:()=>c("pie"),className:"h-10 p-4",children:e.jsx(ht,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Doughnut Chart",onClick:()=>c("doughnut"),className:"h-10 p-4",children:e.jsx(pt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Funnel Chart",onClick:()=>c("funnel"),className:"h-10 p-4",children:e.jsx(Et,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Radar Chart",onClick:()=>c("radar"),className:"h-10 p-4",children:e.jsx(yt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Polar Area Chart",onClick:()=>c("polarArea"),className:"h-10 p-4",children:e.jsx(wt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Tornado Chart",onClick:()=>c("tornado"),className:"h-10 p-4",children:e.jsx(vt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{tooltip:"Range Chart",onClick:()=>c("range"),className:"h-10 p-4",children:e.jsx(mt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"KPI",onClick:()=>c("kpi"),className:"h-10 p-4",children:e.jsx(Dt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Text",onClick:()=>c("text"),className:"h-10 p-4",children:e.jsx(Jt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{tooltip:"Map",onClick:()=>c("map"),className:"h-10 p-4",children:e.jsx(jt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Custom",onClick:()=>c("custom"),className:"h-10 p-4",children:e.jsx(bt,{className:t.cn("size-5",a)})})]})}function pa({chartType:s,className:a,customIcon:n,componentName:r}){const o=ms();switch(s){case"bar":return e.jsx(Ge,{className:a});case"line":return e.jsx($e,{className:a});case"pie":return e.jsx(ht,{className:a});case"radar":return e.jsx(yt,{className:a});case"scatter":return e.jsx(xt,{className:a});case"bubble":return e.jsx(kt,{className:a});case"doughnut":return e.jsx(pt,{className:a});case"stackedBar":return e.jsx(dt,{className:a});case"stackedLine":return e.jsx(It,{className:a});case"polarArea":return e.jsx(wt,{className:a});case"funnel":return e.jsx(Et,{className:a});case"tornado":case"pyramid":return e.jsx(vt,{className:a});case"range":return e.jsx(mt,{className:a});case"kpi":return e.jsx(Dt,{className:a});case"text":return e.jsx(Zt,{className:a});case"map":return e.jsx(jt,{className:a});case"custom":return n&&o?e.jsx(o,{className:a}):r?r==null?void 0:r.charAt(0).toUpperCase():e.jsx(bt,{className:a});default:return e.jsx(He,{className:a})}}function ps({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(pa,{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(xs,{onChartTypeChange:()=>n(!1)}),e.jsx(ma,{onChartTypeChange:()=>n(!1)})]})]})}const Ae="focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0";function _t(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 fa(){var M,z,R,V,B,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(_t(n,r)),[u,c]=L.useState(((R=(z=(M=n==null?void 0:n.chartOptions)==null?void 0:M.scales)==null?void 0:z[o])==null?void 0:R.min)||""),[h,d]=L.useState(((K=(B=(V=n==null?void 0:n.chartOptions)==null?void 0:V.scales)==null?void 0:B[o])==null?void 0:K.max)||""),[m,g]=L.useState(u||h?"custom":"auto"),[p,j]=L.useState(""),[x,b]=L.useState(0),[f,k]=L.useState(""),[T,E]=L.useState(""),[y,C]=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,P,_,H,Y,Z,de,G,Q,se,me;l(_t(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(((_=(P=(q=n==null?void 0:n.chartOptions)==null?void 0:q.scales)==null?void 0:P[o])==null?void 0:_.max)||""),j(((de=(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:de.stepSize)||""),b(((G=n==null?void 0:n.numberAxisFormat)==null?void 0:G.decimalPlaces)||0),k(((Q=n==null?void 0:n.numberAxisFormat)==null?void 0:Q.suffix)||""),E(((se=n==null?void 0:n.numberAxisFormat)==null?void 0:se.currency)||""),C(((me=n==null?void 0:n.numberAxisFormat)==null?void 0:me.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:y,onValueChange:$=>C($),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:$=>b(Number($.target.value)),id:"format",className:`col-span-6 h-8 w-full tracking-wide ${Ae}`})]})]})}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:m,onValueChange:J=>g(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"})]})]})]}),m==="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 ${Ae}`}),e.jsx(t.Input,{value:h,onChange:J=>d($=>N($,J.target.value)),id:"max",className:`col-span-1 h-8 w-full ${Ae}`})]}),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:p,onChange:J=>j($=>N($,J.target.value)),id:"step-size",className:`col-span-1 h-8 w-full ${Ae}`})]})]})}function S(){var q;let J={};m==="custom"&&(J={min:u,max:h,ticks:{stepSize:p}});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:f,currency:T,locale:y}};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(ln,{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:S,variant:"secondary",className:"col-span-1 col-start-3 h-8 w-full",children:"Apply"})})]})]})})]})}function ga(){const s=t.useEditorStore(u=>{var c,h,d,m;return(m=(d=(h=(c=u.card.preferences)==null?void 0:c.chartOptions)==null?void 0:h.plugins)==null?void 0:d.legend)==null?void 0:m.position}),a=t.useEditorStore(u=>{var c,h,d,m;return(m=(d=(h=(c=u.card.preferences)==null?void 0:c.chartOptions)==null?void 0:h.plugins)==null?void 0:d.legend)==null?void 0:m.align}),n=t.useEditorStore(u=>{var c,h,d,m;return(m=(d=(h=(c=u.card.preferences)==null?void 0:c.chartOptions)==null?void 0:h.plugins)==null?void 0:d.legend)==null?void 0:m.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(jn,{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(_e,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Left",onClick:()=>i("left"),children:e.jsx($s,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Bottom",onClick:()=>i("bottom"),children:e.jsx(qe,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Right",onClick:()=>i("right"),children:e.jsx(Hs,{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(Vs,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Center",onClick:()=>l("center"),children:e.jsx(Rs,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"End",onClick:()=>l("end"),children:e.jsx(Ps,{className:"size-4"})})]})]})]})]})]})})]})}function ja(){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(Bt,{className:"size-4"}):e.jsx(zt,{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(Bt,{className:"size-4"}):e.jsx(zt,{className:"size-4"})})}return e.jsx(e.Fragment,{children:a==="funnel"?o():r()})}function fs(){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(ja,{}),!["kpi","text","custom","table"].includes(s.type)&&e.jsxs(e.Fragment,{children:[e.jsx(fa,{}),e.jsx(ga,{})]}),!["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(pn,{className:"size-4"}),r==="x"&&e.jsx(an,{className:"size-4"}),r==="y"&&e.jsx(Dn,{className:"size-4"}),r==="none"&&e.jsx(An,{className:"size-4"})]})]}):null}function ya(){const s=t.useEditorStore(j=>j.frame),a=t.useEditorStore(j=>j.card),{setFrame:n,setActiveTabCardId:r,setCard:o,updateCardInFrame:i}=t.useEditorActions(),l=(j,x)=>{j.dataTransfer.setData("tabIndex",x.toString())},u=j=>{j.preventDefault()},c=(j,x)=>{const b=j.dataTransfer.getData("tabIndex");if(b===x.toString())return;const f=Array.from(s.cards),[k]=f.splice(parseInt(b),1);f.splice(x,0,k),n({...s,cards:f})};function h(j){const x=s.cards.filter(k=>k.id!==j),b=x[0],f={...s,cards:x,activeCardId:b.id};n(f),r(b.id),o(b)}function d(j,x){const b={...s,cards:[...s.cards,x],activeCardId:j.id};n(b),r(x.id)}function m(){const j={...a,id:t.v4(),title:`${a.title} Copy`,tabTitle:`${a.tabTitle||a.title} Copy`};d(a,j)}function g(j){const x={connectionId:j.connectionId,lastSelectedDatabase:j.lastSelectedDatabase,lastSelectedSchema:j.lastSelectedSchema,lastSelectedTable:j.lastSelectedTable,lastSelectedDatamodelId:j.lastSelectedDatamodelId,id:t.v4(),title:"Title",description:"",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"",data:[]};d(j,x)}function p(j,x){return j.cards.length===1&&(x.displayTab===!0||x.displayTab===void 0)||j.activeCardId!==x.id&&(x.displayTab===!0||x.displayTab===void 0)?null:e.jsx("div",{onClick:()=>{const b=x.displayTab===void 0?!1:!x.displayTab;o({...x,displayTab:b}),i({...x,displayTab:b})},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(cn,{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((j,x)=>e.jsxs(t.TabsTrigger,{draggable:!0,onDragStart:b=>l(b,x),onDragOver:u,onDrop:b=>c(b,x),className:"",value:j.id,children:[p(s,j),e.jsx(t.Editable,{enabled:s.activeCardId===j.id,text:j.tabTitle||j.title,onSave:b=>{o({...a,tabTitle:b}),i({...a,tabTitle:b})},children:j.tabTitle||j.title},j.id),s.activeCardId===j.id&&s.cards.length>1&&e.jsx(t.X,{className:"ml-2 size-3.5 text-muted-foreground hover:text-foreground",onClick:()=>h(j.id)})]},j.id)),e.jsx(t.Button,{className:"ml-1 h-8 px-2 hover:bg-muted-foreground/50",variant:"outline",onClick:()=>g(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:m,children:e.jsx(on,{className:"h-4 w-4"})})]})})}function gs(){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:h,isLoading:d,isFetching:m}=t.useDashboardCardQuery(a);function g(x){const b=s.cards.find(f=>f.id===x);if(b!=null&&b.sql){r||u(!0),i(x);return}if(b!=null&&b.queryConfig){r&&u(!1),p(x),i(x);return}r||p(x),i(x)}function p(x){const b={...s,cards:s.cards.map(k=>k.id===a.id?a:k),activeCardId:x};o(b);const f=b.cards.find(k=>k.id===x);f.sql&&c(!0),l(f)}function j(){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:h==null?void 0:h.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:h==null?void 0:h.records})})})}):e.jsx(t.ErrorBoundary,{FallbackComponent:t.FallbackEditorCard,children:e.jsx(us,{className:"grow border-none shadow-none"})})}return e.jsxs(t.Tabs,{onValueChange:g,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:j()},x.id)),e.jsx(ya,{})]})}function Le({children:s}){var k;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:h,setIsDevMode:d}=t.useEditorActions(),{data:m,isLoading:g,isFetching:p,error:j}=t.useDashboardCardQuery(a);function x(){const T=JSON.stringify(m==null?void 0:m.records,null,2),E=new Blob([T],{type:"application/json"}),y=URL.createObjectURL(E),C=document.createElement("a");C.href=y,C.download=`${a.title}.json`,C.click()}function b(){const E=[Object.keys(m==null?void 0:m.records.reduce((w,I)=>({...w,...I}),{})).join(","),...((m==null?void 0:m.records)||[]).map(w=>Object.values(w).join(","))].join(`
399
- `),y=new Blob([E],{type:"text/csv"}),C=URL.createObjectURL(y),v=document.createElement("a");v.href=C,v.download=`${a.title}.csv`,v.click()}function f(){const T=`Can you get the documentation for ${a.type} chart?`;h(T)}return a?e.jsxs("div",{className:"relative isolate flex h-full flex-col py-2 pb-3",children:[(g||p)&&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(ce,{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(ps,{}),o&&e.jsx(t.IconButton,{tooltip:"Visual Docs",onClick:f,children:e.jsx(Ks,{className:"size-4"})}),!["table","custom"].includes(a.type)&&o&&e.jsx(ua,{})]}),!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:b,children:e.jsx(xa,{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(un,{strokeWidth:1.5,className:"size-4"})}),e.jsx(t.CopyButton,{text:JSON.stringify(m==null?void 0:m.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(fs,{})]}),n&&e.jsx(va,{})]}),r?e.jsx(gs,{}):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(ba,{})}),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:[(m==null?void 0:m.records)&&(m==null?void 0:m.records.length)>0&&e.jsx(oa,{data:(m==null?void 0:m.records)||[]}),(j||(m==null?void 0:m.error))&&e.jsx("span",{className:"font-mono text-xs",children:(j==null?void 0:j.message)||((k=m==null?void 0:m.error)==null?void 0:k.message)})]})]})]}):e.jsx(e.Fragment,{children:"No Active Card"})}function ba(){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 va(){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 Ca(){var x,b;const s=t.useEditorStore(f=>f.card.customCardPreferences),{data:a}=hs(),n=(a==null?void 0:a.plugins)||[],r=t.useEditorStore(f=>f.card),o=t.useEditorStore(f=>f.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)||""),h=(x=c==null?void 0:c.visuals)==null?void 0:x.find(f=>f.name===(s==null?void 0:s.componentName));function d(f,k){if(!s)return;const E={...(s==null?void 0:s.dataInputCardIds)||{},[f]:{cardId:k,hookRef:null}};l({...s,dataInputCardIds:E})}function m(f){var T,E;const k=(T=o==null?void 0:o.cards)==null?void 0:T.filter(y=>{var C;return((C=y==null?void 0:y.customCardPreferences)==null?void 0:C.visualType)!=="multiple"}).map(y=>({value:y.id,label:y.tabTitle||y.title}));return e.jsx("div",{className:"space-y-2",children:(E=f==null?void 0:f.dataInputs)==null?void 0:E.map((y,C)=>{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:y}),e.jsx(le,{className:"col-span-6 h-8 w-full justify-between",label:"",options:k||[],value:((w=(v=s==null?void 0:s.dataInputCardIds)==null?void 0:v[C])==null?void 0:w.cardId)||"",onValueChange:I=>d(C,I)})]},C+Math.random())})})}function g(f,k,T=[],E=""){var y,C;return s?f==="input"?e.jsx(t.Input,{className:`h-8 w-full ${t.removeRing}`,value:((y=s==null?void 0:s.settings)==null?void 0:y[k])||E,onChange:v=>{l({...s,settings:{...s==null?void 0:s.settings,[k]:v.target.value}})}},k):f==="select"?e.jsx(le,{className:"h-8 w-full",label:"",options:T,value:((C=s==null?void 0:s.settings)==null?void 0:C[k])||E,onValueChange:v=>{l({...s,settings:{...s==null?void 0:s.settings,[k]:v}})}}):null:null}function p(f){const k=Object.entries((f==null?void 0:f.settings)||{});return e.jsx("div",{className:"space-y-3",children:k.map(([T,E])=>e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:E.title}),g(E.ui,T,E.options,E.defaultValue)]},T))})}function j(f){s&&l({...s,visualType:f,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(le,{icon:e.jsx(Ys,{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:f=>l({...s||{url:"",componentName:""},url:f})}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&e.jsx(t.Tabs,{value:i,onValueChange:j,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(le,{icon:e.jsx(rn,{className:"h-3.5 w-3.5"}),className:"h-9 w-full",label:"Select Component",options:(u==null?void 0:u.filter(f=>f.type===i).map(f=>({value:f.name,label:f.name})))||[],value:s.componentName,onValueChange:f=>{console.log("changing value",f),l({...s,componentName:f})}})})]})})]}),((b=r==null?void 0:r.customCardPreferences)==null?void 0:b.componentName)&&e.jsxs(t.AccordionItem,{className:"border-none",value:"component-settings",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsxs(t.AccordionContent,{children:[h&&h.dataInputs&&e.jsxs("div",{className:"space-y-3",children:[e.jsx(t.Label,{children:"Input Mapping"}),e.jsx("div",{className:"px-2",children:m(h)})]}),h&&h.settings&&e.jsx("div",{className:"space-y-3",children:e.jsx("div",{className:"px-2",children:p(h)})})]})]})]})}function be(){const[s,a]=L.useState([]),n=t.useEditorStore(h=>h.card.preferences),{setFilterOnClickColumnIndex:r,setCardPreferences:o}=t.useEditorStore(h=>h.actions),i=t.useEditorStore(h=>h.queryResultColumns);t.useEditorStore(h=>{var d;return(d=h.card.preferences)==null?void 0:d.filterOnClickColumnIndex}),L.useEffect(()=>{i&&a(new Array(i.length).fill(!1))},[i]);function l(h,d){var m,g;d?n!=null&&n.onClickFilter&&((m=n==null?void 0:n.onClickFilter)==null?void 0:m.length)>0?o({...n,onClickFilter:[...n.onClickFilter,{columnIndex:h,expression:""}]}):o({...n,onClickFilter:[{columnIndex:h,expression:""}]}):(o({...n,onClickFilter:(g=n==null?void 0:n.onClickFilter)==null?void 0:g.filter(p=>p.columnIndex!==h)}),a(p=>{const j=[...p];return j[h]=!1,j}))}function u(h,d){var g;const m=(g=n==null?void 0:n.onClickFilter)==null?void 0:g.map(p=>p.columnIndex===h?{...p,expression:d.target.value}:p);o({...n,onClickFilter:m})}function c(h){var d,m,g,p;if(s!=null&&s[h]||(m=(d=n==null?void 0:n.onClickFilter)==null?void 0:d.find(j=>j.columnIndex===h))!=null&&m.expression)return e.jsx(t.Input,{value:(p=(g=n==null?void 0:n.onClickFilter)==null?void 0:g.find(j=>j.columnIndex===h))==null?void 0:p.expression,onChange:j=>u(h,j),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((h,d)=>{var m,g;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:!!((m=n==null?void 0:n.onClickFilter)!=null&&m.find(p=>p.columnIndex===d)),onCheckedChange:p=>l(d,p)}),e.jsx("label",{className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:h}),e.jsx("div",{className:"flex items-center gap-2",children:((g=n==null?void 0:n.onClickFilter)==null?void 0:g.find(p=>p.columnIndex===d))&&e.jsx(t.Pencil,{onClick:()=>{a(p=>{const j=[...p];return j[d]=!p[d],j})},className:"invisible size-3 cursor-pointer text-gray-400 group-hover:visible"})})]}),c(d)]})},h)})]})}function Na({idx:s}){var u;const a=t.useEditorStore(c=>{var h;return(h=c.card)==null?void 0:h.preferences}),n=t.useEditorStore(c=>{var h;return(h=c.card.preferences)==null?void 0:h.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,h){(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:h,datalabels:d}]});else{const m={...i};m.datalabels=d;const g=n==null?void 0:n.map(p=>p.idx===h?m:p);r({...a,datasetOptions:g})}}return e.jsxs(t.Popover,{children:[e.jsx(t.PopoverTrigger,{children:e.jsx(Wt,{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(yn,{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(vn,{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(bn,{className:t.cn("h-4 w-4",{"rotate-90":o==="y"})})})]})})]})}function js(){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 Pe({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 ys(){const s=t.useEditorStore(c=>c.card),a=t.useEditorStore(c=>{var h,d,m;return(m=(d=(h=c==null?void 0:c.card)==null?void 0:h.preferences)==null?void 0:d.chartOptions)==null?void 0:m.indexAxis}),{data:n}=t.useDashboardCardQuery(s),r=a==="y"?"Metric":"Dimension",o=a==="y"?"Dimension":"Metric",{dimensionKeys:i,transformedMetricKeys:l,keys:u}=js();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:bs(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,h)=>e.jsx(vs,{className:"flex h-8 items-center bg-muted/70 px-3 hover:bg-muted",iconClassName:"invisible group-hover:visible",col:c,idx:h},c))})]})]})}function bs(s,a=30){return s.length>a?s.slice(0,a)+"...":s}function vs({col:s,idx:a,className:n,iconClassName:r,children:o}){const i=t.useEditorStore(d=>{var m;return(m=d.card)==null?void 0:m.preferences}),l=t.useEditorStore(d=>{var m,g;return(g=(m=d.card)==null?void 0:m.preferences)==null?void 0:g.datasetOptions}),u=l==null?void 0:l.find(d=>d.idx===a),{setCardPreferences:c}=t.useEditorStore(d=>d.actions);function h(d){if(!u)c({...i,datasetOptions:[...l||[],{idx:a,type:d==="area"?"line":d,fill:d==="area"?"origin":""}]});else{const m={...u};m.type=d==="area"?"line":d,m.fill=d==="area"?"origin":"";const g=l==null?void 0:l.map(p=>p.idx===a?m:p);c({...i,datasetOptions:g})}}return e.jsxs("div",{className:t.cn("group flex items-center justify-between gap-2 rounded-md",n),children:[o||e.jsx(Pe,{className:"max-w-[100px]",title:s,children:bs(s)}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx(Ge,{onClick:()=>h("bar"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx($e,{onClick:()=>h("line"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(Zs,{onClick:()=>h("area"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(Na,{idx:a})]})]})}function Cs(){const s=t.useEditorStore(p=>p.selectedConnectionId),a=t.useEditorStore(p=>p.selectedDatamodelId),n=t.useEditorStore(p=>p.selectedDatabaseName),r=t.useEditorStore(p=>p.selectedSchemaName),o=t.useEditorStore(p=>p.selectedTableName),i=t.useDashboardStore(p=>p.dashboard.filters)||[],l=t.useDashboardStore(p=>p.actions.addFilter),u=t.useDashboardStore(p=>p.actions.removeFilter),{removeFilterValues:c}=t.useDashboardActions(),{modelItems:h,tableName:d,connectionType:m}=t.useEditorAside();function g(p,j="dashboard"){var v;const x=t.fmt(p.column_name),b=t.fmt(n||""),f=t.fmt(r||""),k=t.fmt(d);let T=t.getQualifiedTableName({schemaName:f,tableName:k,connectionType:m,databaseName:b}),E=`${T}.${x}`;const y=(v=h==null?void 0:h.find(w=>w.id===a))==null?void 0:v.name;a&&a!=="none"&&(E=`${t.DATAMODEL_NAMESPCACE}.${y}.${x}`,T=`${t.DATAMODEL_NAMESPCACE}.${y}`);const C=i==null?void 0:i.find(w=>w.column===E&&w.table===k&&(w.database===b||w.database===n));if(C)c(C.id),u(C.id);else{const w=t.v4();return d==="api"&&s?(l({location:j,id:w,column:E,title:p.column_name,dataType:p.data_type,table:"api",database:"",connectionId:s,operation:"in",sql:t.getDefaultFilterSql(p.data_type,T,x)}),w):(l({id:w,location:j,column:E,title:p.column_name,dataType:p.data_type,table:o||"",database:n||"",connectionId:s||"",operation:"in",sql:t.getDefaultFilterSql(p.data_type,T,x)}),w)}}return{assignFilter:g}}function we(){const s=t.useDashboardStore(u=>u.dashboard.filters),a=t.useEditorStore(u=>u.frame),{setFrame:n}=t.useEditorActions(),{columns:r}=t.useEditorAside(),{assignFilter:o}=Cs();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(Sa,{onSelect:i,columns:r}),l&&e.jsx(t.FilterHeader,{filter:l})]})}function Sa({columns:s,onSelect:a}){var l;const[n,r]=re.useState(!1),[o,i]=re.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 h=c===o?"":c;i(h),r(!1),h&&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 wa({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(ys,{})})]}),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(be,{}),e.jsx(we,{})]})]})]})})}function Tt(){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}},h={...a,chartOptions:{...a==null?void 0:a.chartOptions,plugins:{...(d=a==null?void 0:a.chartOptions)==null?void 0:d.plugins,...c}}};n(h),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 ka({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(Tt,{})})]}),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(be,{}),e.jsx(we,{})]})]})]})})}const Ea={datasets:[{type:"line",label:"Sum_sales",data:[]},{type:"bar",label:"Sum_profit",data:[]}]},Ia={datasets:[{fill:"origin",type:"line",label:"Sum_sales",data:[]}]};function Da(){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:Ta(s)}),!["kpi"].includes(s)&&e.jsxs("div",{className:"space-y-4",children:[e.jsx(Tt,{}),e.jsx(be,{}),e.jsx(we,{})]})]})}function Ta(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(Ea,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(Ia,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 Ma(){var c,h,d,m,g;const s=t.useEditorStore(p=>p.card.preferences),a=t.useEditorStore(p=>p.actions.setCardPreferences),n=t.useEditorStore(p=>p.actions.setNumberFormat);t.useEditorStore(p=>{var j,x;return(x=(j=p.card.preferences)==null?void 0:j.formatNumber)==null?void 0:x.decimalPlaces});const r=t.useEditorStore(p=>{var j,x;return(x=(j=p.card.preferences)==null?void 0:j.formatNumber)==null?void 0:x.locale}),o=t.useEditorStore(p=>{var j,x;return(x=(j=p.card.preferences)==null?void 0:j.formatNumber)==null?void 0:x.currency});t.useEditorStore(p=>p.actions.setFilterOnClickField);const i=t.useEditorStore(p=>{var j,x;return(x=(j=p.card.preferences)==null?void 0:j.formatNumber)==null?void 0:x.colorRanges})||[],l=t.useEditorStore(p=>p.actions.setColorRanges),u=[...new Set(t.LOCALE_CURRENCY_PAIRS.map(p=>p.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:p=>{a({...s,formatNumber:{...s==null?void 0:s.formatNumber,enabled:p}})}}),e.jsx(t.Label,{children:"Format Number"})]}),((h=s==null?void 0:s.formatNumber)==null?void 0:h.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:p=>{var j,x,b;return n(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,((x=s==null?void 0:s.formatNumber)==null?void 0:x.currency)||"",p,((b=s==null?void 0:s.formatNumber)==null?void 0:b.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(p=>e.jsx(t.SelectItem,{value:p.locale,children:p.locale},p.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:p=>{var j,x,b;console.log("currency",p),n(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,p==="none"?"":p,((x=s==null?void 0:s.formatNumber)==null?void 0:x.locale)||"",((b=s==null?void 0:s.formatNumber)==null?void 0:b.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(p=>e.jsx(t.SelectItem,{value:p,children:p},p))]})})]})]})]}),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:((m=(d=s==null?void 0:s.formatNumber)==null?void 0:d.decimalPlaces)==null?void 0:m.toString())||"0",onValueChange:p=>{var j,x,b;return n(Number(p),((j=s==null?void 0:s.formatNumber)==null?void 0:j.currency)||"",((x=s==null?void 0:s.formatNumber)==null?void 0:x.locale)||"",((b=s==null?void 0:s.formatNumber)==null?void 0:b.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(p=>e.jsx(t.SelectItem,{value:p,children:p},p))})]})]}),e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Suffix"}),e.jsx(t.Input,{value:((g=s==null?void 0:s.formatNumber)==null?void 0:g.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:p=>{var j,x,b;return n(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,((x=s==null?void 0:s.formatNumber)==null?void 0:x.currency)||"",((b=s==null?void 0:s.formatNumber)==null?void 0:b.locale)||"",p.target.value)}})]})]})]})}),e.jsx(t.Separator,{className:"my-3"}),e.jsx(t.ColorFormat,{colorRanges:i,setColorRanges:l})]})]})}function Aa(){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(Ma,{})}),e.jsx("div",{}),e.jsx("div",{})]})}function Ze({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 La=[{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"}],Oa=["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"],Fa=Oa.map(s=>({label:s,value:s}));function za(){var c,h,d,m,g,p,j,x,b,f,k,T,E,y,C,v,w,I;const s=t.useEditorStore(D=>D.card),a=(h=(c=s==null?void 0:s.preferences)==null?void 0:c.mapVisualOptions)==null?void 0:h.topoJsonUrl,[n,r]=L.useState(((m=(d=s==null?void 0:s.preferences)==null?void 0:d.mapVisualOptions)==null?void 0:m.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(Ze,{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(Ze,{open:!0,summary:"Settings",children:e.jsxs("div",{className:"space-y-3 px-2",children:[e.jsx(le,{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(le,{className:"h-9",options:l,value:((p=(g=s.preferences)==null?void 0:g.mapVisualOptions)==null?void 0:p.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(le,{className:"h-9",options:La,value:((x=(j=s.preferences)==null?void 0:j.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(le,{className:"h-9",options:Fa,value:((f=(b=s.preferences)==null?void 0:b.mapVisualOptions)==null?void 0:f.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(Ze,{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=(k=s.preferences)==null?void 0:k.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:((C=(y=(E=s.preferences)==null?void 0:E.mapVisualOptions)==null?void 0:y.projectionOffset)==null?void 0:C[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(be,{})]})}function Ba(){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 Oe({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(Tt,{}),s==="text"&&e.jsx(Ba,{})]})]}),!["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(be,{}),e.jsx(we,{})]})]})]})})}function Ra(){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(le,{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(ys,{})]})]}),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(be,{}),e.jsx(we,{})]})]})]})})}function Va({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(be,{}),e.jsx(we,{})]})]})}),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 Pa=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."]})]}),qa=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."]})]}),_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 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 Ga(){const s=t.useEditorStore(n=>n.card.type);function a(n){switch(n){case"stackedBar":case"stackedLine":return e.jsx(Ra,{});case"tornado":case"pyramid":return e.jsx(Oe,{docContent:Pa,cardType:n});case"kpi":return e.jsx(Aa,{});case"line":case"bar":return e.jsx(wa,{cardType:n});case"range":return e.jsx(Oe,{docContent:qa,cardType:n});case"pie":case"doughnut":case"polarArea":case"radar":case"funnel":return e.jsx(Oe,{cardType:n});case"bubble":case"scatter":return e.jsx(ka,{cardType:n});case"table":return e.jsx(Va,{cardType:n});case"text":return e.jsx(Oe,{docContent:_a,cardType:n,suffix:"Visual"});case"map":return e.jsx(za,{});case"custom":return e.jsx(Ca,{});default:return e.jsx(Da,{})}}return e.jsxs(t.ScrollArea,{className:"h-full w-full text-sm",children:[a(s),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})}function Ns({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(le,{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 $a=[{label:"Sum",value:"SUM",logo:e.jsx(Qt,{className:"size-3.5"})},{label:"Count",value:"COUNT",logo:e.jsx(gt,{className:"size-3.5"})},{label:"Unique",value:"DISTINCT",logo:e.jsx(hn,{className:"size-3.5"})},{label:"Average",value:"AVG",logo:e.jsx(Gs,{className:"size-3.5"})},{label:"Min",value:"MIN",logo:e.jsx(qe,{className:"size-3.5"})},{label:"Max",value:"MAX",logo:e.jsx(_e,{className:"size-3.5"})}];function Ha({column:s}){const{updateMetricColumnOld:a}=t.useEditorActions();let n=$a;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:Ee(s.name,o)};a(s.id,i)}return e.jsx(Ns,{column:s,functions:n,onFunctionChange:o=>r(o),label:"Aggregation"})}const Ja=[{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 Ua({column:s}){const{updateGroupByColumnOld:a}=t.useEditorActions();function n(r){const o={...s,granularity:r,label:Se(s.name,r)};a(s.id,o)}return e.jsx(Ns,{column:s,functions:Ja,onFunctionChange:r=>n(r),label:"Granularity"})}function Ya({col:s,onChange:a,droppableId:n}){const{columns:r}=t.useDataColumns(),o=L.useMemo(()=>{let u=[];(n===fe||n===ge||n===je)&&(u=r);const c=u==null?void 0:u.filter(h=>h.column_name!==s.name);return c==null?void 0:c.map(h=>({id:h.column_name,value:h.column_name}))},[r,n,s.name]),i=[{id:s.name,value:s.name}];function l(u){const c=r==null?void 0:r.find(h=>{var d;return h.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 Ka({column:s}){const{updateMetricColumnOld:a}=t.useEditorActions(),{transformedMetricKeys:n,dimensionKeys:r}=js();console.log(n,r);const o=t.useEditorStore(c=>{var h;return(h=c.card.queryConfig)==null?void 0:h.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(vs,{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(Pe,{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(Pe,{className:"font-mono text-xs text-muted-foreground",children:s.aliasTemplate||"{label} ({pivot})"})})]})]})}function Qa({column:s,type:a,onRemoveColumn:n,droppableId:r}){const[o,i]=L.useState(!1),{updateGroupByColumnOld:l,updateMetricColumnOld:u,updatePivotByColumnOld:c}=t.useEditorActions(),{attributes:h,listeners:d,setNodeRef:m,transform:g,transition:p,isDragging:j}=t.useSortable({id:s.id,data:{type:a}}),x=g?{opacity:j?.5:void 0,transform:t.CSS.Translate.toString(g),transition:p}:void 0,b=t.isTextDataType(s.type);function f(C){const v=t.isNumberDataType(C.data_type),w=t.isTextDataType(C.data_type),I=t.isDateDataType(C.data_type),D=v?"number":w?"string":I?"date":"string";if(r===fe){if(w){const N={id:s.id,name:C.column_name,type:D,role:"groupby"};l(s.id,N)}if(I){const N={id:s.id,name:C.column_name,type:D,role:"groupby",label:Se(C.column_name,"month"),granularity:"month"};l(s.id,N)}}if(r===je){if(w){const N={id:s.id,name:C.column_name,type:D,role:"groupby"};c(s.id,N)}if(I){const N={id:s.id,name:C.column_name,type:D,label:Se(C.column_name,"month"),granularity:"month",role:"groupby"};c(s.id,N)}}if(r===ge){const N={id:s.id,name:C.column_name,type:D,role:"metric",label:Ee(C.column_name,"SUM"),aggregate:v?"SUM":"COUNT"};u(s.id,N)}}function k(){if(r===ge)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(Ka,{column:s})})}function T(){const C=t.isDateDataType(s.type);if(r===ge)return e.jsx(Ha,{column:s});if((r===fe||r===je)&&C)return e.jsx(Ua,{column:s})}function E(){return e.jsx("div",{className:t.cn("grow",{"pl-3":(r===fe||r===je)&&b}),children:e.jsx(Ya,{col:s,onChange:f,droppableId:r})})}function y(){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(Mn,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")}):e.jsx(Yt,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")})})})}return e.jsx("div",{...d,...h,ref:m,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:[y(),T(),E()]}),o&&k()]}),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 et({id:s,label:a,columns:n,previewColumns:r,sortableType:o,onRemoveColumn:i}){var x,b;const{setNodeRef:l,isOver:u,over:c}=t.useDroppable({id:s}),h=t.useDndStore(f=>f.activeId),d=t.useEditorStore(f=>{var k;return(k=f.card)==null?void 0:k.type}),m=u||((b=(x=c==null?void 0:c.data)==null?void 0:x.current)==null?void 0:b.type)===o,g=h?r:n,p=o===ze?"Rows":o===Be?"Pivot Columns":"Columns";function j(){if(!g||g.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(f=>f.id),children:e.jsxs("div",{className:t.cn("group space-y-2 rounded-md p-4",m&&"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:p})]}),j(),e.jsx("div",{className:"space-y-2",children:g==null?void 0:g.map(f=>f.id===as.id?e.jsx(Wa,{},f.id):e.jsx(Qa,{droppableId:s,type:o,column:f,onRemoveColumn:i},f.id))})]})})}function Wa(){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 Ss({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}}),h=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:h,children:s})}function Xa(){const s=t.useEditorStore(f=>{var k;return(k=f.card.queryConfig)==null?void 0:k.orderBy})||[],a=t.useEditorStore(f=>{var k;return(k=f.card.queryConfig)==null?void 0:k.groupByColumns})||[],n=t.useEditorStore(f=>{var k;return(k=f.card.queryConfig)==null?void 0:k.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(Us,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),c=e.jsx(_s,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),h=e.jsx(Js,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),d=e.jsx(qs,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),m=l==null?void 0:l.filter(f=>!s.some(k=>k.columnId===f.id)).map(f=>({id:f.id,value:f.label||f.name}));function g(f,k){const T=p(f);return T?T.role==="metric"?k==="asc"?h:d:k==="asc"?u:c:null}function p(f){return l.find(k=>k.id===f)}function j(f){const k=s.find(T=>T.columnId===f);if(k){const T={...k,direction:k.direction==="asc"?"desc":"asc"};i(T)}}const x=f=>{r({columnId:f.id,direction:"asc"})};function b(f){const k=s.find(T=>T.columnId===f);k&&o(k)}return e.jsx(t.SortableContext,{items:s.map(f=>ke(f.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"}),m.length>0&&e.jsx("div",{className:"mr-5",children:e.jsx(t.ComboBox2,{multiple:!1,options:m,selectedOptions:[],onChange:f=>x(f[0]),selectAllChecked:!1,onSelectAllCheckedChange:()=>{},inputClassName:"h-8 bg-muted border-none"})}),s.map(f=>{var k,T;return e.jsx(Ss,{id:ke(f.columnId),type:St,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(Yt,{className:"size-3 cursor-move text-muted-foreground hover:text-foreground"}),e.jsx(Pe,{className:"w-[175px] text-sm",children:((k=p(f.columnId))==null?void 0:k.label)||((T=p(f.columnId))==null?void 0:T.name)})]}),e.jsx("button",{title:f.direction==="asc"?"Ascending":"Descending",onClick:()=>j(f.columnId),className:"rounded-sm p-0",children:g(f.columnId,f.direction)})]}),e.jsx("div",{children:e.jsx("button",{onClick:()=>b(f.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"})})})]})},f.columnId)},ke(f.columnId))})]})})}function Za(){const s=t.useEditorStore(b=>{var f;return((f=b.card.queryConfig)==null?void 0:f.groupByColumns)||[]}),a=t.useEditorStore(b=>b.card.type),n=t.useDndStore(b=>b.previewGroupByColumns),r=t.useEditorStore(b=>{var f;return((f=b.card.queryConfig)==null?void 0:f.metricColumns)||[]}),o=t.useDndStore(b=>b.previewMetricColumns),i=t.useEditorStore(b=>{var f;return((f=b.card.queryConfig)==null?void 0:f.pivotColumns)||[]}),l=t.useDndStore(b=>b.previewPivotColumns),{removeColumnFromGroupBy:u,removeColumnFromMetricColumns:c,removeColumnFromPivotBy:h}=t.useEditorActions();function d(b){u(b)}function m(b){c(b)}function g(b){h(b)}let p="Group By",j="Metrics",x="Stack By";return a==="table"&&(p="Rows",j="Metrics",x="Columns"),e.jsxs("div",{className:"flex h-full w-full flex-col gap-3 py-4",children:[e.jsx(xs,{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(et,{onRemoveColumn:d,sortableType:ze,id:fe,label:p,columns:s,previewColumns:n}),e.jsx(et,{onRemoveColumn:g,sortableType:Be,id:je,label:x,columns:i,previewColumns:l}),e.jsx(et,{onRemoveColumn:m,sortableType:it,id:ge,label:j,columns:r,previewColumns:o}),e.jsx(Xa,{})]}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function Mt({children:s,column:a,id:n,sortableType:r,className:o}){const[i,l]=L.useState(!1),{removeEditorFilter:u,clearEditorFilter:c}=t.useEditorActions(),h=t.useEditorStore(m=>{var g,p;return(p=(g=m.card.queryConfig)==null?void 0:g.filters)==null?void 0:p.some(j=>j.filterColumnName===a.name)});function d(m){u(m)}return e.jsx(Ss,{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}),h&&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 er({column:s,sortableType:a}){const n=t.useDashboardStore(T=>T.themeStyle),r=t.useEditorStore(T=>{var E,y;return(y=(E=T.card)==null?void 0:E.queryConfig)==null?void 0:y.filters}),o=t.useEditorStore(T=>{var E,y;return(y=(E=T.card.queryConfig)==null?void 0:E.filterColumns)==null?void 0:y.find(C=>C.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]),h=L.useMemo(()=>Array.isArray(c)?c.map(T=>({id:T,value:T})):[],[c]),{updateEditorFilterValue:d}=t.useEditorActions(),m={column:s.name,sql:s.sql,id:s.name,connectionId:i,dataType:s.type},{data:g,isLoading:p,isFetching:j,isError:x}=t.useFilterQuery(m),b=L.useMemo(()=>{var E;return m.column?(E=g==null?void 0:g.records)==null?void 0:E.map(y=>{let C=m.column.split(".").slice(-1)[0].replace(/"/g,"");return y[C]===void 0&&(C=C.toLowerCase()),{id:y[C],value:y[C]}}):[]},[g,m.column]);function f(T){const E=T.map(y=>y.id);d(s.name,E)}function k(){return p||j?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(tr,{columnName:s.name}),showNegativeIndicator:(o==null?void 0:o.mode)==="exclude",options:b,onChange:f,selectedOptions:h,selectAllChecked:!1,onSelectAllCheckedChange:()=>{}})}return e.jsx(Mt,{className:"w-60",id:s.id,sortableType:a,column:s,children:k()})}function tr({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 sr({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:h,isError:d,data:m}=t.useFilterQuery(u),g=m==null?void 0:m.records,{dateRange:p,setDateRange:j,initialDateRange:x}=t.useDateRangeFromRecords(g),{updateEditorFilterValue:b}=t.useEditorActions();function f(E){var C,v;const y={gte:(C=E==null?void 0:E.from)==null?void 0:C.toISOString(),lte:(v=E==null?void 0:E.to)==null?void 0:v.toISOString()};b(s.name,y)}function k(){b(s.name,null,!0),j(x)}function T(){return c||h?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"}):g?e.jsx(t.DateRangePopover,{title:u.title,open:n,inputClassName:"h-8",setOpen:r,dateRange:p,setDateRange:j,onApply:f,onClear:k}):e.jsx(t.Label,{className:"flex h-8 w-72 items-center bg-muted px-2",children:"No Data"})}return e.jsx(Mt,{className:"w-72",id:s.id,sortableType:a,column:s,children:T()})}function nr({id:s,label:a,columns:n,previewColumns:r,sortableType:o}){var j,x;const{setNodeRef:i,isOver:l,over:u}=t.useDroppable({id:s}),c=t.useDndStore(b=>b.activeId),h={},d=l||((x=(j=u==null?void 0:u.data)==null?void 0:j.current)==null?void 0:x.type)===o;function m(){if(!p||p.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 g(b){const f=t.isDateDataType(b.type);return b.id===as.id?e.jsx(Mt,{id:b.id,sortableType:o,column:b,children:e.jsx(ar,{})},b.id):f?e.jsx(sr,{droppableId:s,sortableType:o,column:b},b.id):e.jsx(er,{droppableId:s,sortableType:o,column:b},b.id)}const p=c?r:n;return e.jsx(t.SortableContext,{items:n==null?void 0:n.map(b=>b.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:h,children:[e.jsx(t.Label,{className:"text-sm",children:a}),m(),e.jsx("div",{className:"flex flex-wrap items-center gap-4",children:p==null?void 0:p.map(b=>g(b))})]})})}function ar(){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 rr(){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(nr,{onRemoveColumn:r,sortableType:ct,id:lt,label:"Filters",columns:s,previewColumns:a})})}function or(){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(kn,{className:"mr-2 h-4 w-4"}),"Assistant"]}),e.jsx(is,{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 ir(){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,h,d;r?((u=s.current)==null||u.resize(0),(c=a.current)==null||c.resize(0)):((h=s.current)==null||h.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(ra,{})}),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(Ga,{})})}),!r&&e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:40,defaultSize:75,maxSize:100,children:e.jsx(Le,{})})]}):e.jsx(Le,{})})]})}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(Za,{})})}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{defaultSize:75,maxSize:100,children:e.jsxs(t.ResizablePanelGroup,{direction:"vertical",children:[e.jsxs(t.ResizablePanel,{className:"flex min-h-fit flex-col",minSize:10,defaultSize:20,children:[e.jsx(or,{}),e.jsx(rr,{})]}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:60,defaultSize:80,children:e.jsx(Le,{})})]})})]}):e.jsx(Le,{})})})}return e.jsx(t.ResizablePanelGroup,{direction:"vertical",className:"min-h-[250px] min-w-full max-w-lg",children:o?i():l()})}function lr(s,a){const[n,r]=L.useState(""),[o,i]=L.useState(null),{authToken:l}=t.useSemaphorContext(),u=t.useEditorStore(G=>{var Q;return(Q=G==null?void 0:G.card)==null?void 0:Q.sql}),c=t.useEditorStore(G=>G.isDevMode),h=t.useEditorStore(G=>{var Q;return(Q=G==null?void 0:G.card)==null?void 0:Q.python}),{setCardPython:d,setCardSql:m,setRunSql:g,switchCardType:p,setQueryConfig:j}=t.useEditorActions(),x=t.useEditorStore(G=>G.currentAssitantScope)||[],b=t.useEditorStore(G=>G.userInputForAI),f=t.useEditorStore(G=>G.triggerAIRun),k=t.useEditorStore(G=>G.selectedDatabaseName),T=t.useEditorStore(G=>G.selectedTableName),E=t.useEditorStore(G=>G.selectedConnectionId),y=t.useEditorStore(G=>G.selectedSchemaName),C=t.useDashboardStore(G=>G.dashboard.aiScopeTables),{setTriggerAIRun:v,setCurrentAssitantScope:w,setCardConfig:I}=t.useEditorActions(),{selectedDatamodelName:D,connectionType:N,selectedDatamodelId:F}=t.useEditorAside(),{messages:O,setMessages:A,reload:S,error:M,append:z,input:R,setInput:V,status:B,handleInputChange:K,handleSubmit:J,stop:$}=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:G=>{console.log("on error",G)},onToolCall:U,onFinish(G,Q){q(Q.usage),r(""),Q.finishReason==="stop"&&r("")}});L.useEffect(()=>{f&&b&&(K({target:{value:b}}),setTimeout(()=>{J(),v(!1)},100))},[f,J,b,v,K]);async function U({toolCall:G}){if(["createChartFromSql","createForecast"].includes(G.toolName)){const Q=G.args.sql,se=G.args.python,me=G.args.chartType;return p(me),m(Q),d(se),g(!0),{status:"success",message:"Let the user know that chart is created"}}else if(G.toolName==="getTableColumns")r("Getting table columns...");else{if(G.toolName==="getUserSql")return u?{status:"success",sql:u,python:h||""}:{status:"error",message:"No SQL found"};if(G.toolName==="getCurrentTableScope")return r("Getting table scope..."),Y(),{status:"success",tables:x};if(G.toolName==="generateQueryConfig"){r("Generating query config...");const Q=G.args.chartType,se=G.args.queryConfig;return G.args.cardConfig,p(Q),I(se),m(void 0),d(void 0),g(!0),{status:"success",queryConfig:se}}else r("Analyzing...")}}function q(G){i(Q=>Q?{promptTokens:Q.promptTokens+G.promptTokens,completionTokens:Q.completionTokens+G.completionTokens,totalTokens:Q.totalTokens+G.totalTokens}:G)}function P(G){const Q=t.removeFromScopeArray(x,G);_(Q)}function _(G){const Q=t.sanitizeAIScope(G);w(Q),A(se=>[...se,{id:crypto.randomUUID(),role:"system",content:`Current scope of tables. Always use the table reference format when generating SQL | ${JSON.stringify(Q)}`}])}function H(){const G={databaseName:k||"",schemaName:y||"",tableName:T||"",datamodelId:F||"",datamodelName:t.resolveDatamodelName(D),connectionId:E||"",connectionType:N||""},Q=t.dedup([...x,G]);_(Q)}function Y(){const G={databaseName:k||"",schemaName:y||"",tableName:T||"",datamodelName:t.resolveDatamodelName(D),connectionId:E||"",connectionType:N||"",datamodelId:F||""};if(!t.isInAiScopeArray([...C||[],...x],G)||x.length===0){const se=t.dedup([...C||[],...x,G]).filter(me=>me.connectionId===G.connectionId);_(se)}}const Z=!["ready","error"].includes(B),de=t.getErrorMessage(M);return{messages:O,setMessages:A,reload:S,append:z,input:R,setInput:V,isLoading:Z,handleSetAIScope:Y,handleAddCurrentTableToScope:H,removeFromCurrentSelections:P,currentAssitantScope:x,setCurrentAssitantScope:w,handleInputChange:K,handleSubmit:J,stop:$,chatStatus:B,toolStatus:n,llmUsage:o,onFinish:a,errorMessage:de}}const cr=[{title:"Help me write a query for",subtitle:"orders by month"},{title:"Create a bar chart for",subtitle:"sales by category"}];function Gt(){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,h]=L.useState(!1),[d,m]=L.useState({selectedEntities:[]}),g=t.useDashboardStore(_=>_.dashboard.aiContext),p=t.useEditorStore(_=>_.card.dataSource),j=t.useEditorStore(_=>_.actions.setCardSql),x=t.useEditorStore(_=>_.actions.setRunSql),b=t.useEditorStore(_=>_.showAIDialog),f=t.useDashboardStore(_=>_.handleOpenAssistantProfile),{setShowAIDialog:k,setCardPython:T}=t.useEditorActions(),{setDataSource:E}=t.useEditorActions(),{assistantProfile:y}=t.useAssistantProfile(),{messages:C,setMessages:v,reload:w,append:I,input:D,setInput:N,isLoading:F,handleInputChange:O,handleSubmit:A,stop:S,chatStatus:M,llmUsage:z,errorMessage:R}=lr(d);t.useAssistantScroll({scrollContainerRef:s,inputRef:a,messages:C}),L.useEffect(()=>{var _;b&&((_=a.current)==null||_.focus())},[b]);function V(_,H){H==="sql"?(j(_),x(!0)):H==="python"&&(T(_),x(!0))}function B(){var _;(_=g==null?void 0:g.selectedEntities)==null||_[0],h(!0)}function K(){d.selectedEntities.length===0&&m({selectedEntities:(g==null?void 0:g.selectedEntities)||[]})}function J(_){K();const H={role:"user",content:_.title+" "+_.subtitle};I(H)}function $(_){K(),I({role:"user",content:_})}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 P=(D==null?void 0:D.length)===0&&(C==null?void 0:C.filter(_=>_.role==="user").length)===0;return e.jsxs("div",{"data-role":"editor-assistant",className:"flex h-full w-full flex-col justify-between px-6 py-4",children:[e.jsxs("div",{"data-role":"header-section",className:"flex items-start justify-between gap-2",children:[q(),f&&e.jsx(t.Button,{variant:"outline",size:"sm",className:"h-7 p-2",onClick:f,children:(y==null?void 0:y.name)||"Default Profile"}),e.jsxs("div",{"data-role":"header-actions",className:"flex items-center gap-2",children:[U(),e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-7 p-2",onClick:B,children:e.jsx(t.Settings,{className:"size-4"})}),e.jsx(t.Button,{className:"h-7 p-2",size:"sm",variant:"ghost",onClick:()=>{v([]),w()},children:e.jsx(t.SquarePen,{className:"size-4"})}),e.jsx(t.Button,{variant:"ghost",className:"h-8",size:"sm",onClick:()=>{k(!1)},children:e.jsx(t.ChevronRight,{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:C,showTools:o,handleRun:V,showSystemMessage:l}),e.jsx(t.ChatStatus,{messages:C,chatStatus:M,errorMessage:R})]})}),e.jsxs("div",{className:"mb-3",children:[P&&!y&&e.jsx(t.Placeholders,{onClick:J,placeholders:cr}),e.jsx("div",{children:P&&y&&e.jsx(t.SeedQuestions,{seedQuestions:y.seedQuestions||[],handleSeedQuestionClick:$})})]}),e.jsx(t.ChatInputWithContext,{ref:a,setInput:N,stop:S,input:D,localAiContext:d,setLocalAiContext:m,handleInputChange:O,handleSubmit:_=>{K(),A(_)},isLoading:F,onFocus:()=>{}}),z&&n&&e.jsx("div",{className:"flex h-8 items-center justify-between",children:e.jsxs("div",{className:"text-xs text-muted-foreground",children:["Usage: ",z.promptTokens," prompt tokens,"," ",z.completionTokens," completion tokens,"," ",z.totalTokens," total tokens"]})}),e.jsx(t.DataSourceDialog,{incomingSelectedEntities:(g==null?void 0:g.selectedEntities)||[],open:c,onOpenChange:h,dataSource:p||t.EMPTY_DATA_SOURCE,fallbackDataSource:t.EMPTY_DATA_SOURCE,dialogMode:"aiContext"})]})}function dr(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 ur(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 Me(s){var j;const a=t.useDashboardStore(x=>x.authToken)||s,{hasSchemaSupport:n}=t.useSelectedConnection(s),r=t.useEditorStore(x=>{var b;return(b=x.card.dataSource)==null?void 0:b.connectionId}),o=t.useEditorStore(x=>{var b,f;return(f=(b=x.card.dataSource)==null?void 0:b.selectedEntities)==null?void 0:f.filter(k=>k.type==="model")})||[],i=t.useEditorStore(x=>{var b,f;return(f=(b=x.card.dataSource)==null?void 0:b.selectedEntities)==null?void 0:f.filter(k=>k.type==="table"||k.type==="view")})||[];function l(x){return x.type==="model"?!!r&&!!x.id:x.type==="table"||x.type==="view"?n?!!r&&!!x.name&&!!x.database&&!!x.schema:!!r&&!!x.name&&!!x.database:!1}const u=[...o,...i],c=Bs({queries:u.map(x=>({queryKey:["columns",r,x],queryFn:()=>t.getRequest("https://semaphor.cloud/api/v1/columns",(a==null?void 0:a.accessToken)||"",x.type==="model"?{connection_id:r,datamodel_id:x.id,database_name:"",schema_name:"",table_name:""}:{connection_id:r,datamodel_id:"",database_name:x.database,schema_name:x.schema,table_name:x.name}),enabled:!!r&&l(x)}))}),h=c.some(x=>x.isPending),d=c.some(x=>x.isError),m=(j=c.find(x=>x.isError))==null?void 0:j.error,g=c.map((x,b)=>{var T;const f=u[b],k=ur(f);return{entityId:f.id||f.name,entityType:f.type,entityName:f.name,label:f.label,description:f.description,qualifiedEntityName:k,columns:(T=x.data)==null?void 0:T.columns.map(E=>({id:`${f.name}-${E.column_name}`,name:E.column_name,dataType:E.data_type,label:E.label||t.toLabel(E.column_name),description:E.description||"",qualifiedEntityName:k,entityId:f.id||f.name,entityName:f.name,entityType:f.type}))}}).filter(x=>{var b;return((b=x==null?void 0:x.columns)==null?void 0:b.length)>0})||[],p=dr(g);return{columnGroups:g,columns:p,isLoading:h,hasError:d,error:m,refetch:()=>{c.forEach(x=>x.refetch())}}}function mr({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),h={transform:t.CSS.Transform.toString(o),transition:i},d=t.getDataType(s.dataType),g=(p=>{const j=(p||"").toLowerCase();switch(t.getDataType(j)){case"number":return gt;case"date":return t.Calendar;case"boolean":return Xt;case"json":return nn;case"geo":return Sn;default:return Zt}})(s.dataType);return e.jsxs("div",{ref:r,style:h,...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(g,{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:"space-y-1",children:[e.jsx("p",{className:"font-medium",children:s.label||s.name}),s.label&&s.label!==s.name&&e.jsxs("p",{className:"text-xs text-gray-500",children:["Name: ",s.name]}),e.jsx("p",{className:"text-xs text-gray-500",children:s.qualifiedEntityName?`${s.qualifiedEntityName}.${s.name}`:s.name}),e.jsxs("p",{className:"text-xs text-gray-500",children:["Type: ",s.dataType]})]})})]})}),e.jsx("button",{onClick:p=>{p.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(Wt,{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(Ln,{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 hr({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(mr,{field:o},o.id))})})]})}function xr(){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:h,error:d}=Me(),m=u.filter(E=>E.name.toLowerCase().includes(s.toLowerCase())||E.dataType.toLowerCase().includes(s.toLowerCase())||E.qualifiedEntityName&&E.qualifiedEntityName.toLowerCase().includes(s.toLowerCase())),g=E=>E.dataType==="number"||E.dataType==="integer"||E.dataType==="float"||E.dataType==="decimal"||E.dataType==="currency"?"metrics":"dimensions",j=(o==="all"?m:m.filter(E=>g(E)===o)).reduce((E,y)=>{const C=y.qualifiedEntityName||"Other Fields";return E[C]||(E[C]={label:t.toLabel(y.entityName),fields:[]}),E[C].fields.push(y),E},{});L.useEffect(()=>{const E=Object.keys(j);r(new Set(E))},[Object.keys(j).join(",")]);const x=E=>{const y=new Set(n);y.has(E)?y.delete(E):y.add(E),r(y)},b=m.filter(E=>g(E)==="dimensions").length,f=m.filter(E=>g(E)==="metrics").length,k=m.filter(E=>g(E)==="calculated").length,T=m.length>0;return h?e.jsxs("div",{className:"flex h-[calc(100vh-200px)] w-[290px] flex-col items-center justify-center",children:[e.jsx(ce,{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:m.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:b})]}),e.jsxs(t.TabsTrigger,{value:"metrics",className:"text-xs",children:[e.jsx(ut,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:f})]}),e.jsxs(t.TabsTrigger,{value:"calculated",className:"text-xs",children:[e.jsx(Xs,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:k})]})]})})]}),e.jsxs(t.CustomScrollArea,{className:"py-2",children:[e.jsxs("div",{className:"space-y-2",children:[Object.entries(j).map(([E,y])=>{const C=c.find(v=>v.entityName===E)||{entityName:E,label:y.label};return e.jsx(hr,{entityGroup:C,fields:y.fields,isOpen:n.has(E),onToggle:()=>x(E)},E)}),Object.keys(j).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(j).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 pr(){return e.jsxs("div",{className:" h-full flex flex-col items-center",children:[" ",e.jsx(xr,{})," "]})}function fr({initialJoinPlan:s,availableDataSources:a}){const[n,r]=L.useState(s),[o,i]=L.useState(new Set),l=()=>{const C=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:C,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=C=>{r({...n,joins:n.joins.filter(v=>v.id!==C)}),i(new Set([...o].filter(v=>v!==C)))},c=(C,v)=>{var N,F;const w=n.joins.find(O=>O.id===C);if(!w)return;const I={...w,...v},D=n.joins.map(O=>O.id===C?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(z=>{var R;return z.name===((R=I.source)==null?void 0:R.name)}),A=a.find(z=>{var R;return z.name===((R=I.target)==null?void 0:R.name)}),S={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:[S]},I.joinKeyGroups=M,D[D.findIndex(z=>z.id===C)]=I}r({...n,joins:D})};return{joinPlan:n,expandedJoins:o,setJoinPlan:r,addJoin:l,removeJoin:u,updateJoin:c,moveJoinUp:C=>{const v=n.joins.findIndex(w=>w.id===C);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:C=>{const v=n.joins.findIndex(w=>w.id===C);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:C=>{const v=new Set(o);v.has(C)?v.delete(C):v.add(C),i(v)},getAvailableSourceEntities:C=>{if(n.joins.length===0)return a;const v=n.joins.findIndex(I=>I.id===C);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:C=>a.filter(v=>v.name!==C),addJoinKeyGroup:C=>{const v=n.joins.find(I=>I.id===C);if(!v)return;const w=[...v.joinKeyGroups,{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}];c(C,{joinKeyGroups:w})},updateGroupOperator:(C,v,w)=>{const I=n.joins.find(N=>N.id===C);if(!I)return;const D=[...I.joinKeyGroups];D[v]={...D[v],operator:w},c(C,{joinKeyGroups:D})},removeJoinKeyGroup:(C,v)=>{const w=n.joins.find(D=>D.id===C);if(!w)return;const I=[...w.joinKeyGroups];I.splice(v,1),c(C,{joinKeyGroups:I})},addJoinKey:(C,v)=>{const w=n.joins.find(O=>O.id===C);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(C,{joinKeyGroups:N})},updateJoinKey:(C,v,w,I,D)=>{const N=n.joins.find(M=>M.id===C);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],S=A[v].keys[w];I==="sourceColumnName"&&F?A[v].keys[w]={...S,source:{...S.source,name:D}}:I==="targetColumnName"&&O?A[v].keys[w]={...S,target:{...S.target,name:D}}:I==="operator"&&(A[v].keys[w]={...S,operator:D}),c(C,{joinKeyGroups:A})},removeJoinKey:(C,v,w)=>{const I=n.joins.find(N=>N.id===C);if(!I)return;const D=[...I.joinKeyGroups];D[v].keys.splice(w,1),c(C,{joinKeyGroups:D})},generateSQLPreview:()=>{const C=[...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
- FROM ${v.name}`;return C.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(S=>{var M,z,R,V;return((M=S.source)==null?void 0:M.name)&&((z=S.target)==null?void 0:z.name)&&((R=S.source)==null?void 0:R.entityName)&&((V=S.target)==null?void 0:V.entityName)}).map(S=>`${S.source.entityName}.${S.source.name} ${S.operator} ${S.target.entityName}.${S.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+=`
398
+ `;k(z)}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(aa,{jsonString:JSON.stringify(h,null,2)})})}),h&&h.length>0&&e.jsx(t.Button,{variant:"ghost",onClick:()=>i(!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(ft,{className:"size-3.5 text-muted-foreground"})})]})}function R(){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(sa,{})}),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(na,{})}),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(ce,{className:"mr-2 h-4 w-4 animate-spin"}):e.jsx(t.Play,{className:"mr-2 h-4 w-4"}),"Run"]}),e.jsx(os,{sql:v==null?void 0:v.sql,error:S,onClick:M}),e.jsx(t.EditorClearButton,{}),e.jsx(t.Toggle,{pressed:a,onPressedChange:z=>n(z),className:"",size:"sm",children:e.jsx(ta,{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:[R(),B()]}),P()]})}function ia({data:s}){var l;const[a,n]=L.useState([]),i=Object.keys(s[0]).map(u=>({accessorKey:u,header:({column:c})=>{const h=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,h==="asc"?e.jsx(t.TriangleUpIcon,{className:"ml-2 h-5 w-5"}):h==="desc"?e.jsx(t.TriangleDownIcon,{className:"ml-2 h-5 w-5"}):null]})})}})),o=t.useReactTable({data:s,columns:i,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:o.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=o.getRowModel().rows)!=null&&l.length?o.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:i.length,className:"h-24 text-center",children:"No results."})})})]}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})}function oa({card:s}){var k,T,E,y,N,v,w,I,D,C,F;const[a,n]=L.useState(!1),[r,i]=L.useState([]),{authToken:o}=t.useSemaphorContext(),l=t.getTokenParams(o==null?void 0:o.accessToken),u=t.useDashboardStore(O=>O.themeStyle),c={colors:((T=(k=u==null?void 0:u.chart)==null?void 0:k.dataset)==null?void 0:T.backgroundColor)||[]};(E=s.customCardPreferences)!=null&&E.inputData;const{getCard:h}=t.useCustomVisual(((y=s.customCardPreferences)==null?void 0:y.url)||""),d=((N=s.customCardPreferences)==null?void 0:N.visualType)||"single",m=t.useEditorStore(O=>O.frame),{setCustomCardPreferences:g}=t.useEditorActions(),{data:p}=t.useDashboardCardQuery(s),j=L.useCallback((O,A)=>{i(S=>({...S,[O]:A}))},[]);if(!((v=s.customCardPreferences)!=null&&v.componentName))return null;const x=h((w=s.customCardPreferences)==null?void 0:w.componentName);function b(O){n(O)}const f=Object.keys(((I=s.customCardPreferences)==null?void 0:I.dataInputCardIds)||{}).map(O=>{var M,B,R;const A=(B=(M=s.customCardPreferences)==null?void 0:M.dataInputCardIds)==null?void 0:B[O].cardId,S=(R=m==null?void 0:m.cards)==null?void 0:R.find(P=>P.id===A);return S||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:j,data:(p==null?void 0:p.records)||[]}),x&&d==="multiple"&&e.jsxs(e.Fragment,{children:[Object.keys(((C=s.customCardPreferences)==null?void 0:C.dataInputCardIds)||{}).map(O=>{var M,B,R;const A=(B=(M=s.customCardPreferences)==null?void 0:M.dataInputCardIds)==null?void 0:B[O].cardId,S=(R=m==null?void 0:m.cards)==null?void 0:R.find(P=>P.id===A);if(S)return e.jsx(t.MultiInputEmptyRenderer,{onLoadingStatus:b,onDataChange:j,dataInputIndex:O,card:S},S.id+O)}),e.jsx("div",{className:"flex flex-col gap-2",children:e.jsx(x,{theme:c,onDataChange:j,settings:f.map(O=>{var A;return(A=O==null?void 0:O.customCardPreferences)==null?void 0:A.settings}),data:f.map(O=>O!=null&&O.id?r==null?void 0:r[O.id]:[])})})]})]},(F=s.customCardPreferences)==null?void 0:F.componentName)})}function us({className:s,...a}){var b;const n=t.useEditorStore(f=>f.card),r=((b=n.customCardPreferences)==null?void 0:b.showCardHeader)??!0,i=t.useEditorStore(f=>f.frame),o=t.useDashboardStore(f=>f.dashboard.filters);t.useEditorStore(f=>f.actions.setRunSql);const{updateFilter:l}=t.useDashboardActions(),u=o==null?void 0:o.find(f=>f.id===i.filterId),{data:c,isLoading:h,isFetching:d}=t.useDashboardCardQuery(n),{setCard:m}=t.useEditorActions(),{data:g}=t.useTopoJson(n),p=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:g}),[n.id,c==null?void 0:c.records,n.type,n.queryConfig,n.customCfg,n.preferences,g]);function j(f){return e.jsx(oa,{card:f})}function x(){if(c!=null&&c.records&&(c==null?void 0:c.records.length)===0&&!h&&!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 j(n);if(!["table","custom"].includes(n.type)&&p)return e.jsx(e.Fragment,{children:h||d?e.jsx(e.Fragment,{}):e.jsx(t.ChartJsVisual,{cfg:p})});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:f=>m({...n,title:f}),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:f=>m({...n,description:f}),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:f=>l({...u,title:f}),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 Xe=({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}),la=()=>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."})]})]}),ca=({customCode:s,cardCustomCfgString:a,mergedConfig:n,onConfigChange:r,onCodeChange:i})=>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(Xe,{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(Xe,{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(Xe,{language:"javascript",value:s,onChange:i})})]}),da=({error:s,hasCardCustomConfig:a,onReset:n,onApply:r,onClose:i})=>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:i,variant:"outline",children:"Close"})]});function ua(){const[s,a]=L.useState(!1),[n,r]=L.useState(""),[i,o]=L.useState(""),[l,u]=L.useState(""),[c,h]=L.useState(""),d=t.useEditorStore(y=>y.card),m=t.useEditorStore(y=>y.card.customCfg),g=m?JSON.stringify(m,null,2):"",{data:p}=t.useDashboardCardQuery(d),{data:j}=t.useTopoJson(d),{setCardCustomCfg:x,setCustomVisualCode:b}=t.useEditorActions(),f=y=>{var N,v;return JSON.stringify({...y,data:{...y.data,datasets:(v=(N=y.data)==null?void 0:N.datasets)==null?void 0:v.map(w=>({...w,data:[]}))}},null,2)},k=()=>{var N,v;if(!((N=p==null?void 0:p.records)!=null&&N.length))return;const y=t.createChartConfig({card:d,data:p.records,cardType:d.type,queryConfig:d.queryConfig,preferences:d.preferences,topoJson:j});if(y){r(f(y)),u(((v=d.preferences)==null?void 0:v.customVisualCode)||"");const w=t.merge(y,m);o(f(w))}},T=()=>{try{if(l&&b(l),i){const y=JSON.parse(i),N=t.getObjectDiff(JSON.parse(n),y);x(N),h("")}}catch{h("Invalid JSON configuration")}},E=Object.keys(m||{}).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:k,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(la,{}),e.jsxs("div",{className:"flex grow gap-2",children:[e.jsx(t.ErrorBoundary,{FallbackComponent:t.FallbackEditorCard,children:e.jsx(us,{className:"w-1/2 rounded shadow-none"})}),e.jsx(ca,{customCode:l,cardCustomCfgString:g,mergedConfig:i,onConfigChange:y=>o(y??""),onCodeChange:y=>u(y??"")})]}),e.jsx(da,{error:c,hasCardCustomConfig:!!m,onReset:()=>{o(n),x(null)},onApply:T,onClose:()=>a(!1)})]})]})}function ms(s){const[a,n]=L.useState(null);return a}function hs(){const{authToken:s}=t.useSemaphorContext(),{data:a,isLoading:n,isFetching:r,isError:i}=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:i}}function ma({onChartTypeChange:s}){const[a,n]=L.useState([]),{setCardCustomCfg:r,setCardPreferences:i,setCardType:o,setCustomCardPreferences:l}=t.useEditorActions(),{data:u}=hs();function c(h,d){r(null),i({}),o(h),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 g=(await Promise.all((d=u==null?void 0:u.plugins)==null?void 0:d.map(async p=>(await t.loadManifest(p.value)).visuals.map(b=>({name:b.name,icon:b.icon,url:p.value}))))).flat();n(g)}})()},[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((h,d)=>e.jsx(ha,{text:h.name,onClick:()=>c("custom",h),icon:h.icon},h.url+h.name+d))})]})}const ha=({text:s,icon:a,onClick:n})=>{const r=ms(),i=s.charAt(0).toUpperCase();return e.jsx(t.IconButton,{onClick:n,tooltip:s,children:r?e.jsx(r,{className:"h-4 w-4"}):i})};function wt(s){return ye({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 xa(s){return ye({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 kt(s){return ye({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 Et(s){return ye({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 It(s){return ye({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 Dt(s){return ye({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 xs({onChartTypeChange:s,iconClassName:a}){const{setCardType:n,setCardPreferences:r,setIsDevMode:i}=t.useEditorStore(d=>d.actions),{setCardCustomCfg:o,setCustomCardPreferences:l,setQueryConfig:u}=t.useEditorActions();function c(d,m){o(null),r({}),n(d),["kpi","custom","text","map"].includes(d)&&(i(!0),u(void 0)),s==null||s()}const h=1e3;return e.jsxs("div",{className:"grid grid-cols-5 place-items-center",children:[e.jsx(t.IconButton,{openDelay:h,tooltip:"Table",onClick:()=>c("table"),className:"h-10 p-4",children:e.jsx(He,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Bar Chart",onClick:()=>c("bar"),className:"h-10 p-4",children:e.jsx(Ge,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Line Chart",onClick:()=>c("line"),className:"h-10 p-4",children:e.jsx($e,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Stacked Bar Chart",onClick:()=>c("stackedBar"),className:"h-10 p-4",children:e.jsx(dt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Stacked Line Chart",onClick:()=>c("stackedLine"),className:"h-10 p-4",children:e.jsx(It,{className:t.cn("size-5",a),strokeWidth:0})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Scatter Chart",onClick:()=>c("scatter"),className:"h-10 p-4",children:e.jsx(xt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Bubble Chart",onClick:()=>c("bubble"),className:"h-10 p-4",children:e.jsx(kt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Pie Chart",onClick:()=>c("pie"),className:"h-10 p-4",children:e.jsx(ht,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Doughnut Chart",onClick:()=>c("doughnut"),className:"h-10 p-4",children:e.jsx(pt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Funnel Chart",onClick:()=>c("funnel"),className:"h-10 p-4",children:e.jsx(Et,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Radar Chart",onClick:()=>c("radar"),className:"h-10 p-4",children:e.jsx(yt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Polar Area Chart",onClick:()=>c("polarArea"),className:"h-10 p-4",children:e.jsx(wt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Tornado Chart",onClick:()=>c("tornado"),className:"h-10 p-4",children:e.jsx(vt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{tooltip:"Range Chart",onClick:()=>c("range"),className:"h-10 p-4",children:e.jsx(mt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"KPI",onClick:()=>c("kpi"),className:"h-10 p-4",children:e.jsx(Dt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Text",onClick:()=>c("text"),className:"h-10 p-4",children:e.jsx(Jt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{tooltip:"Map",onClick:()=>c("map"),className:"h-10 p-4",children:e.jsx(jt,{className:t.cn("size-5",a)})}),e.jsx(t.IconButton,{openDelay:h,tooltip:"Custom",onClick:()=>c("custom"),className:"h-10 p-4",children:e.jsx(bt,{className:t.cn("size-5",a)})})]})}function pa({chartType:s,className:a,customIcon:n,componentName:r}){const i=ms();switch(s){case"bar":return e.jsx(Ge,{className:a});case"line":return e.jsx($e,{className:a});case"pie":return e.jsx(ht,{className:a});case"radar":return e.jsx(yt,{className:a});case"scatter":return e.jsx(xt,{className:a});case"bubble":return e.jsx(kt,{className:a});case"doughnut":return e.jsx(pt,{className:a});case"stackedBar":return e.jsx(dt,{className:a});case"stackedLine":return e.jsx(It,{className:a});case"polarArea":return e.jsx(wt,{className:a});case"funnel":return e.jsx(Et,{className:a});case"tornado":case"pyramid":return e.jsx(vt,{className:a});case"range":return e.jsx(mt,{className:a});case"kpi":return e.jsx(Dt,{className:a});case"text":return e.jsx(Zt,{className:a});case"map":return e.jsx(jt,{className:a});case"custom":return n&&i?e.jsx(i,{className:a}):r?r==null?void 0:r.charAt(0).toUpperCase():e.jsx(bt,{className:a});default:return e.jsx(He,{className:a})}}function ps({variant:s="ghost"}){var o,l;const[a,n]=L.useState(!1),r=t.useEditorStore(u=>u.card),i=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(pa,{className:"size-4",chartType:i,customIcon:(o=r.customCardPreferences)==null?void 0:o.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(xs,{onChartTypeChange:()=>n(!1)}),e.jsx(ma,{onChartTypeChange:()=>n(!1)})]})]})}const Ae="focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0";function _t(s,a){var r,i,o;const n=t.getNumberAxis(s,{});return["pie","doughnut","polarArea","funnel"].includes(a)?"category":((o=(i=(r=s==null?void 0:s.chartOptions)==null?void 0:r.scales)==null?void 0:i[n])==null?void 0:o.type)||"linear"}function fa(){var M,B,R,P,z,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}),i=t.getNumberAxis(n,{}),[o,l]=L.useState(_t(n,r)),[u,c]=L.useState(((R=(B=(M=n==null?void 0:n.chartOptions)==null?void 0:M.scales)==null?void 0:B[i])==null?void 0:R.min)||""),[h,d]=L.useState(((K=(z=(P=n==null?void 0:n.chartOptions)==null?void 0:P.scales)==null?void 0:z[i])==null?void 0:K.max)||""),[m,g]=L.useState(u||h?"custom":"auto"),[p,j]=L.useState(""),[x,b]=L.useState(0),[f,k]=L.useState(""),[T,E]=L.useState(""),[y,N]=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,_,H,Y,Z,de,G,Q,se,me;l(_t(n,r)),c(((U=($=(J=n==null?void 0:n.chartOptions)==null?void 0:J.scales)==null?void 0:$[i])==null?void 0:U.min)===0?0:""),d(((_=(V=(q=n==null?void 0:n.chartOptions)==null?void 0:q.scales)==null?void 0:V[i])==null?void 0:_.max)||""),j(((de=(Z=(Y=(H=n==null?void 0:n.chartOptions)==null?void 0:H.scales)==null?void 0:Y[i])==null?void 0:Z.ticks)==null?void 0:de.stepSize)||""),b(((G=n==null?void 0:n.numberAxisFormat)==null?void 0:G.decimalPlaces)||0),k(((Q=n==null?void 0:n.numberAxisFormat)==null?void 0:Q.suffix)||""),E(((se=n==null?void 0:n.numberAxisFormat)==null?void 0:se.currency)||""),N(((me=n==null?void 0:n.numberAxisFormat)==null?void 0:me.locale)||"")},[s,n,i,r]);function C(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:y,onValueChange:$=>N($),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:$=>b(Number($.target.value)),id:"format",className:`col-span-6 h-8 w-full tracking-wide ${Ae}`})]})]})}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:o,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"})]})})]})]}),o=="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:m,onValueChange:J=>g(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"})]})]})]}),m==="custom"&&o=="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($=>C($,J.target.value)),className:`col-span-1 h-8 w-full ${Ae}`}),e.jsx(t.Input,{value:h,onChange:J=>d($=>C($,J.target.value)),id:"max",className:`col-span-1 h-8 w-full ${Ae}`})]}),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:p,onChange:J=>j($=>C($,J.target.value)),id:"step-size",className:`col-span-1 h-8 w-full ${Ae}`})]})]})}function S(){var q;let J={};m==="custom"&&(J={min:u,max:h,ticks:{stepSize:p}});const $={...n||{},chartOptions:{...n==null?void 0:n.chartOptions,scales:{...(q=n==null?void 0:n.chartOptions)==null?void 0:q.scales,[i]:{type:o,...o==="linear"?J:{}}}},numberAxisFormat:{decimalPlaces:x,suffix:f,currency:T,locale:y}};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(ln,{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:S,variant:"secondary",className:"col-span-1 col-start-3 h-8 w-full",children:"Apply"})})]})]})})]})}function ga(){const s=t.useEditorStore(u=>{var c,h,d,m;return(m=(d=(h=(c=u.card.preferences)==null?void 0:c.chartOptions)==null?void 0:h.plugins)==null?void 0:d.legend)==null?void 0:m.position}),a=t.useEditorStore(u=>{var c,h,d,m;return(m=(d=(h=(c=u.card.preferences)==null?void 0:c.chartOptions)==null?void 0:h.plugins)==null?void 0:d.legend)==null?void 0:m.align}),n=t.useEditorStore(u=>{var c,h,d,m;return(m=(d=(h=(c=u.card.preferences)==null?void 0:c.chartOptions)==null?void 0:h.plugins)==null?void 0:d.legend)==null?void 0:m.display}),{setLegendOptions:r}=t.useEditorActions(),i=u=>{r({display:u,position:s,align:a})},o=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(jn,{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:i,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:()=>o("top"),children:e.jsx(_e,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Left",onClick:()=>o("left"),children:e.jsx($s,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Bottom",onClick:()=>o("bottom"),children:e.jsx(qe,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Right",onClick:()=>o("right"),children:e.jsx(Hs,{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(Ps,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"Center",onClick:()=>l("center"),children:e.jsx(Rs,{className:"size-4"})}),e.jsx(t.IconButton,{tooltip:"End",onClick:()=>l("end"),children:e.jsx(Vs,{className:"size-4"})})]})]})]})]})]})})]})}function ja(){const s=t.useEditorStore(o=>{var l,u;return(u=(l=o.card.preferences)==null?void 0:l.chartOptions)==null?void 0:u.indexAxis}),a=t.useEditorStore(o=>o.card.type),{setChartOrientation:n}=t.useEditorStore(o=>o.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(zt,{className:"size-4"}):e.jsx(Bt,{className:"size-4"})})}function i(){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(zt,{className:"size-4"}):e.jsx(Bt,{className:"size-4"})})}return e.jsx(e.Fragment,{children:a==="funnel"?i():r()})}function fs(){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:i}=t.useEditorActions();function o(){const l=["xy","none","x","y"],c=(l.indexOf(r)+1)%l.length;i(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(ja,{}),!["kpi","text","custom","table"].includes(s.type)&&e.jsxs(e.Fragment,{children:[e.jsx(fa,{}),e.jsx(ga,{})]}),!["pie","doughnut","funnel","radar","polarArea","table","custom","kpi","text","map"].includes(s.type)&&e.jsxs(t.IconButton,{tooltip:"Grid Style",onClick:o,children:[(r==="xy"||!r)&&e.jsx(pn,{className:"size-4"}),r==="x"&&e.jsx(an,{className:"size-4"}),r==="y"&&e.jsx(Dn,{className:"size-4"}),r==="none"&&e.jsx(An,{className:"size-4"})]})]}):null}function ya(){const s=t.useEditorStore(j=>j.frame),a=t.useEditorStore(j=>j.card),{setFrame:n,setActiveTabCardId:r,setCard:i,updateCardInFrame:o}=t.useEditorActions(),l=(j,x)=>{j.dataTransfer.setData("tabIndex",x.toString())},u=j=>{j.preventDefault()},c=(j,x)=>{const b=j.dataTransfer.getData("tabIndex");if(b===x.toString())return;const f=Array.from(s.cards),[k]=f.splice(parseInt(b),1);f.splice(x,0,k),n({...s,cards:f})};function h(j){const x=s.cards.filter(k=>k.id!==j),b=x[0],f={...s,cards:x,activeCardId:b.id};n(f),r(b.id),i(b)}function d(j,x){const b={...s,cards:[...s.cards,x],activeCardId:j.id};n(b),r(x.id)}function m(){const j={...a,id:t.v4(),title:`${a.title} Copy`,tabTitle:`${a.tabTitle||a.title} Copy`};d(a,j)}function g(j){const x={connectionId:j.connectionId,lastSelectedDatabase:j.lastSelectedDatabase,lastSelectedSchema:j.lastSelectedSchema,lastSelectedTable:j.lastSelectedTable,lastSelectedDatamodelId:j.lastSelectedDatamodelId,id:t.v4(),title:"Title",description:"",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"",data:[]};d(j,x)}function p(j,x){return j.cards.length===1&&(x.displayTab===!0||x.displayTab===void 0)||j.activeCardId!==x.id&&(x.displayTab===!0||x.displayTab===void 0)?null:e.jsx("div",{onClick:()=>{const b=x.displayTab===void 0?!1:!x.displayTab;i({...x,displayTab:b}),o({...x,displayTab:b})},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(cn,{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((j,x)=>e.jsxs(t.TabsTrigger,{draggable:!0,onDragStart:b=>l(b,x),onDragOver:u,onDrop:b=>c(b,x),className:"",value:j.id,children:[p(s,j),e.jsx(t.Editable,{enabled:s.activeCardId===j.id,text:j.tabTitle||j.title,onSave:b=>{i({...a,tabTitle:b}),o({...a,tabTitle:b})},children:j.tabTitle||j.title},j.id),s.activeCardId===j.id&&s.cards.length>1&&e.jsx(t.X,{className:"ml-2 size-3.5 text-muted-foreground hover:text-foreground",onClick:()=>h(j.id)})]},j.id)),e.jsx(t.Button,{className:"ml-1 h-8 px-2 hover:bg-muted-foreground/50",variant:"outline",onClick:()=>g(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:m,children:e.jsx(on,{className:"h-4 w-4"})})]})})}function gs(){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:i,setActiveTabCardId:o,setCard:l,setIsDevMode:u,setRunSql:c}=t.useEditorActions(),{data:h,isLoading:d,isFetching:m}=t.useDashboardCardQuery(a);function g(x){const b=s.cards.find(f=>f.id===x);if(b!=null&&b.sql){r||u(!0),o(x);return}if(b!=null&&b.queryConfig){r&&u(!1),p(x),o(x);return}r||p(x),o(x)}function p(x){const b={...s,cards:s.cards.map(k=>k.id===a.id?a:k),activeCardId:x};i(b);const f=b.cards.find(k=>k.id===x);f.sql&&c(!0),l(f)}function j(){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:h==null?void 0:h.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:h==null?void 0:h.records})})})}):e.jsx(t.ErrorBoundary,{FallbackComponent:t.FallbackEditorCard,children:e.jsx(us,{className:"grow border-none shadow-none"})})}return e.jsxs(t.Tabs,{onValueChange:g,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:j()},x.id)),e.jsx(ya,{})]})}function Le({children:s}){var k;t.useEditorStore(T=>T.frame);const a=t.useEditorStore(T=>T.card),n=t.useEditorStore(T=>T.isDevMode),r=t.useEditorStore(T=>T.isShowingVisual),i=t.useDashboardStore(T=>T.isVisualEditing),o=t.useEditorStore(T=>T.pythonStdOut);t.useEditorStore(T=>T.actions.setRunSql);const{setFrame:l,setCard:u,setActiveTabCardId:c,runAssistant:h,setIsDevMode:d}=t.useEditorActions(),{data:m,isLoading:g,isFetching:p,error:j}=t.useDashboardCardQuery(a);function x(){const T=JSON.stringify(m==null?void 0:m.records,null,2),E=new Blob([T],{type:"application/json"}),y=URL.createObjectURL(E),N=document.createElement("a");N.href=y,N.download=`${a.title}.json`,N.click()}function b(){const E=[Object.keys(m==null?void 0:m.records.reduce((w,I)=>({...w,...I}),{})).join(","),...((m==null?void 0:m.records)||[]).map(w=>Object.values(w).join(","))].join(`
399
+ `),y=new Blob([E],{type:"text/csv"}),N=URL.createObjectURL(y),v=document.createElement("a");v.href=N,v.download=`${a.title}.csv`,v.click()}function f(){const T=`Can you get the documentation for ${a.type} chart?`;h(T)}return a?e.jsxs("div",{className:"relative isolate flex h-full flex-col py-2 pb-3",children:[(g||p)&&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(ce,{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(ps,{}),i&&e.jsx(t.IconButton,{tooltip:"Visual Docs",onClick:f,children:e.jsx(Ks,{className:"size-4"})}),!["table","custom"].includes(a.type)&&i&&e.jsx(ua,{})]}),!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:b,children:e.jsx(xa,{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(un,{strokeWidth:1.5,className:"size-4"})}),e.jsx(t.CopyButton,{text:JSON.stringify(m==null?void 0:m.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(fs,{})]}),n&&e.jsx(va,{})]}),r?e.jsx(gs,{}):e.jsxs(t.ResizablePanelGroup,{className:"px-6",direction:"horizontal",children:[o&&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:o&&e.jsx(ba,{})}),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:[(m==null?void 0:m.records)&&(m==null?void 0:m.records.length)>0&&e.jsx(ia,{data:(m==null?void 0:m.records)||[]}),(j||(m==null?void 0:m.error))&&e.jsx("span",{className:"font-mono text-xs",children:(j==null?void 0:j.message)||((k=m==null?void 0:m.error)==null?void 0:k.message)})]})]})]}):e.jsx(e.Fragment,{children:"No Active Card"})}function ba(){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 va(){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 Na(){var x,b;const s=t.useEditorStore(f=>f.card.customCardPreferences),{data:a}=hs(),n=(a==null?void 0:a.plugins)||[],r=t.useEditorStore(f=>f.card),i=t.useEditorStore(f=>f.frame),o=(s==null?void 0:s.visualType)||"single",{setCustomCardPreferences:l}=t.useEditorActions(),{components:u,manifest:c}=t.useCustomVisual((s==null?void 0:s.url)||""),h=(x=c==null?void 0:c.visuals)==null?void 0:x.find(f=>f.name===(s==null?void 0:s.componentName));function d(f,k){if(!s)return;const E={...(s==null?void 0:s.dataInputCardIds)||{},[f]:{cardId:k,hookRef:null}};l({...s,dataInputCardIds:E})}function m(f){var T,E;const k=(T=i==null?void 0:i.cards)==null?void 0:T.filter(y=>{var N;return((N=y==null?void 0:y.customCardPreferences)==null?void 0:N.visualType)!=="multiple"}).map(y=>({value:y.id,label:y.tabTitle||y.title}));return e.jsx("div",{className:"space-y-2",children:(E=f==null?void 0:f.dataInputs)==null?void 0:E.map((y,N)=>{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:y}),e.jsx(le,{className:"col-span-6 h-8 w-full justify-between",label:"",options:k||[],value:((w=(v=s==null?void 0:s.dataInputCardIds)==null?void 0:v[N])==null?void 0:w.cardId)||"",onValueChange:I=>d(N,I)})]},N+Math.random())})})}function g(f,k,T=[],E=""){var y,N;return s?f==="input"?e.jsx(t.Input,{className:`h-8 w-full ${t.removeRing}`,value:((y=s==null?void 0:s.settings)==null?void 0:y[k])||E,onChange:v=>{l({...s,settings:{...s==null?void 0:s.settings,[k]:v.target.value}})}},k):f==="select"?e.jsx(le,{className:"h-8 w-full",label:"",options:T,value:((N=s==null?void 0:s.settings)==null?void 0:N[k])||E,onValueChange:v=>{l({...s,settings:{...s==null?void 0:s.settings,[k]:v}})}}):null:null}function p(f){const k=Object.entries((f==null?void 0:f.settings)||{});return e.jsx("div",{className:"space-y-3",children:k.map(([T,E])=>e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:E.title}),g(E.ui,T,E.options,E.defaultValue)]},T))})}function j(f){s&&l({...s,visualType:f,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(le,{icon:e.jsx(Ys,{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:f=>l({...s||{url:"",componentName:""},url:f})}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&e.jsx(t.Tabs,{value:o,onValueChange:j,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(le,{icon:e.jsx(rn,{className:"h-3.5 w-3.5"}),className:"h-9 w-full",label:"Select Component",options:(u==null?void 0:u.filter(f=>f.type===o).map(f=>({value:f.name,label:f.name})))||[],value:s.componentName,onValueChange:f=>{console.log("changing value",f),l({...s,componentName:f})}})})]})})]}),((b=r==null?void 0:r.customCardPreferences)==null?void 0:b.componentName)&&e.jsxs(t.AccordionItem,{className:"border-none",value:"component-settings",children:[e.jsx(t.AccordionTrigger,{children:"Settings"}),e.jsxs(t.AccordionContent,{children:[h&&h.dataInputs&&e.jsxs("div",{className:"space-y-3",children:[e.jsx(t.Label,{children:"Input Mapping"}),e.jsx("div",{className:"px-2",children:m(h)})]}),h&&h.settings&&e.jsx("div",{className:"space-y-3",children:e.jsx("div",{className:"px-2",children:p(h)})})]})]})]})}function be(){const[s,a]=L.useState([]),n=t.useEditorStore(h=>h.card.preferences),{setFilterOnClickColumnIndex:r,setCardPreferences:i}=t.useEditorStore(h=>h.actions),o=t.useEditorStore(h=>h.queryResultColumns);t.useEditorStore(h=>{var d;return(d=h.card.preferences)==null?void 0:d.filterOnClickColumnIndex}),L.useEffect(()=>{o&&a(new Array(o.length).fill(!1))},[o]);function l(h,d){var m,g;d?n!=null&&n.onClickFilter&&((m=n==null?void 0:n.onClickFilter)==null?void 0:m.length)>0?i({...n,onClickFilter:[...n.onClickFilter,{columnIndex:h,expression:""}]}):i({...n,onClickFilter:[{columnIndex:h,expression:""}]}):(i({...n,onClickFilter:(g=n==null?void 0:n.onClickFilter)==null?void 0:g.filter(p=>p.columnIndex!==h)}),a(p=>{const j=[...p];return j[h]=!1,j}))}function u(h,d){var g;const m=(g=n==null?void 0:n.onClickFilter)==null?void 0:g.map(p=>p.columnIndex===h?{...p,expression:d.target.value}:p);i({...n,onClickFilter:m})}function c(h){var d,m,g,p;if(s!=null&&s[h]||(m=(d=n==null?void 0:n.onClickFilter)==null?void 0:d.find(j=>j.columnIndex===h))!=null&&m.expression)return e.jsx(t.Input,{value:(p=(g=n==null?void 0:n.onClickFilter)==null?void 0:g.find(j=>j.columnIndex===h))==null?void 0:p.expression,onChange:j=>u(h,j),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"}),o==null?void 0:o.map((h,d)=>{var m,g;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:!!((m=n==null?void 0:n.onClickFilter)!=null&&m.find(p=>p.columnIndex===d)),onCheckedChange:p=>l(d,p)}),e.jsx("label",{className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:h}),e.jsx("div",{className:"flex items-center gap-2",children:((g=n==null?void 0:n.onClickFilter)==null?void 0:g.find(p=>p.columnIndex===d))&&e.jsx(t.Pencil,{onClick:()=>{a(p=>{const j=[...p];return j[d]=!p[d],j})},className:"invisible size-3 cursor-pointer text-gray-400 group-hover:visible"})})]}),c(d)]})},h)})]})}function Ca({idx:s}){var u;const a=t.useEditorStore(c=>{var h;return(h=c.card)==null?void 0:h.preferences}),n=t.useEditorStore(c=>{var h;return(h=c.card.preferences)==null?void 0:h.datasetOptions}),r=t.useEditorStore(c=>c.actions.setCardPreferences),i=(u=a==null?void 0:a.chartOptions)==null?void 0:u.indexAxis,o=n==null?void 0:n.find(c=>c.idx===s);function l(c,h){(c==="end"||c==="start")&&t.getContrastColor(t.getCanvasBackgroundColor());const d={display:c!=="none",align:c,anchor:c,clamp:!0};if(!o)r({...a,datasetOptions:[...n||[],{idx:h,datalabels:d}]});else{const m={...o};m.datalabels=d;const g=n==null?void 0:n.map(p=>p.idx===h?m:p);r({...a,datasetOptions:g})}}return e.jsxs(t.Popover,{children:[e.jsx(t.PopoverTrigger,{children:e.jsx(Wt,{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(yn,{className:t.cn("h-4 w-4",{"rotate-90":i==="y"})})}),e.jsx("button",{onClick:()=>l("center",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(vn,{className:t.cn("h-4 w-4",{"rotate-90":i==="y"})})}),e.jsx("button",{onClick:()=>l("end",s),className:"h-7 p-1 text-xs font-normal",children:e.jsx(bn,{className:t.cn("h-4 w-4",{"rotate-90":i==="y"})})})]})})]})}function js(){const s=t.useEditorStore(o=>o.card),{data:a}=t.useDashboardCardQuery(s),{keys:n}=t.getKeys((a==null?void 0:a.records)||[]),r=n.slice(1).filter(o=>!t.METADATA_KEYS.includes(o));let i=r;if(["stackedBar","stackedLine"].includes(s.type)){const o=t.pivotData({dataArray:(a==null?void 0:a.records)||[],groupKey:n[0],pivotKey:n[1],valueKey:n[2]}),{keys:l}=t.getKeys(o);i=l.slice(1)}return{transformedMetricKeys:i,dimensionKeys:n.slice(0,1),keys:n,defaultMetricKeys:r}}function Ve({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 ys(){const s=t.useEditorStore(c=>c.card),a=t.useEditorStore(c=>{var h,d,m;return(m=(d=(h=c==null?void 0:c.card)==null?void 0:h.preferences)==null?void 0:d.chartOptions)==null?void 0:m.indexAxis}),{data:n}=t.useDashboardCardQuery(s),r=a==="y"?"Metric":"Dimension",i=a==="y"?"Dimension":"Metric",{dimensionKeys:o,transformedMetricKeys:l,keys:u}=js();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:o.map(c=>e.jsx("p",{className:"flex h-8 items-center rounded-md bg-muted/70 px-3 hover:bg-muted",title:c,children:bs(c)},c))})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:i}),e.jsx("div",{className:"my-1 max-h-[125px] space-y-1 overflow-y-auto",children:l.map((c,h)=>e.jsx(vs,{className:"flex h-8 items-center bg-muted/70 px-3 hover:bg-muted",iconClassName:"invisible group-hover:visible",col:c,idx:h},c))})]})]})}function bs(s,a=30){return s.length>a?s.slice(0,a)+"...":s}function vs({col:s,idx:a,className:n,iconClassName:r,children:i}){const o=t.useEditorStore(d=>{var m;return(m=d.card)==null?void 0:m.preferences}),l=t.useEditorStore(d=>{var m,g;return(g=(m=d.card)==null?void 0:m.preferences)==null?void 0:g.datasetOptions}),u=l==null?void 0:l.find(d=>d.idx===a),{setCardPreferences:c}=t.useEditorStore(d=>d.actions);function h(d){if(!u)c({...o,datasetOptions:[...l||[],{idx:a,type:d==="area"?"line":d,fill:d==="area"?"origin":""}]});else{const m={...u};m.type=d==="area"?"line":d,m.fill=d==="area"?"origin":"";const g=l==null?void 0:l.map(p=>p.idx===a?m:p);c({...o,datasetOptions:g})}}return e.jsxs("div",{className:t.cn("group flex items-center justify-between gap-2 rounded-md",n),children:[i||e.jsx(Ve,{className:"max-w-[100px]",title:s,children:bs(s)}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx(Ge,{onClick:()=>h("bar"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx($e,{onClick:()=>h("line"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(Zs,{onClick:()=>h("area"),className:t.cn("size-4 cursor-pointer text-muted-foreground hover:text-foreground",r)}),e.jsx(Ca,{idx:a})]})]})}function Ns(){const s=t.useEditorStore(p=>p.selectedConnectionId),a=t.useEditorStore(p=>p.selectedDatamodelId),n=t.useEditorStore(p=>p.selectedDatabaseName),r=t.useEditorStore(p=>p.selectedSchemaName),i=t.useEditorStore(p=>p.selectedTableName),o=t.useDashboardStore(p=>p.dashboard.filters)||[],l=t.useDashboardStore(p=>p.actions.addFilter),u=t.useDashboardStore(p=>p.actions.removeFilter),{removeFilterValues:c}=t.useDashboardActions(),{modelItems:h,tableName:d,connectionType:m}=t.useEditorAside();function g(p,j="dashboard"){var v;const x=t.fmt(p.column_name),b=t.fmt(n||""),f=t.fmt(r||""),k=t.fmt(d);let T=t.getQualifiedTableName({schemaName:f,tableName:k,connectionType:m,databaseName:b}),E=`${T}.${x}`;const y=(v=h==null?void 0:h.find(w=>w.id===a))==null?void 0:v.name;a&&a!=="none"&&(E=`${t.DATAMODEL_NAMESPCACE}.${y}.${x}`,T=`${t.DATAMODEL_NAMESPCACE}.${y}`);const N=o==null?void 0:o.find(w=>w.column===E&&w.table===k&&(w.database===b||w.database===n));if(N)c(N.id),u(N.id);else{const w=t.v4();return d==="api"&&s?(l({location:j,id:w,column:E,title:p.column_name,dataType:p.data_type,table:"api",database:"",connectionId:s,operation:"in",sql:t.getDefaultFilterSql(p.data_type,T,x)}),w):(l({id:w,location:j,column:E,title:p.column_name,dataType:p.data_type,table:i||"",database:n||"",connectionId:s||"",operation:"in",sql:t.getDefaultFilterSql(p.data_type,T,x)}),w)}}return{assignFilter:g}}function we(){const s=t.useDashboardStore(u=>u.dashboard.filters),a=t.useEditorStore(u=>u.frame),{setFrame:n}=t.useEditorActions(),{columns:r}=t.useEditorAside(),{assignFilter:i}=Ns();function o(u){const c=i(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(Sa,{onSelect:o,columns:r}),l&&e.jsx(t.FilterHeader,{filter:l})]})}function Sa({columns:s,onSelect:a}){var l;const[n,r]=re.useState(!1),[i,o]=re.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:[i?(l=s.find(u=>u.column_name===i))==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 h=c===i?"":c;o(h),r(!1),h&&a(u)},children:[u.column_name,e.jsx(t.CheckIcon,{className:t.cn("ml-auto h-4 w-4",i===u.column_name?"opacity-100":"opacity-0")})]},u.column_name))})]})]})})]})}function wa({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(ys,{})})]}),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(be,{}),e.jsx(we,{})]})]})]})})}function Tt(){var i,o,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}},h={...a,chartOptions:{...a==null?void 0:a.chartOptions,plugins:{...(d=a==null?void 0:a.chartOptions)==null?void 0:d.plugins,...c}}};n(h),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=(o=(i=a==null?void 0:a.chartOptions)==null?void 0:i.plugins)==null?void 0:o.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 ka({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:o=>o.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(Tt,{})})]}),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(be,{}),e.jsx(we,{})]})]})]})})}const Ea={datasets:[{type:"line",label:"Sum_sales",data:[]},{type:"bar",label:"Sum_profit",data:[]}]},Ia={datasets:[{fill:"origin",type:"line",label:"Sum_sales",data:[]}]};function Da(){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:Ta(s)}),!["kpi"].includes(s)&&e.jsxs("div",{className:"space-y-4",children:[e.jsx(Tt,{}),e.jsx(be,{}),e.jsx(we,{})]})]})}function Ta(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(Ea,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(Ia,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 Ma(){var c,h,d,m,g;const s=t.useEditorStore(p=>p.card.preferences),a=t.useEditorStore(p=>p.actions.setCardPreferences),n=t.useEditorStore(p=>p.actions.setNumberFormat);t.useEditorStore(p=>{var j,x;return(x=(j=p.card.preferences)==null?void 0:j.formatNumber)==null?void 0:x.decimalPlaces});const r=t.useEditorStore(p=>{var j,x;return(x=(j=p.card.preferences)==null?void 0:j.formatNumber)==null?void 0:x.locale}),i=t.useEditorStore(p=>{var j,x;return(x=(j=p.card.preferences)==null?void 0:j.formatNumber)==null?void 0:x.currency});t.useEditorStore(p=>p.actions.setFilterOnClickField);const o=t.useEditorStore(p=>{var j,x;return(x=(j=p.card.preferences)==null?void 0:j.formatNumber)==null?void 0:x.colorRanges})||[],l=t.useEditorStore(p=>p.actions.setColorRanges),u=[...new Set(t.LOCALE_CURRENCY_PAIRS.map(p=>p.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:p=>{a({...s,formatNumber:{...s==null?void 0:s.formatNumber,enabled:p}})}}),e.jsx(t.Label,{children:"Format Number"})]}),((h=s==null?void 0:s.formatNumber)==null?void 0:h.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:p=>{var j,x,b;return n(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,((x=s==null?void 0:s.formatNumber)==null?void 0:x.currency)||"",p,((b=s==null?void 0:s.formatNumber)==null?void 0:b.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(p=>e.jsx(t.SelectItem,{value:p.locale,children:p.locale},p.locale))]})})]})]}),e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Currency"}),e.jsxs(t.Select,{value:i||"none",onValueChange:p=>{var j,x,b;console.log("currency",p),n(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,p==="none"?"":p,((x=s==null?void 0:s.formatNumber)==null?void 0:x.locale)||"",((b=s==null?void 0:s.formatNumber)==null?void 0:b.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(p=>e.jsx(t.SelectItem,{value:p,children:p},p))]})})]})]})]}),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:((m=(d=s==null?void 0:s.formatNumber)==null?void 0:d.decimalPlaces)==null?void 0:m.toString())||"0",onValueChange:p=>{var j,x,b;return n(Number(p),((j=s==null?void 0:s.formatNumber)==null?void 0:j.currency)||"",((x=s==null?void 0:s.formatNumber)==null?void 0:x.locale)||"",((b=s==null?void 0:s.formatNumber)==null?void 0:b.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(p=>e.jsx(t.SelectItem,{value:p,children:p},p))})]})]}),e.jsxs("div",{className:"w-full space-y-1",children:[e.jsx(t.Label,{children:"Suffix"}),e.jsx(t.Input,{value:((g=s==null?void 0:s.formatNumber)==null?void 0:g.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:p=>{var j,x,b;return n(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,((x=s==null?void 0:s.formatNumber)==null?void 0:x.currency)||"",((b=s==null?void 0:s.formatNumber)==null?void 0:b.locale)||"",p.target.value)}})]})]})]})}),e.jsx(t.Separator,{className:"my-3"}),e.jsx(t.ColorFormat,{colorRanges:o,setColorRanges:l})]})]})}function Aa(){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(Ma,{})}),e.jsx("div",{}),e.jsx("div",{})]})}function Ze({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 La=[{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"}],Oa=["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"],Fa=Oa.map(s=>({label:s,value:s}));function Ba(){var c,h,d,m,g,p,j,x,b,f,k,T,E,y,N,v,w,I;const s=t.useEditorStore(D=>D.card),a=(h=(c=s==null?void 0:s.preferences)==null?void 0:c.mapVisualOptions)==null?void 0:h.topoJsonUrl,[n,r]=L.useState(((m=(d=s==null?void 0:s.preferences)==null?void 0:d.mapVisualOptions)==null?void 0:m.customTopoJsonUrl)||""),{setCardPreferences:i}=t.useEditorActions(),{data:o}=t.useTopoJson(s),l=Object.keys((o==null?void 0:o.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(Ze,{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(Ze,{open:!0,summary:"Settings",children:e.jsxs("div",{className:"space-y-3 px-2",children:[e.jsx(le,{className:"h-9",options:u,onValueChange:D=>{console.log("value",D),i({...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),i({...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"}),o&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Map Object"}),e.jsx(le,{className:"h-9",options:l,value:((p=(g=s.preferences)==null?void 0:g.mapVisualOptions)==null?void 0:p.objectKey)||"",label:"Map Object",onValueChange:D=>{var C;i({...s.preferences,mapVisualOptions:{...(C=s.preferences)==null?void 0:C.mapVisualOptions,objectKey:D}})}})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Projection"}),e.jsx(le,{className:"h-9",options:La,value:((x=(j=s.preferences)==null?void 0:j.mapVisualOptions)==null?void 0:x.projection)||"",label:"Projection",onValueChange:D=>{var C;i({...s.preferences,mapVisualOptions:{...(C=s.preferences)==null?void 0:C.mapVisualOptions,projection:D}})}})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{children:"Colors"}),e.jsx(le,{className:"h-9",options:Fa,value:((f=(b=s.preferences)==null?void 0:b.mapVisualOptions)==null?void 0:f.colorScale)||"",label:"Select Color Scale",onValueChange:D=>{var C;i({...s.preferences,mapVisualOptions:{...(C=s.preferences)==null?void 0:C.mapVisualOptions,colorScale:D}})}})]})]})]})}),e.jsx(t.Separator,{className:"my-4"}),e.jsx(Ze,{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=(k=s.preferences)==null?void 0:k.mapVisualOptions)==null?void 0:T.projectionScale)||1,onChange:D=>{var C;i({...s.preferences,mapVisualOptions:{...(C=s.preferences)==null?void 0:C.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:((N=(y=(E=s.preferences)==null?void 0:E.mapVisualOptions)==null?void 0:y.projectionOffset)==null?void 0:N[0])||0,onChange:D=>{var C,F,O,A;i({...s.preferences,mapVisualOptions:{...(C=s.preferences)==null?void 0:C.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 C,F,O,A;i({...s.preferences,mapVisualOptions:{...(C=s.preferences)==null?void 0:C.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(be,{})]})}function za(){var r;const s=t.useEditorStore(i=>i.card.preferences),{setCardPreferences:a}=t.useEditorStore(i=>i.actions);function n(i){a({...s,textVisualOptions:{...s==null?void 0:s.textVisualOptions,isDynamicText:i==="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 Oe({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:i=>i.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(Tt,{}),s==="text"&&e.jsx(za,{})]})]}),!["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(be,{}),e.jsx(we,{})]})]})]})})}function Ra(){const s=t.useEditorStore(r=>{var i,o;return(o=(i=r==null?void 0:r.card)==null?void 0:i.preferences)==null?void 0:o.sortChart}),{setSortChart:a}=t.useEditorActions();function n(){return e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Sort"}),e.jsx(le,{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(ys,{})]})]}),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(be,{}),e.jsx(we,{})]})]})]})})}function Pa({cardType:s="table"}){console.log("cardType",s);const a=t.useEditorStore(i=>{var o;return(o=i.card)==null?void 0:o.preferences}),n=t.useEditorStore(i=>i.actions.setCardPreferences),r=i=>{n({...a,allowDownload:i})};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(be,{}),e.jsx(we,{})]})]})}),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 Va=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."]})]}),qa=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."]})]}),_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 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 Ga(){const s=t.useEditorStore(n=>n.card.type);function a(n){switch(n){case"stackedBar":case"stackedLine":return e.jsx(Ra,{});case"tornado":case"pyramid":return e.jsx(Oe,{docContent:Va,cardType:n});case"kpi":return e.jsx(Aa,{});case"line":case"bar":return e.jsx(wa,{cardType:n});case"range":return e.jsx(Oe,{docContent:qa,cardType:n});case"pie":case"doughnut":case"polarArea":case"radar":case"funnel":return e.jsx(Oe,{cardType:n});case"bubble":case"scatter":return e.jsx(ka,{cardType:n});case"table":return e.jsx(Pa,{cardType:n});case"text":return e.jsx(Oe,{docContent:_a,cardType:n,suffix:"Visual"});case"map":return e.jsx(Ba,{});case"custom":return e.jsx(Na,{});default:return e.jsx(Da,{})}}return e.jsxs(t.ScrollArea,{className:"h-full w-full text-sm",children:[a(s),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})}function Cs({label:s,column:a,functions:n,onFunctionChange:r}){let i=n[0];"aggregate"in a?i=n.find(l=>l.value===a.aggregate)||n[0]:"granularity"in a&&(i=n.find(l=>l.value===a.granularity)||n[0]);function o(l){r(l)}return e.jsx(le,{className:"flex h-8 w-8 justify-center overflow-clip rounded-none border-none bg-muted px-0 [&>svg]:hidden",icon:i.logo,options:n,value:i.value,onValueChange:l=>o(l),label:s,showPlaceholderLabel:!1})}const $a=[{label:"Sum",value:"SUM",logo:e.jsx(Qt,{className:"size-3.5"})},{label:"Count",value:"COUNT",logo:e.jsx(gt,{className:"size-3.5"})},{label:"Unique",value:"DISTINCT",logo:e.jsx(hn,{className:"size-3.5"})},{label:"Average",value:"AVG",logo:e.jsx(Gs,{className:"size-3.5"})},{label:"Min",value:"MIN",logo:e.jsx(qe,{className:"size-3.5"})},{label:"Max",value:"MAX",logo:e.jsx(_e,{className:"size-3.5"})}];function Ha({column:s}){const{updateMetricColumnOld:a}=t.useEditorActions();let n=$a;t.isTextDataType(s.type)&&(n=n.filter(i=>["COUNT","DISTINCT"].includes(i.value))),t.isNumberDataType(s.type)&&(n=n.filter(i=>!["DISTINCT"].includes(i.value)));function r(i){const o={...s,aggregate:i,label:Ee(s.name,i)};a(s.id,o)}return e.jsx(Cs,{column:s,functions:n,onFunctionChange:i=>r(i),label:"Aggregation"})}const Ja=[{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 Ua({column:s}){const{updateGroupByColumnOld:a}=t.useEditorActions();function n(r){const i={...s,granularity:r,label:Se(s.name,r)};a(s.id,i)}return e.jsx(Cs,{column:s,functions:Ja,onFunctionChange:r=>n(r),label:"Granularity"})}function Ya({col:s,onChange:a,droppableId:n}){const{columns:r}=t.useDataColumns(),i=L.useMemo(()=>{let u=[];(n===fe||n===ge||n===je)&&(u=r);const c=u==null?void 0:u.filter(h=>h.column_name!==s.name);return c==null?void 0:c.map(h=>({id:h.column_name,value:h.column_name}))},[r,n,s.name]),o=[{id:s.name,value:s.name}];function l(u){const c=r==null?void 0:r.find(h=>{var d;return h.column_name===((d=u[0])==null?void 0:d.id)});c&&a(c)}return i!=null&&i.length?e.jsx(t.ComboBox2,{multiple:!1,options:i,selectedOptions:o,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 Ka({column:s}){const{updateMetricColumnOld:a}=t.useEditorActions(),{transformedMetricKeys:n,dimensionKeys:r}=js();console.log(n,r);const i=t.useEditorStore(c=>{var h;return(h=c.card.queryConfig)==null?void 0:h.pivotColumns}),o=!!(i&&i.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(vs,{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(Ve,{className:"w-[130px]",children:s.label||s.name})})}),o&&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(Ve,{className:"font-mono text-xs text-muted-foreground",children:s.aliasTemplate||"{label} ({pivot})"})})]})]})}function Qa({column:s,type:a,onRemoveColumn:n,droppableId:r}){const[i,o]=L.useState(!1),{updateGroupByColumnOld:l,updateMetricColumnOld:u,updatePivotByColumnOld:c}=t.useEditorActions(),{attributes:h,listeners:d,setNodeRef:m,transform:g,transition:p,isDragging:j}=t.useSortable({id:s.id,data:{type:a}}),x=g?{opacity:j?.5:void 0,transform:t.CSS.Translate.toString(g),transition:p}:void 0,b=t.isTextDataType(s.type);function f(N){const v=t.isNumberDataType(N.data_type),w=t.isTextDataType(N.data_type),I=t.isDateDataType(N.data_type),D=v?"number":w?"string":I?"date":"string";if(r===fe){if(w){const C={id:s.id,name:N.column_name,type:D,role:"groupby"};l(s.id,C)}if(I){const C={id:s.id,name:N.column_name,type:D,role:"groupby",label:Se(N.column_name,"month"),granularity:"month"};l(s.id,C)}}if(r===je){if(w){const C={id:s.id,name:N.column_name,type:D,role:"groupby"};c(s.id,C)}if(I){const C={id:s.id,name:N.column_name,type:D,label:Se(N.column_name,"month"),granularity:"month",role:"groupby"};c(s.id,C)}}if(r===ge){const C={id:s.id,name:N.column_name,type:D,role:"metric",label:Ee(N.column_name,"SUM"),aggregate:v?"SUM":"COUNT"};u(s.id,C)}}function k(){if(r===ge)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(Ka,{column:s})})}function T(){const N=t.isDateDataType(s.type);if(r===ge)return e.jsx(Ha,{column:s});if((r===fe||r===je)&&N)return e.jsx(Ua,{column:s})}function E(){return e.jsx("div",{className:t.cn("grow",{"pl-3":(r===fe||r===je)&&b}),children:e.jsx(Ya,{col:s,onChange:f,droppableId:r})})}function y(){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:()=>o(!i),children:i?e.jsx(Mn,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")}):e.jsx(Yt,{className:t.cn("size-3 cursor-pointer items-center justify-center rounded-r-sm text-muted-foreground")})})})}return e.jsx("div",{...d,...h,ref:m,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:[y(),T(),E()]}),i&&k()]}),e.jsx("div",{className:t.cn("opacity-0 transition-opacity duration-200 group-hover:opacity-100",{hidden:i}),children:e.jsx("button",{onClick:()=>n(s.id),children:e.jsx(t.X,{className:"size-3 cursor-pointer text-muted-foreground"})})})]})})}function et({id:s,label:a,columns:n,previewColumns:r,sortableType:i,onRemoveColumn:o}){var x,b;const{setNodeRef:l,isOver:u,over:c}=t.useDroppable({id:s}),h=t.useDndStore(f=>f.activeId),d=t.useEditorStore(f=>{var k;return(k=f.card)==null?void 0:k.type}),m=u||((b=(x=c==null?void 0:c.data)==null?void 0:x.current)==null?void 0:b.type)===i,g=h?r:n,p=i===Be?"Rows":i===ze?"Pivot Columns":"Columns";function j(){if(!g||g.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(f=>f.id),children:e.jsxs("div",{className:t.cn("group space-y-2 rounded-md p-4",m&&"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:p})]}),j(),e.jsx("div",{className:"space-y-2",children:g==null?void 0:g.map(f=>f.id===as.id?e.jsx(Wa,{},f.id):e.jsx(Qa,{droppableId:s,type:i,column:f,onRemoveColumn:o},f.id))})]})})}function Wa(){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 Ss({children:s,id:a,type:n}){const{attributes:r,listeners:i,setNodeRef:o,transform:l,transition:u,isDragging:c}=t.useSortable({id:a,data:{type:n}}),h=l?{opacity:c?.5:void 0,transform:t.CSS.Translate.toString(l),transition:u}:void 0;return e.jsx("div",{...i,...r,ref:o,style:h,children:s})}function Xa(){const s=t.useEditorStore(f=>{var k;return(k=f.card.queryConfig)==null?void 0:k.orderBy})||[],a=t.useEditorStore(f=>{var k;return(k=f.card.queryConfig)==null?void 0:k.groupByColumns})||[],n=t.useEditorStore(f=>{var k;return(k=f.card.queryConfig)==null?void 0:k.metricColumns})||[],{addOrderByColumn:r,removeOrderByColumn:i,updateOrderByColumn:o}=t.useEditorActions(),l=[...a,...n];if(l.length===0)return e.jsx(e.Fragment,{});const u=e.jsx(Us,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),c=e.jsx(_s,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),h=e.jsx(Js,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),d=e.jsx(qs,{className:"size-3.5 text-muted-foreground hover:text-foreground"}),m=l==null?void 0:l.filter(f=>!s.some(k=>k.columnId===f.id)).map(f=>({id:f.id,value:f.label||f.name}));function g(f,k){const T=p(f);return T?T.role==="metric"?k==="asc"?h:d:k==="asc"?u:c:null}function p(f){return l.find(k=>k.id===f)}function j(f){const k=s.find(T=>T.columnId===f);if(k){const T={...k,direction:k.direction==="asc"?"desc":"asc"};o(T)}}const x=f=>{r({columnId:f.id,direction:"asc"})};function b(f){const k=s.find(T=>T.columnId===f);k&&i(k)}return e.jsx(t.SortableContext,{items:s.map(f=>ke(f.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"}),m.length>0&&e.jsx("div",{className:"mr-5",children:e.jsx(t.ComboBox2,{multiple:!1,options:m,selectedOptions:[],onChange:f=>x(f[0]),selectAllChecked:!1,onSelectAllCheckedChange:()=>{},inputClassName:"h-8 bg-muted border-none"})}),s.map(f=>{var k,T;return e.jsx(Ss,{id:ke(f.columnId),type:St,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(Yt,{className:"size-3 cursor-move text-muted-foreground hover:text-foreground"}),e.jsx(Ve,{className:"w-[175px] text-sm",children:((k=p(f.columnId))==null?void 0:k.label)||((T=p(f.columnId))==null?void 0:T.name)})]}),e.jsx("button",{title:f.direction==="asc"?"Ascending":"Descending",onClick:()=>j(f.columnId),className:"rounded-sm p-0",children:g(f.columnId,f.direction)})]}),e.jsx("div",{children:e.jsx("button",{onClick:()=>b(f.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"})})})]})},f.columnId)},ke(f.columnId))})]})})}function Za(){const s=t.useEditorStore(b=>{var f;return((f=b.card.queryConfig)==null?void 0:f.groupByColumns)||[]}),a=t.useEditorStore(b=>b.card.type),n=t.useDndStore(b=>b.previewGroupByColumns),r=t.useEditorStore(b=>{var f;return((f=b.card.queryConfig)==null?void 0:f.metricColumns)||[]}),i=t.useDndStore(b=>b.previewMetricColumns),o=t.useEditorStore(b=>{var f;return((f=b.card.queryConfig)==null?void 0:f.pivotColumns)||[]}),l=t.useDndStore(b=>b.previewPivotColumns),{removeColumnFromGroupBy:u,removeColumnFromMetricColumns:c,removeColumnFromPivotBy:h}=t.useEditorActions();function d(b){u(b)}function m(b){c(b)}function g(b){h(b)}let p="Group By",j="Metrics",x="Stack By";return a==="table"&&(p="Rows",j="Metrics",x="Columns"),e.jsxs("div",{className:"flex h-full w-full flex-col gap-3 py-4",children:[e.jsx(xs,{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(et,{onRemoveColumn:d,sortableType:Be,id:fe,label:p,columns:s,previewColumns:n}),e.jsx(et,{onRemoveColumn:g,sortableType:ze,id:je,label:x,columns:o,previewColumns:l}),e.jsx(et,{onRemoveColumn:m,sortableType:ot,id:ge,label:j,columns:r,previewColumns:i}),e.jsx(Xa,{})]}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function Mt({children:s,column:a,id:n,sortableType:r,className:i}){const[o,l]=L.useState(!1),{removeEditorFilter:u,clearEditorFilter:c}=t.useEditorActions(),h=t.useEditorStore(m=>{var g,p;return(p=(g=m.card.queryConfig)==null?void 0:g.filters)==null?void 0:p.some(j=>j.filterColumnName===a.name)});function d(m){u(m)}return e.jsx(Ss,{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":o}),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}),h&&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",!o&&"rounded-b-md",o&&"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",i),children:s})]})]})})}function er({column:s,sortableType:a}){const n=t.useDashboardStore(T=>T.themeStyle),r=t.useEditorStore(T=>{var E,y;return(y=(E=T.card)==null?void 0:E.queryConfig)==null?void 0:y.filters}),i=t.useEditorStore(T=>{var E,y;return(y=(E=T.card.queryConfig)==null?void 0:E.filterColumns)==null?void 0:y.find(N=>N.name===s.name)}),{selectedConnectionId:o,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]),h=L.useMemo(()=>Array.isArray(c)?c.map(T=>({id:T,value:T})):[],[c]),{updateEditorFilterValue:d}=t.useEditorActions(),m={column:s.name,sql:s.sql,id:s.name,connectionId:o,dataType:s.type},{data:g,isLoading:p,isFetching:j,isError:x}=t.useFilterQuery(m),b=L.useMemo(()=>{var E;return m.column?(E=g==null?void 0:g.records)==null?void 0:E.map(y=>{let N=m.column.split(".").slice(-1)[0].replace(/"/g,"");return y[N]===void 0&&(N=N.toLowerCase()),{id:y[N],value:y[N]}}):[]},[g,m.column]);function f(T){const E=T.map(y=>y.id);d(s.name,E)}function k(){return p||j?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(tr,{columnName:s.name}),showNegativeIndicator:(i==null?void 0:i.mode)==="exclude",options:b,onChange:f,selectedOptions:h,selectAllChecked:!1,onSelectAllCheckedChange:()=>{}})}return e.jsx(Mt,{className:"w-60",id:s.id,sortableType:a,column:s,children:k()})}function tr({columnName:s}){const{setEditorFilterMode:a}=t.useEditorActions(),n=t.useEditorStore(i=>{var o,l;return(l=(o=i.card.queryConfig)==null?void 0:o.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 sr({column:s,sortableType:a}){const[n,r]=L.useState(!1),{selectedConnectionId:i,selectedDatabaseName:o,selectedTableName:l}=t.useEditorAside(),u={column:s.name,sql:s.sql,id:s.name,connectionId:i,title:"",dataType:s.type},{isLoading:c,isFetching:h,isError:d,data:m}=t.useFilterQuery(u),g=m==null?void 0:m.records,{dateRange:p,setDateRange:j,initialDateRange:x}=t.useDateRangeFromRecords(g),{updateEditorFilterValue:b}=t.useEditorActions();function f(E){var N,v;const y={gte:(N=E==null?void 0:E.from)==null?void 0:N.toISOString(),lte:(v=E==null?void 0:E.to)==null?void 0:v.toISOString()};b(s.name,y)}function k(){b(s.name,null,!0),j(x)}function T(){return c||h?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"}):g?e.jsx(t.DateRangePopover,{title:u.title,open:n,inputClassName:"h-8",setOpen:r,dateRange:p,setDateRange:j,onApply:f,onClear:k}):e.jsx(t.Label,{className:"flex h-8 w-72 items-center bg-muted px-2",children:"No Data"})}return e.jsx(Mt,{className:"w-72",id:s.id,sortableType:a,column:s,children:T()})}function nr({id:s,label:a,columns:n,previewColumns:r,sortableType:i}){var j,x;const{setNodeRef:o,isOver:l,over:u}=t.useDroppable({id:s}),c=t.useDndStore(b=>b.activeId),h={},d=l||((x=(j=u==null?void 0:u.data)==null?void 0:j.current)==null?void 0:x.type)===i;function m(){if(!p||p.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 g(b){const f=t.isDateDataType(b.type);return b.id===as.id?e.jsx(Mt,{id:b.id,sortableType:i,column:b,children:e.jsx(ar,{})},b.id):f?e.jsx(sr,{droppableId:s,sortableType:i,column:b},b.id):e.jsx(er,{droppableId:s,sortableType:i,column:b},b.id)}const p=c?r:n;return e.jsx(t.SortableContext,{items:n==null?void 0:n.map(b=>b.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:o,style:h,children:[e.jsx(t.Label,{className:"text-sm",children:a}),m(),e.jsx("div",{className:"flex flex-wrap items-center gap-4",children:p==null?void 0:p.map(b=>g(b))})]})})}function ar(){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 rr(){const s=t.useEditorStore(i=>{var o;return((o=i.card.queryConfig)==null?void 0:o.filterColumns)||[]}),a=t.useDndStore(i=>i.previewFilterColumns),{removeColumnFromFilterColumns:n}=t.useEditorActions();function r(i){n(i)}return e.jsx("section",{className:"size-full px-4 pb-4",children:e.jsx(nr,{onRemoveColumn:r,sortableType:ct,id:lt,label:"Filters",columns:s,previewColumns:a})})}function ir(){const s=t.useEditorStore(o=>o.card),a=t.useEditorStore(o=>o.showAIDialog),{setShowAIDialog:n}=t.useEditorActions(),{data:r,errorMessage:i}=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(kn,{className:"mr-2 h-4 w-4"}),"Assistant"]}),e.jsx(os,{sql:r==null?void 0:r.sql,error:i})]}),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 or(){const s=L.useRef(null),a=L.useRef(null),n=t.useEditorStore(u=>u.isShowingVisual),r=t.useEditorStore(u=>u.showAIDialog),i=t.useEditorStore(u=>u.isDevMode);L.useEffect(()=>{var u,c,h,d;r?((u=s.current)==null||u.resize(0),(c=a.current)==null||c.resize(0)):((h=s.current)==null||h.resize(25),(d=a.current)==null||d.resize(25))},[r]);function o(){return e.jsxs(e.Fragment,{children:[e.jsx(t.ResizablePanel,{role:"query-section",className:"flex",minSize:20,defaultSize:40,children:e.jsx(ra,{})}),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(Ga,{})})}),!r&&e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:40,defaultSize:75,maxSize:100,children:e.jsx(Le,{})})]}):e.jsx(Le,{})})]})}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(Za,{})})}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{defaultSize:75,maxSize:100,children:e.jsxs(t.ResizablePanelGroup,{direction:"vertical",children:[e.jsxs(t.ResizablePanel,{className:"flex min-h-fit flex-col",minSize:10,defaultSize:20,children:[e.jsx(ir,{}),e.jsx(rr,{})]}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{minSize:60,defaultSize:80,children:e.jsx(Le,{})})]})})]}):e.jsx(Le,{})})})}return e.jsx(t.ResizablePanelGroup,{direction:"vertical",className:"min-h-[250px] min-w-full max-w-lg",children:i?o():l()})}function lr(s,a){const[n,r]=L.useState(""),[i,o]=L.useState(null),{authToken:l}=t.useSemaphorContext(),u=t.useEditorStore(G=>{var Q;return(Q=G==null?void 0:G.card)==null?void 0:Q.sql}),c=t.useEditorStore(G=>G.isDevMode),h=t.useEditorStore(G=>{var Q;return(Q=G==null?void 0:G.card)==null?void 0:Q.python}),{setCardPython:d,setCardSql:m,setRunSql:g,switchCardType:p,setQueryConfig:j}=t.useEditorActions(),x=t.useEditorStore(G=>G.currentAssitantScope)||[],b=t.useEditorStore(G=>G.userInputForAI),f=t.useEditorStore(G=>G.triggerAIRun),k=t.useEditorStore(G=>G.selectedDatabaseName),T=t.useEditorStore(G=>G.selectedTableName),E=t.useEditorStore(G=>G.selectedConnectionId),y=t.useEditorStore(G=>G.selectedSchemaName),N=t.useDashboardStore(G=>G.dashboard.aiScopeTables),{setTriggerAIRun:v,setCurrentAssitantScope:w,setCardConfig:I}=t.useEditorActions(),{selectedDatamodelName:D,connectionType:C,selectedDatamodelId:F}=t.useEditorAside(),{messages:O,setMessages:A,reload:S,error:M,append:B,input:R,setInput:P,status:z,handleInputChange:K,handleSubmit:J,stop:$}=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:G=>{console.log("on error",G)},onToolCall:U,onFinish(G,Q){q(Q.usage),r(""),Q.finishReason==="stop"&&r("")}});L.useEffect(()=>{f&&b&&(K({target:{value:b}}),setTimeout(()=>{J(),v(!1)},100))},[f,J,b,v,K]);async function U({toolCall:G}){if(["createChartFromSql","createForecast"].includes(G.toolName)){const Q=G.args.sql,se=G.args.python,me=G.args.chartType;return p(me),m(Q),d(se),g(!0),{status:"success",message:"Let the user know that chart is created"}}else if(G.toolName==="getTableColumns")r("Getting table columns...");else{if(G.toolName==="getUserSql")return u?{status:"success",sql:u,python:h||""}:{status:"error",message:"No SQL found"};if(G.toolName==="getCurrentTableScope")return r("Getting table scope..."),Y(),{status:"success",tables:x};if(G.toolName==="generateQueryConfig"){r("Generating query config...");const Q=G.args.chartType,se=G.args.queryConfig;return G.args.cardConfig,p(Q),I(se),m(void 0),d(void 0),g(!0),{status:"success",queryConfig:se}}else r("Analyzing...")}}function q(G){o(Q=>Q?{promptTokens:Q.promptTokens+G.promptTokens,completionTokens:Q.completionTokens+G.completionTokens,totalTokens:Q.totalTokens+G.totalTokens}:G)}function V(G){const Q=t.removeFromScopeArray(x,G);_(Q)}function _(G){const Q=t.sanitizeAIScope(G);w(Q),A(se=>[...se,{id:crypto.randomUUID(),role:"system",content:`Current scope of tables. Always use the table reference format when generating SQL | ${JSON.stringify(Q)}`}])}function H(){const G={databaseName:k||"",schemaName:y||"",tableName:T||"",datamodelId:F||"",datamodelName:t.resolveDatamodelName(D),connectionId:E||"",connectionType:C||""},Q=t.dedup([...x,G]);_(Q)}function Y(){const G={databaseName:k||"",schemaName:y||"",tableName:T||"",datamodelName:t.resolveDatamodelName(D),connectionId:E||"",connectionType:C||"",datamodelId:F||""};if(!t.isInAiScopeArray([...N||[],...x],G)||x.length===0){const se=t.dedup([...N||[],...x,G]).filter(me=>me.connectionId===G.connectionId);_(se)}}const Z=!["ready","error"].includes(z),de=t.getErrorMessage(M);return{messages:O,setMessages:A,reload:S,append:B,input:R,setInput:P,isLoading:Z,handleSetAIScope:Y,handleAddCurrentTableToScope:H,removeFromCurrentSelections:V,currentAssitantScope:x,setCurrentAssitantScope:w,handleInputChange:K,handleSubmit:J,stop:$,chatStatus:z,toolStatus:n,llmUsage:i,onFinish:a,errorMessage:de}}const cr=[{title:"Help me write a query for",subtitle:"orders by month"},{title:"Create a bar chart for",subtitle:"sales by category"}];function Gt(){const s=L.useRef(null),a=L.useRef(null),[n,r]=L.useState(!1),[i,o]=L.useState(t.isDevEnv),[l,u]=L.useState(!1),[c,h]=L.useState(!1),[d,m]=L.useState({selectedEntities:[]}),g=t.useDashboardStore(_=>_.dashboard.aiContext),p=t.useEditorStore(_=>_.card.dataSource),j=t.useEditorStore(_=>_.actions.setCardSql),x=t.useEditorStore(_=>_.actions.setRunSql),b=t.useEditorStore(_=>_.showAIDialog),f=t.useDashboardStore(_=>_.handleOpenAssistantProfile),{setShowAIDialog:k,setCardPython:T}=t.useEditorActions(),{setDataSource:E}=t.useEditorActions(),{assistantProfile:y}=t.useAssistantProfile(),{messages:N,setMessages:v,reload:w,append:I,input:D,setInput:C,isLoading:F,handleInputChange:O,handleSubmit:A,stop:S,chatStatus:M,llmUsage:B,errorMessage:R}=lr(d);t.useAssistantScroll({scrollContainerRef:s,inputRef:a,messages:N}),L.useEffect(()=>{var _;b&&((_=a.current)==null||_.focus())},[b]);function P(_,H){H==="sql"?(j(_),x(!0)):H==="python"&&(T(_),x(!0))}function z(){var _;(_=g==null?void 0:g.selectedEntities)==null||_[0],h(!0)}function K(){d.selectedEntities.length===0&&m({selectedEntities:(g==null?void 0:g.selectedEntities)||[]})}function J(_){K();const H={role:"user",content:_.title+" "+_.subtitle};I(H)}function $(_){K(),I({role:"user",content:_})}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:i,onCheckedChange:o,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&&(N==null?void 0:N.filter(_=>_.role==="user").length)===0;return e.jsxs("div",{"data-role":"editor-assistant",className:"flex h-full w-full flex-col justify-between px-6 py-4",children:[e.jsxs("div",{"data-role":"header-section",className:"flex items-start justify-between gap-2",children:[q(),f&&e.jsx(t.Button,{variant:"outline",size:"sm",className:"h-7 p-2",onClick:f,children:(y==null?void 0:y.name)||"Default Profile"}),e.jsxs("div",{"data-role":"header-actions",className:"flex items-center gap-2",children:[U(),e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-7 p-2",onClick:z,children:e.jsx(t.Settings,{className:"size-4"})}),e.jsx(t.Button,{className:"h-7 p-2",size:"sm",variant:"ghost",onClick:()=>{v([]),w()},children:e.jsx(t.SquarePen,{className:"size-4"})}),e.jsx(t.Button,{variant:"ghost",className:"h-8",size:"sm",onClick:()=>{k(!1)},children:e.jsx(t.ChevronRight,{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:N,showTools:i,handleRun:P,showSystemMessage:l}),e.jsx(t.ChatStatus,{messages:N,chatStatus:M,errorMessage:R})]})}),e.jsxs("div",{className:"mb-3",children:[V&&!y&&e.jsx(t.Placeholders,{onClick:J,placeholders:cr}),e.jsx("div",{children:V&&y&&e.jsx(t.SeedQuestions,{seedQuestions:y.seedQuestions||[],handleSeedQuestionClick:$})})]}),e.jsx(t.ChatInputWithContext,{ref:a,setInput:C,stop:S,input:D,localAiContext:d,setLocalAiContext:m,handleInputChange:O,handleSubmit:_=>{K(),A(_)},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:(g==null?void 0:g.selectedEntities)||[],open:c,onOpenChange:h,dataSource:p||t.EMPTY_DATA_SOURCE,fallbackDataSource:t.EMPTY_DATA_SOURCE,dialogMode:"aiContext"})]})}function dr(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 ur(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 Me(s){var j;const a=t.useDashboardStore(x=>x.authToken)||s,{hasSchemaSupport:n}=t.useSelectedConnection(s),r=t.useEditorStore(x=>{var b;return(b=x.card.dataSource)==null?void 0:b.connectionId}),i=t.useEditorStore(x=>{var b,f;return(f=(b=x.card.dataSource)==null?void 0:b.selectedEntities)==null?void 0:f.filter(k=>k.type==="model")})||[],o=t.useEditorStore(x=>{var b,f;return(f=(b=x.card.dataSource)==null?void 0:b.selectedEntities)==null?void 0:f.filter(k=>k.type==="table"||k.type==="view")})||[];function l(x){return x.type==="model"?!!r&&!!x.id:x.type==="table"||x.type==="view"?n?!!r&&!!x.name&&!!x.database&&!!x.schema:!!r&&!!x.name&&!!x.database:!1}const u=[...i,...o],c=zs({queries:u.map(x=>({queryKey:["columns",r,x],queryFn:()=>t.getRequest("https://semaphor.cloud/api/v1/columns",(a==null?void 0:a.accessToken)||"",x.type==="model"?{connection_id:r,datamodel_id:x.id,database_name:"",schema_name:"",table_name:""}:{connection_id:r,datamodel_id:"",database_name:x.database,schema_name:x.schema,table_name:x.name}),enabled:!!r&&l(x)}))}),h=c.some(x=>x.isPending),d=c.some(x=>x.isError),m=(j=c.find(x=>x.isError))==null?void 0:j.error,g=c.map((x,b)=>{var T;const f=u[b],k=ur(f);return{entityId:f.id||f.name,entityType:f.type,entityName:f.name,label:f.label,description:f.description,qualifiedEntityName:k,columns:(T=x.data)==null?void 0:T.columns.map(E=>({id:`${f.name}-${E.column_name}`,name:E.column_name,dataType:E.data_type,label:E.label||t.toLabel(E.column_name),description:E.description||"",qualifiedEntityName:k,entityId:f.id||f.name,entityName:f.name,entityType:f.type}))}}).filter(x=>{var b;return((b=x==null?void 0:x.columns)==null?void 0:b.length)>0})||[],p=dr(g);return{columnGroups:g,columns:p,isLoading:h,hasError:d,error:m,refetch:()=>{c.forEach(x=>x.refetch())}}}function mr({field:s}){const{attributes:a,listeners:n,setNodeRef:r,transform:i,transition:o,isDragging:l}=t.useSortable({id:s.id}),[u,c]=L.useState(!1),h={transform:t.CSS.Transform.toString(i),transition:o},d=t.getDataType(s.dataType),g=(p=>{const j=(p||"").toLowerCase();switch(t.getDataType(j)){case"number":return gt;case"date":return t.Calendar;case"boolean":return Xt;case"json":return nn;case"geo":return Sn;default:return Zt}})(s.dataType);return e.jsxs("div",{ref:r,style:h,...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(g,{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:"space-y-1 overflow-x-auto",children:[e.jsx("p",{className:"font-medium",children:s.label||s.name}),s.label&&s.label!==s.name&&e.jsxs("p",{className:"text-xs text-gray-500",children:["Name: ",s.name]}),e.jsx("p",{className:"text-xs text-gray-500",children:s.qualifiedEntityName?`${s.qualifiedEntityName}.${s.name}`:s.name}),e.jsxs("p",{className:"text-xs text-gray-500",children:["Type: ",s.dataType]})]})})]})}),e.jsx("button",{onClick:p=>{p.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(Wt,{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(Ln,{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 hr({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(i=>i.id),strategy:t.verticalListSortingStrategy,children:a.map(i=>e.jsx(mr,{field:i},i.id))})})]})}function xr(){const[s,a]=L.useState(""),[n,r]=L.useState(new Set),[i,o]=L.useState("all"),l=t.useEditorStore(E=>E.card.dataSource),{columns:u=[],columnGroups:c=[],isLoading:h,error:d}=Me(),m=u.filter(E=>E.name.toLowerCase().includes(s.toLowerCase())||E.dataType.toLowerCase().includes(s.toLowerCase())||E.qualifiedEntityName&&E.qualifiedEntityName.toLowerCase().includes(s.toLowerCase())),g=E=>E.dataType==="number"||E.dataType==="integer"||E.dataType==="float"||E.dataType==="decimal"||E.dataType==="currency"?"metrics":"dimensions",j=(i==="all"?m:m.filter(E=>g(E)===i)).reduce((E,y)=>{const N=y.qualifiedEntityName||"Other Fields";return E[N]||(E[N]={label:t.toLabel(y.entityName),fields:[]}),E[N].fields.push(y),E},{});L.useEffect(()=>{const E=Object.keys(j);r(new Set(E))},[Object.keys(j).join(",")]);const x=E=>{const y=new Set(n);y.has(E)?y.delete(E):y.add(E),r(y)},b=m.filter(E=>g(E)==="dimensions").length,f=m.filter(E=>g(E)==="metrics").length,k=m.filter(E=>g(E)==="calculated").length,T=m.length>0;return h?e.jsxs("div",{className:"flex h-[calc(100vh-200px)] w-[290px] flex-col items-center justify-center",children:[e.jsx(ce,{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:i,onValueChange:E=>o(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:m.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:b})]}),e.jsxs(t.TabsTrigger,{value:"metrics",className:"text-xs",children:[e.jsx(ut,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:f})]}),e.jsxs(t.TabsTrigger,{value:"calculated",className:"text-xs",children:[e.jsx(Xs,{className:"size-4 shrink-0"}),e.jsx("span",{className:"ml-2 text-xs font-semibold",children:k})]})]})})]}),e.jsxs(t.CustomScrollArea,{className:"py-2",children:[e.jsxs("div",{className:"space-y-2",children:[Object.entries(j).map(([E,y])=>{const N=c.find(v=>v.entityName===E)||{entityName:E,label:y.label};return e.jsx(hr,{entityGroup:N,fields:y.fields,isOpen:n.has(E),onToggle:()=>x(E)},E)}),Object.keys(j).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(j).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 pr(){return e.jsxs("div",{className:" h-full flex flex-col items-center",children:[" ",e.jsx(xr,{})," "]})}function fr({initialJoinPlan:s,availableDataSources:a}){const[n,r]=L.useState(s),[i,o]=L.useState(new Set),l=()=>{const N=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:N,joinKeyGroups:[{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}]};r({...n,joins:[...n.joins,v]}),o(new Set([...i,v.id]))},u=N=>{r({...n,joins:n.joins.filter(v=>v.id!==N)}),o(new Set([...i].filter(v=>v!==N)))},c=(N,v)=>{var C,F;const w=n.joins.find(O=>O.id===N);if(!w)return;const I={...w,...v},D=n.joins.map(O=>O.id===N?I:O);if((C=I.source)!=null&&C.name&&((F=I.target)!=null&&F.name)&&I.joinKeyGroups[0].keys.length===0){const O=a.find(B=>{var R;return B.name===((R=I.source)==null?void 0:R.name)}),A=a.find(B=>{var R;return B.name===((R=I.target)==null?void 0:R.name)}),S={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:[S]},I.joinKeyGroups=M,D[D.findIndex(B=>B.id===N)]=I}r({...n,joins:D})};return{joinPlan:n,expandedJoins:i,setJoinPlan:r,addJoin:l,removeJoin:u,updateJoin:c,moveJoinUp:N=>{const v=n.joins.findIndex(w=>w.id===N);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 C={...n,joins:w};r(C)}},moveJoinDown:N=>{const v=n.joins.findIndex(w=>w.id===N);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 C={...n,joins:w};r(C)}},toggleJoinExpansion:N=>{const v=new Set(i);v.has(N)?v.delete(N):v.add(N),o(v)},getAvailableSourceEntities:N=>{if(n.joins.length===0)return a;const v=n.joins.findIndex(I=>I.id===N);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:N=>a.filter(v=>v.name!==N),addJoinKeyGroup:N=>{const v=n.joins.find(I=>I.id===N);if(!v)return;const w=[...v.joinKeyGroups,{id:"group-"+Date.now()+"-"+Math.random().toString(36).substr(2,9),operator:"AND",keys:[]}];c(N,{joinKeyGroups:w})},updateGroupOperator:(N,v,w)=>{const I=n.joins.find(C=>C.id===N);if(!I)return;const D=[...I.joinKeyGroups];D[v]={...D[v],operator:w},c(N,{joinKeyGroups:D})},removeJoinKeyGroup:(N,v)=>{const w=n.joins.find(D=>D.id===N);if(!w)return;const I=[...w.joinKeyGroups];I.splice(v,1),c(N,{joinKeyGroups:I})},addJoinKey:(N,v)=>{const w=n.joins.find(O=>O.id===N);if(!w)return;const I=a.find(O=>O.name===w.source.name),D=a.find(O=>O.name===w.target.name),C=[...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:"="};C[v]={...C[v],keys:[...C[v].keys,F]},c(N,{joinKeyGroups:C})},updateJoinKey:(N,v,w,I,D)=>{const C=n.joins.find(M=>M.id===N);if(!C)return;const F=a.find(M=>M.name===C.source.name),O=a.find(M=>M.name===C.target.name),A=[...C.joinKeyGroups],S=A[v].keys[w];I==="sourceColumnName"&&F?A[v].keys[w]={...S,source:{...S.source,name:D}}:I==="targetColumnName"&&O?A[v].keys[w]={...S,target:{...S.target,name:D}}:I==="operator"&&(A[v].keys[w]={...S,operator:D}),c(N,{joinKeyGroups:A})},removeJoinKey:(N,v,w)=>{const I=n.joins.find(C=>C.id===N);if(!I)return;const D=[...I.joinKeyGroups];D[v].keys.splice(w,1),c(N,{joinKeyGroups:D})},generateSQLPreview:()=>{const N=[...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
+ FROM ${v.name}`;return N.forEach(I=>{const D=a.find(O=>O.name===I.target.name);if(!D)return;const C=I.joinKeyGroups.filter(O=>O.keys&&O.keys.length>0).map(O=>{const A=O.keys.filter(S=>{var M,B,R,P;return((M=S.source)==null?void 0:M.name)&&((B=S.target)==null?void 0:B.name)&&((R=S.source)==null?void 0:R.entityName)&&((P=S.target)==null?void 0:P.entityName)}).map(S=>`${S.source.entityName}.${S.source.name} ${S.operator} ${S.target.entityName}.${S.target.name}`);return A.length>1?`(${A.join(` ${O.operator} `)})`:A[0]}).filter(Boolean),F=C.length>1?C.join(" OR "):C[0]||"condition_here";w+=`
401
401
  ${I.joinType} JOIN ${D.name}
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 gr({joinPlan:s,availableDataSources:a,onSave:n,onRemove:r,onCancel:o}){const{setCardConfig:i}=t.useEditorActions();t.useEditorStore(N=>N.card.config);const{columnGroups:l}=Me(),{joinPlan:u,expandedJoins:c,setJoinPlan:h,addJoin:d,removeJoin:m,updateJoin:g,moveJoinUp:p,moveJoinDown:j,toggleJoinExpansion:x,getAvailableSourceEntities:b,getAvailableTargetEntities:f,addJoinKeyGroup:k,updateGroupOperator:T,removeJoinKeyGroup:E,addJoinKey:y,updateJoinKey:C,removeJoinKey:v,generateSQLPreview:w,isValidConfiguration:I}=fr({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);h({...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-gray-500",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 bg-gray-100 p-3",children:[e.jsx("div",{className:"mb-2 text-xs font-medium text-gray-600",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-gray-500",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(S=>S.name===N.source.name),O=a.find(S=>S.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:()=>p(N.id),disabled:N.sequence===1,children:e.jsx(_e,{className:"h-4 w-4"})}),e.jsx(t.Button,{variant:"ghost",size:"sm",onClick:()=>j(N.id),disabled:N.sequence===u.joins.length,children:e.jsx(qe,{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:()=>m(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:S=>{const M=a.find(z=>z.name===S);g(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:S,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:b(N.id).map(S=>e.jsx(t.SelectItem,{value:S.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:S.type}),S.name]})},S.name))})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Join Type"}),e.jsxs(t.Select,{value:N.joinType,onValueChange:S=>g(N.id,{joinType:S}),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:S=>{const M=a.find(z=>z.name===S);g(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:S,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?f(N.source.name).map(S=>e.jsx(t.SelectItem,{value:S.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:S.type}),S.name,S.name===N.source.name&&e.jsx(t.Badge,{variant:"outline",className:"text-xs text-yellow-600",children:"(Self-join)"})]})},S.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:()=>k(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((S,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:S.operator,onValueChange:z=>T(N.id,M,z),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:[S.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:S.keys.map((z,R)=>e.jsxs("div",{className:"flex flex-col items-start gap-2 rounded-md border p-2 sm:flex-row sm:items-center",children:[R>0&&e.jsx("div",{className:"self-center rounded-md bg-gray-100 px-2 py-1 text-xs font-medium",children:S.operator}),e.jsx("div",{className:"mb-2 w-full sm:mb-0 sm:flex-1",children:e.jsxs(t.Select,{value:z.source.name,onValueChange:V=>C(N.id,M,R,"sourceColumnName",V),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Source column"})}),e.jsx(t.SelectContent,{children:D(N.source.name).map(V=>e.jsx(t.SelectItem,{value:V.name,children:e.jsxs("div",{className:"flex w-full items-center justify-between",children:[e.jsx("span",{children:V.name}),e.jsx(t.Badge,{variant:"outline",className:"ml-2 text-xs",children:V.dataType})]})},V.name))})]})}),e.jsx("div",{className:"mb-2 w-full sm:mb-0 sm:w-20",children:e.jsxs(t.Select,{value:z.operator,onValueChange:V=>C(N.id,M,R,"operator",V),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:z.target.name,onValueChange:V=>C(N.id,M,R,"targetColumnName",V),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Target column"})}),e.jsx(t.SelectContent,{children:D(N.target.name).map(V=>e.jsx(t.SelectItem,{value:V.name,children:e.jsxs("div",{className:"flex w-full items-center justify-between",children:[e.jsx("span",{children:V.name}),e.jsx(t.Badge,{variant:"outline",className:"ml-2 text-xs",children:V.dataType})]})},V.name))})]})}),e.jsx(t.Button,{type:"button",variant:"ghost",size:"sm",className:"self-center",onClick:()=>v(N.id,M,R),children:e.jsx(t.X,{className:"size-3.5"})})]},z.id||R))}),e.jsxs(t.Button,{type:"button",variant:"outline",size:"sm",className:"mt-2",onClick:()=>y(N.id,M),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"})," Add Condition"]})]})]},S.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 $t({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.jsx(t.DialogContent,{className:"max-w-4xl",children:e.jsx(gr,{joinPlan:r,availableDataSources:o,onSave:l,onCancel:u,onRemove:i})}),s]})}function jr({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,h)=>c+h.keys.length,0)," ","condition",o.joinKeyGroups.reduce((c,h)=>c+h.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 yr(){var m,g;Me(),t.useEditorStore(p=>p.card.dataSource);const s=t.useEditorStore(p=>p.frame),a=t.useEditorStore(p=>p.card),n=t.useEditorStore(p=>p.actions.updateCardConfig),r=((m=a==null?void 0:a.config)==null?void 0:m.joinPlan)||{baseEntity:{type:"table",name:"",database:"",schema:"",connectionId:"",connectionType:"none",dialect:"none"},joins:[]},[o,i]=L.useState(!1),l=((g=a==null?void 0:a.dataSource)==null?void 0:g.selectedEntities)||[],u=p=>{s.activeCardId&&(n(s.activeCardId,{...a==null?void 0:a.config,joinPlan:p}),i(!1))},c=()=>{n(s.activeCardId,{...a==null?void 0:a.config,joinPlan:void 0})},h=()=>{i(!1)},d=()=>{const p=[...r.joins].sort((b,f)=>b.sequence-f.sequence),j=r.baseEntity;if(!j.name)return"SELECT * FROM table -- Please select a base entity";let x=`SELECT *
403
- FROM ${j.name}`;return p.forEach(b=>{const f=l.find(E=>E.name===b.target.name);if(!f)return;const k=b.joinKeyGroups.filter(E=>E.keys&&E.keys.length>0).map(E=>{const y=E.keys.filter(C=>{var v,w,I,D;return((v=C.source)==null?void 0:v.name)&&((w=C.target)==null?void 0:w.name)&&((I=C.source)==null?void 0:I.entityName)&&((D=C.target)==null?void 0:D.entityName)}).map(C=>`${C.source.entityName}.${C.source.name} ${C.operator} ${C.target.entityName}.${C.target.name}`);return y.length>1?`(${y.join(` ${E.operator} `)})`:y[0]}).filter(Boolean),T=k.length>1?k.join(" OR "):k[0]||"condition_here";x+=`
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(C=>!C.source.name||!C.target.name||!C.operator))))}}function gr({joinPlan:s,availableDataSources:a,onSave:n,onRemove:r,onCancel:i}){const{setCardConfig:o}=t.useEditorActions();t.useEditorStore(C=>C.card.config);const{columnGroups:l}=Me(),{joinPlan:u,expandedJoins:c,setJoinPlan:h,addJoin:d,removeJoin:m,updateJoin:g,moveJoinUp:p,moveJoinDown:j,toggleJoinExpansion:x,getAvailableSourceEntities:b,getAvailableTargetEntities:f,addJoinKeyGroup:k,updateGroupOperator:T,removeJoinKeyGroup:E,addJoinKey:y,updateJoinKey:N,removeJoinKey:v,generateSQLPreview:w,isValidConfiguration:I}=fr({initialJoinPlan:s,availableDataSources:a}),D=C=>{const F=l.find(O=>O.entityName===C);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:C=>{const F=a.find(O=>O.name===C);h({...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:C,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(C=>e.jsx(t.SelectItem,{value:C.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:C.type}),C.name,e.jsx(t.Badge,{variant:"outline",className:"text-xs text-green-600",children:"BASE"})]})},C.name))})]}),e.jsx("p",{className:"text-xs text-gray-500",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 bg-gray-100 p-3",children:[e.jsx("div",{className:"mb-2 text-xs font-medium text-gray-600",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-gray-500",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(C=>{const F=a.find(S=>S.name===C.source.name),O=a.find(S=>S.name===C.target.name),A=c.has(C.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:C.sequence}),e.jsxs(t.CardTitle,{className:"text-sm",children:["Join ",C.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:()=>p(C.id),disabled:C.sequence===1,children:e.jsx(_e,{className:"h-4 w-4"})}),e.jsx(t.Button,{variant:"ghost",size:"sm",onClick:()=>j(C.id),disabled:C.sequence===u.joins.length,children:e.jsx(qe,{className:"h-4 w-4"})}),e.jsx(t.Button,{variant:"ghost",size:"sm",onClick:()=>x(C.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:()=>m(C.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:C.source.name,onValueChange:S=>{const M=a.find(B=>B.name===S);g(C.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:S,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:b(C.id).map(S=>e.jsx(t.SelectItem,{value:S.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:S.type}),S.name]})},S.name))})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(t.Label,{children:"Join Type"}),e.jsxs(t.Select,{value:C.joinType,onValueChange:S=>g(C.id,{joinType:S}),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:C.target.name,onValueChange:S=>{const M=a.find(B=>B.name===S);g(C.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:S,database:M==null?void 0:M.database,schema:M==null?void 0:M.schema}})},disabled:!C.source.name,children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Select target..."})}),e.jsx(t.SelectContent,{children:C.source.name?f(C.source.name).map(S=>e.jsx(t.SelectItem,{value:S.name,children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Badge,{variant:"outline",className:"text-xs",children:S.type}),S.name,S.name===C.source.name&&e.jsx(t.Badge,{variant:"outline",className:"text-xs text-yellow-600",children:"(Self-join)"})]})},S.name)):[]})]})]})]}),C.source.name&&C.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:()=>k(C.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"})," Add Condition Group"]})]}),C.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:C.joinKeyGroups.map((S,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:S.operator,onValueChange:B=>T(C.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(C.id,M),children:e.jsx(t.Trash2,{className:"h-4 w-4"})})]})]}),e.jsxs("div",{className:"space-y-2",children:[S.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:S.keys.map((B,R)=>e.jsxs("div",{className:"flex flex-col items-start gap-2 rounded-md border p-2 sm:flex-row sm:items-center",children:[R>0&&e.jsx("div",{className:"self-center rounded-md bg-gray-100 px-2 py-1 text-xs font-medium",children:S.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=>N(C.id,M,R,"sourceColumnName",P),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Source column"})}),e.jsx(t.SelectContent,{children:D(C.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=>N(C.id,M,R,"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=>N(C.id,M,R,"targetColumnName",P),children:[e.jsx(t.SelectTrigger,{children:e.jsx(t.SelectValue,{placeholder:"Target column"})}),e.jsx(t.SelectContent,{children:D(C.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(C.id,M,R),children:e.jsx(t.X,{className:"size-3.5"})})]},B.id||R))}),e.jsxs(t.Button,{type:"button",variant:"outline",size:"sm",className:"mt-2",onClick:()=>y(C.id,M),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"})," Add Condition"]})]})]},S.id))})]})]})]},C.id)})})]}),e.jsxs("div",{className:"flex justify-end gap-2 border-t pt-4",children:[e.jsx(t.Button,{variant:"outline",onClick:()=>{r(),i()},children:"Remove All"}),e.jsx(t.Button,{variant:"outline",onClick:i,children:"Cancel"}),e.jsx(t.Button,{onClick:()=>n(u),disabled:!I(),children:"Save"})]})]})}function $t({children:s,open:a,onOpenChange:n,joinPlan:r,availableDataSources:i,onRemove:o,onSave:l,onCancel:u}){return e.jsxs(t.Dialog,{open:a,onOpenChange:n,children:[e.jsx(t.DialogContent,{className:"max-w-4xl",children:e.jsx(gr,{joinPlan:r,availableDataSources:i,onSave:l,onCancel:u,onRemove:o})}),s]})}function jr({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 i=[...s].sort((l,u)=>l.sequence-u.sequence),o=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:o==null?void 0:o.type}),e.jsx("span",{className:"text-xs font-medium",children:o==null?void 0:o.name}),e.jsx(t.Badge,{variant:"outline",className:"text-xs text-green-600",children:"BASE"})]}),i.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((i,o)=>i.sequence-o.sequence).map((i,o)=>{const l=n.find(c=>c.name===i.source.name),u=n.find(c=>c.name===i.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:o+1}),e.jsx(t.Badge,{variant:"outline",className:"shrink-0 text-xs",children:i.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:[i.joinKeyGroups.reduce((c,h)=>c+h.keys.length,0)," ","condition",i.joinKeyGroups.reduce((c,h)=>c+h.keys.length,0)>1?"s":""]})]},i.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 yr(){var m,g;Me(),t.useEditorStore(p=>p.card.dataSource);const s=t.useEditorStore(p=>p.frame),a=t.useEditorStore(p=>p.card),n=t.useEditorStore(p=>p.actions.updateCardConfig),r=((m=a==null?void 0:a.config)==null?void 0:m.joinPlan)||{baseEntity:{type:"table",name:"",database:"",schema:"",connectionId:"",connectionType:"none",dialect:"none"},joins:[]},[i,o]=L.useState(!1),l=((g=a==null?void 0:a.dataSource)==null?void 0:g.selectedEntities)||[],u=p=>{s.activeCardId&&(n(s.activeCardId,{...a==null?void 0:a.config,joinPlan:p}),o(!1))},c=()=>{n(s.activeCardId,{...a==null?void 0:a.config,joinPlan:void 0})},h=()=>{o(!1)},d=()=>{const p=[...r.joins].sort((b,f)=>b.sequence-f.sequence),j=r.baseEntity;if(!j.name)return"SELECT * FROM table -- Please select a base entity";let x=`SELECT *
403
+ FROM ${j.name}`;return p.forEach(b=>{const f=l.find(E=>E.name===b.target.name);if(!f)return;const k=b.joinKeyGroups.filter(E=>E.keys&&E.keys.length>0).map(E=>{const y=E.keys.filter(N=>{var v,w,I,D;return((v=N.source)==null?void 0:v.name)&&((w=N.target)==null?void 0:w.name)&&((I=N.source)==null?void 0:I.entityName)&&((D=N.target)==null?void 0:D.entityName)}).map(N=>`${N.source.entityName}.${N.source.name} ${N.operator} ${N.target.entityName}.${N.target.name}`);return y.length>1?`(${y.join(` ${E.operator} `)})`:y[0]}).filter(Boolean),T=k.length>1?k.join(" OR "):k[0]||"condition_here";x+=`
404
404
  ${b.joinType} JOIN ${f.name}
405
- ON ${T}`}),x};return l.length<2?null:e.jsx(e.Fragment,{children:e.jsx("div",{className:"space-y-4",children:e.jsxs("div",{className:"flex items-center justify-between",children:[r.joins.length>0&&e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.TooltipProvider$1,{children:e.jsxs(t.Tooltip,{children:[e.jsx(t.TooltipTrigger,{asChild:!0,children:e.jsxs(t.Button,{variant:"outline",size:"sm",className:"h-6 text-xs font-semibold",onClick:()=>i(!0),children:[e.jsx(t.Link,{className:t.cn("mr-1 h-3 w-3",{"text-blue-500":r.joins.length>0,"text-gray-500":r.joins.length===0})}),"Join",r.joins.length>1?"s":""," (",r.joins.length,")"]})}),e.jsx(t.TooltipContent,{side:"right",className:"max-w-md overflow-hidden p-0",children:e.jsx(jr,{joins:r.joins,baseEntityId:r.baseEntity.name,availableDataSources:l,generateSQLPreview:d})})]})}),e.jsx($t,{open:o,onOpenChange:i,joinPlan:r,availableDataSources:l,onSave:u,onCancel:h,onRemove:c,children:e.jsx("div",{})})]}),r.joins.length===0&&e.jsx($t,{open:o,onOpenChange:i,joinPlan:r,availableDataSources:l,onSave:u,onCancel:h,onRemove:c,children:e.jsxs(t.Button,{onClick:()=>i(!0),variant:"outline",className:"h-6 text-xs font-semibold",children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"}),"Configure Join"]})})]})})})}function br(){const[s,a]=L.useState(!1),[n,r]=L.useState(!0),o=t.useEditorStore(c=>c.card.dataSource),{updateDataSource:i}=t.useEditorActions(),l={connectionId:"",connectionType:"",mode:"database",selectedEntities:[]},u={...l,...o,selectedEntities:(o==null?void 0:o.selectedEntities)||[]};return e.jsxs("div",{className:"flex w-[325px] flex-col border-r bg-background",children:[e.jsxs("div",{onMouseEnter:()=>r(!0),onMouseLeave:()=>r(!1),children:[e.jsx("div",{className:t.cn("p-4 px-6",{"pb-0":!n}),children:e.jsxs("div",{className:"flex w-full items-center justify-between",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Database,{className:"h-5 w-5 text-cyan-600"}),e.jsx("h2",{className:"font-semibold text-gray-900",children:"Data Source"})]}),e.jsxs(t.Button,{size:"sm",variant:"outline",className:"h-7",onClick:()=>a(!0),children:[e.jsx(t.Plus,{className:"mr-1 h-3.5 w-3.5"}),"Add"]})]})}),e.jsxs("div",{className:`overflow-hidden px-6 ${n?"max-h-96 space-y-4":"max-h-0 py-0 opacity-0"}`,children:[u.selectedEntities.length>0&&e.jsxs("div",{className:"flex flex-wrap gap-1",children:[u.selectedEntities.slice(0,3).map((c,h)=>e.jsxs(t.Badge,{variant:"secondary",className:"group relative cursor-pointer pr-6 text-xs transition-colors hover:border-red-200 hover:bg-red-50 dark:hover:border-red-800 dark:hover:bg-red-950",children:[c.name,e.jsx("button",{onClick:d=>{d.stopPropagation();const m=u.selectedEntities.filter(g=>!(g.name===c.name&&g.type===c.type));i({...l,...o,selectedEntities:m})},className:"absolute right-1 top-1/2 -translate-y-1/2 rounded-full p-0.5 opacity-0 transition-opacity hover:bg-red-100 group-hover:opacity-100",children:e.jsx(t.X,{className:"h-2.5 w-2.5 text-red-500"})})]},`${c.type}-${c.name}-${h}`)),u.selectedEntities.length>3&&e.jsxs(t.Badge,{variant:"outline",className:"text-xs",children:["+",u.selectedEntities.length-3," more"]})]}),e.jsx(yr,{})]})]}),e.jsx(pr,{}),e.jsx(t.DataSourceDialog,{incomingSelectedEntities:(o==null?void 0:o.selectedEntities)||[],dialogMode:"dataSource",open:s,onOpenChange:a,dataSource:u,fallbackDataSource:l})]})}const vr=[{id:"table",icon:He,label:"Table"},{id:"bar",icon:Ge,label:"Bar Chart"},{id:"line",icon:$e,label:"Line Chart"},{id:"stackedBar",icon:dt,label:"Stacked Bar Chart"},{id:"stackedLine",icon:It,label:"Stacked Line Chart"},{id:"scatter",icon:xt,label:"Scatter Chart"},{id:"bubble",icon:kt,label:"Bubble Chart"},{id:"pie",icon:ht,label:"Pie Chart"},{id:"doughnut",icon:pt,label:"Doughnut Chart"},{id:"funnel",icon:Et,label:"Funnel Chart"},{id:"radar",icon:yt,label:"Radar Chart"},{id:"polarArea",icon:wt,label:"Polar Area Chart"},{id:"tornado",icon:vt,label:"Tornado Chart"},{id:"range",icon:mt,label:"Range Chart"},{id:"kpi",icon:Dt,label:"KPI"},{id:"text",icon:Jt,label:"Text"},{id:"map",icon:jt,label:"Map"},{id:"custom",icon:bt,label:"Custom"}];function Cr({selectedChart:s,onChartChange:a}){const{setCardType:n,setCardPreferences:r,setIsDevMode:o}=t.useEditorStore(h=>h.actions),{setCardCustomCfg:i,setCustomCardPreferences:l,setQueryConfig:u}=t.useEditorActions();function c(h){i(null),r({}),n(h),["kpi","custom","text","map"].includes(h)&&(o(!0),u(void 0)),a(h)}return e.jsx("div",{className:"mb-6",children:e.jsxs(t.Select,{value:s,onValueChange:c,children:[e.jsx(t.SelectTrigger,{className:"w-full",children:e.jsx(t.SelectValue,{placeholder:"Select chart type"})}),e.jsx(t.SelectContent,{children:vr.map(h=>{const d=h.icon;return e.jsx(t.SelectItem,{value:h.id,className:"flex items-center gap-2",children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(d,{className:"h-4 w-4"}),e.jsx("span",{children:h.label})]})},h.id)})})]})})}const ws=({dataType:s})=>{const a=t.getDataType(s);return a==="string"?e.jsx("span",{className:"flex h-4 w-4 items-center justify-center rounded-sm bg-blue-500 text-xs text-white",children:"T"}):a==="number"?e.jsx("span",{className:"flex h-4 w-4 items-center justify-center rounded-sm bg-green-500 text-xs text-white",children:"#"}):a==="date"?e.jsx("span",{className:"flex h-4 w-4 items-center justify-center rounded-sm bg-purple-500 text-xs text-white",children:"D"}):a==="boolean"?e.jsx("span",{className:"flex h-4 w-4 items-center justify-center rounded-sm bg-orange-500 text-xs text-white",children:"B"}):e.jsx("span",{className:"flex h-4 w-4 items-center justify-center rounded-sm bg-gray-500 text-xs text-white",children:"?"})};function Nr({label:s,onLabelChange:a}){const[n,r]=L.useState(s??""),[o,i]=L.useState(!1);return e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Display Label"}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Input$1,{placeholder:"Display label...",value:o?n:s??"",onChange:l=>{r(l.target.value),i(!0)},onFocus:()=>i(!0),onClick:l=>l.stopPropagation(),className:"h-8 text-xs",onPointerDown:l=>l.stopPropagation(),onKeyDown:l=>{l.stopPropagation(),l.key==="Enter"&&o&&n!==(s??"")?(a(n),i(!1)):l.key==="Escape"&&(r(s??""),i(!1))},"aria-label":"Edit display label"}),o&&n!==(s??"")&&e.jsxs(e.Fragment,{children:[e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Confirm label",onClick:()=>{a(n),i(!1)},children:e.jsx(t.Check,{className:"h-4 w-4 text-green-600"})}),e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Cancel label edit",onClick:()=>{r(s??""),i(!1)},children:e.jsx(t.X,{className:"h-4 w-4 text-gray-400"})})]})]})]})}function Sr({aliasTemplate:s,onAliasTemplateChange:a}){var c;const[n,r]=L.useState(s),[o,i]=L.useState(!1),l=(c=t.useEditorStore(h=>{var d;return(d=h.card.config)==null?void 0:d.pivotByColumns}))==null?void 0:c[0],u=l?`e.g. Min Sales in {{${l.name}}}`:"e.g. Min Sales in {{region}}";return e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Pivot Alias Template"}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Input$1,{placeholder:u,value:o?n:s,onChange:h=>{r(h.target.value),i(!0)},onFocus:()=>i(!0),onPointerDown:h=>h.stopPropagation(),className:"h-8 text-xs",onKeyDown:h=>{h.key==="Enter"&&o&&n!==s?(a(n),i(!1)):h.key==="Escape"&&(r(s),i(!1))},"aria-label":"Edit alias template"}),o&&n!==s&&e.jsxs(e.Fragment,{children:[e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Confirm alias template",onClick:()=>{a(n),i(!1)},children:e.jsx(t.Check,{className:"h-4 w-4 text-green-600"})}),e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Cancel alias template edit",onClick:()=>{r(s),i(!1)},children:e.jsx(t.X,{className:"h-4 w-4 text-gray-400"})})]})]})]})}function wr({valueAliases:s,onValueAliasesChange:a}){const[n,r]=L.useState(null),[o,i]=L.useState(""),[l,u]=L.useState(""),c=()=>{a({...s,"":""})},h=m=>{const g={...s};delete g[m],a(g)},d=m=>{const g={...s};delete g[m],g[o]=l,a(g),r(null)};return e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Pivot Value Aliases"}),e.jsxs("div",{className:"space-y-2",children:[Object.entries(s).map(([m,g],p)=>e.jsx("div",{className:"flex items-center gap-2",children:n===m?e.jsxs(e.Fragment,{children:[e.jsx(t.Input$1,{placeholder:"Value key",value:o,onChange:j=>i(j.target.value),className:"h-8 w-24 text-xs",onPointerDown:j=>j.stopPropagation(),onKeyDown:j=>{j.key==="Enter"?d(m):j.key==="Escape"&&r(null)},"aria-label":"Edit value alias key"}),e.jsx(t.Input$1,{placeholder:"Alias label",value:l,onChange:j=>u(j.target.value),className:"h-8 w-24 text-xs",onPointerDown:j=>j.stopPropagation(),onKeyDown:j=>{j.key==="Enter"?d(m):j.key==="Escape"&&r(null)},"aria-label":"Edit value alias label"}),e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Confirm value alias edit",onClick:()=>d(m),children:e.jsx(t.Check,{className:"h-4 w-4 text-green-600"})}),e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Cancel value alias edit",onClick:()=>r(null),children:e.jsx(t.X,{className:"h-4 w-4 text-gray-400"})})]}):e.jsxs(e.Fragment,{children:[e.jsx(t.Input$1,{placeholder:"Value key",value:m,className:"h-8 w-24 text-xs",readOnly:!0,onClick:()=>{r(m),i(m),u(g)},"aria-label":"Edit value alias key"}),e.jsx(t.Input$1,{placeholder:"Alias label",value:g,className:"h-8 w-24 text-xs",readOnly:!0,onClick:()=>{r(m),i(m),u(g)},"aria-label":"Edit value alias label"}),e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-8 w-8 p-0",onClick:()=>h(m),"aria-label":"Remove value alias",children:e.jsx(t.X,{className:"h-3 w-3"})})]})},m+p)),e.jsxs(t.Button,{variant:"outline",size:"sm",className:"mt-1 h-8 text-xs",onClick:c,children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"})," Add Value Alias"]})]})]})}function kr({field:s,zone:a,onRemove:n,onLabelChange:r,sortDirection:o,onSortDirectionChange:i,onAliasTemplateChange:l,onValueAliasesChange:u,onAggregationChange:c,onDateFormatChange:h,onGranularityChange:d,hasPivotColumns:m=!1}){const{attributes:g,listeners:p,setNodeRef:j,transform:x,transition:b,isDragging:f}=t.useSortable({id:s.id}),[k,T]=L.useState(!1),[E,y]=L.useState(s.dateFormat||"YYYY-MM-DD"),[C,v]=L.useState(s.customFormat||""),[w,I]=L.useState(!!s.customFormat),[D,N]=L.useState(s.granularity||"day"),[F,O]=L.useState(s.aliasTemplate||""),[A,S]=L.useState(s.valueAliases||{}),M=q=>{q==="custom"?I(!0):(I(!1),y(q),a==="groupBy"&&h&&h(q,""))},z=q=>{v(q),a==="groupBy"&&h&&h("custom",q)},R=q=>{N(q),a==="groupBy"&&d&&d(q)},V=q=>{O(q),l&&l(q)},B=q=>{S(q),u&&u(q)},K={transform:t.CSS.Transform.toString(x),transition:b},J=t.getDataType(s.dataType),$=J==="date",U=[{value:"YYYY-MM-DD",label:"2024-01-15 (YYYY-MM-DD)"},{value:"MM/DD/YYYY",label:"01/15/2024 (MM/DD/YYYY)"},{value:"DD/MM/YYYY",label:"15/01/2024 (DD/MM/YYYY)"},{value:"MMMM DD, YYYY",label:"January 15, 2024 (MMMM DD, YYYY)"},{value:"MMM DD, YYYY",label:"Jan 15, 2024 (MMM DD, YYYY)"},{value:"DD MMM YYYY",label:"15 Jan 2024 (DD MMM YYYY)"},{value:"YYYY-MM",label:"2024-01 (YYYY-MM)"},{value:"MMMM YYYY",label:"January 2024 (MMMM YYYY)"},{value:"custom",label:"Custom Format..."}];return e.jsxs("div",{ref:j,style:K,...g,...p,className:`group flex w-full flex-col gap-2 rounded border border-border bg-background p-2 transition-all hover:shadow-sm dark:border-gray-800 ${f?"z-50 scale-95 opacity-50":"border-slate-200"} ${a==="filters"?"cursor-default":"cursor-move"}`,children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.GripVertical,{className:"h-3 w-3"}),e.jsx(ws,{dataType:J}),e.jsx("span",{className:"max-w-[180px] flex-1 overflow-hidden truncate text-sm",children:s.label||s.name}),a!=="sortBy"&&e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-6 w-6 p-0 opacity-0 group-hover:opacity-100",onClick:q=>{q.stopPropagation(),T(!k)},children:e.jsx(t.ChevronDown,{className:`h-3 w-3 transition-transform ${k?"rotate-180":""}`})}),a==="sortBy"&&e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-6 w-6 p-0 group-hover:opacity-100",onClick:q=>{q.stopPropagation(),console.log("DraggableField - Current sortDirection:",o);const P=o==="asc"?"desc":"asc";console.log("DraggableField - New direction to set:",P),i(P)},children:o==="asc"?e.jsx(_e,{className:"h-3 w-3"}):e.jsx(qe,{className:"h-3 w-3"})}),e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-6 w-6 p-0 opacity-0 group-hover:opacity-100",onClick:q=>{q.stopPropagation(),n()},children:e.jsx(t.X,{className:"h-3 w-3"})})]}),k&&e.jsxs("div",{className:"space-y-3",children:[e.jsx("span",{className:"flex-1 overflow-hidden truncate px-0.5 text-xs text-gray-500",children:`${s.entityName}.${s.name}`}),a!=="pivotBy"&&e.jsx(Nr,{label:s.label??"",onLabelChange:r}),$&&a!=="groupBy"&&e.jsx("div",{className:"space-y-1",children:e.jsxs(t.Select,{defaultValue:"day",children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full text-xs",children:e.jsx(t.SelectValue,{placeholder:"Select granularity..."})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"day",children:"Day"}),e.jsx(t.SelectItem,{value:"week",children:"Week"}),e.jsx(t.SelectItem,{value:"month",children:"Month"}),e.jsx(t.SelectItem,{value:"quarter",children:"Quarter"}),e.jsx(t.SelectItem,{value:"year",children:"Year"})]})]})}),$&&a==="groupBy"&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Granularity"}),e.jsxs(t.Select,{value:D,onValueChange:R,children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full text-xs",children:e.jsx(t.SelectValue,{placeholder:"Select granularity..."})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"day",children:"Day"}),e.jsx(t.SelectItem,{value:"week",children:"Week"}),e.jsx(t.SelectItem,{value:"month",children:"Month"}),e.jsx(t.SelectItem,{value:"quarter",children:"Quarter"}),e.jsx(t.SelectItem,{value:"year",children:"Year"})]})]})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Date Format"}),e.jsxs(t.Select,{value:w?"custom":E,onValueChange:M,children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full text-xs",children:e.jsx(t.SelectValue,{placeholder:"Select date format..."})}),e.jsx(t.SelectContent,{children:U.map(q=>e.jsx(t.SelectItem,{value:q.value,children:q.label},q.value))})]}),w&&e.jsxs("div",{className:"mt-2 space-y-1",children:[e.jsx(t.Input$1,{placeholder:"Enter custom format (e.g., YYYY-MM-DD HH:mm)",value:C,onChange:q=>{q.stopPropagation(),z(q.target.value)},onClick:q=>q.stopPropagation(),className:"h-8 text-xs"}),e.jsx("div",{className:"text-xs text-gray-500",children:"Examples: YYYY-MM-DD, MM/DD/YY, DD-MMM-YYYY HH:mm"})]})]})]}),a==="metrics"&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Aggregation"}),e.jsxs(t.Select,{value:s.aggregate,onValueChange:q=>{c&&c(q)},children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full text-xs",children:e.jsx(t.SelectValue,{placeholder:"Select function..."})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"COUNT",children:"Count"}),e.jsx(t.SelectItem,{value:"DISTINCT",children:"Count Distinct"}),t.getDataType(s.dataType)==="number"&&e.jsxs(e.Fragment,{children:[e.jsx(t.SelectItem,{value:"SUM",children:"Sum"}),e.jsx(t.SelectItem,{value:"AVG",children:"Average"}),e.jsx(t.SelectItem,{value:"MIN",children:"Min"}),e.jsx(t.SelectItem,{value:"MAX",children:"Max"}),e.jsx(t.SelectItem,{value:"MEDIAN",children:"Median"})]})]})]})]}),m&&e.jsxs(e.Fragment,{children:[e.jsx(Sr,{aliasTemplate:F,onAliasTemplateChange:V}),e.jsx(wr,{valueAliases:A,onValueAliasesChange:B})]})]})]})]})}function Fe({zone:s,fields:a,label:n,placeholder:r,onRemove:o,onLabelChange:i,onAggregationChange:l,onDateFormatChange:u,onGranularityChange:c,onAliasTemplateChange:h,onValueAliasesChange:d,shouldShow:m,hasPivotColumns:g=!1}){const{isOver:p,setNodeRef:j}=t.useDroppable({id:s}),{updateSortByColumn:x}=t.useEditorActions(),b=t.useEditorStore(T=>T.card),f=a.length>0,k=(T,E)=>{var C;!((C=b.config)!=null&&C.sortByColumns)||b.config.sortByColumns.findIndex(v=>v.id===T)===-1||x(b.id,T,{direction:E})};return s==="sortBy"&&m===!1?null:e.jsxs("div",{className:"mb-4",children:[e.jsx(t.Label,{className:"mb-2 block text-sm font-medium",children:n}),e.jsx("div",{ref:j,className:`min-h-[60px] rounded-lg border-2 border-dashed p-3 transition-all ${p?"border-blue-500 bg-blue-50 dark:bg-blue-950":"border-muted-foreground/20 bg-muted/50"}`,children:a.length===0?e.jsxs("div",{className:"flex min-h-[40px] items-center justify-center text-sm text-gray-400",children:[e.jsx(t.Plus,{className:"mr-2 h-4 w-4"}),r]}):e.jsx(t.SortableContext,{items:a.map(T=>T.id),strategy:t.verticalListSortingStrategy,children:e.jsx("div",{className:"flex flex-wrap gap-2",children:a.map((T,E)=>{const C=T.direction;return e.jsx("div",{className:"flex w-full items-center gap-2",children:e.jsx("div",{className:"flex-1",children:e.jsx(kr,{field:T,zone:s,onRemove:()=>o(E),onLabelChange:v=>i(E,v),sortDirection:C,onSortDirectionChange:v=>k(T.id,v),onAggregationChange:l?v=>l(E,v):void 0,onAliasTemplateChange:h?v=>h(E,v):void 0,onValueAliasesChange:d?v=>d(E,v):void 0,onDateFormatChange:u?(v,w)=>u(E,v,w):void 0,onGranularityChange:c?v=>c(E,v):void 0,hasPivotColumns:g})})},T.id)})})})})]})}function Er({groupByFields:s,pivotByFields:a,metricsFields:n,sortByFields:r,onRemoveField:o,onLabelChange:i,onAggregationChange:l,onDateFormatChange:u,onGranularityChange:c,onAliasTemplateChange:h,onValueAliasesChange:d}){return e.jsxs("div",{className:"space-y-4",children:[e.jsx(Fe,{zone:"groupBy",fields:s,label:"Group By",placeholder:"Drop fields to group data",onRemove:m=>o("groupBy",m),onLabelChange:(m,g)=>i("groupBy",m,g),onDateFormatChange:(m,g,p)=>u&&u(m,g,p),onGranularityChange:(m,g)=>c&&c(m,g)}),e.jsx(Fe,{zone:"pivotBy",fields:a,label:"Pivot By",placeholder:"Drop fields to pivot data",onRemove:m=>o("pivotBy",m),onLabelChange:(m,g)=>i("pivotBy",m,g)}),e.jsx(Fe,{zone:"metrics",fields:n,label:"Metrics",placeholder:"Drop fields to measure",onRemove:m=>o("metrics",m),onLabelChange:(m,g)=>i("metrics",m,g),onAggregationChange:l,onAliasTemplateChange:h,onValueAliasesChange:d,hasPivotColumns:a.length>0}),r&&r.length>0&&e.jsx(Fe,{zone:"sortBy",fields:r,label:"Sort By",placeholder:"Drop fields to sort data",onRemove:m=>o("sortBy",m),onLabelChange:(m,g)=>i("sortBy",m,g),shouldShow:s.length>0||a.length>0||n.length>0})]})}function Ir({selectedChart:s,onChartChange:a,groupByFields:n,pivotByFields:r,metricsFields:o,sortByFields:i,onRemoveField:l,onLabelChange:u,onAggregationChange:c,onDateFormatChange:h,onGranularityChange:d,onAliasTemplateChange:m,onValueAliasesChange:g}){t.useEditorStore(j=>j.showAIDialog);const{setShowAIDialog:p}=t.useEditorActions();return e.jsxs("div",{className:"flex w-96 flex-col border-r bg-background",children:[e.jsxs("div",{className:"mt-1 space-y-4 border-b px-6 py-4",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(ut,{className:"h-5 w-5 text-cyan-600"}),e.jsx("h2",{className:"font-semibold",children:"Chart Configuration"})]}),e.jsx(Cr,{selectedChart:s,onChartChange:a})]}),e.jsxs(t.ScrollArea,{className:"flex-1 p-6",children:[e.jsx(Er,{groupByFields:n,pivotByFields:r,metricsFields:o,sortByFields:i,onRemoveField:l,onLabelChange:u,onAggregationChange:c,onDateFormatChange:h,onGranularityChange:d,onAliasTemplateChange:m,onValueAliasesChange:g}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function Dr({initialFilters:s,availableFields:a}={}){const[n,r]=L.useState(s||{id:`group-${Date.now()}`,logicalOperator:"AND",negate:!1,conditions:[],groups:[]});t.useEditorStore(y=>y.card.dataSource);const{columns:o,isLoading:i}=Me(),u=a||o||[],c={id:"default",name:"default",dataType:"string",label:"Default",entityId:"default",entityName:"Default",entityType:"table"},h=y=>{const C=v=>{if(v.id===y){const w=u[0]||c;return{...v,conditions:[...v.conditions,{id:`condition-${Date.now()}`,field:w,operator:"=",value:""}]}}return{...v,groups:v.groups.map(C)}};r(C(n))},d=y=>{const C=v=>{if(v.id===y){const w=u[0]||c;return{...v,groups:[...v.groups,{id:`group-${Date.now()}`,logicalOperator:"AND",negate:!1,conditions:[{id:`condition-${Date.now()}`,field:w,operator:"=",value:""}],groups:[]}]}}return{...v,groups:v.groups.map(C)}};r(C(n))},m=(y,C)=>{const v=w=>w.id===y?{...w,conditions:w.conditions.filter(I=>I.id!==C)}:{...w,groups:w.groups.map(v)};r(v(n))},g=(y,C)=>{const v=w=>w.id===y?{...w,groups:w.groups.filter(I=>I.id!==C)}:{...w,groups:w.groups.map(v)};r(v(n))},p=(y,C,v,w)=>{if(v==="field")throw new Error("Use a dedicated method to update the field property with a Field object");const I=D=>D.id===y?{...D,conditions:D.conditions.map(N=>N.id===C?{...N,[v]:w}:N)}:{...D,groups:D.groups.map(I)};r(I(n))},j=(y,C,v)=>{const w=I=>I.id===y?{...I,conditions:I.conditions.map(D=>D.id===C?{...D,...v}:D)}:{...I,groups:I.groups.map(w)};r(w(n))},x=(y,C)=>{const v=w=>w.id===y?{...w,logicalOperator:C}:{...w,groups:w.groups.map(v)};r(v(n))},b=(y,C)=>{const v=w=>w.id===y?{...w,negate:C}:{...w,groups:w.groups.map(v)};r(v(n))},f=(y,C,v)=>{const w=I=>I.id===y?{...I,conditions:t.arrayMove(I.conditions,C,v)}:{...I,groups:I.groups.map(w)};r(w(n))},k=(y,C,v)=>{const w=I=>I.id===y?{...I,groups:t.arrayMove(I.groups,C,v)}:{...I,groups:I.groups.map(w)};r(w(n))},T=y=>{if(!y||y.conditions.length===0&&y.groups.length===0)return"-- No filters defined";const C=w=>{let I="";typeof w.field=="object"?I=w.field.entityName?`${w.field.entityName}.${w.field.name}`:w.field.name:I=String(w.field);const D=w.operator;let N=w.value;if(w.field.dataType==="string"&&!["in","not in"].includes(w.operator))typeof N=="string"?N=`'${N}'`:Array.isArray(N)&&(N=`'${N.join(", ")}'`);else if(w.field.dataType==="date")(typeof N=="string"||N instanceof Date)&&(N=`DATE('${N}')`);else if(["in","not in"].includes(w.operator)){let F=[];Array.isArray(N)?F=N.map(O=>typeof O=="string"?`'${O}'`:String(O)):typeof N=="string"?F=N.split(",").map(O=>{const A=O.trim();return w.field.dataType==="string"?`'${A}'`:A}):typeof N=="number"&&(F=[String(N)]),N=`(${F.join(", ")})`}switch(D){case"contains":return typeof N=="string"?`${I} LIKE '%${N.replace(/'/g,"")}'`:`${I} LIKE '%${String(N)}'`;case"startsWith":return typeof N=="string"?`${I} LIKE '${N.replace(/'/g,"")}%'`:`${I} LIKE '${String(N)}%'`;case"endsWith":return typeof N=="string"?`${I} LIKE '%${N.replace(/'/g,"")}'`:`${I} LIKE '%${String(N)}'`;default:return`${I} ${D} ${N}`}},v=w=>{const I=w.conditions.map(C),D=w.groups.map(A=>v(A)),N=[...I,...D].filter(Boolean);if(N.length===0)return"";const F=N.join(` ${w.logicalOperator} `),O=N.length>1?`(${F})`:F;return w.negate?`NOT ${O}`:O};return v(y)},E=n.conditions.length>0||n.groups.length>0;return{currentFilters:n,setCurrentFilters:r,availableFields:u,isLoading:i,addCondition:h,addGroup:d,removeCondition:m,removeGroup:g,updateCondition:p,updateConditionFields:j,updateGroupOperator:x,updateGroupNegate:b,reorderConditions:f,reorderGroups:k,generateSQLPreview:T,hasAnyFilters:E}}const Tr=s=>{switch(s){case"table":return e.jsx(t.Table,{className:"h-3 w-3"});case"view":return e.jsx(t.Eye,{className:"h-3 w-3"});case"dataset":return e.jsx(ut,{className:"h-3 w-3"});case"file":return e.jsx(mn,{className:"h-3 w-3"});default:return e.jsx(t.Table,{className:"h-3 w-3"})}},Mr=s=>{switch(s){case"table":return"Table";case"view":return"View";case"dataset":return"Dataset";case"file":return"File";default:return"Table"}},Ar=s=>{if(s.qualifiedEntityName){const a=s.qualifiedEntityName.split(".");return a.length>1?a[0]:"default"}return"default"};function Lr({value:s,onValueChange:a,availableFields:n,placeholder:r="Select field",className:o="w-64"}){const[i,l]=L.useState(!1),u=L.useMemo(()=>{const c={};return n.forEach(h=>{const d=Ar(h);c[d]||(c[d]={}),c[d][h.entityId]||(c[d][h.entityId]=[]),c[d][h.entityId].push(h)}),c},[n]);return e.jsxs(t.Popover,{modal:!0,open:i,onOpenChange:l,children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsxs(t.Button,{variant:"outline",role:"combobox","aria-expanded":i,className:t.cn("justify-between",!s&&"text-muted-foreground",o),children:[s?e.jsx("div",{className:"flex items-center gap-2",children:e.jsxs("span",{className:"truncate text-sm",children:[s.entityName,".",s.name]})}):r,e.jsx(en,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})}),e.jsx(t.PopoverContent,{className:"z-50 w-80 p-0",align:"start",children:e.jsxs(t.Command,{children:[e.jsx(t.CommandInput,{placeholder:"Search fields...",className:"h-9"}),e.jsx(t.CommandEmpty,{children:"No fields found."}),e.jsx(t.CommandList,{className:"max-h-80",children:Object.entries(u).map(([c,h])=>e.jsx(t.CommandGroup,{heading:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Database,{className:"h-3 w-3"}),c]}),children:Object.entries(h).map(([d,m])=>e.jsxs("div",{children:[e.jsxs("div",{className:"flex items-center gap-2 bg-gray-50/50 px-2 py-1 text-xs font-medium text-gray-600",children:[Tr(m[0].entityType),e.jsx("span",{children:m[0].entityName}),e.jsx(t.Badge,{variant:"secondary",className:"text-xs",children:Mr(m[0].entityType)})]}),m.map(g=>e.jsxs(t.CommandItem,{value:g.id,onSelect:()=>{a(g),l(!1)},className:"pl-6",children:[e.jsx(t.Check,{className:t.cn("mr-2 h-4 w-4",(s==null?void 0:s.id)===g.id?"opacity-100":"opacity-0")}),e.jsxs("div",{className:"flex min-w-0 flex-1 flex-col",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx("span",{className:"truncate",children:g.label}),g.role&&e.jsx(t.Badge,{variant:"outline",className:"text-xs capitalize",children:g.role})]}),e.jsxs("div",{className:"flex items-center gap-2 text-xs text-gray-500",children:[e.jsx("span",{children:g.dataType}),g.description&&e.jsxs("span",{children:["• ",g.description]}),g.customFormat&&e.jsxs("span",{children:["• ",g.customFormat]})]})]})]},g.id))]},`${c}-${d}`))},c))})]})})]})}function At(s){var p;const a=t.useEditorStore(j=>j.card),{authToken:n}=t.useSemaphorContext(),r=t.useEditorStore(j=>j.card.config),o=r==null?void 0:r.joinPlan,i={...s,label:"value",role:"groupby"},l={...s,role:"metric",label:"count",aggregate:"COUNT"},u={joinPlan:o,groupByColumns:[i],metricColumns:[l]},c=((p=a.dataSource)==null?void 0:p.connectionId)||a.connectionId,{data:h,isPending:d,error:m}=t.useQuery({queryKey:["filterValues",s.entityId,s.name,s.qualifiedEntityName],queryFn:async()=>{try{return await t.postRequestRegular("https://semaphor.cloud/api/v1/query",(n==null?void 0:n.accessToken)||"",{connection_id:c,cardConfig:u,cardDataSource:a.dataSource})}catch(j){console.log(s),console.error("error",j)}},enabled:!!c,refetchOnMount:!0,refetchOnWindowFocus:!1});return{filterValues:((h==null?void 0:h.records)||[]).map(j=>({label:j.value||"BLANK",value:j.value||"BLANK",count:j.count})),isPending:d,error:m}}function Or({field:s,selected:a,onChange:n,placeholder:r="Select items...",className:o}){const[i,l]=re.useState(!1),{filterValues:u}=At(s),c=d=>{n(a.filter(m=>m!==d))},h=d=>{a.includes(d)?n(a.filter(m=>m!==d)):n([...a,d])};return e.jsx("div",{className:t.cn("w-full",o),children:e.jsxs(t.Popover,{open:i,onOpenChange:l,modal:!0,children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsxs(t.Button,{variant:"outline",role:"combobox","aria-expanded":i,className:"h-auto min-h-10 w-full justify-between p-2",children:[e.jsx("div",{className:"flex flex-1 flex-wrap gap-1",children:a.length>0?a.map(d=>{const m=u.find(g=>g.value===d);return e.jsxs(t.Badge,{variant:"secondary",className:"text-xs",children:[m==null?void 0:m.label,e.jsx("div",{className:"ml-1 rounded-full outline-none ring-offset-background focus:ring-2 focus:ring-ring focus:ring-offset-2",onKeyDown:g=>{g.key==="Enter"&&c(d)},onMouseDown:g=>{g.preventDefault(),g.stopPropagation()},onClick:g=>{g.stopPropagation(),c(d)},children:e.jsx(t.X,{className:"h-3 w-3 text-muted-foreground hover:text-foreground"})})]},d)}):e.jsx("span",{className:"text-muted-foreground",children:r})}),e.jsx(t.ChevronDown,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})}),e.jsx(t.PopoverContent,{className:"z-50 w-fit overflow-auto p-0",align:"start",children:e.jsxs(t.Command,{children:[e.jsx(t.CommandInput,{placeholder:"Search..."}),e.jsxs(t.CommandList,{children:[e.jsx(t.CommandEmpty,{children:"No results found."}),e.jsx(t.CommandGroup,{children:u.map(d=>e.jsxs(t.CommandItem,{onSelect:()=>h(d.value),children:[e.jsx(t.Check,{className:t.cn("mr-2 h-4 w-4",a.includes(d.value)?"opacity-100":"opacity-0")}),e.jsxs("div",{className:"flex grow items-center justify-between gap-4",children:[e.jsx("span",{children:d.label}),e.jsx("span",{className:"text-xs text-muted-foreground",children:d.count})]})]},d.value))})]})]})})]})})}const ks=s=>{if(!s)return 0;let a=s.conditions.length;return s.groups.forEach(n=>{a+=ks(n)}),a};function Fr({field:s,value:a,onChange:n,placeholder:r="Select value...",className:o}){const{filterValues:i,isPending:l,error:u}=At(s);return l?e.jsxs("div",{className:"flex flex-1 items-center justify-center p-2 text-xs text-gray-500",children:[e.jsx(ce,{className:"mr-2 size-3.5 animate-spin"})," Loading values..."]}):u?e.jsx("div",{className:"flex-1 p-2 text-xs text-red-500",children:"Error loading values"}):e.jsxs(t.Select,{value:a,onValueChange:n,children:[e.jsx(t.SelectTrigger,{className:o||"flex-1",children:e.jsx(t.SelectValue,{placeholder:r,children:a})}),e.jsx(t.SelectContent,{children:i.map(c=>e.jsx(t.SelectItem,{value:c.value,children:c.label},c.value))})]})}const zr=["=","!=",">",">=","<","<=","contains","startsWith","endsWith","in","not in"],Br=["=","!=","contains","startsWith","endsWith","in","not in"],Rr=["=","!=",">",">=","<","<=","in","not in"],Vr=["=","!="],Pr=["=","!=",">",">=","<","<=","in","not in"];function qr(s){switch(s){case"string":return Br;case"number":return Rr;case"boolean":return Vr;case"date":return Pr;default:return zr}}function Es({condition:s,index:a,groupId:n,groupLogicalOperator:r,onUpdateCondition:o,onRemoveCondition:i,onUpdateGroupOperator:l,availableFields:u,updateConditionFields:c}){const{attributes:h,listeners:d,setNodeRef:m,transform:g,transition:p,isDragging:j}=t.useSortable({id:s.id}),{isPending:x,error:b}=At(s.field),f={transform:t.CSS.Transform.toString(g),transition:p};return e.jsxs("div",{ref:m,style:f,className:`mb-2 flex items-center gap-2 rounded p-2 hover:bg-gray-50 ${j?"z-50 opacity-50":""}`,children:[e.jsx("div",{...h,...d,className:"cursor-grab active:cursor-grabbing",children:e.jsx(t.GripVertical,{className:"h-4 w-4 flex-shrink-0 text-gray-400"})}),a>0&&e.jsxs(t.Select,{value:r,onValueChange:k=>l(n,k),children:[e.jsx(t.SelectTrigger,{className:"w-24",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"})]})]}),a===0&&e.jsx("div",{className:"w-24"}),e.jsx(Lr,{value:s.field,onValueChange:k=>{c(n,s.id,{field:k,value:""})},availableFields:u,placeholder:"Select field",className:"w-64"}),e.jsxs(t.Select,{value:s.operator,onValueChange:k=>{k==="in"||k==="not in"?c(n,s.id,{operator:k,value:[]}):c(n,s.id,{operator:k,value:""})},children:[e.jsx(t.SelectTrigger,{className:"w-28",children:e.jsx(t.SelectValue,{})}),e.jsx(t.SelectContent,{children:qr(t.getDataType(s.field.dataType)).map(k=>e.jsx(t.SelectItem,{value:k,children:k},k))})]}),t.getDataType(s.field.dataType)==="string"?s.operator==="in"||s.operator==="not in"?x?e.jsxs("div",{className:"flex flex-1 items-center justify-center p-2 text-xs text-gray-500",children:[e.jsx(ce,{className:"mr-2 size-3.5 animate-spin"})," Loading values..."]}):b?e.jsx("div",{className:"flex-1 p-2 text-xs text-red-500",children:"Error loading values"}):e.jsx(Or,{field:s.field,selected:Array.isArray(s.value)&&s.value.every(k=>typeof k=="string")?s.value:[],onChange:k=>c(n,s.id,{value:k}),placeholder:`Select values for ${s.operator}...`,className:"flex-1"}):["contains","startsWith","endsWith"].includes(s.operator)?e.jsx(t.Input$1,{value:typeof s.value=="string"?s.value:"",onChange:k=>c(n,s.id,{value:k.target.value}),className:"flex-1",placeholder:s.operator.charAt(0).toUpperCase()+s.operator.slice(1)+"..."}):e.jsx(Fr,{field:s.field,value:typeof s.value=="string"?s.value:"",onChange:k=>c(n,s.id,{value:k}),placeholder:"Select value...",className:"flex-1"}):t.getDataType(s.field.dataType)==="boolean"?e.jsxs(t.Select,{value:typeof s.value=="boolean"?String(s.value):"",onValueChange:k=>c(n,s.id,{value:k==="true"}),children:[e.jsx(t.SelectTrigger,{className:"flex-1",children:e.jsx(t.SelectValue,{placeholder:"Select value..."})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"true",children:"True"}),e.jsx(t.SelectItem,{value:"false",children:"False"})]})]}):e.jsx(t.Input$1,{value:typeof s.value=="string"||typeof s.value=="number"?s.value:"",onChange:k=>o(n,s.id,"value",k.target.value),className:"flex-1",placeholder:s.operator==="in"||s.operator==="not in"?"value1, value2, value3":"Value"}),e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-7 w-7 flex-shrink-0 p-0",onClick:()=>i(n,s.id),children:e.jsx(t.X,{className:"h-3 w-3"})})]})}function _r({group:s,depth:a,parentGroupId:n,onUpdateGroupOperator:r,onUpdateGroupNegate:o,onRemoveGroup:i,onUpdateCondition:l,onUpdateField:u,onRemoveCondition:c,onReorderConditions:h,onReorderGroups:d,onAddCondition:m,onAddGroup:g,availableFields:p,renderFilterGroup:j,updateConditionFields:x}){const{attributes:b,listeners:f,setNodeRef:k,transform:T,transition:E,isDragging:y}=t.useSortable({id:s.id}),C={transform:t.CSS.Transform.toString(T),transition:E},v=I=>{const{active:D,over:N}=I;if(N&&D.id!==N.id){const F=s.conditions.findIndex(A=>A.id===D.id),O=s.conditions.findIndex(A=>A.id===N.id);F!==-1&&O!==-1&&h(s.id,F,O)}},w=I=>{const{active:D,over:N}=I;if(N&&D.id!==N.id&&n){const F=s.groups.findIndex(A=>A.id===D.id),O=s.groups.findIndex(A=>A.id===N.id);F!==-1&&O!==-1&&d(n,F,O)}};return e.jsxs("div",{ref:k,style:C,className:`rounded-lg ${a>0?"mt-2 border border-gray-200":""} ${y?"z-50 opacity-50":""}`,children:[a>0&&e.jsxs("div",{className:"flex items-center justify-between rounded-t-lg bg-gray-50 p-2",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx("div",{...b,...f,className:"cursor-grab active:cursor-grabbing",children:e.jsx(t.GripVertical,{className:"h-4 w-4 text-gray-400"})}),e.jsx(t.Button,{variant:s.negate?"default":"outline",size:"sm",className:"h-7 px-2 text-xs",onClick:()=>o(s.id,!s.negate),children:"NOT"}),e.jsxs(t.Select,{value:s.logicalOperator,onValueChange:I=>r(s.id,I),children:[e.jsx(t.SelectTrigger,{className:"h-7 w-20",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("span",{className:"text-sm font-medium",children:"Group"})]}),e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-7 w-7 p-0",onClick:()=>n&&i(n,s.id),children:e.jsx(t.Trash2,{className:"h-3 w-3"})})]}),e.jsxs("div",{className:`p-3 ${a>0?"":"px-0"}`,children:[e.jsx(t.DndContext,{sensors:t.useSensors(t.useSensor(t.PointerSensor),t.useSensor(t.KeyboardSensor,{coordinateGetter:t.sortableKeyboardCoordinates})),collisionDetection:t.closestCenter,onDragEnd:v,children:e.jsx(t.SortableContext,{items:s.conditions.map(I=>I.id),strategy:t.verticalListSortingStrategy,children:s.conditions.map((I,D)=>e.jsx(Es,{condition:I,index:D,groupId:s.id,groupLogicalOperator:s.logicalOperator,onUpdateCondition:l,onUpdateField:u,onRemoveCondition:c,onUpdateGroupOperator:r,availableFields:p,updateConditionFields:x},I.id))})}),e.jsx(t.DndContext,{sensors:t.useSensors(t.useSensor(t.PointerSensor),t.useSensor(t.KeyboardSensor,{coordinateGetter:t.sortableKeyboardCoordinates})),collisionDetection:t.closestCenter,onDragEnd:w,children:e.jsx(t.SortableContext,{items:s.groups.map(I=>I.id),strategy:t.verticalListSortingStrategy,children:s.groups.map(I=>j(I,a+1,s.id))})}),e.jsxs("div",{className:"mt-3 flex items-center gap-2",children:[e.jsxs(t.Button,{size:"sm",variant:"outline",className:"h-7 text-xs",onClick:()=>m(s.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"}),"Add Condition"]}),e.jsxs(t.Button,{variant:"outline",size:"sm",className:"h-7 text-xs",onClick:()=>g(s.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"}),"Add Group"]})]})]})]})}function Gr({filters:s,availableFields:a,onSave:n,onClearAll:r,onCancel:o}){const{currentFilters:i,availableFields:l,isLoading:u,addCondition:c,addGroup:h,removeCondition:d,removeGroup:m,updateCondition:g,updateConditionFields:p,updateGroupOperator:j,updateGroupNegate:x,reorderConditions:b,reorderGroups:f,generateSQLPreview:k,hasAnyFilters:T,setCurrentFilters:E}=Dr({initialFilters:s,availableFields:a}),y=t.useSensors(t.useSensor(t.PointerSensor),t.useSensor(t.KeyboardSensor,{coordinateGetter:t.sortableKeyboardCoordinates})),[C,v]=L.useState(!1),w=(N,F,O)=>{const A=S=>S.id===N?{...S,conditions:S.conditions.map(M=>M.id===F?{...M,field:O,dataType:O.dataType}:M)}:{...S,groups:S.groups.map(A)};E(A(i))},I=(N,F=0,O)=>F===0?e.jsx("div",{className:"rounded-lg",children:e.jsxs("div",{className:"p-3 px-0",children:[e.jsx(t.DndContext,{sensors:y,collisionDetection:t.closestCenter,onDragEnd:A=>{const{active:S,over:M}=A;if(M&&S.id!==M.id){const z=N.conditions.findIndex(V=>V.id===S.id),R=N.conditions.findIndex(V=>V.id===M.id);z!==-1&&R!==-1&&b(N.id,z,R)}},children:e.jsx(t.SortableContext,{items:N.conditions.map(A=>A.id),strategy:t.verticalListSortingStrategy,children:N.conditions.map((A,S)=>e.jsx(Es,{condition:A,index:S,groupId:N.id,groupLogicalOperator:N.logicalOperator,onUpdateCondition:g,onUpdateField:w,onRemoveCondition:d,onUpdateGroupOperator:j,availableFields:l,updateConditionFields:p},A.id))})}),e.jsx(t.DndContext,{sensors:y,collisionDetection:t.closestCenter,onDragEnd:A=>{const{active:S,over:M}=A;if(M&&S.id!==M.id){const z=N.groups.findIndex(V=>V.id===S.id),R=N.groups.findIndex(V=>V.id===M.id);z!==-1&&R!==-1&&f(N.id,z,R)}},children:e.jsx(t.SortableContext,{items:N.groups.map(A=>A.id),strategy:t.verticalListSortingStrategy,children:N.groups.map(A=>I(A,F+1,N.id))})}),e.jsxs("div",{className:"mt-3 flex items-center gap-2",children:[e.jsxs(t.Button,{size:"sm",className:"h-7 text-xs",variant:"outline",onClick:()=>c(N.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"}),"Add Condition"]}),C&&e.jsxs(t.Button,{variant:"outline",size:"sm",className:"h-7 text-xs",onClick:()=>h(N.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"}),"Add Group"]})]})]})},N.id):e.jsx(_r,{group:N,depth:F,parentGroupId:O,onUpdateGroupOperator:j,onUpdateGroupNegate:x,onRemoveGroup:m,onUpdateCondition:g,onUpdateField:w,onRemoveCondition:d,onReorderConditions:b,onReorderGroups:f,onAddCondition:c,onAddGroup:h,availableFields:l,renderFilterGroup:I,updateConditionFields:p},N.id),D=ks(s);return e.jsxs("div",{className:"space-y-4",children:[e.jsx(t.Card,{children:e.jsx(t.CardContent,{className:"p-4",children:e.jsxs("div",{className:"space-y-4",children:[u?e.jsxs("div",{className:"flex items-center justify-center p-4",children:[e.jsx("div",{className:"h-5 w-5 animate-spin rounded-full border-2 border-gray-300 border-t-gray-600"}),e.jsx("span",{className:"ml-2 text-sm text-gray-600",children:"Loading columns..."})]}):I(i),e.jsx("div",{className:"mt-4 border-t border-gray-200 pt-4",children:e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.Checkbox,{id:"advanced-mode",checked:C,onCheckedChange:N=>v(!!N)}),e.jsx("label",{htmlFor:"advanced-mode",className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:"Advanced mode (enable grouping)"})]})}),T&&e.jsxs("div",{className:"mt-4 border-t border-gray-200 pt-4",children:[e.jsx("div",{className:"mb-2 text-xs font-medium text-gray-700",children:"SQL WHERE Clause Preview"}),e.jsx("div",{className:"overflow-x-auto rounded-md border bg-gray-50 p-3",children:e.jsx("pre",{className:"whitespace-pre-wrap font-mono text-xs text-gray-800",children:k(i)})})]})]})})}),e.jsxs("div",{className:"flex justify-end gap-2",children:[e.jsx(t.Button,{size:"sm",variant:"outline",onClick:o,children:"Cancel"}),D>0&&e.jsx(t.Button,{variant:"outline",size:"sm",onClick:r,children:"Clear All"}),e.jsx(t.Button,{size:"sm",onClick:()=>n(T?i:null),children:"Apply Filters"})]})]})}function $r({cardId:s,filters:a,onFiltersChange:n,onClearFilters:r,availableFields:o,isOpen:i,onOpenChange:l}){const u=h=>{n(s,h),l(!1)},c=()=>{r(s),l(!1)};return e.jsx(t.Dialog,{open:i,onOpenChange:l,children:e.jsxs(t.DialogContent,{className:"max-h-[80vh] max-w-4xl overflow-y-auto",children:[e.jsxs(t.DialogHeader,{children:[e.jsx(t.DialogTitle,{children:"Card Filters"}),e.jsx(t.DialogDescription,{children:"Add filters to the card to limit the data that is displayed."})]}),e.jsx(Gr,{filters:a,availableFields:o,onSave:u,onCancel:()=>l(!1),onClearAll:c})]})})}function Is(s,a){return`${t.toLabel(a)} of ${t.toLabel(s)}`}function Ds(s,a){return`${s}-${a.qualifiedEntityName}-${a.name}-${Date.now()}`}function Hr({activeCardId:s,sourceFields:a,getFieldsForContainer:n,setFieldsForContainer:r}){const[o,i]=L.useState(null),l=[...a,...n("groupBy"),...n("pivotBy"),...n("metrics"),...n("sortBy")],u=L.useCallback(g=>g.startsWith("card-")?null:g.startsWith("source-")||a.find(p=>p.id===g)?"source":n("groupBy").find(p=>p.id===g)?"groupBy":n("metrics").find(p=>p.id===g)?"metrics":n("pivotBy").find(p=>p.id===g)?"pivotBy":n("sortBy").find(p=>p.id===g)?"sortBy":null,[a,n]),c=(g,p)=>{const j=Ds(p,g),x=t.getDataType(g.dataType),b=x==="date",f={id:j,name:g.name,dataType:g.dataType,label:t.toLabel(g.name),qualifiedEntityName:g.qualifiedEntityName,entityId:g.entityId,entityName:g.entityName,entityType:g.entityType};if(p==="metrics"){const k=x==="number"?"SUM":"COUNT",T=Is(g.label,k);return{...f,role:"metric",label:T,aggregate:k}}return p==="groupBy"?{...f,role:"groupby",...b&&{granularity:"month"}}:p==="pivotBy"?{...f,role:"pivotby"}:p==="sortBy"?{...f,role:"sortby",direction:"asc"}:null},h=L.useCallback(g=>{i(g.active.id)},[]),d=L.useCallback(g=>{const{active:p,over:j}=g;if(!j||!s){i(null);return}const x=p.id,b=j.id,f=u(x),k=u(b)||b;if(f==="source"&&k!=="source"){const T=[...a].find(v=>v.id===x);if(!T){i(null);return}const E=n(k);if(E.some(v=>v.name===T.name&&v.qualifiedEntityName===T.qualifiedEntityName)){i(null);return}const C=c(T,k);i(null),r(k,[...E,C]);return}if(f&&k&&f!=="source"&&k!=="source"&&f!==k){const T=n(f),E=n(k),y=T.find(w=>w.id===x);if(!y){i(null);return}const C=c(y,k);i(null);const v=T.filter(w=>w.id!==x);r(f,v),r(k,[...E,C]);return}if(f&&k&&f===k&&f!=="source"){const T=n(f),E=T.findIndex(C=>C.id===x),y=T.findIndex(C=>C.id===b);if(E!==y){const C=t.arrayMove(T,E,y);r(f,C)}}i(null)},[s,a,n,r,u]),m=o?l.find(g=>g.id===o):null;return{activeId:o,activeField:m,handleDragStart:h,handleDragEnd:d}}const Jr=s=>{const{updateCardConfig:a,updateGroupByColumn:n,updateMetricColumn:r,updatePivotByColumn:o,updateSortByColumn:i,removeGroupByColumn:l,removeMetricColumn:u,removePivotByColumn:c,removeSortByColumn:h}=t.useEditorActions(),d=s==null?void 0:s.id,m=L.useCallback(E=>{if(!(s!=null&&s.config))return[];switch(E){case"groupBy":return(s.config.groupByColumns||[]).map(y=>({id:y.id,name:y.name,dataType:y.dataType,label:y.label!==void 0?y.label:y.name,qualifiedEntityName:y.qualifiedEntityName,entityId:y.entityId,entityName:y.entityName,entityType:y.entityType,dateFormat:y.dateFormat,customFormat:y.customFormat,granularity:y.granularity}));case"metrics":return s.config.metricColumns||[];case"pivotBy":return(s.config.pivotByColumns||[]).map(y=>({id:y.id,name:y.name,dataType:y.dataType,label:y.label!==void 0?y.label:y.name,qualifiedEntityName:y.qualifiedEntityName,entityId:y.entityId,entityName:y.entityName,entityType:y.entityType}));case"sortBy":return(s.config.sortByColumns||[]).map(y=>({id:y.id,name:y.name,dataType:y.dataType,label:y.label!==void 0?y.label:y.name,qualifiedEntityName:y.qualifiedEntityName,entityId:y.entityId,entityName:y.entityName,entityType:y.entityType,direction:y.direction}));case"source":return[];default:return[]}},[s]),g=L.useCallback((E,y)=>{if(d)switch(E){case"groupBy":{a(d,{groupByColumns:y});break}case"metrics":{a(d,{metricColumns:y});break}case"pivotBy":{a(d,{pivotByColumns:y});break}case"sortBy":{a(d,{sortByColumns:y});break}}},[d,a]),p=L.useCallback((E,y,C)=>{if(!d)return;const w=m(E)[y];if(w)switch(E){case"groupBy":n(d,w.id,{label:C});break;case"metrics":r(d,w.id,{label:C});break;case"pivotBy":o(d,w.id,{label:C});break;case"sortBy":i(d,w.id,{label:C});break}},[d,m,n,r,o,i]),j=L.useCallback((E,y)=>{if(!d)return;const v=m("metrics")[E];v&&r(d,v.id,{aggregate:y,label:Is(v.name,y)})},[d,m,r]),x=L.useCallback((E,y,C)=>{if(!d)return;const w=m("groupBy")[E];if(!w)return;const I={dateFormat:y};y==="custom"&&C?I.customFormat=C:I.customFormat=void 0,n(d,w.id,I)},[d,m,n]),b=L.useCallback((E,y)=>{if(!d)return;const v=m("groupBy")[E];v&&n(d,v.id,{granularity:y})},[d,m,n]),f=L.useCallback((E,y)=>{if(!d)return;const v=m("metrics")[E];v&&r(d,v.id,{aliasTemplate:y})},[d,m,r]),k=L.useCallback((E,y)=>{if(console.log("handleValueAliasesChange",E,y),!d)return;console.log("handleValueAliasesChange",E,y);const v=m("metrics")[E];v&&(console.log("handleValueAliasesChange",y),r(d,v.id,{valueAliases:y}))},[d,m,r]),T=L.useCallback((E,y)=>{if(!d)return;const v=m(E)[y];if(v)switch(E){case"groupBy":l(d,v.id);break;case"metrics":u(d,v.id);break;case"pivotBy":c(d,v.id);break;case"sortBy":h(d,v.id);break}},[d,m,l,u,c,h]);return{getFieldsForContainer:m,setFieldsForContainer:g,updateLabel:p,handleAggregationChange:j,handleDateFormatChange:x,handleGranularityChange:b,handleAliasTemplateChange:f,handleValueAliasesChange:k,removeField:T}};function Ur({activeView:s,onViewChange:a}){return e.jsx(t.Tabs,{value:s,onValueChange:n=>a(n),children:e.jsxs(t.TabsList,{className:"h-9 w-fit",children:[e.jsx(t.TabsTrigger,{value:"table",className:"text-xs",children:"Results"}),e.jsx(t.TabsTrigger,{value:"chart",className:"text-xs",children:"Chart"}),e.jsx(t.TabsTrigger,{value:"sql",className:"text-xs",children:"SQL"})]})})}const Yr=[{value:"10",label:"Limit 10"},{value:"20",label:"Limit 20"},{value:"50",label:"Limit 50"},{value:"100",label:"Limit 100"},{value:"200",label:"Limit 200"},{value:"500",label:"Limit 500"},{value:"1000",label:"Limit 1000"}];function Kr(){var c,h;const s=t.useEditorStore(d=>d.card),{updateRowLimit:a}=t.useEditorActions(),[n,r]=L.useState(!1),[o,i]=L.useState(""),l=d=>{if(d==="custom"){r(!0);return}r(!1),a(s.id,parseInt(d))},u=d=>{const m=d.target.value;i(m),m&&!isNaN(parseInt(m))&&a(s.id,parseInt(m))};return e.jsx("div",{className:"flex items-center gap-2",children:n?e.jsx(t.Input,{type:"number",value:o,onChange:u,className:"h-9 w-28",placeholder:"Enter limit",min:1}):e.jsxs(t.Select,{value:((h=(c=s.config)==null?void 0:c.rowLimit)==null?void 0:h.toString())||"100",onValueChange:l,children:[e.jsx(t.SelectTrigger,{className:"h-9 w-28",children:e.jsx(t.SelectValue,{placeholder:"Select limit"})}),e.jsx(t.SelectContent,{children:Yr.map(d=>e.jsx(t.SelectItem,{value:d.value,children:d.label},d.value))})]})})}function Qr({activeView:s,onViewChange:a,showDebug:n,onDebugToggle:r,onAccept:o,onClear:i,onAdvancedToggle:l,onFiltersClick:u,filterCount:c,activeCard:h,columns:d,columnsLoading:m,columnsError:g}){var w;const p=t.useEditorStore(I=>I.card),{updateCardConfig:j}=t.useEditorActions(),x=t.useEditorStore(I=>I.showAIDialog),{data:b,errorMessage:f,isPending:k,isLoading:T,isFetching:E}=t.useDashboardCardQuery(h);function y(){return e.jsx("div",{className:"border-b border-border bg-background p-4",children:e.jsxs("div",{className:"space-y-4",children:[e.jsxs("div",{children:[e.jsx("h3",{className:"mb-2 text-sm font-medium text-gray-700",children:"Active Card Config"}),e.jsx("pre",{className:"max-h-40 overflow-auto rounded border bg-background p-3 text-xs text-gray-800",children:JSON.stringify(p.config||{},null,2)})]}),e.jsxs("div",{children:[e.jsx("h3",{className:"mb-2 text-sm font-medium text-gray-700",children:"Card Data Source State"}),e.jsx("pre",{className:"max-h-40 overflow-auto rounded border bg-background p-3 text-xs text-gray-800",children:JSON.stringify(h.dataSource||{},null,2)})]}),e.jsxs("div",{children:[e.jsxs("h3",{className:"mb-2 text-sm font-medium text-gray-700",children:["Columns (",d.length,")"]}),e.jsx("pre",{className:"max-h-40 overflow-auto rounded border bg-background p-3 text-xs text-gray-800",children:m?"Loading...":g?"Error loading columns":JSON.stringify(d.slice(0,5),null,2)})]})]})})}const C=I=>{if(!p.config)return;if(!I.length){j(p.id,{...p.config,sortByColumns:[]});return}const D=p.config,N=I.map(({id:F,desc:O})=>{var z,R;const A=(z=D.metricColumns)==null?void 0:z.find(V=>V.label===F),S=(R=D.groupByColumns)==null?void 0:R.find(V=>V.label===F),M=A||S;return M?{id:Ds("sortBy",M),name:M.name,dataType:M.dataType,label:M.label,qualifiedEntityName:M.qualifiedEntityName,entityId:M.entityId,entityName:M.entityName,entityType:M.entityType,role:"sortby",direction:O?"desc":"asc"}:null}).filter(F=>F!==null);j(p.id,{...D,sortByColumns:N})},v=L.useMemo(()=>{var I,D;return(D=(I=p.config)==null?void 0:I.sortByColumns)==null?void 0:D.map(N=>({id:N.label,desc:N.direction==="desc"}))},[(w=p.config)==null?void 0:w.sortByColumns]);return e.jsxs("div",{className:"flex w-0 grow flex-col",children:[e.jsx(t.ExplorerHeader,{showDebug:n,onDebugToggle:r,onAccept:o,onClear:i,onAdvancedToggle:l,onFiltersClick:u,filterCount:c}),n&&y(),e.jsxs("div",{className:"group/visualization flex max-w-full grow flex-col",children:[e.jsxs("div",{className:"z-50 flex items-center gap-2 px-6",children:[e.jsxs("div",{className:"flex items-center justify-between gap-2",children:[e.jsx(Ur,{activeView:s,onViewChange:a}),e.jsx(Kr,{})]}),u&&e.jsxs(t.Button,{variant:"outline",size:"sm",className:"gap-1",onClick:u,children:[e.jsx(ft,{className:"h-3.5 w-3.5"}),c>0&&e.jsx("span",{className:"ml-1 rounded-full bg-blue-100 px-1.5 py-0.5 text-xs text-blue-800",children:c})]}),e.jsxs("div",{className:t.cn("flex grow items-center justify-end",{"justify-between":x}),children:[s==="chart"&&x&&e.jsx(ps,{variant:"outline"}),e.jsx("div",{className:"opacity-0 transition-opacity group-hover/visualization:opacity-100",children:s==="chart"&&e.jsx(fs,{})})]})]}),e.jsxs("div",{className:"flex grow flex-col",children:[s==="chart"&&e.jsx("div",{className:"flex grow flex-col pb-6",children:T||E?e.jsx("div",{className:"m-auto flex h-10 w-10 items-center justify-center rounded-md bg-muted",children:e.jsx(ce,{className:"h-8 w-8 animate-spin text-muted-foreground"})}):e.jsx(gs,{})}),s==="table"&&(b==null?void 0:b.records)&&e.jsx("div",{className:"flex h-full min-h-0 max-w-full flex-1 grow basis-0 p-6",children:e.jsx(t.TableVisual,{card:h,data:b==null?void 0:b.records,onSortChange:C,sortState:v})}),s==="sql"&&e.jsx("div",{className:"p-6",children:e.jsxs("div",{className:"rounded-md border bg-background p-4",children:[e.jsx("h3",{className:"mb-3 text-sm font-medium text-gray-700",children:"Generated SQL Query"}),e.jsx(os,{sql:b==null?void 0:b.sql,error:f})]})})]})]})]})}function Wr({activeField:s}){const[a,n]=L.useState(!0);return L.useEffect(()=>{s&&n(!0)},[s]),s?e.jsxs("div",{className:`flex items-center gap-2 rounded-lg border border-blue-500 bg-background p-2 shadow-lg transition-all duration-200 ${a?"scale-100 opacity-100":"scale-95 opacity-0"}`,children:[e.jsx(t.GripVertical,{className:"h-3 w-3 text-gray-400"}),e.jsx(ws,{dataType:s.dataType}),e.jsx("span",{className:"text-sm dark:text-muted-foreground",children:s.name})]}):null}const Xr=()=>{const s=console.error;console.error=(...r)=>{r.length>0&&typeof r[0]=="string"&&r[0].includes("ResizeObserver loop completed with undelivered notifications")||s.apply(console,r)};const a=r=>{if(r.message&&(r.message.includes("ResizeObserver loop completed with undelivered notifications")||r.message.includes("ResizeObserver loop limit exceeded")))return r.preventDefault(),r.stopPropagation(),!1},n=r=>{var o;if((o=r.reason)!=null&&o.message&&(r.reason.message.includes("ResizeObserver loop completed with undelivered notifications")||r.reason.message.includes("ResizeObserver loop limit exceeded")))return r.preventDefault(),!1};return window.addEventListener("error",a,!0),window.addEventListener("unhandledrejection",n,!0),()=>{console.error=s,window.removeEventListener("error",a,!0),window.removeEventListener("unhandledrejection",n,!0)}};function Zr(){var _,H;const[s,a]=L.useState("chart"),[n,r]=L.useState(!1),[o,i]=L.useState(!1),l=t.useEditorStore(Y=>Y.showAIDialog),{setCardType:u}=t.useEditorActions(),c=t.useEditorStore(Y=>Y.card.type);L.useEffect(()=>Xr(),[]);const h=()=>{console.log("Accept clicked - would save/apply current configuration")},d=()=>{console.log("Clear clicked - would reset all configurations")},m=()=>{console.log("Advanced mode toggled")},g=()=>{i(!0)},p=Y=>{u(Y)},j=t.useEditorStore(Y=>Y.frame),x=t.useEditorStore(Y=>Y.card);t.useEditorStore(Y=>Y.activeTabCardId),t.useEditorStore(Y=>Y.actions.getAvailableFields);const{addCard:b,removeCard:f,updateCard:k,setActiveCard:T,updateFilters:E}=t.useEditorActions(),{columns:y=[],isLoading:C,error:v}=Me(),w=t.useSensors(t.useSensor(t.PointerSensor,{activationConstraint:{distance:8}})),I=x,{getFieldsForContainer:D,setFieldsForContainer:N,updateLabel:F,handleAggregationChange:O,handleDateFormatChange:A,handleGranularityChange:S,handleAliasTemplateChange:M,handleValueAliasesChange:z,removeField:R}=Jr(I),{activeField:V,handleDragStart:B,handleDragEnd:K}=Hr({activeCardId:j.activeCardId,sourceFields:y,getFieldsForContainer:D,setFieldsForContainer:N}),J=(Y,Z)=>{Z&&E(Y,Z)},$=Y=>{var Z;k(Y,{config:{...(Z=j.cards.find(de=>de.id===Y))==null?void 0:Z.config,filters:void 0}})},U=y,q=Y=>{if(!Y)return 0;let Z=Y.conditions.length;return Y.groups.forEach(de=>{Z+=q(de)}),Z},P=q(((_=I==null?void 0:I.config)==null?void 0:_.filters)||null);return e.jsxs(t.DndContext,{sensors:w,collisionDetection:t.closestCenter,onDragStart:B,onDragEnd:K,children:[e.jsxs("div",{className:"flex h-full grow",children:[e.jsx(br,{}),!l&&e.jsx(Ir,{selectedChart:c,onChartChange:p,groupByFields:D("groupBy"),pivotByFields:D("pivotBy"),metricsFields:D("metrics"),sortByFields:D("sortBy"),onRemoveField:R,onLabelChange:F,onAggregationChange:O,onDateFormatChange:A,onGranularityChange:S,onAliasTemplateChange:M,onValueAliasesChange:z}),e.jsx(Qr,{selectedChart:c,activeView:s,onViewChange:a,showDebug:n,onDebugToggle:()=>r(!n),onAccept:h,onClear:d,onAdvancedToggle:m,onFiltersClick:g,filterCount:P,activeCard:I,dataSourceState:x.dataSource||t.EMPTY_DATA_SOURCE,columns:y,columnsLoading:C,columnsError:v,getFieldsForContainer:D,cards:j.cards,activeCardId:j.activeCardId,addCard:b,setActiveCard:T})]}),I&&e.jsx($r,{cardId:I.id,filters:((H=I.config)==null?void 0:H.filters)||null,onFiltersChange:J,onClearFilters:$,availableFields:U,isOpen:o,onOpenChange:i}),e.jsx(t.DragOverlay,{dropAnimation:null,children:e.jsx(Wr,{activeField:V||null})})]})}function eo({authToken:s,onSave:a,onClose:n}){const r=L.useRef(null),o=t.useEditorStore(k=>k.showAIDialog),i=t.useEditorStore(k=>k.isDevMode),{setAuthToken:l}=t.useDashboardActions(),{setShowAIDialog:u,setOnSave:c,setOnClose:h}=t.useEditorActions(),{handleDragOver:d,handleDragEnd:m,handleDragStart:g,handleDragCancel:p,sensors:j}=Jn();L.useEffect(()=>{a&&c(a),n&&h(n)},[a,c,n,h]),L.useEffect(()=>{s&&s.accessToken&&l(s)},[s,l]),L.useEffect(()=>{var k,T;o?((k=r.current)==null||k.resize(40),u(!0)):(u(!1),(T=r.current)==null||T.resize(0))},[o,u]);function x(k){k<1?u(!1):o||u(!0)}function b(){return e.jsxs(e.Fragment,{children:[e.jsx(rs,{type:"main"}),e.jsxs(t.ResizablePanelGroup,{"data-content":"editor-main",className:"grow",direction:"horizontal",children:[e.jsx(t.ResizablePanel,{className:"min-w-[510px] rounded-none",children:e.jsx(ir,{})}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{"data-role":"editor-assistant-panel",ref:r,onResize:x,defaultSize:0,children:e.jsx(Gt,{})})]})]})}function f(){return e.jsxs(t.ResizablePanelGroup,{"data-content":"explorer",className:"flex grow",direction:"horizontal",children:[e.jsx(t.ResizablePanel,{className:"min-w-[510px] grow rounded-none",children:e.jsx(Zr,{})}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{"data-role":"editor-assistant-panel",ref:r,onResize:x,defaultSize:0,children:e.jsx(Gt,{})})]})}return e.jsx(t.ErrorBoundary,{FallbackComponent:t.Fallback,children:i?e.jsx(t.DndContext,{sensors:j,onDragStart:g,onDragEnd:m,onDragOver:d,onDragCancel:p,children:e.jsx("section",{className:"isolate flex h-full grow","data-content":"editor-panel",children:b()})}):f()})}function to(){t.useDashboardStore(l=>l.selectedCardId);const s=t.useDashboardStore(l=>l.selectedSheetId),{setIsVisualEditing:a}=t.useDashboardStore(l=>l.actions),n=t.useDashboardStore(l=>l.isVisualEditing),r=t.useDashboardStore(l=>l.actions.updateFrame);function o(l){s&&(r(s,l),a(!1))}function i(){a(!1)}return e.jsx("div",{role:"editor-container",className:t.cn("flex grow",{"max-h-0 overflow-hidden":!n}),children:e.jsx(eo,{onSave:o,onClose:i})})}function so(){const s=t.useEditorStore(i=>i.selectedDatabaseName),a=t.useEditorStore(i=>i.selectedTableName),n=t.useDashboardStore(i=>i.dashboard.filters)||[],{columns:r}=t.useEditorAside(),{assignFilter:o}=Cs();return e.jsx(t.ScrollArea,{className:"flex-1 basis-0 flex-col px-3",children:r==null?void 0:r.map(i=>{const l=n==null?void 0:n.find(u=>u.column===t.fmt(i.column_name)&&u.table===a&&u.database===s);return e.jsx("div",{onClick:()=>o(i),className:t.cn("group flex cursor-pointer items-center justify-between border border-dashed border-background px-3 py-[6px] text-sm transition-colors hover:bg-muted/50",{"bg-muted":l}),children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(Nt,{column:i}),e.jsx("span",{children:i.column_name})]})},i.column_name)})})}function no(){t.useDashboardStore(a=>a.showFilters);const s=t.useDashboardStore(a=>a.actions.setShowFilters);return e.jsxs("section",{className:"relative flex min-w-[320px] grow flex-col border-l px-1",children:[e.jsxs("div",{className:"mt-4 flex items-center justify-between gap-2 px-3",children:[e.jsx(t.Label,{className:"px-2 text-lg",children:"Filters"}),e.jsx(t.Button,{onClick:()=>s(!1),className:"h-7 w-7 p-0",variant:"ghost",children:e.jsx(t.Cross2Icon,{})})]}),e.jsx("div",{className:"flex grow",children:e.jsx(rs,{type:"filter",ColumnsComponent:()=>e.jsx(so,{})})})]})}function ao(){const s=t.useDashboardStore(r=>r.dashboard.filters),a=t.useDashboardStore(r=>r.theme),n=s==null?void 0:s.filter(r=>r.hide);return n!=null&&n.length?e.jsx("div",{className:t.cn("mb-1 flex items-center gap-2 border-y px-0.5 pb-0.5",{"bg-[repeating-linear-gradient(45deg,_#ffffff_0_3px,_#f3f3f3_3px_6px)]":a==="light","bg-[repeating-linear-gradient(45deg,_#18171d_0_3px,_#272729_3px_6px)]":a==="dark"}),children:n==null?void 0:n.map(r=>e.jsxs("div",{className:"flex min-w-[250px] max-w-fit flex-col gap-1 p-2",children:[e.jsx(t.FilterHeader,{filter:r}),e.jsx(t.FilterComponent,{filter:r})]},r.id))}):null}function ro(){const s=t.useDashboardStore(r=>r.showFilters),a=t.useDashboardStore(r=>r.isVisualEditing),n=t.useDashboardStore(r=>r.isDashboardEditing);return e.jsxs("div",{role:"dashboard-plus-main",className:t.cn("",{"max-h-0 overflow-hidden":a,"flex grow overflow-auto":!a}),children:[e.jsxs("section",{className:"flex grow flex-col",children:[n&&e.jsx(ao,{}),e.jsx(t.DashboardTabs,{})]}),s&&e.jsx("div",{role:"filter-aside-container",className:"flex",children:e.jsx(no,{})})]})}function oo(){const s=t.useDashboardStore(o=>o.dashboard),a=t.useDashboardStore(o=>o.actions.setDashboard),n=t.useDashboardStore(o=>o.showDashboardJSON),r=t.useDashboardStore(o=>o.actions.setShowDashboardJSON);return e.jsxs("div",{className:t.cn("relative p-2",{hidden:!n}),children:[e.jsxs(t.Button,{variant:"secondary",size:"sm",className:"absolute right-2 top-2 z-10 h-8",onClick:()=>r(!1),children:[e.jsx(t.X,{className:"mr-2 h-4 w-4"}),"Close"]}),e.jsx(t.de,{onChange:o=>{if(o)try{JSON.parse(o),a(JSON.parse(o))}catch{}},defaultLanguage:"json",className:"h-[550px] overflow-y-auto",value:JSON.stringify(s,null,2),options:{minimap:{enabled:!1},glyphMargin:!1,wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:12,renderLineHighlight:"none"}})]})}function io({showControls:s=!1,showFooter:a=!0,...n}){return e.jsx(t.ErrorBoundary,{FallbackComponent:t.Fallback,children:e.jsxs(t.SemaphorContextProvider,{dashboardProps:n,children:[e.jsx(t.$e,{}),e.jsxs(t.UXProvider,{children:[e.jsx(oo,{}),e.jsxs(t.DashboardPanel,{...n,children:[s&&e.jsx(qn,{}),e.jsx(to,{}),e.jsx(ro,{})]})]})]})})}exports.DashboardPlus=io;exports.ScheduleDashboard=ns;exports.SelectComponent=ve;exports.cleanCard=es;exports.downloadPdf=ss;exports.getDashbaordStateWithoutData=Ct;
405
+ ON ${T}`}),x};return l.length<2?null:e.jsx(e.Fragment,{children:e.jsx("div",{className:"space-y-4",children:e.jsxs("div",{className:"flex items-center justify-between",children:[r.joins.length>0&&e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.TooltipProvider$1,{children:e.jsxs(t.Tooltip,{children:[e.jsx(t.TooltipTrigger,{asChild:!0,children:e.jsxs(t.Button,{variant:"outline",size:"sm",className:"h-6 text-xs font-semibold",onClick:()=>o(!0),children:[e.jsx(t.Link,{className:t.cn("mr-1 h-3 w-3",{"text-blue-500":r.joins.length>0,"text-gray-500":r.joins.length===0})}),"Join",r.joins.length>1?"s":""," (",r.joins.length,")"]})}),e.jsx(t.TooltipContent,{side:"right",className:"max-w-md overflow-hidden p-0",children:e.jsx(jr,{joins:r.joins,baseEntityId:r.baseEntity.name,availableDataSources:l,generateSQLPreview:d})})]})}),e.jsx($t,{open:i,onOpenChange:o,joinPlan:r,availableDataSources:l,onSave:u,onCancel:h,onRemove:c,children:e.jsx("div",{})})]}),r.joins.length===0&&e.jsx($t,{open:i,onOpenChange:o,joinPlan:r,availableDataSources:l,onSave:u,onCancel:h,onRemove:c,children:e.jsxs(t.Button,{onClick:()=>o(!0),variant:"outline",className:"h-6 text-xs font-semibold",children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"}),"Configure Join"]})})]})})})}function br(){const[s,a]=L.useState(!1),[n,r]=L.useState(!0),i=t.useEditorStore(c=>c.card.dataSource),{updateDataSource:o}=t.useEditorActions(),l={connectionId:"",connectionType:"",mode:"database",selectedEntities:[]},u={...l,...i,selectedEntities:(i==null?void 0:i.selectedEntities)||[]};return e.jsxs("div",{className:"flex w-[325px] flex-col border-r bg-background",children:[e.jsxs("div",{onMouseEnter:()=>r(!0),onMouseLeave:()=>r(!1),children:[e.jsx("div",{className:t.cn("p-4 px-6",{"pb-0":!n}),children:e.jsxs("div",{className:"flex w-full items-center justify-between",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Database,{className:"h-5 w-5 text-cyan-600"}),e.jsx("h2",{className:"font-semibold text-gray-900",children:"Data Source"})]}),e.jsxs(t.Button,{size:"sm",variant:"outline",className:"h-7",onClick:()=>a(!0),children:[e.jsx(t.Plus,{className:"mr-1 h-3.5 w-3.5"}),"Add"]})]})}),e.jsxs("div",{className:`overflow-hidden px-6 ${n?"max-h-96 space-y-4":"max-h-0 py-0 opacity-0"}`,children:[u.selectedEntities.length>0&&e.jsxs("div",{className:"flex flex-wrap gap-1",children:[u.selectedEntities.slice(0,3).map((c,h)=>e.jsxs(t.Badge,{variant:"secondary",className:"group relative cursor-pointer pr-6 text-xs transition-colors hover:border-red-200 hover:bg-red-50 dark:hover:border-red-800 dark:hover:bg-red-950",children:[c.name,e.jsx("button",{onClick:d=>{d.stopPropagation();const m=u.selectedEntities.filter(g=>!(g.name===c.name&&g.type===c.type));o({...l,...i,selectedEntities:m})},className:"absolute right-1 top-1/2 -translate-y-1/2 rounded-full p-0.5 opacity-0 transition-opacity hover:bg-red-100 group-hover:opacity-100",children:e.jsx(t.X,{className:"h-2.5 w-2.5 text-red-500"})})]},`${c.type}-${c.name}-${h}`)),u.selectedEntities.length>3&&e.jsxs(t.Badge,{variant:"outline",className:"text-xs",children:["+",u.selectedEntities.length-3," more"]})]}),e.jsx(yr,{})]})]}),e.jsx(pr,{}),e.jsx(t.DataSourceDialog,{incomingSelectedEntities:(i==null?void 0:i.selectedEntities)||[],dialogMode:"dataSource",open:s,onOpenChange:a,dataSource:u,fallbackDataSource:l})]})}const vr=[{id:"table",icon:He,label:"Table"},{id:"bar",icon:Ge,label:"Bar Chart"},{id:"line",icon:$e,label:"Line Chart"},{id:"stackedBar",icon:dt,label:"Stacked Bar Chart"},{id:"stackedLine",icon:It,label:"Stacked Line Chart"},{id:"scatter",icon:xt,label:"Scatter Chart"},{id:"bubble",icon:kt,label:"Bubble Chart"},{id:"pie",icon:ht,label:"Pie Chart"},{id:"doughnut",icon:pt,label:"Doughnut Chart"},{id:"funnel",icon:Et,label:"Funnel Chart"},{id:"radar",icon:yt,label:"Radar Chart"},{id:"polarArea",icon:wt,label:"Polar Area Chart"},{id:"tornado",icon:vt,label:"Tornado Chart"},{id:"range",icon:mt,label:"Range Chart"},{id:"kpi",icon:Dt,label:"KPI"},{id:"text",icon:Jt,label:"Text"},{id:"map",icon:jt,label:"Map"},{id:"custom",icon:bt,label:"Custom"}];function Nr({selectedChart:s,onChartChange:a}){const{setCardType:n,setCardPreferences:r,setIsDevMode:i}=t.useEditorStore(h=>h.actions),{setCardCustomCfg:o,setCustomCardPreferences:l,setQueryConfig:u}=t.useEditorActions();function c(h){o(null),r({}),n(h),["kpi","custom","text","map"].includes(h)&&(i(!0),u(void 0)),a(h)}return e.jsx("div",{className:"mb-6",children:e.jsxs(t.Select,{value:s,onValueChange:c,children:[e.jsx(t.SelectTrigger,{className:"w-full",children:e.jsx(t.SelectValue,{placeholder:"Select chart type"})}),e.jsx(t.SelectContent,{children:vr.map(h=>{const d=h.icon;return e.jsx(t.SelectItem,{value:h.id,className:"flex items-center gap-2",children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(d,{className:"h-4 w-4"}),e.jsx("span",{children:h.label})]})},h.id)})})]})})}const ws=({dataType:s})=>{const a=t.getDataType(s);return a==="string"?e.jsx("span",{className:"flex h-4 w-4 items-center justify-center rounded-sm bg-blue-500 text-xs text-white",children:"T"}):a==="number"?e.jsx("span",{className:"flex h-4 w-4 items-center justify-center rounded-sm bg-green-500 text-xs text-white",children:"#"}):a==="date"?e.jsx("span",{className:"flex h-4 w-4 items-center justify-center rounded-sm bg-purple-500 text-xs text-white",children:"D"}):a==="boolean"?e.jsx("span",{className:"flex h-4 w-4 items-center justify-center rounded-sm bg-orange-500 text-xs text-white",children:"B"}):e.jsx("span",{className:"flex h-4 w-4 items-center justify-center rounded-sm bg-gray-500 text-xs text-white",children:"?"})};function Cr({label:s,onLabelChange:a}){const[n,r]=L.useState(s??""),[i,o]=L.useState(!1);return e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Display Label"}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Input$1,{placeholder:"Display label...",value:i?n:s??"",onChange:l=>{r(l.target.value),o(!0)},onFocus:()=>o(!0),onClick:l=>l.stopPropagation(),className:"h-8 text-xs",onPointerDown:l=>l.stopPropagation(),onKeyDown:l=>{l.stopPropagation(),l.key==="Enter"&&i&&n!==(s??"")?(a(n),o(!1)):l.key==="Escape"&&(r(s??""),o(!1))},"aria-label":"Edit display label"}),i&&n!==(s??"")&&e.jsxs(e.Fragment,{children:[e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Confirm label",onClick:()=>{a(n),o(!1)},children:e.jsx(t.Check,{className:"h-4 w-4 text-green-600"})}),e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Cancel label edit",onClick:()=>{r(s??""),o(!1)},children:e.jsx(t.X,{className:"h-4 w-4 text-gray-400"})})]})]})]})}function Sr({aliasTemplate:s,onAliasTemplateChange:a}){var c;const[n,r]=L.useState(s),[i,o]=L.useState(!1),l=(c=t.useEditorStore(h=>{var d;return(d=h.card.config)==null?void 0:d.pivotByColumns}))==null?void 0:c[0],u=l?`e.g. Min Sales in {{${l.name}}}`:"e.g. Min Sales in {{region}}";return e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Pivot Alias Template"}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Input$1,{placeholder:u,value:i?n:s,onChange:h=>{r(h.target.value),o(!0)},onFocus:()=>o(!0),onPointerDown:h=>h.stopPropagation(),className:"h-8 text-xs",onKeyDown:h=>{h.key==="Enter"&&i&&n!==s?(a(n),o(!1)):h.key==="Escape"&&(r(s),o(!1))},"aria-label":"Edit alias template"}),i&&n!==s&&e.jsxs(e.Fragment,{children:[e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Confirm alias template",onClick:()=>{a(n),o(!1)},children:e.jsx(t.Check,{className:"h-4 w-4 text-green-600"})}),e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Cancel alias template edit",onClick:()=>{r(s),o(!1)},children:e.jsx(t.X,{className:"h-4 w-4 text-gray-400"})})]})]})]})}function wr({valueAliases:s,onValueAliasesChange:a}){const[n,r]=L.useState(null),[i,o]=L.useState(""),[l,u]=L.useState(""),c=()=>{a({...s,"":""})},h=m=>{const g={...s};delete g[m],a(g)},d=m=>{const g={...s};delete g[m],g[i]=l,a(g),r(null)};return e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Pivot Value Aliases"}),e.jsxs("div",{className:"space-y-2",children:[Object.entries(s).map(([m,g],p)=>e.jsx("div",{className:"flex items-center gap-2",children:n===m?e.jsxs(e.Fragment,{children:[e.jsx(t.Input$1,{placeholder:"Value key",value:i,onChange:j=>o(j.target.value),className:"h-8 w-24 text-xs",onPointerDown:j=>j.stopPropagation(),onKeyDown:j=>{j.key==="Enter"?d(m):j.key==="Escape"&&r(null)},"aria-label":"Edit value alias key"}),e.jsx(t.Input$1,{placeholder:"Alias label",value:l,onChange:j=>u(j.target.value),className:"h-8 w-24 text-xs",onPointerDown:j=>j.stopPropagation(),onKeyDown:j=>{j.key==="Enter"?d(m):j.key==="Escape"&&r(null)},"aria-label":"Edit value alias label"}),e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Confirm value alias edit",onClick:()=>d(m),children:e.jsx(t.Check,{className:"h-4 w-4 text-green-600"})}),e.jsx(t.Button,{variant:"ghost",size:"icon",className:"h-6 w-6 p-0","aria-label":"Cancel value alias edit",onClick:()=>r(null),children:e.jsx(t.X,{className:"h-4 w-4 text-gray-400"})})]}):e.jsxs(e.Fragment,{children:[e.jsx(t.Input$1,{placeholder:"Value key",value:m,className:"h-8 w-24 text-xs",readOnly:!0,onClick:()=>{r(m),o(m),u(g)},"aria-label":"Edit value alias key"}),e.jsx(t.Input$1,{placeholder:"Alias label",value:g,className:"h-8 w-24 text-xs",readOnly:!0,onClick:()=>{r(m),o(m),u(g)},"aria-label":"Edit value alias label"}),e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-8 w-8 p-0",onClick:()=>h(m),"aria-label":"Remove value alias",children:e.jsx(t.X,{className:"h-3 w-3"})})]})},m+p)),e.jsxs(t.Button,{variant:"outline",size:"sm",className:"mt-1 h-8 text-xs",onClick:c,children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"})," Add Value Alias"]})]})]})}function kr({field:s,zone:a,onRemove:n,onLabelChange:r,sortDirection:i,onSortDirectionChange:o,onAliasTemplateChange:l,onValueAliasesChange:u,onAggregationChange:c,onDateFormatChange:h,onGranularityChange:d,hasPivotColumns:m=!1}){const{attributes:g,listeners:p,setNodeRef:j,transform:x,transition:b,isDragging:f}=t.useSortable({id:s.id}),[k,T]=L.useState(!1),[E,y]=L.useState(s.dateFormat||"YYYY-MM-DD"),[N,v]=L.useState(s.customFormat||""),[w,I]=L.useState(!!s.customFormat),[D,C]=L.useState(s.granularity||"day"),[F,O]=L.useState(s.aliasTemplate||""),[A,S]=L.useState(s.valueAliases||{}),M=q=>{q==="custom"?I(!0):(I(!1),y(q),a==="groupBy"&&h&&h(q,""))},B=q=>{v(q),a==="groupBy"&&h&&h("custom",q)},R=q=>{C(q),a==="groupBy"&&d&&d(q)},P=q=>{O(q),l&&l(q)},z=q=>{S(q),u&&u(q)},K={transform:t.CSS.Transform.toString(x),transition:b},J=t.getDataType(s.dataType),$=J==="date",U=[{value:"YYYY-MM-DD",label:"2024-01-15 (YYYY-MM-DD)"},{value:"MM/DD/YYYY",label:"01/15/2024 (MM/DD/YYYY)"},{value:"DD/MM/YYYY",label:"15/01/2024 (DD/MM/YYYY)"},{value:"MMMM DD, YYYY",label:"January 15, 2024 (MMMM DD, YYYY)"},{value:"MMM DD, YYYY",label:"Jan 15, 2024 (MMM DD, YYYY)"},{value:"DD MMM YYYY",label:"15 Jan 2024 (DD MMM YYYY)"},{value:"YYYY-MM",label:"2024-01 (YYYY-MM)"},{value:"MMMM YYYY",label:"January 2024 (MMMM YYYY)"},{value:"custom",label:"Custom Format..."}];return e.jsxs("div",{ref:j,style:K,...g,...p,className:`group flex w-full flex-col gap-2 rounded border border-border bg-background p-2 transition-all hover:shadow-sm dark:border-gray-800 ${f?"z-50 scale-95 opacity-50":"border-slate-200"} ${a==="filters"?"cursor-default":"cursor-move"}`,children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.GripVertical,{className:"h-3 w-3"}),e.jsx(ws,{dataType:J}),e.jsx("span",{className:"max-w-[180px] flex-1 overflow-hidden truncate text-sm",children:s.label||s.name}),a!=="sortBy"&&e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-6 w-6 p-0 opacity-0 group-hover:opacity-100",onClick:q=>{q.stopPropagation(),T(!k)},children:e.jsx(t.ChevronDown,{className:`h-3 w-3 transition-transform ${k?"rotate-180":""}`})}),a==="sortBy"&&e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-6 w-6 p-0 group-hover:opacity-100",onClick:q=>{q.stopPropagation(),console.log("DraggableField - Current sortDirection:",i);const V=i==="asc"?"desc":"asc";console.log("DraggableField - New direction to set:",V),o(V)},children:i==="asc"?e.jsx(_e,{className:"h-3 w-3"}):e.jsx(qe,{className:"h-3 w-3"})}),e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-6 w-6 p-0 opacity-0 group-hover:opacity-100",onClick:q=>{q.stopPropagation(),n()},children:e.jsx(t.X,{className:"h-3 w-3"})})]}),k&&e.jsxs("div",{className:"space-y-3",children:[e.jsx("span",{className:"flex-1 overflow-hidden truncate px-0.5 text-xs text-gray-500",children:`${s.entityName}.${s.name}`}),a!=="pivotBy"&&e.jsx(Cr,{label:s.label??"",onLabelChange:r}),$&&a!=="groupBy"&&e.jsx("div",{className:"space-y-1",children:e.jsxs(t.Select,{defaultValue:"day",children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full text-xs",children:e.jsx(t.SelectValue,{placeholder:"Select granularity..."})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"day",children:"Day"}),e.jsx(t.SelectItem,{value:"week",children:"Week"}),e.jsx(t.SelectItem,{value:"month",children:"Month"}),e.jsx(t.SelectItem,{value:"quarter",children:"Quarter"}),e.jsx(t.SelectItem,{value:"year",children:"Year"})]})]})}),$&&a==="groupBy"&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Granularity"}),e.jsxs(t.Select,{value:D,onValueChange:R,children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full text-xs",children:e.jsx(t.SelectValue,{placeholder:"Select granularity..."})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"day",children:"Day"}),e.jsx(t.SelectItem,{value:"week",children:"Week"}),e.jsx(t.SelectItem,{value:"month",children:"Month"}),e.jsx(t.SelectItem,{value:"quarter",children:"Quarter"}),e.jsx(t.SelectItem,{value:"year",children:"Year"})]})]})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Date Format"}),e.jsxs(t.Select,{value:w?"custom":E,onValueChange:M,children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full text-xs",children:e.jsx(t.SelectValue,{placeholder:"Select date format..."})}),e.jsx(t.SelectContent,{children:U.map(q=>e.jsx(t.SelectItem,{value:q.value,children:q.label},q.value))})]}),w&&e.jsxs("div",{className:"mt-2 space-y-1",children:[e.jsx(t.Input$1,{placeholder:"Enter custom format (e.g., YYYY-MM-DD HH:mm)",value:N,onChange:q=>{q.stopPropagation(),B(q.target.value)},onClick:q=>q.stopPropagation(),className:"h-8 text-xs"}),e.jsx("div",{className:"text-xs text-gray-500",children:"Examples: YYYY-MM-DD, MM/DD/YY, DD-MMM-YYYY HH:mm"})]})]})]}),a==="metrics"&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"space-y-1",children:[e.jsx(t.Label,{className:"text-xs font-medium text-gray-600",children:"Aggregation"}),e.jsxs(t.Select,{value:s.aggregate,onValueChange:q=>{c&&c(q)},children:[e.jsx(t.SelectTrigger,{className:"h-8 w-full text-xs",children:e.jsx(t.SelectValue,{placeholder:"Select function..."})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"COUNT",children:"Count"}),e.jsx(t.SelectItem,{value:"DISTINCT",children:"Count Distinct"}),t.getDataType(s.dataType)==="number"&&e.jsxs(e.Fragment,{children:[e.jsx(t.SelectItem,{value:"SUM",children:"Sum"}),e.jsx(t.SelectItem,{value:"AVG",children:"Average"}),e.jsx(t.SelectItem,{value:"MIN",children:"Min"}),e.jsx(t.SelectItem,{value:"MAX",children:"Max"}),e.jsx(t.SelectItem,{value:"MEDIAN",children:"Median"})]})]})]})]}),m&&e.jsxs(e.Fragment,{children:[e.jsx(Sr,{aliasTemplate:F,onAliasTemplateChange:P}),e.jsx(wr,{valueAliases:A,onValueAliasesChange:z})]})]})]})]})}function Er({concept:s}){const a=()=>{switch(s){case"groupBy":return e.jsxs("div",{className:"w-64 space-y-2",children:[e.jsx("h4",{className:"text-sm font-medium",children:"Group By = Rows"}),e.jsx("p",{className:"text-xs text-muted-foreground",children:"Fields that define how your data is grouped into rows."}),e.jsxs("div",{className:"rounded-md border bg-white p-2",children:[e.jsxs("div",{className:"flex border-b pb-1",children:[e.jsx("div",{className:"w-1/3 text-xs font-medium",children:"Product"}),e.jsx("div",{className:"w-1/3 text-center text-xs",children:"Sales"}),e.jsx("div",{className:"w-1/3 text-center text-xs",children:"Profit"})]}),e.jsxs("div",{className:"flex border-b bg-amber-50 py-1",children:[e.jsx("div",{className:"w-1/3 text-xs font-medium",children:"Electronics"}),e.jsx("div",{className:"w-1/3 text-center text-xs",children:"$5,200"}),e.jsx("div",{className:"w-1/3 text-center text-xs",children:"$1,300"})]}),e.jsxs("div",{className:"flex border-b bg-amber-100 py-1",children:[e.jsx("div",{className:"w-1/3 text-xs font-medium",children:"Clothing"}),e.jsx("div",{className:"w-1/3 text-center text-xs",children:"$3,100"}),e.jsx("div",{className:"w-1/3 text-center text-xs",children:"$620"})]}),e.jsxs("div",{className:"flex bg-amber-50 py-1",children:[e.jsx("div",{className:"w-1/3 text-xs font-medium",children:"Food"}),e.jsx("div",{className:"w-1/3 text-center text-xs",children:"$2,400"}),e.jsx("div",{className:"w-1/3 text-center text-xs",children:"$480"})]})]})]});case"pivotBy":return e.jsxs("div",{className:"w-64 space-y-2",children:[e.jsx("h4",{className:"text-sm font-medium",children:"Stack By = Columns"}),e.jsx("p",{className:"text-xs text-muted-foreground",children:"Fields that split your data into multiple columns or series."}),e.jsxs("div",{className:"rounded-md border bg-white p-2",children:[e.jsxs("div",{className:"flex border-b pb-1",children:[e.jsx("div",{className:"w-1/4 text-xs font-medium",children:"Region"}),e.jsx("div",{className:"w-1/4 rounded-t bg-purple-50 text-center text-xs",children:"North"}),e.jsx("div",{className:"w-1/4 rounded-t bg-purple-100 text-center text-xs",children:"South"}),e.jsx("div",{className:"w-1/4 rounded-t bg-purple-50 text-center text-xs",children:"East"})]}),e.jsxs("div",{className:"flex border-b py-1",children:[e.jsx("div",{className:"w-1/4 text-xs font-medium",children:"Sales"}),e.jsx("div",{className:"w-1/4 bg-purple-50 text-center text-xs",children:"$2,300"}),e.jsx("div",{className:"w-1/4 bg-purple-100 text-center text-xs",children:"$1,800"}),e.jsx("div",{className:"w-1/4 bg-purple-50 text-center text-xs",children:"$3,400"})]}),e.jsxs("div",{className:"flex py-1",children:[e.jsx("div",{className:"w-1/4 text-xs font-medium",children:"Profit"}),e.jsx("div",{className:"w-1/4 rounded-b bg-purple-50 text-center text-xs",children:"$460"}),e.jsx("div",{className:"w-1/4 rounded-b bg-purple-100 text-center text-xs",children:"$360"}),e.jsx("div",{className:"w-1/4 rounded-b bg-purple-50 text-center text-xs",children:"$680"})]})]})]});case"metrics":return e.jsxs("div",{className:"w-64 space-y-2",children:[e.jsx("h4",{className:"text-sm font-medium",children:"Metrics = Values (Cells)"}),e.jsx("p",{className:"text-xs text-muted-foreground",children:"Fields that represent the values shown in your visualization."}),e.jsxs("div",{className:"rounded-md border bg-white p-2",children:[e.jsxs("div",{className:"grid grid-cols-4 gap-1",children:[e.jsx("div",{className:"col-span-1"}),e.jsx("div",{className:"col-span-1 text-center text-xs font-medium",children:"Q1"}),e.jsx("div",{className:"col-span-1 text-center text-xs font-medium",children:"Q2"}),e.jsx("div",{className:"col-span-1 text-center text-xs font-medium",children:"Q3"})]}),e.jsxs("div",{className:"mt-1 grid grid-cols-4 gap-1",children:[e.jsx("div",{className:"text-xs font-medium",children:"Sales"}),e.jsx("div",{className:"rounded bg-blue-100 p-1 text-center text-xs",children:"$2,300"}),e.jsx("div",{className:"rounded bg-blue-200 p-1 text-center text-xs",children:"$3,100"}),e.jsx("div",{className:"rounded bg-blue-300 p-1 text-center text-xs",children:"$4,200"})]}),e.jsxs("div",{className:"mt-1 grid grid-cols-4 gap-1",children:[e.jsx("div",{className:"text-xs font-medium",children:"Profit"}),e.jsx("div",{className:"rounded bg-green-100 p-1 text-center text-xs",children:"$460"}),e.jsx("div",{className:"rounded bg-green-200 p-1 text-center text-xs",children:"$620"}),e.jsx("div",{className:"rounded bg-green-300 p-1 text-center text-xs",children:"$840"})]})]})]});default:return null}};return e.jsx(t.TooltipProvider$1,{children:e.jsxs(t.Tooltip,{delayDuration:300,children:[e.jsx(t.TooltipTrigger,{asChild:!0,children:e.jsx(t.CircleHelp,{className:"size-4 text-muted-foreground hover:text-foreground"})}),e.jsx(t.TooltipContent,{side:"right",align:"start",className:"p-3",children:a()})]})})}function Fe({zone:s,fields:a,label:n,placeholder:r,onRemove:i,onLabelChange:o,onAggregationChange:l,onDateFormatChange:u,onGranularityChange:c,onAliasTemplateChange:h,onValueAliasesChange:d,shouldShow:m,hasPivotColumns:g=!1}){const{isOver:p,setNodeRef:j}=t.useDroppable({id:s}),{updateSortByColumn:x}=t.useEditorActions(),b=t.useEditorStore(T=>T.card),f=a.length>0,k=(T,E)=>{var N;!((N=b.config)!=null&&N.sortByColumns)||b.config.sortByColumns.findIndex(v=>v.id===T)===-1||x(b.id,T,{direction:E})};return s==="sortBy"&&m===!1?null:e.jsxs("div",{className:"mb-4",children:[e.jsxs("div",{className:"mb-2 flex items-center gap-2",children:[e.jsx(t.Label,{className:"block w-16 text-sm font-medium",children:n}),e.jsx(Er,{concept:s})]}),e.jsx("div",{ref:j,className:`min-h-[60px] rounded-lg border-2 border-dashed p-3 transition-all ${p?"border-blue-500 bg-blue-50 dark:bg-blue-950":"border-muted-foreground/20 bg-muted/50"}`,children:a.length===0?e.jsxs("div",{className:"flex min-h-[40px] items-center justify-center text-sm text-gray-400",children:[e.jsx(t.Plus,{className:"mr-2 h-4 w-4"}),r]}):e.jsx(t.SortableContext,{items:a.map(T=>T.id),strategy:t.verticalListSortingStrategy,children:e.jsx("div",{className:"flex flex-wrap gap-2",children:a.map((T,E)=>{const N=T.direction;return e.jsx("div",{className:"flex w-full items-center gap-2",children:e.jsx("div",{className:"flex-1",children:e.jsx(kr,{field:T,zone:s,onRemove:()=>i(E),onLabelChange:v=>o(E,v),sortDirection:N,onSortDirectionChange:v=>k(T.id,v),onAggregationChange:l?v=>l(E,v):void 0,onAliasTemplateChange:h?v=>h(E,v):void 0,onValueAliasesChange:d?v=>d(E,v):void 0,onDateFormatChange:u?(v,w)=>u(E,v,w):void 0,onGranularityChange:c?v=>c(E,v):void 0,hasPivotColumns:g})})},T.id)})})})})]})}function Ir({groupByFields:s,pivotByFields:a,metricsFields:n,sortByFields:r,onRemoveField:i,onLabelChange:o,onAggregationChange:l,onDateFormatChange:u,onGranularityChange:c,onAliasTemplateChange:h,onValueAliasesChange:d}){return e.jsxs("div",{className:"space-y-4",children:[e.jsx(Fe,{zone:"groupBy",fields:s,label:"Group By",placeholder:"Drop fields to group data",onRemove:m=>i("groupBy",m),onLabelChange:(m,g)=>o("groupBy",m,g),onDateFormatChange:(m,g,p)=>u&&u(m,g,p),onGranularityChange:(m,g)=>c&&c(m,g)}),e.jsx(Fe,{zone:"pivotBy",fields:a,label:"Pivot By",placeholder:"Drop fields to pivot data",onRemove:m=>i("pivotBy",m),onLabelChange:(m,g)=>o("pivotBy",m,g)}),e.jsx(Fe,{zone:"metrics",fields:n,label:"Metrics",placeholder:"Drop fields to measure",onRemove:m=>i("metrics",m),onLabelChange:(m,g)=>o("metrics",m,g),onAggregationChange:l,onAliasTemplateChange:h,onValueAliasesChange:d,hasPivotColumns:a.length>0}),r&&r.length>0&&e.jsx(Fe,{zone:"sortBy",fields:r,label:"Sort By",placeholder:"Drop fields to sort data",onRemove:m=>i("sortBy",m),onLabelChange:(m,g)=>o("sortBy",m,g),shouldShow:s.length>0||a.length>0||n.length>0})]})}function Dr({selectedChart:s,onChartChange:a,groupByFields:n,pivotByFields:r,metricsFields:i,sortByFields:o,onRemoveField:l,onLabelChange:u,onAggregationChange:c,onDateFormatChange:h,onGranularityChange:d,onAliasTemplateChange:m,onValueAliasesChange:g}){t.useEditorStore(j=>j.showAIDialog);const{setShowAIDialog:p}=t.useEditorActions();return e.jsxs("div",{className:"flex w-96 flex-col border-r bg-background",children:[e.jsxs("div",{className:"mt-1 space-y-4 border-b px-6 py-4",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(ut,{className:"h-5 w-5 text-cyan-600"}),e.jsx("h2",{className:"font-semibold",children:"Chart Configuration"})]}),e.jsx(Nr,{selectedChart:s,onChartChange:a})]}),e.jsxs(t.ScrollArea,{className:"flex-1 p-6",children:[e.jsx(Ir,{groupByFields:n,pivotByFields:r,metricsFields:i,sortByFields:o,onRemoveField:l,onLabelChange:u,onAggregationChange:c,onDateFormatChange:h,onGranularityChange:d,onAliasTemplateChange:m,onValueAliasesChange:g}),e.jsx(t.ScrollBar,{orientation:"horizontal"})]})]})}function Tr({initialFilters:s,availableFields:a}={}){const[n,r]=L.useState(s||{id:`group-${Date.now()}`,logicalOperator:"AND",negate:!1,conditions:[],groups:[]});t.useEditorStore(y=>y.card.dataSource);const{columns:i,isLoading:o}=Me(),u=a||i||[],c={id:"default",name:"default",dataType:"string",label:"Default",entityId:"default",entityName:"Default",entityType:"table"},h=y=>{const N=v=>{if(v.id===y){const w=u[0]||c;return{...v,conditions:[...v.conditions,{id:`condition-${Date.now()}`,field:w,operator:"=",value:""}]}}return{...v,groups:v.groups.map(N)}};r(N(n))},d=y=>{const N=v=>{if(v.id===y){const w=u[0]||c;return{...v,groups:[...v.groups,{id:`group-${Date.now()}`,logicalOperator:"AND",negate:!1,conditions:[{id:`condition-${Date.now()}`,field:w,operator:"=",value:""}],groups:[]}]}}return{...v,groups:v.groups.map(N)}};r(N(n))},m=(y,N)=>{const v=w=>w.id===y?{...w,conditions:w.conditions.filter(I=>I.id!==N)}:{...w,groups:w.groups.map(v)};r(v(n))},g=(y,N)=>{const v=w=>w.id===y?{...w,groups:w.groups.filter(I=>I.id!==N)}:{...w,groups:w.groups.map(v)};r(v(n))},p=(y,N,v,w)=>{if(v==="field")throw new Error("Use a dedicated method to update the field property with a Field object");const I=D=>D.id===y?{...D,conditions:D.conditions.map(C=>C.id===N?{...C,[v]:w}:C)}:{...D,groups:D.groups.map(I)};r(I(n))},j=(y,N,v)=>{const w=I=>I.id===y?{...I,conditions:I.conditions.map(D=>D.id===N?{...D,...v}:D)}:{...I,groups:I.groups.map(w)};r(w(n))},x=(y,N)=>{const v=w=>w.id===y?{...w,logicalOperator:N}:{...w,groups:w.groups.map(v)};r(v(n))},b=(y,N)=>{const v=w=>w.id===y?{...w,negate:N}:{...w,groups:w.groups.map(v)};r(v(n))},f=(y,N,v)=>{const w=I=>I.id===y?{...I,conditions:t.arrayMove(I.conditions,N,v)}:{...I,groups:I.groups.map(w)};r(w(n))},k=(y,N,v)=>{const w=I=>I.id===y?{...I,groups:t.arrayMove(I.groups,N,v)}:{...I,groups:I.groups.map(w)};r(w(n))},T=y=>{if(!y||y.conditions.length===0&&y.groups.length===0)return"-- No filters defined";const N=w=>{let I="";typeof w.field=="object"?I=w.field.entityName?`${w.field.entityName}.${w.field.name}`:w.field.name:I=String(w.field);const D=w.operator;let C=w.value;if(w.field.dataType==="string"&&!["in","not in"].includes(w.operator))typeof C=="string"?C=`'${C}'`:Array.isArray(C)&&(C=`'${C.join(", ")}'`);else if(w.field.dataType==="date")(typeof C=="string"||C instanceof Date)&&(C=`DATE('${C}')`);else if(["in","not in"].includes(w.operator)){let F=[];Array.isArray(C)?F=C.map(O=>typeof O=="string"?`'${O}'`:String(O)):typeof C=="string"?F=C.split(",").map(O=>{const A=O.trim();return w.field.dataType==="string"?`'${A}'`:A}):typeof C=="number"&&(F=[String(C)]),C=`(${F.join(", ")})`}switch(D){case"contains":return typeof C=="string"?`${I} LIKE '%${C.replace(/'/g,"")}'`:`${I} LIKE '%${String(C)}'`;case"startsWith":return typeof C=="string"?`${I} LIKE '${C.replace(/'/g,"")}%'`:`${I} LIKE '${String(C)}%'`;case"endsWith":return typeof C=="string"?`${I} LIKE '%${C.replace(/'/g,"")}'`:`${I} LIKE '%${String(C)}'`;default:return`${I} ${D} ${C}`}},v=w=>{const I=w.conditions.map(N),D=w.groups.map(A=>v(A)),C=[...I,...D].filter(Boolean);if(C.length===0)return"";const F=C.join(` ${w.logicalOperator} `),O=C.length>1?`(${F})`:F;return w.negate?`NOT ${O}`:O};return v(y)},E=n.conditions.length>0||n.groups.length>0;return{currentFilters:n,setCurrentFilters:r,availableFields:u,isLoading:o,addCondition:h,addGroup:d,removeCondition:m,removeGroup:g,updateCondition:p,updateConditionFields:j,updateGroupOperator:x,updateGroupNegate:b,reorderConditions:f,reorderGroups:k,generateSQLPreview:T,hasAnyFilters:E}}const Mr=s=>{switch(s){case"table":return e.jsx(t.Table,{className:"h-3 w-3"});case"view":return e.jsx(t.Eye,{className:"h-3 w-3"});case"dataset":return e.jsx(ut,{className:"h-3 w-3"});case"file":return e.jsx(mn,{className:"h-3 w-3"});default:return e.jsx(t.Table,{className:"h-3 w-3"})}},Ar=s=>{switch(s){case"table":return"Table";case"view":return"View";case"dataset":return"Dataset";case"file":return"File";default:return"Table"}},Lr=s=>{if(s.qualifiedEntityName){const a=s.qualifiedEntityName.split(".");return a.length>1?a[0]:"default"}return"default"};function Or({value:s,onValueChange:a,availableFields:n,placeholder:r="Select field",className:i="w-64"}){const[o,l]=L.useState(!1),u=L.useMemo(()=>{const c={};return n.forEach(h=>{const d=Lr(h);c[d]||(c[d]={}),c[d][h.entityId]||(c[d][h.entityId]=[]),c[d][h.entityId].push(h)}),c},[n]);return e.jsxs(t.Popover,{modal:!0,open:o,onOpenChange:l,children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsxs(t.Button,{variant:"outline",role:"combobox","aria-expanded":o,className:t.cn("justify-between",!s&&"text-muted-foreground",i),children:[s?e.jsx("div",{className:"flex items-center gap-2",children:e.jsxs("span",{className:"truncate text-sm",children:[s.entityName,".",s.name]})}):r,e.jsx(en,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})}),e.jsx(t.PopoverContent,{className:"z-50 w-80 p-0",align:"start",children:e.jsxs(t.Command,{children:[e.jsx(t.CommandInput,{placeholder:"Search fields...",className:"h-9"}),e.jsx(t.CommandEmpty,{children:"No fields found."}),e.jsx(t.CommandList,{className:"max-h-80",children:Object.entries(u).map(([c,h])=>e.jsx(t.CommandGroup,{heading:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(t.Database,{className:"h-3 w-3"}),c]}),children:Object.entries(h).map(([d,m])=>e.jsxs("div",{children:[e.jsxs("div",{className:"flex items-center gap-2 bg-gray-50/50 px-2 py-1 text-xs font-medium text-gray-600",children:[Mr(m[0].entityType),e.jsx("span",{children:m[0].entityName}),e.jsx(t.Badge,{variant:"secondary",className:"text-xs",children:Ar(m[0].entityType)})]}),m.map(g=>e.jsxs(t.CommandItem,{value:g.id,onSelect:()=>{a(g),l(!1)},className:"pl-6",children:[e.jsx(t.Check,{className:t.cn("mr-2 h-4 w-4",(s==null?void 0:s.id)===g.id?"opacity-100":"opacity-0")}),e.jsxs("div",{className:"flex min-w-0 flex-1 flex-col",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx("span",{className:"truncate",children:g.label}),g.role&&e.jsx(t.Badge,{variant:"outline",className:"text-xs capitalize",children:g.role})]}),e.jsxs("div",{className:"flex items-center gap-2 text-xs text-gray-500",children:[e.jsx("span",{children:g.dataType}),g.description&&e.jsxs("span",{children:["• ",g.description]}),g.customFormat&&e.jsxs("span",{children:["• ",g.customFormat]})]})]})]},g.id))]},`${c}-${d}`))},c))})]})})]})}function At(s){var p;const a=t.useEditorStore(j=>j.card),{authToken:n}=t.useSemaphorContext(),r=t.useEditorStore(j=>j.card.config),i=r==null?void 0:r.joinPlan,o={...s,label:"value",role:"groupby"},l={...s,role:"metric",label:"count",aggregate:"COUNT"},u={joinPlan:i,groupByColumns:[o],metricColumns:[l]},c=((p=a.dataSource)==null?void 0:p.connectionId)||a.connectionId,{data:h,isPending:d,error:m}=t.useQuery({queryKey:["filterValues",s.entityId,s.name,s.qualifiedEntityName],queryFn:async()=>{try{return await t.postRequestRegular("https://semaphor.cloud/api/v1/query",(n==null?void 0:n.accessToken)||"",{connection_id:c,cardConfig:u,cardDataSource:a.dataSource})}catch(j){console.log(s),console.error("error",j)}},enabled:!!c,refetchOnMount:!0,refetchOnWindowFocus:!1});return{filterValues:((h==null?void 0:h.records)||[]).map(j=>({label:j.value||"BLANK",value:j.value||"BLANK",count:j.count})),isPending:d,error:m}}function Fr({field:s,selected:a,onChange:n,placeholder:r="Select items...",className:i}){const[o,l]=re.useState(!1),{filterValues:u}=At(s),c=d=>{n(a.filter(m=>m!==d))},h=d=>{a.includes(d)?n(a.filter(m=>m!==d)):n([...a,d])};return e.jsx("div",{className:t.cn("w-full",i),children:e.jsxs(t.Popover,{open:o,onOpenChange:l,modal:!0,children:[e.jsx(t.PopoverTrigger,{asChild:!0,children:e.jsxs(t.Button,{variant:"outline",role:"combobox","aria-expanded":o,className:"h-auto min-h-10 w-full justify-between p-2",children:[e.jsx("div",{className:"flex flex-1 flex-wrap gap-1",children:a.length>0?a.map(d=>{const m=u.find(g=>g.value===d);return e.jsxs(t.Badge,{variant:"secondary",className:"text-xs",children:[m==null?void 0:m.label,e.jsx("div",{className:"ml-1 rounded-full outline-none ring-offset-background focus:ring-2 focus:ring-ring focus:ring-offset-2",onKeyDown:g=>{g.key==="Enter"&&c(d)},onMouseDown:g=>{g.preventDefault(),g.stopPropagation()},onClick:g=>{g.stopPropagation(),c(d)},children:e.jsx(t.X,{className:"h-3 w-3 text-muted-foreground hover:text-foreground"})})]},d)}):e.jsx("span",{className:"text-muted-foreground",children:r})}),e.jsx(t.ChevronDown,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})}),e.jsx(t.PopoverContent,{className:"z-50 w-fit overflow-auto p-0",align:"start",children:e.jsxs(t.Command,{children:[e.jsx(t.CommandInput,{placeholder:"Search..."}),e.jsxs(t.CommandList,{children:[e.jsx(t.CommandEmpty,{children:"No results found."}),e.jsx(t.CommandGroup,{children:u.map(d=>e.jsxs(t.CommandItem,{onSelect:()=>h(d.value),children:[e.jsx(t.Check,{className:t.cn("mr-2 h-4 w-4",a.includes(d.value)?"opacity-100":"opacity-0")}),e.jsxs("div",{className:"flex grow items-center justify-between gap-4",children:[e.jsx("span",{children:d.label}),e.jsx("span",{className:"text-xs text-muted-foreground",children:d.count})]})]},d.value))})]})]})})]})})}const ks=s=>{if(!s)return 0;let a=s.conditions.length;return s.groups.forEach(n=>{a+=ks(n)}),a};function Br({field:s,value:a,onChange:n,placeholder:r="Select value...",className:i}){const{filterValues:o,isPending:l,error:u}=At(s);return l?e.jsxs("div",{className:"flex flex-1 items-center justify-center p-2 text-xs text-gray-500",children:[e.jsx(ce,{className:"mr-2 size-3.5 animate-spin"})," Loading values..."]}):u?e.jsx("div",{className:"flex-1 p-2 text-xs text-red-500",children:"Error loading values"}):e.jsxs(t.Select,{value:a,onValueChange:n,children:[e.jsx(t.SelectTrigger,{className:i||"flex-1",children:e.jsx(t.SelectValue,{placeholder:r,children:a})}),e.jsx(t.SelectContent,{children:o.map(c=>e.jsx(t.SelectItem,{value:c.value,children:c.label},c.value))})]})}const zr=["=","!=",">",">=","<","<=","contains","startsWith","endsWith","in","not in"],Rr=["=","!=","contains","startsWith","endsWith","in","not in"],Pr=["=","!=",">",">=","<","<=","in","not in"],Vr=["=","!="],qr=["=","!=",">",">=","<","<=","in","not in"];function _r(s){switch(s){case"string":return Rr;case"number":return Pr;case"boolean":return Vr;case"date":return qr;default:return zr}}function Es({condition:s,index:a,groupId:n,groupLogicalOperator:r,onUpdateCondition:i,onRemoveCondition:o,onUpdateGroupOperator:l,availableFields:u,updateConditionFields:c}){const{attributes:h,listeners:d,setNodeRef:m,transform:g,transition:p,isDragging:j}=t.useSortable({id:s.id}),{isPending:x,error:b}=At(s.field),f={transform:t.CSS.Transform.toString(g),transition:p};return e.jsxs("div",{ref:m,style:f,className:`mb-2 flex items-center gap-2 rounded p-2 hover:bg-gray-50 ${j?"z-50 opacity-50":""}`,children:[e.jsx("div",{...h,...d,className:"cursor-grab active:cursor-grabbing",children:e.jsx(t.GripVertical,{className:"h-4 w-4 flex-shrink-0 text-gray-400"})}),a>0&&e.jsxs(t.Select,{value:r,onValueChange:k=>l(n,k),children:[e.jsx(t.SelectTrigger,{className:"w-24",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"})]})]}),a===0&&e.jsx("div",{className:"w-24"}),e.jsx(Or,{value:s.field,onValueChange:k=>{c(n,s.id,{field:k,value:""})},availableFields:u,placeholder:"Select field",className:"w-64"}),e.jsxs(t.Select,{value:s.operator,onValueChange:k=>{k==="in"||k==="not in"?c(n,s.id,{operator:k,value:[]}):c(n,s.id,{operator:k,value:""})},children:[e.jsx(t.SelectTrigger,{className:"w-28",children:e.jsx(t.SelectValue,{})}),e.jsx(t.SelectContent,{children:_r(t.getDataType(s.field.dataType)).map(k=>e.jsx(t.SelectItem,{value:k,children:k},k))})]}),t.getDataType(s.field.dataType)==="string"?s.operator==="in"||s.operator==="not in"?x?e.jsxs("div",{className:"flex flex-1 items-center justify-center p-2 text-xs text-gray-500",children:[e.jsx(ce,{className:"mr-2 size-3.5 animate-spin"})," Loading values..."]}):b?e.jsx("div",{className:"flex-1 p-2 text-xs text-red-500",children:"Error loading values"}):e.jsx(Fr,{field:s.field,selected:Array.isArray(s.value)&&s.value.every(k=>typeof k=="string")?s.value:[],onChange:k=>c(n,s.id,{value:k}),placeholder:`Select values for ${s.operator}...`,className:"flex-1"}):["contains","startsWith","endsWith"].includes(s.operator)?e.jsx(t.Input$1,{value:typeof s.value=="string"?s.value:"",onChange:k=>c(n,s.id,{value:k.target.value}),className:"flex-1",placeholder:s.operator.charAt(0).toUpperCase()+s.operator.slice(1)+"..."}):e.jsx(Br,{field:s.field,value:typeof s.value=="string"?s.value:"",onChange:k=>c(n,s.id,{value:k}),placeholder:"Select value...",className:"flex-1"}):t.getDataType(s.field.dataType)==="boolean"?e.jsxs(t.Select,{value:typeof s.value=="boolean"?String(s.value):"",onValueChange:k=>c(n,s.id,{value:k==="true"}),children:[e.jsx(t.SelectTrigger,{className:"flex-1",children:e.jsx(t.SelectValue,{placeholder:"Select value..."})}),e.jsxs(t.SelectContent,{children:[e.jsx(t.SelectItem,{value:"true",children:"True"}),e.jsx(t.SelectItem,{value:"false",children:"False"})]})]}):e.jsx(t.Input$1,{value:typeof s.value=="string"||typeof s.value=="number"?s.value:"",onChange:k=>i(n,s.id,"value",k.target.value),className:"flex-1",placeholder:s.operator==="in"||s.operator==="not in"?"value1, value2, value3":"Value"}),e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-7 w-7 flex-shrink-0 p-0",onClick:()=>o(n,s.id),children:e.jsx(t.X,{className:"h-3 w-3"})})]})}function Gr({group:s,depth:a,parentGroupId:n,onUpdateGroupOperator:r,onUpdateGroupNegate:i,onRemoveGroup:o,onUpdateCondition:l,onUpdateField:u,onRemoveCondition:c,onReorderConditions:h,onReorderGroups:d,onAddCondition:m,onAddGroup:g,availableFields:p,renderFilterGroup:j,updateConditionFields:x}){const{attributes:b,listeners:f,setNodeRef:k,transform:T,transition:E,isDragging:y}=t.useSortable({id:s.id}),N={transform:t.CSS.Transform.toString(T),transition:E},v=I=>{const{active:D,over:C}=I;if(C&&D.id!==C.id){const F=s.conditions.findIndex(A=>A.id===D.id),O=s.conditions.findIndex(A=>A.id===C.id);F!==-1&&O!==-1&&h(s.id,F,O)}},w=I=>{const{active:D,over:C}=I;if(C&&D.id!==C.id&&n){const F=s.groups.findIndex(A=>A.id===D.id),O=s.groups.findIndex(A=>A.id===C.id);F!==-1&&O!==-1&&d(n,F,O)}};return e.jsxs("div",{ref:k,style:N,className:`rounded-lg ${a>0?"mt-2 border border-gray-200":""} ${y?"z-50 opacity-50":""}`,children:[a>0&&e.jsxs("div",{className:"flex items-center justify-between rounded-t-lg bg-gray-50 p-2",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx("div",{...b,...f,className:"cursor-grab active:cursor-grabbing",children:e.jsx(t.GripVertical,{className:"h-4 w-4 text-gray-400"})}),e.jsx(t.Button,{variant:s.negate?"default":"outline",size:"sm",className:"h-7 px-2 text-xs",onClick:()=>i(s.id,!s.negate),children:"NOT"}),e.jsxs(t.Select,{value:s.logicalOperator,onValueChange:I=>r(s.id,I),children:[e.jsx(t.SelectTrigger,{className:"h-7 w-20",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("span",{className:"text-sm font-medium",children:"Group"})]}),e.jsx(t.Button,{variant:"ghost",size:"sm",className:"h-7 w-7 p-0",onClick:()=>n&&o(n,s.id),children:e.jsx(t.Trash2,{className:"h-3 w-3"})})]}),e.jsxs("div",{className:`p-3 ${a>0?"":"px-0"}`,children:[e.jsx(t.DndContext,{sensors:t.useSensors(t.useSensor(t.PointerSensor),t.useSensor(t.KeyboardSensor,{coordinateGetter:t.sortableKeyboardCoordinates})),collisionDetection:t.closestCenter,onDragEnd:v,children:e.jsx(t.SortableContext,{items:s.conditions.map(I=>I.id),strategy:t.verticalListSortingStrategy,children:s.conditions.map((I,D)=>e.jsx(Es,{condition:I,index:D,groupId:s.id,groupLogicalOperator:s.logicalOperator,onUpdateCondition:l,onUpdateField:u,onRemoveCondition:c,onUpdateGroupOperator:r,availableFields:p,updateConditionFields:x},I.id))})}),e.jsx(t.DndContext,{sensors:t.useSensors(t.useSensor(t.PointerSensor),t.useSensor(t.KeyboardSensor,{coordinateGetter:t.sortableKeyboardCoordinates})),collisionDetection:t.closestCenter,onDragEnd:w,children:e.jsx(t.SortableContext,{items:s.groups.map(I=>I.id),strategy:t.verticalListSortingStrategy,children:s.groups.map(I=>j(I,a+1,s.id))})}),e.jsxs("div",{className:"mt-3 flex items-center gap-2",children:[e.jsxs(t.Button,{size:"sm",variant:"outline",className:"h-7 text-xs",onClick:()=>m(s.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"}),"Add Condition"]}),e.jsxs(t.Button,{variant:"outline",size:"sm",className:"h-7 text-xs",onClick:()=>g(s.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"}),"Add Group"]})]})]})]})}function $r({filters:s,availableFields:a,onSave:n,onClearAll:r,onCancel:i}){const{currentFilters:o,availableFields:l,isLoading:u,addCondition:c,addGroup:h,removeCondition:d,removeGroup:m,updateCondition:g,updateConditionFields:p,updateGroupOperator:j,updateGroupNegate:x,reorderConditions:b,reorderGroups:f,generateSQLPreview:k,hasAnyFilters:T,setCurrentFilters:E}=Tr({initialFilters:s,availableFields:a}),y=t.useSensors(t.useSensor(t.PointerSensor),t.useSensor(t.KeyboardSensor,{coordinateGetter:t.sortableKeyboardCoordinates})),[N,v]=L.useState(!1),w=(C,F,O)=>{const A=S=>S.id===C?{...S,conditions:S.conditions.map(M=>M.id===F?{...M,field:O,dataType:O.dataType}:M)}:{...S,groups:S.groups.map(A)};E(A(o))},I=(C,F=0,O)=>F===0?e.jsx("div",{className:"rounded-lg",children:e.jsxs("div",{className:"p-3 px-0",children:[e.jsx(t.DndContext,{sensors:y,collisionDetection:t.closestCenter,onDragEnd:A=>{const{active:S,over:M}=A;if(M&&S.id!==M.id){const B=C.conditions.findIndex(P=>P.id===S.id),R=C.conditions.findIndex(P=>P.id===M.id);B!==-1&&R!==-1&&b(C.id,B,R)}},children:e.jsx(t.SortableContext,{items:C.conditions.map(A=>A.id),strategy:t.verticalListSortingStrategy,children:C.conditions.map((A,S)=>e.jsx(Es,{condition:A,index:S,groupId:C.id,groupLogicalOperator:C.logicalOperator,onUpdateCondition:g,onUpdateField:w,onRemoveCondition:d,onUpdateGroupOperator:j,availableFields:l,updateConditionFields:p},A.id))})}),e.jsx(t.DndContext,{sensors:y,collisionDetection:t.closestCenter,onDragEnd:A=>{const{active:S,over:M}=A;if(M&&S.id!==M.id){const B=C.groups.findIndex(P=>P.id===S.id),R=C.groups.findIndex(P=>P.id===M.id);B!==-1&&R!==-1&&f(C.id,B,R)}},children:e.jsx(t.SortableContext,{items:C.groups.map(A=>A.id),strategy:t.verticalListSortingStrategy,children:C.groups.map(A=>I(A,F+1,C.id))})}),e.jsxs("div",{className:"mt-3 flex items-center gap-2",children:[e.jsxs(t.Button,{size:"sm",className:"h-7 text-xs",variant:"outline",onClick:()=>c(C.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"}),"Add Condition"]}),N&&e.jsxs(t.Button,{variant:"outline",size:"sm",className:"h-7 text-xs",onClick:()=>h(C.id),children:[e.jsx(t.Plus,{className:"mr-1 h-3 w-3"}),"Add Group"]})]})]})},C.id):e.jsx(Gr,{group:C,depth:F,parentGroupId:O,onUpdateGroupOperator:j,onUpdateGroupNegate:x,onRemoveGroup:m,onUpdateCondition:g,onUpdateField:w,onRemoveCondition:d,onReorderConditions:b,onReorderGroups:f,onAddCondition:c,onAddGroup:h,availableFields:l,renderFilterGroup:I,updateConditionFields:p},C.id),D=ks(s);return e.jsxs("div",{className:"space-y-4",children:[e.jsx(t.Card,{children:e.jsx(t.CardContent,{className:"p-4",children:e.jsxs("div",{className:"space-y-4",children:[u?e.jsxs("div",{className:"flex items-center justify-center p-4",children:[e.jsx("div",{className:"h-5 w-5 animate-spin rounded-full border-2 border-gray-300 border-t-gray-600"}),e.jsx("span",{className:"ml-2 text-sm text-gray-600",children:"Loading columns..."})]}):I(o),e.jsx("div",{className:"mt-4 border-t border-gray-200 pt-4",children:e.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsx(t.Checkbox,{id:"advanced-mode",checked:N,onCheckedChange:C=>v(!!C)}),e.jsx("label",{htmlFor:"advanced-mode",className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:"Advanced mode (enable grouping)"})]})}),T&&e.jsxs("div",{className:"mt-4 border-t border-gray-200 pt-4",children:[e.jsx("div",{className:"mb-2 text-xs font-medium text-gray-700",children:"SQL WHERE Clause Preview"}),e.jsx("div",{className:"overflow-x-auto rounded-md border bg-gray-50 p-3",children:e.jsx("pre",{className:"whitespace-pre-wrap font-mono text-xs text-gray-800",children:k(o)})})]})]})})}),e.jsxs("div",{className:"flex justify-end gap-2",children:[e.jsx(t.Button,{size:"sm",variant:"outline",onClick:i,children:"Cancel"}),D>0&&e.jsx(t.Button,{variant:"outline",size:"sm",onClick:r,children:"Clear All"}),e.jsx(t.Button,{size:"sm",onClick:()=>n(T?o:null),children:"Apply Filters"})]})]})}function Hr({cardId:s,filters:a,onFiltersChange:n,onClearFilters:r,availableFields:i,isOpen:o,onOpenChange:l}){const u=h=>{n(s,h),l(!1)},c=()=>{r(s),l(!1)};return e.jsx(t.Dialog,{open:o,onOpenChange:l,children:e.jsxs(t.DialogContent,{className:"max-h-[80vh] max-w-4xl overflow-y-auto",children:[e.jsxs(t.DialogHeader,{children:[e.jsx(t.DialogTitle,{children:"Card Filters"}),e.jsx(t.DialogDescription,{children:"Add filters to the card to limit the data that is displayed."})]}),e.jsx($r,{filters:a,availableFields:i,onSave:u,onCancel:()=>l(!1),onClearAll:c})]})})}function Is(s,a){return`${t.toLabel(a)} of ${t.toLabel(s)}`}function Ds(s,a){return`${s}-${a.qualifiedEntityName}-${a.name}-${Date.now()}`}function Jr({activeCardId:s,sourceFields:a,getFieldsForContainer:n,setFieldsForContainer:r}){const[i,o]=L.useState(null),l=[...a,...n("groupBy"),...n("pivotBy"),...n("metrics"),...n("sortBy")],u=L.useCallback(g=>g.startsWith("card-")?null:g.startsWith("source-")||a.find(p=>p.id===g)?"source":n("groupBy").find(p=>p.id===g)?"groupBy":n("metrics").find(p=>p.id===g)?"metrics":n("pivotBy").find(p=>p.id===g)?"pivotBy":n("sortBy").find(p=>p.id===g)?"sortBy":null,[a,n]),c=(g,p)=>{const j=Ds(p,g),x=t.getDataType(g.dataType),b=x==="date",f={id:j,name:g.name,dataType:g.dataType,label:t.toLabel(g.name),qualifiedEntityName:g.qualifiedEntityName,entityId:g.entityId,entityName:g.entityName,entityType:g.entityType};if(p==="metrics"){const k=x==="number"?"SUM":"COUNT",T=Is(g.label,k);return{...f,role:"metric",label:T,aggregate:k}}return p==="groupBy"?{...f,role:"groupby",...b&&{granularity:"month"}}:p==="pivotBy"?{...f,role:"pivotby"}:p==="sortBy"?{...f,role:"sortby",direction:"asc"}:null},h=L.useCallback(g=>{o(g.active.id)},[]),d=L.useCallback(g=>{const{active:p,over:j}=g;if(!j||!s){o(null);return}const x=p.id,b=j.id,f=u(x),k=u(b)||b;if(f==="source"&&k!=="source"){const T=[...a].find(v=>v.id===x);if(!T){o(null);return}const E=n(k);if(E.some(v=>v.name===T.name&&v.qualifiedEntityName===T.qualifiedEntityName)){o(null);return}const N=c(T,k);o(null),r(k,[...E,N]);return}if(f&&k&&f!=="source"&&k!=="source"&&f!==k){const T=n(f),E=n(k),y=T.find(w=>w.id===x);if(!y){o(null);return}const N=c(y,k);o(null);const v=T.filter(w=>w.id!==x);r(f,v),r(k,[...E,N]);return}if(f&&k&&f===k&&f!=="source"){const T=n(f),E=T.findIndex(N=>N.id===x),y=T.findIndex(N=>N.id===b);if(E!==y){const N=t.arrayMove(T,E,y);r(f,N)}}o(null)},[s,a,n,r,u]),m=i?l.find(g=>g.id===i):null;return{activeId:i,activeField:m,handleDragStart:h,handleDragEnd:d}}const Ur=s=>{const{updateCardConfig:a,updateGroupByColumn:n,updateMetricColumn:r,updatePivotByColumn:i,updateSortByColumn:o,removeGroupByColumn:l,removeMetricColumn:u,removePivotByColumn:c,removeSortByColumn:h}=t.useEditorActions(),d=s==null?void 0:s.id,m=L.useCallback(E=>{if(!(s!=null&&s.config))return[];switch(E){case"groupBy":return(s.config.groupByColumns||[]).map(y=>({id:y.id,name:y.name,dataType:y.dataType,label:y.label!==void 0?y.label:y.name,qualifiedEntityName:y.qualifiedEntityName,entityId:y.entityId,entityName:y.entityName,entityType:y.entityType,dateFormat:y.dateFormat,customFormat:y.customFormat,granularity:y.granularity}));case"metrics":return s.config.metricColumns||[];case"pivotBy":return(s.config.pivotByColumns||[]).map(y=>({id:y.id,name:y.name,dataType:y.dataType,label:y.label!==void 0?y.label:y.name,qualifiedEntityName:y.qualifiedEntityName,entityId:y.entityId,entityName:y.entityName,entityType:y.entityType}));case"sortBy":return(s.config.sortByColumns||[]).map(y=>({id:y.id,name:y.name,dataType:y.dataType,label:y.label!==void 0?y.label:y.name,qualifiedEntityName:y.qualifiedEntityName,entityId:y.entityId,entityName:y.entityName,entityType:y.entityType,direction:y.direction}));case"source":return[];default:return[]}},[s]),g=L.useCallback((E,y)=>{if(d)switch(E){case"groupBy":{a(d,{groupByColumns:y});break}case"metrics":{a(d,{metricColumns:y});break}case"pivotBy":{a(d,{pivotByColumns:y});break}case"sortBy":{a(d,{sortByColumns:y});break}}},[d,a]),p=L.useCallback((E,y,N)=>{if(!d)return;const w=m(E)[y];if(w)switch(E){case"groupBy":n(d,w.id,{label:N});break;case"metrics":r(d,w.id,{label:N});break;case"pivotBy":i(d,w.id,{label:N});break;case"sortBy":o(d,w.id,{label:N});break}},[d,m,n,r,i,o]),j=L.useCallback((E,y)=>{if(!d)return;const v=m("metrics")[E];v&&r(d,v.id,{aggregate:y,label:Is(v.name,y)})},[d,m,r]),x=L.useCallback((E,y,N)=>{if(!d)return;const w=m("groupBy")[E];if(!w)return;const I={dateFormat:y};y==="custom"&&N?I.customFormat=N:I.customFormat=void 0,n(d,w.id,I)},[d,m,n]),b=L.useCallback((E,y)=>{if(!d)return;const v=m("groupBy")[E];v&&n(d,v.id,{granularity:y})},[d,m,n]),f=L.useCallback((E,y)=>{if(!d)return;const v=m("metrics")[E];v&&r(d,v.id,{aliasTemplate:y})},[d,m,r]),k=L.useCallback((E,y)=>{if(console.log("handleValueAliasesChange",E,y),!d)return;console.log("handleValueAliasesChange",E,y);const v=m("metrics")[E];v&&(console.log("handleValueAliasesChange",y),r(d,v.id,{valueAliases:y}))},[d,m,r]),T=L.useCallback((E,y)=>{if(!d)return;const v=m(E)[y];if(v)switch(E){case"groupBy":l(d,v.id);break;case"metrics":u(d,v.id);break;case"pivotBy":c(d,v.id);break;case"sortBy":h(d,v.id);break}},[d,m,l,u,c,h]);return{getFieldsForContainer:m,setFieldsForContainer:g,updateLabel:p,handleAggregationChange:j,handleDateFormatChange:x,handleGranularityChange:b,handleAliasTemplateChange:f,handleValueAliasesChange:k,removeField:T}};function Yr({activeView:s,onViewChange:a}){return e.jsx(t.Tabs,{value:s,onValueChange:n=>a(n),children:e.jsxs(t.TabsList,{className:"h-9 w-fit",children:[e.jsx(t.TabsTrigger,{value:"table",className:"text-xs",children:"Results"}),e.jsx(t.TabsTrigger,{value:"chart",className:"text-xs",children:"Chart"}),e.jsx(t.TabsTrigger,{value:"sql",className:"text-xs",children:"SQL"})]})})}const Kr=[{value:"10",label:"Top 10"},{value:"20",label:"Top 20"},{value:"50",label:"Top 50"},{value:"100",label:"Top 100"},{value:"200",label:"Top 200"},{value:"500",label:"Top 500"},{value:"1000",label:"Top 1000"}];function Qr(){var c,h;const s=t.useEditorStore(d=>d.card),{updateRowLimit:a}=t.useEditorActions(),[n,r]=L.useState(!1),[i,o]=L.useState(""),l=d=>{if(d==="custom"){r(!0);return}r(!1),a(s.id,parseInt(d))},u=d=>{const m=d.target.value;o(m),m&&!isNaN(parseInt(m))&&a(s.id,parseInt(m))};return e.jsx("div",{className:"flex items-center gap-2",children:n?e.jsx(t.Input,{type:"number",value:i,onChange:u,className:"h-9 w-24",placeholder:"Enter limit",min:1}):e.jsxs(t.Select,{value:((h=(c=s.config)==null?void 0:c.rowLimit)==null?void 0:h.toString())||"100",onValueChange:l,children:[e.jsx(t.SelectTrigger,{className:"h-9 w-24",children:e.jsx(t.SelectValue,{placeholder:"Select limit"})}),e.jsx(t.SelectContent,{children:Kr.map(d=>e.jsx(t.SelectItem,{value:d.value,children:d.label},d.value))})]})})}function Wr({activeView:s,onViewChange:a,showDebug:n,onDebugToggle:r,onAccept:i,onClear:o,onAdvancedToggle:l,onFiltersClick:u,filterCount:c,activeCard:h,columns:d,columnsLoading:m,columnsError:g}){var w;const p=t.useEditorStore(I=>I.card),{updateCardConfig:j}=t.useEditorActions(),x=t.useEditorStore(I=>I.showAIDialog),{data:b,errorMessage:f,isPending:k,isLoading:T,isFetching:E}=t.useDashboardCardQuery(h);function y(){return e.jsx("div",{className:"border-b border-border bg-background p-4",children:e.jsxs("div",{className:"space-y-4",children:[e.jsxs("div",{children:[e.jsx("h3",{className:"mb-2 text-sm font-medium text-gray-700",children:"Active Card Config"}),e.jsx("pre",{className:"max-h-40 overflow-auto rounded border bg-background p-3 text-xs text-gray-800",children:JSON.stringify(p.config||{},null,2)})]}),e.jsxs("div",{children:[e.jsx("h3",{className:"mb-2 text-sm font-medium text-gray-700",children:"Card Data Source State"}),e.jsx("pre",{className:"max-h-40 overflow-auto rounded border bg-background p-3 text-xs text-gray-800",children:JSON.stringify(h.dataSource||{},null,2)})]}),e.jsxs("div",{children:[e.jsxs("h3",{className:"mb-2 text-sm font-medium text-gray-700",children:["Columns (",d.length,")"]}),e.jsx("pre",{className:"max-h-40 overflow-auto rounded border bg-background p-3 text-xs text-gray-800",children:m?"Loading...":g?"Error loading columns":JSON.stringify(d.slice(0,5),null,2)})]})]})})}const N=I=>{if(!p.config)return;if(!I.length){j(p.id,{...p.config,sortByColumns:[]});return}const D=p.config,C=I.map(({id:F,desc:O})=>{var B,R;const A=(B=D.metricColumns)==null?void 0:B.find(P=>P.label===F),S=(R=D.groupByColumns)==null?void 0:R.find(P=>P.label===F),M=A||S;return M?{id:Ds("sortBy",M),name:M.name,dataType:M.dataType,label:M.label,qualifiedEntityName:M.qualifiedEntityName,entityId:M.entityId,entityName:M.entityName,entityType:M.entityType,role:"sortby",direction:O?"desc":"asc"}:null}).filter(F=>F!==null);j(p.id,{...D,sortByColumns:C})},v=L.useMemo(()=>{var I,D;return(D=(I=p.config)==null?void 0:I.sortByColumns)==null?void 0:D.map(C=>({id:C.label,desc:C.direction==="desc"}))},[(w=p.config)==null?void 0:w.sortByColumns]);return e.jsxs("div",{className:"flex w-0 grow flex-col",children:[e.jsx(t.ExplorerHeader,{showDebug:n,onDebugToggle:r,onAccept:i,onClear:o,onAdvancedToggle:l,onFiltersClick:u,filterCount:c}),n&&y(),e.jsxs("div",{className:"group/visualization flex max-w-full grow flex-col",children:[e.jsxs("div",{className:"z-50 flex items-center gap-2 px-6",children:[e.jsxs("div",{className:"flex items-center justify-between gap-2",children:[e.jsx(Yr,{activeView:s,onViewChange:a}),e.jsx(Qr,{})]}),u&&e.jsxs(t.Button,{variant:"outline",size:"sm",className:"gap-1",onClick:u,children:[e.jsx(ft,{className:"h-3.5 w-3.5"}),c>0&&e.jsx("span",{className:"ml-1 rounded-full bg-blue-100 px-1.5 py-0.5 text-xs text-blue-800",children:c})]}),e.jsxs("div",{className:t.cn("flex grow items-center justify-end",{"justify-between":x}),children:[s==="chart"&&x&&e.jsx(ps,{variant:"outline"}),e.jsx("div",{className:"opacity-0 transition-opacity group-hover/visualization:opacity-100",children:s==="chart"&&e.jsx(fs,{})})]})]}),e.jsxs("div",{className:"flex grow flex-col",children:[s==="chart"&&e.jsx("div",{className:"flex grow flex-col pb-6",children:T||E?e.jsx("div",{className:"m-auto flex h-10 w-10 items-center justify-center rounded-md bg-muted",children:e.jsx(ce,{className:"h-8 w-8 animate-spin text-muted-foreground"})}):e.jsx(gs,{})}),s==="table"&&(b==null?void 0:b.records)&&e.jsx("div",{className:"flex h-full min-h-0 max-w-full flex-1 grow basis-0 p-6",children:e.jsx(t.TableVisual,{card:h,data:b==null?void 0:b.records,onSortChange:N,sortState:v})}),s==="sql"&&e.jsx("div",{className:"p-6",children:e.jsxs("div",{className:"rounded-md border bg-background p-4",children:[e.jsx("h3",{className:"mb-3 text-sm font-medium text-gray-700",children:"Generated SQL Query"}),e.jsx(is,{sql:b==null?void 0:b.sql,error:f})]})})]})]})]})}function Xr({activeField:s}){const[a,n]=L.useState(!0);return L.useEffect(()=>{s&&n(!0)},[s]),s?e.jsxs("div",{className:`flex items-center gap-2 rounded-lg border border-blue-500 bg-background p-2 shadow-lg transition-all duration-200 ${a?"scale-100 opacity-100":"scale-95 opacity-0"}`,children:[e.jsx(t.GripVertical,{className:"h-3 w-3 text-gray-400"}),e.jsx(ws,{dataType:s.dataType}),e.jsx("span",{className:"text-sm dark:text-muted-foreground",children:s.name})]}):null}const Zr=()=>{const s=console.error;console.error=(...r)=>{r.length>0&&typeof r[0]=="string"&&r[0].includes("ResizeObserver loop completed with undelivered notifications")||s.apply(console,r)};const a=r=>{if(r.message&&(r.message.includes("ResizeObserver loop completed with undelivered notifications")||r.message.includes("ResizeObserver loop limit exceeded")))return r.preventDefault(),r.stopPropagation(),!1},n=r=>{var i;if((i=r.reason)!=null&&i.message&&(r.reason.message.includes("ResizeObserver loop completed with undelivered notifications")||r.reason.message.includes("ResizeObserver loop limit exceeded")))return r.preventDefault(),!1};return window.addEventListener("error",a,!0),window.addEventListener("unhandledrejection",n,!0),()=>{console.error=s,window.removeEventListener("error",a,!0),window.removeEventListener("unhandledrejection",n,!0)}};function ei(){var _,H;const[s,a]=L.useState("chart"),[n,r]=L.useState(!1),[i,o]=L.useState(!1),l=t.useEditorStore(Y=>Y.showAIDialog),{setCardType:u}=t.useEditorActions(),c=t.useEditorStore(Y=>Y.card.type);L.useEffect(()=>Zr(),[]);const h=()=>{console.log("Accept clicked - would save/apply current configuration")},d=()=>{console.log("Clear clicked - would reset all configurations")},m=()=>{console.log("Advanced mode toggled")},g=()=>{o(!0)},p=Y=>{u(Y)},j=t.useEditorStore(Y=>Y.frame),x=t.useEditorStore(Y=>Y.card);t.useEditorStore(Y=>Y.activeTabCardId),t.useEditorStore(Y=>Y.actions.getAvailableFields);const{addCard:b,removeCard:f,updateCard:k,setActiveCard:T,updateFilters:E}=t.useEditorActions(),{columns:y=[],isLoading:N,error:v}=Me(),w=t.useSensors(t.useSensor(t.PointerSensor,{activationConstraint:{distance:8}})),I=x,{getFieldsForContainer:D,setFieldsForContainer:C,updateLabel:F,handleAggregationChange:O,handleDateFormatChange:A,handleGranularityChange:S,handleAliasTemplateChange:M,handleValueAliasesChange:B,removeField:R}=Ur(I),{activeField:P,handleDragStart:z,handleDragEnd:K}=Jr({activeCardId:j.activeCardId,sourceFields:y,getFieldsForContainer:D,setFieldsForContainer:C}),J=(Y,Z)=>{Z&&E(Y,Z)},$=Y=>{var Z;k(Y,{config:{...(Z=j.cards.find(de=>de.id===Y))==null?void 0:Z.config,filters:void 0}})},U=y,q=Y=>{if(!Y)return 0;let Z=Y.conditions.length;return Y.groups.forEach(de=>{Z+=q(de)}),Z},V=q(((_=I==null?void 0:I.config)==null?void 0:_.filters)||null);return e.jsxs(t.DndContext,{sensors:w,collisionDetection:t.closestCenter,onDragStart:z,onDragEnd:K,children:[e.jsxs("div",{className:"flex h-full grow",children:[e.jsx(br,{}),!l&&e.jsx(Dr,{selectedChart:c,onChartChange:p,groupByFields:D("groupBy"),pivotByFields:D("pivotBy"),metricsFields:D("metrics"),sortByFields:D("sortBy"),onRemoveField:R,onLabelChange:F,onAggregationChange:O,onDateFormatChange:A,onGranularityChange:S,onAliasTemplateChange:M,onValueAliasesChange:B}),e.jsx(Wr,{selectedChart:c,activeView:s,onViewChange:a,showDebug:n,onDebugToggle:()=>r(!n),onAccept:h,onClear:d,onAdvancedToggle:m,onFiltersClick:g,filterCount:V,activeCard:I,dataSourceState:x.dataSource||t.EMPTY_DATA_SOURCE,columns:y,columnsLoading:N,columnsError:v,getFieldsForContainer:D,cards:j.cards,activeCardId:j.activeCardId,addCard:b,setActiveCard:T})]}),I&&e.jsx(Hr,{cardId:I.id,filters:((H=I.config)==null?void 0:H.filters)||null,onFiltersChange:J,onClearFilters:$,availableFields:U,isOpen:i,onOpenChange:o}),e.jsx(t.DragOverlay,{dropAnimation:null,children:e.jsx(Xr,{activeField:P||null})})]})}function ti({authToken:s,onSave:a,onClose:n}){const r=L.useRef(null),i=t.useEditorStore(k=>k.showAIDialog),o=t.useEditorStore(k=>k.isDevMode),{setAuthToken:l}=t.useDashboardActions(),{setShowAIDialog:u,setOnSave:c,setOnClose:h}=t.useEditorActions(),{handleDragOver:d,handleDragEnd:m,handleDragStart:g,handleDragCancel:p,sensors:j}=Jn();L.useEffect(()=>{a&&c(a),n&&h(n)},[a,c,n,h]),L.useEffect(()=>{s&&s.accessToken&&l(s)},[s,l]),L.useEffect(()=>{var k,T;i?((k=r.current)==null||k.resize(40),u(!0)):(u(!1),(T=r.current)==null||T.resize(0))},[i,u]);function x(k){k<1?u(!1):i||u(!0)}function b(){return e.jsxs(e.Fragment,{children:[e.jsx(rs,{type:"main"}),e.jsxs(t.ResizablePanelGroup,{"data-content":"editor-main",className:"grow",direction:"horizontal",children:[e.jsx(t.ResizablePanel,{className:"min-w-[510px] rounded-none",children:e.jsx(or,{})}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{"data-role":"editor-assistant-panel",ref:r,onResize:x,defaultSize:0,children:e.jsx(Gt,{})})]})]})}function f(){return e.jsxs(t.ResizablePanelGroup,{"data-content":"explorer",className:"flex grow",direction:"horizontal",children:[e.jsx(t.ResizablePanel,{className:"min-w-[510px] grow rounded-none",children:e.jsx(ei,{})}),e.jsx(t.ResizableHandle,{}),e.jsx(t.ResizablePanel,{"data-role":"editor-assistant-panel",ref:r,onResize:x,defaultSize:0,children:e.jsx(Gt,{})})]})}return e.jsx(t.ErrorBoundary,{FallbackComponent:t.Fallback,children:o?e.jsx(t.DndContext,{sensors:j,onDragStart:g,onDragEnd:m,onDragOver:d,onDragCancel:p,children:e.jsx("section",{className:"isolate flex h-full grow","data-content":"editor-panel",children:b()})}):f()})}function si(){t.useDashboardStore(l=>l.selectedCardId);const s=t.useDashboardStore(l=>l.selectedSheetId),{setIsVisualEditing:a}=t.useDashboardStore(l=>l.actions),n=t.useDashboardStore(l=>l.isVisualEditing),r=t.useDashboardStore(l=>l.actions.updateFrame);function i(l){s&&(r(s,l),a(!1))}function o(){a(!1)}return e.jsx("div",{role:"editor-container",className:t.cn("flex grow",{"max-h-0 overflow-hidden":!n}),children:e.jsx(ti,{onSave:i,onClose:o})})}function ni(){const s=t.useEditorStore(o=>o.selectedDatabaseName),a=t.useEditorStore(o=>o.selectedTableName),n=t.useDashboardStore(o=>o.dashboard.filters)||[],{columns:r}=t.useEditorAside(),{assignFilter:i}=Ns();return e.jsx(t.ScrollArea,{className:"flex-1 basis-0 flex-col px-3",children:r==null?void 0:r.map(o=>{const l=n==null?void 0:n.find(u=>u.column===t.fmt(o.column_name)&&u.table===a&&u.database===s);return e.jsx("div",{onClick:()=>i(o),className:t.cn("group flex cursor-pointer items-center justify-between border border-dashed border-background px-3 py-[6px] text-sm transition-colors hover:bg-muted/50",{"bg-muted":l}),children:e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(Ct,{column:o}),e.jsx("span",{children:o.column_name})]})},o.column_name)})})}function ai(){t.useDashboardStore(a=>a.showFilters);const s=t.useDashboardStore(a=>a.actions.setShowFilters);return e.jsxs("section",{className:"relative flex min-w-[320px] grow flex-col border-l px-1",children:[e.jsxs("div",{className:"mt-4 flex items-center justify-between gap-2 px-3",children:[e.jsx(t.Label,{className:"px-2 text-lg",children:"Filters"}),e.jsx(t.Button,{onClick:()=>s(!1),className:"h-7 w-7 p-0",variant:"ghost",children:e.jsx(t.Cross2Icon,{})})]}),e.jsx("div",{className:"flex grow",children:e.jsx(rs,{type:"filter",ColumnsComponent:()=>e.jsx(ni,{})})})]})}function ri(){const s=t.useDashboardStore(r=>r.dashboard.filters),a=t.useDashboardStore(r=>r.theme),n=s==null?void 0:s.filter(r=>r.hide);return n!=null&&n.length?e.jsx("div",{className:t.cn("mb-1 flex items-center gap-2 border-y px-0.5 pb-0.5",{"bg-[repeating-linear-gradient(45deg,_#ffffff_0_3px,_#f3f3f3_3px_6px)]":a==="light","bg-[repeating-linear-gradient(45deg,_#18171d_0_3px,_#272729_3px_6px)]":a==="dark"}),children:n==null?void 0:n.map(r=>e.jsxs("div",{className:"flex min-w-[250px] max-w-fit flex-col gap-1 p-2",children:[e.jsx(t.FilterHeader,{filter:r}),e.jsx(t.FilterComponent,{filter:r})]},r.id))}):null}function ii(){const s=t.useDashboardStore(r=>r.showFilters),a=t.useDashboardStore(r=>r.isVisualEditing),n=t.useDashboardStore(r=>r.isDashboardEditing);return e.jsxs("div",{role:"dashboard-plus-main",className:t.cn("",{"max-h-0 overflow-hidden":a,"flex grow overflow-auto":!a}),children:[e.jsxs("section",{className:"flex grow flex-col",children:[n&&e.jsx(ri,{}),e.jsx(t.DashboardTabs,{})]}),s&&e.jsx("div",{role:"filter-aside-container",className:"flex",children:e.jsx(ai,{})})]})}function oi(){const s=t.useDashboardStore(i=>i.dashboard),a=t.useDashboardStore(i=>i.actions.setDashboard),n=t.useDashboardStore(i=>i.showDashboardJSON),r=t.useDashboardStore(i=>i.actions.setShowDashboardJSON);return e.jsxs("div",{className:t.cn("relative p-2",{hidden:!n}),children:[e.jsxs(t.Button,{variant:"secondary",size:"sm",className:"absolute right-2 top-2 z-10 h-8",onClick:()=>r(!1),children:[e.jsx(t.X,{className:"mr-2 h-4 w-4"}),"Close"]}),e.jsx(t.de,{onChange:i=>{if(i)try{JSON.parse(i),a(JSON.parse(i))}catch{}},defaultLanguage:"json",className:"h-[550px] overflow-y-auto",value:JSON.stringify(s,null,2),options:{minimap:{enabled:!1},glyphMargin:!1,wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:12,renderLineHighlight:"none"}})]})}function li({showControls:s=!1,showFooter:a=!0,...n}){return e.jsx(t.ErrorBoundary,{FallbackComponent:t.Fallback,children:e.jsxs(t.SemaphorContextProvider,{dashboardProps:n,children:[e.jsx(t.$e,{}),e.jsxs(t.UXProvider,{children:[e.jsx(oi,{}),e.jsxs(t.DashboardPanel,{...n,children:[s&&e.jsx(qn,{}),e.jsx(si,{}),e.jsx(ii,{})]})]})]})})}exports.DashboardPlus=li;exports.ScheduleDashboard=ns;exports.SelectComponent=ve;exports.cleanCard=es;exports.downloadPdf=ss;exports.getDashbaordStateWithoutData=Nt;