semaphor 0.0.89 → 0.0.90

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";const e=require("./index-CmfbQklE.js"),b=require("react");require("react-dom");function Ms(s){const r=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(s){for(const t in s)if(t!=="default"){const n=Object.getOwnPropertyDescriptor(s,t);Object.defineProperty(r,t,n.get?n:{enumerable:!0,get:()=>s[t]})}}return r.default=s,Object.freeze(r)}const Fe=Ms(b);/**
1
+ "use strict";const e=require("./index-CqZ8hSTF.js"),b=require("react");require("react-dom");function Fs(s){const r=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(s){for(const t in s)if(t!=="default"){const n=Object.getOwnPropertyDescriptor(s,t);Object.defineProperty(r,t,n.get?n:{enumerable:!0,get:()=>s[t]})}}return r.default=s,Object.freeze(r)}const Fe=Fs(b);/**
2
2
  * @license lucide-react v0.453.0 - ISC
3
3
  *
4
4
  * This source code is licensed under the ISC license.
@@ -73,12 +73,12 @@
73
73
  *
74
74
  * This source code is licensed under the ISC license.
75
75
  * See the LICENSE file in the root directory of this source tree.
76
- */const Ye=e.createLucideIcon("Glasses",[["circle",{cx:"6",cy:"15",r:"4",key:"vux9w4"}],["circle",{cx:"18",cy:"15",r:"4",key:"18o8ve"}],["path",{d:"M14 15a2 2 0 0 0-2-2 2 2 0 0 0-2 2",key:"1ag4bs"}],["path",{d:"M2.5 13 5 7c.7-1.3 1.4-2 3-2",key:"1hm1gs"}],["path",{d:"M21.5 13 19 7c-.7-1.3-1.5-2-3-2",key:"1r31ai"}]]);/**
76
+ */const Xe=e.createLucideIcon("Glasses",[["circle",{cx:"6",cy:"15",r:"4",key:"vux9w4"}],["circle",{cx:"18",cy:"15",r:"4",key:"18o8ve"}],["path",{d:"M14 15a2 2 0 0 0-2-2 2 2 0 0 0-2 2",key:"1ag4bs"}],["path",{d:"M2.5 13 5 7c.7-1.3 1.4-2 3-2",key:"1hm1gs"}],["path",{d:"M21.5 13 19 7c-.7-1.3-1.5-2-3-2",key:"1r31ai"}]]);/**
77
77
  * @license lucide-react v0.453.0 - ISC
78
78
  *
79
79
  * This source code is licensed under the ISC license.
80
80
  * See the LICENSE file in the root directory of this source tree.
81
- */const Xe=e.createLucideIcon("Hammer",[["path",{d:"m15 12-8.373 8.373a1 1 0 1 1-3-3L12 9",key:"eefl8a"}],["path",{d:"m18 15 4-4",key:"16gjal"}],["path",{d:"m21.5 11.5-1.914-1.914A2 2 0 0 1 19 8.172V7l-2.26-2.26a6 6 0 0 0-4.202-1.756L9 2.96l.92.82A6.18 6.18 0 0 1 12 8.4V10l2 2h1.172a2 2 0 0 1 1.414.586L18.5 14.5",key:"b7pghm"}]]);/**
81
+ */const Ye=e.createLucideIcon("Hammer",[["path",{d:"m15 12-8.373 8.373a1 1 0 1 1-3-3L12 9",key:"eefl8a"}],["path",{d:"m18 15 4-4",key:"16gjal"}],["path",{d:"m21.5 11.5-1.914-1.914A2 2 0 0 1 19 8.172V7l-2.26-2.26a6 6 0 0 0-4.202-1.756L9 2.96l.92.82A6.18 6.18 0 0 1 12 8.4V10l2 2h1.172a2 2 0 0 1 1.414.586L18.5 14.5",key:"b7pghm"}]]);/**
82
82
  * @license lucide-react v0.453.0 - ISC
83
83
  *
84
84
  * This source code is licensed under the ISC license.
@@ -173,7 +173,12 @@
173
173
  *
174
174
  * This source code is licensed under the ISC license.
175
175
  * See the LICENSE file in the root directory of this source tree.
176
- */const ps=e.createLucideIcon("ToggleLeft",[["rect",{width:"20",height:"12",x:"2",y:"6",rx:"6",ry:"6",key:"f2vt7d"}],["circle",{cx:"8",cy:"12",r:"2",key:"1nvbw3"}]]);/**
176
+ */const ps=e.createLucideIcon("TicketX",[["path",{d:"M2 9a3 3 0 0 1 0 6v2a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-2a3 3 0 0 1 0-6V7a2 2 0 0 0-2-2H4a2 2 0 0 0-2 2Z",key:"qn84l0"}],["path",{d:"m9.5 14.5 5-5",key:"qviqfa"}],["path",{d:"m9.5 9.5 5 5",key:"18nt4w"}]]);/**
177
+ * @license lucide-react v0.453.0 - ISC
178
+ *
179
+ * This source code is licensed under the ISC license.
180
+ * See the LICENSE file in the root directory of this source tree.
181
+ */const js=e.createLucideIcon("ToggleLeft",[["rect",{width:"20",height:"12",x:"2",y:"6",rx:"6",ry:"6",key:"f2vt7d"}],["circle",{cx:"8",cy:"12",r:"2",key:"1nvbw3"}]]);/**
177
182
  * @license lucide-react v0.453.0 - ISC
178
183
  *
179
184
  * This source code is licensed under the ISC license.
@@ -183,7 +188,7 @@
183
188
  *
184
189
  * This source code is licensed under the ISC license.
185
190
  * See the LICENSE file in the root directory of this source tree.
186
- */const js=e.createLucideIcon("User",[["path",{d:"M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2",key:"975kel"}],["circle",{cx:"12",cy:"7",r:"4",key:"17ys0d"}]]);function Le(s){var r;return{...s,sheets:(r=s==null?void 0:s.sheets)==null?void 0:r.map(t=>{var n;return{...t,frames:(n=t.frames)==null?void 0:n.map(o=>{var i;return{...o,cards:(i=o.cards)==null?void 0:i.map(l=>hs(l))}})}})}}function hs(s){var r,t,n,o;return{...s,cfg:{...s.cfg,data:{...(r=s.cfg)==null?void 0:r.data,labels:[],datasets:(o=(n=(t=s.cfg)==null?void 0:t.data)==null?void 0:n.datasets)==null?void 0:o.map(i=>({...i,data:[]}))}},customCfg:Fs(s.customCfg),data:[]}}function Fs(s){var r,t;return s?{...s,data:{...s==null?void 0:s.data,labels:[],datasets:(t=(r=s==null?void 0:s.data)==null?void 0:r.datasets)==null?void 0:t.map(n=>({...n,data:[]}))}}:null}async function Vs(s,r,t,n){if(!n)return null;const o=JSON.stringify(r);return await e.postRequest("https://semaphor.cloud/api/v1/lens",n,{name:s,template:o,filterValues:t,operation:"create"})}async function Se(s,r){if(!r)return null;const{id:t,template:n,filterValues:o,isDefault:i,shared:l}=s;return await e.postRequest("https://semaphor.cloud/api/v1/lens",r,{lensId:t,template:n,filterValues:o,isDefault:i,shared:l,operation:"update"})}async function qs(s,r){return r?await e.postRequest("https://semaphor.cloud/api/v1/lens",r,{operation:"delete",lensId:s}):null}function Bs(){const[s,r]=b.useState(""),[t,n]=b.useState(!1),o=e.useDashboardStore(p=>p.lenses),{setLenses:i,setSelectedLensId:l}=e.useDashboardActions(),[a,x]=b.useState(!1),[d,c]=b.useState(!1),f=e.useDashboardStore(p=>p.dashboard),h=e.useDashboardStore(p=>p.filterValues),{authToken:u}=e.useSemaphorContext();async function j(){x(!0);const p=Le(f),v=await Vs(s,p,h,u==null?void 0:u.accessToken);v&&(i([...o||[],v]),l(v.id),c(!1)),x(!1)}return e.jsxRuntimeExports.jsxs(e.Dialog,{open:d,onOpenChange:c,children:[e.jsxRuntimeExports.jsx(e.DialogTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsxs(e.Button,{variant:"secondary",className:"h-7 p-2",size:"sm",children:[e.jsxRuntimeExports.jsx(e.Plus,{className:"mr-2 h-4 w-4",strokeWidth:1.5}),"Lens"]})}),e.jsxRuntimeExports.jsxs(e.DialogContent,{className:"sm:max-w-[425px]",children:[e.jsxRuntimeExports.jsxs(e.DialogHeader,{children:[e.jsxRuntimeExports.jsx(e.DialogTitle,{children:"Create Lens"}),e.jsxRuntimeExports.jsx(e.DialogDescription,{children:"Lenses are private by default and are only visible to you."})]}),e.jsxRuntimeExports.jsx("div",{className:"grid gap-4 py-4",children:e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-8 items-center gap-4",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"text-right",children:"Name"}),e.jsxRuntimeExports.jsx(e.Input,{value:s,onChange:p=>{r(p.target.value)},id:"name",className:"col-span-7 focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0"})]})}),t&&e.jsxRuntimeExports.jsx("p",{className:"text-sm",children:"The lens name already exists. Use a differnet name."}),e.jsxRuntimeExports.jsx(e.DialogFooter,{children:e.jsxRuntimeExports.jsx(e.Button,{size:"sm",variant:"outline",type:"submit",onClick:j,disabled:a,children:a?"Creating...":"Add"})})]})]})}function _s(){const[s,r]=b.useState(!1),t=e.useDashboardStore(c=>c.lenses),n=e.useDashboardStore(c=>c.selectedLensId),{setLenses:o,setSelectedLensId:i}=e.useDashboardActions(),{authToken:l}=e.useSemaphorContext();async function a(c){i(c)}async function x(c){if(await qs(c,l==null?void 0:l.accessToken)){const h=t==null?void 0:t.filter(u=>u.id!==c);o(h||[]),i("original")}}async function d(c){const f=t==null?void 0:t.map(j=>j.id===c.id?{...j,isDefault:!c.isDefault}:{...j,isDefault:!1});o(f||[]);const h={...c,isDefault:!c.isDefault};await Se(h,l==null?void 0:l.accessToken);const u=t==null?void 0:t.find(j=>j.isDefault);if(u&&u.id!==c.id){const j={...u,isDefault:!1};await Se(j,l==null?void 0:l.accessToken)}}return e.jsxRuntimeExports.jsxs(e.DropdownMenu,{open:s,onOpenChange:r,children:[e.jsxRuntimeExports.jsx(e.DropdownMenuTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{variant:"ghost",className:"h-7 p-2",children:e.jsxRuntimeExports.jsx(Ye,{className:"h-4 w-4",strokeWidth:1.5})})}),e.jsxRuntimeExports.jsxs(e.DropdownMenuContent,{align:"end",className:"w-60",children:[e.jsxRuntimeExports.jsx(e.DropdownMenuLabel,{className:"px-3",children:"Lenses"}),e.jsxRuntimeExports.jsx(e.DropdownMenuSeparator,{}),e.jsxRuntimeExports.jsxs(e.DropdownMenuRadioGroup,{value:n,onValueChange:a,children:[e.jsxRuntimeExports.jsx(e.DropdownMenuRadioItem,{value:"original",children:"Original"}),t==null?void 0:t.map(c=>e.jsxRuntimeExports.jsxs(e.DropdownMenuRadioItem,{className:"group flex justify-between gap-2",value:c.id,children:[e.jsxRuntimeExports.jsx("p",{children:c.name}),e.jsxRuntimeExports.jsxs("span",{className:"flex items-center gap-3",children:[e.jsxRuntimeExports.jsx(es,{onClick:f=>{f.preventDefault(),d(c)},className:e.cn("size-3.5 text-muted-foreground hover:cursor-pointer hover:text-foreground group-hover:visible",{invisible:!c.isDefault,"text-green-500":c.isDefault}),strokeWidth:1.5}),e.jsxRuntimeExports.jsx(e.Cross2Icon,{onClick:f=>{f.preventDefault(),x(c.id)},className:"invisible size-3.5 text-muted-foreground hover:cursor-pointer hover:text-foreground group-hover:visible",strokeWidth:1.5})]})]},c.id))]})]})]})}function Hs({iconClassName:s}){const[r,t]=b.useState(!1),{authToken:n}=e.useSemaphorContext(),o=e.useDashboardStore(a=>a.theme),i=e.useDashboardStore(a=>a.filterValues);async function l(){{t(!0);const a=new URLSearchParams;a.set("token",(n==null?void 0:n.accessToken)||""),a.set("theme",o||"light"),a.set("filterValues",JSON.stringify(i));const x=`https://semaphor.cloud/api/v1/generate-pdf?params=${encodeURIComponent(a.toString())}`,c=await(await fetch(x,{method:"GET",headers:{Authorization:`Bearer ${n==null?void 0:n.accessToken}`}})).blob(),f=URL.createObjectURL(c);window.open(f,"_blank"),t(!1)}}return e.jsxRuntimeExports.jsx(e.Button,{variant:"link",className:"group h-7 p-2",size:"sm",onClick:l,children:r?e.jsxRuntimeExports.jsx(se,{className:e.cn("size-3.5 animate-spin",s)}):e.jsxRuntimeExports.jsx(e.Download,{className:e.cn("size-3.5",s),strokeWidth:1.5})})}function Ps(){const{authToken:s}=e.useSemaphorContext();e.useDashboardStore(E=>E.theme);const r=e.useDashboardStore(E=>E.lenses),t=e.useDashboardStore(E=>E.selectedLensId),n=r==null?void 0:r.find(E=>E.id===t),o=e.useDashboardStore(E=>E.dashboard);e.useDashboardStore(E=>E.selectedSheetId);const i=e.useDashboardStore(E=>E.isDashboardEditing),l=e.useEditorStore(E=>E.selectedConnectionId),[a,x]=b.useState(!1),d=e.useDashboardStore(E=>E.filterValues),c=e.useDashboardStore(E=>E.isVisualEditing),f=e.useDashboardStore(E=>E.showFilters);e.useDashboardStore(E=>E.showDashboardJSON);const h=e.useDashboardStore(E=>E.onSaveFunction),u=e.useDashboardStore(E=>E.actions.setShowFilters),{addFrame:j,setSelectedFrameId:p}=e.useDashboardStore(E=>E.actions),{getSelectedSheet:v,setIsDashboardEditing:g,setShowDashboardJSON:z}=e.useDashboardStore(E=>E.actions),I=v(),{tenantId:w,endUserId:D}=b.useMemo(()=>e.getTenantAndEndUserId(s==null?void 0:s.accessToken),[s==null?void 0:s.accessToken]),L=b.useMemo(()=>w||D,[w,D]),O=()=>{if(!i||!I)return;const E={connectionId:l,id:e.v4(),title:"Title",description:"Description",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"select COUNT(*) from YOUR_TABLE",data:[]},k={id:e.v4(),cards:[E],activeCardId:E.id};j(I.id,k),p(k.id)},m=()=>{g(!0)};async function R(){if(x(!0),!t||!n)return;const E=Le(o),k=JSON.stringify(E),S={...n,template:k,filterValues:d};await Se(S,s==null?void 0:s.accessToken),e.ce.success("Lens saved"),h==null||h(E),x(!1)}return c?null:e.jsxRuntimeExports.jsxs("div",{className:"flex items-center justify-between gap-2 border-b bg-muted/50 py-2 pl-3 pr-2",role:"dashboard-controls",children:[!c&&e.jsxRuntimeExports.jsx("div",{className:"flex items-center gap-3",children:e.jsxRuntimeExports.jsx(e.Label,{children:n==null?void 0:n.name})}),e.jsxRuntimeExports.jsxs("div",{className:"flex gap-2",children:[e.jsxRuntimeExports.jsx(Hs,{}),i&&!c&&L&&e.jsxRuntimeExports.jsx(Bs,{}),!c&&L&&e.jsxRuntimeExports.jsx(_s,{}),i&&!c&&e.jsxRuntimeExports.jsxs(e.Button,{variant:"secondary",className:"h-7 p-2",size:"sm",disabled:!i,onClick:O,children:[e.jsxRuntimeExports.jsx(e.Plus,{className:"mr-2 h-4 w-4",strokeWidth:1.5}),"Frame"]}),!i&&e.jsxRuntimeExports.jsx(e.Button,{variant:"ghost",className:"h-7 p-2",onClick:m,size:"sm",children:e.jsxRuntimeExports.jsx(e.Pencil,{className:"h-4 w-4",strokeWidth:1.5})}),i&&!c&&e.jsxRuntimeExports.jsx(e.Button,{variant:"ghost",role:"close",className:"h-7 p-2",onClick:()=>{g(!1),z(!1)},size:"sm",children:e.jsxRuntimeExports.jsx(e.Cross2Icon,{className:"h-4 w-4",strokeWidth:1.5})}),i&&!c&&L&&e.jsxRuntimeExports.jsx(e.Button,{className:"h-7 p-2",variant:"ghost",disabled:a,onClick:R,size:"sm",children:e.jsxRuntimeExports.jsx(cs,{className:"h-4 w-4",strokeWidth:1.5})}),!f&&!c&&i&&e.jsxRuntimeExports.jsx(e.Button,{className:"h-7 p-2",variant:"ghost",onClick:()=>u(!0),size:"sm",children:e.jsxRuntimeExports.jsx(e.Filter,{className:"h-4 w-4",strokeWidth:1.5})}),!c&&i&&!1,!c&&!1]})]})}function ce({title:s,items:r,value:t,isLoading:n,isError:o,connectionTooltip:i,onChange:l,showNone:a=!1,className:x,showIcon:d=!0,disabled:c=!1}){const f=n?"Loading...":o?"Error":t;function h(){if(s==="Connection")return e.jsxRuntimeExports.jsx(ls,{className:"size-4 rotate-90"});if(s==="Database")return e.jsxRuntimeExports.jsx(Ke,{className:"size-4"});if(s==="Schema")return e.jsxRuntimeExports.jsx(is,{className:"size-4"});if(s==="Table")return e.jsxRuntimeExports.jsx(e.Table,{className:"size-4"});if(s==="Model")return e.jsxRuntimeExports.jsx(Pe,{className:"size-4"})}return e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[d&&e.jsxRuntimeExports.jsx("div",{className:"shrink-0",children:i?e.jsxRuntimeExports.jsxs(e.Tooltip,{children:[e.jsxRuntimeExports.jsx(e.TooltipTrigger,{children:h()}),e.jsxRuntimeExports.jsx(e.TooltipContent,{className:"text-xs",align:"start",children:i})]}):h()}),e.jsxRuntimeExports.jsxs(e.Select,{disabled:c,value:f,onValueChange:l,children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:e.cn("h-9 w-full focus:ring-1 focus:ring-offset-0",x),children:e.jsxRuntimeExports.jsx(e.SelectValue,{placeholder:n?"Loading...":o?"Error":`Select ${s}`})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[n?e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Loading..."}):e.jsxRuntimeExports.jsx(e.SelectLabel,{children:s}),e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[a&&e.jsxRuntimeExports.jsx(e.SelectItem,{value:"none",children:"None"},"none"),r&&r.map((u,j)=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:u.id,children:u.name},j))]}),(n||o)&&e.jsxRuntimeExports.jsx(e.SelectItem,{value:f,children:f})]})})]})]})}function Gs({column:s}){const[r,t]=b.useState(!1),n=e.useEditorStore(u=>u.selectedTableName),o=e.useEditorStore(u=>u.selectedSchemaName),i=e.useEditorStore(u=>u.selectedDatamodelId),l=e.useEditorStore(u=>u.sqlGen),{modelItems:a}=te(),x=e.useEditorStore(u=>u.actions.setSqlGen),d=e.useEditorStore(u=>u.actions.setCardSql),c=e.useEditorStore(u=>u.actions.setRunSql);function f(u,j){var z;const p=e.createSqlGenConfig(u,l,j),v=(z=a==null?void 0:a.find(I=>I.id===i))==null?void 0:z.name;x(p);const g=e.getSql(p,e.fmt(o||""),e.fmt(n),v);g&&(d(g),c(!0)),t(!1)}function h(){return e.jsxRuntimeExports.jsxs("ul",{className:"text-xs",children:[e.jsxRuntimeExports.jsx("li",{onClick:()=>f(s,"COUNT"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Count"}),e.jsxRuntimeExports.jsx("li",{onClick:()=>f(s,"AVG"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Avg"}),e.jsxRuntimeExports.jsx("li",{onClick:()=>f(s,"SUM"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Sum"}),e.jsxRuntimeExports.jsx("li",{onClick:()=>f(s,"MAX"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Max"}),e.jsxRuntimeExports.jsx("li",{onClick:()=>f(s,"MIN"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Min"})]})}return e.jsxRuntimeExports.jsxs(e.HoverCard,{openDelay:0,open:r,onOpenChange:t,children:[e.jsxRuntimeExports.jsx(e.HoverCardTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(ke,{className:"invisible size-3.5 cursor-pointer text-foreground/40 group-hover:visible"})}),e.jsxRuntimeExports.jsx(e.HoverCardContent,{align:"center",className:"w-20 rounded-md p-0 shadow-none",children:h()})]})}function Es({column:s}){return e.jsxRuntimeExports.jsxs(e.Tooltip,{children:[e.jsxRuntimeExports.jsx(e.TooltipTrigger$1,{asChild:!0,children:e.isTextDataType(s.data_type)?e.jsxRuntimeExports.jsx(be,{className:"size-3"}):e.isNumberDataType(s.data_type)?e.jsxRuntimeExports.jsx(Ze,{className:"size-3"}):e.isDateDataType(s.data_type)?e.jsxRuntimeExports.jsx(e.Calendar,{className:"size-3"}):e.isBooleanDataType(s.data_type)?e.jsxRuntimeExports.jsx(ps,{className:"size-3"}):s.data_type.toLowerCase()==="json"?e.jsxRuntimeExports.jsx(Ge,{className:"size-3"}):e.jsxRuntimeExports.jsx(xs,{className:"size-3"})}),e.jsxRuntimeExports.jsx(e.TooltipContent,{children:e.jsxRuntimeExports.jsx("p",{className:"font-mono text-xs",children:s.data_type})})]})}function $s({schemaName:s,tableName:r,columns:t,status:n}){const o=e.useEditorStore(m=>m.sqlGen),i=e.useEditorStore(m=>m.selectedConnectionId),l=e.useEditorStore(m=>m.selectedDatabaseName),a=e.useEditorStore(m=>m.selectedSchemaName),x=e.useEditorStore(m=>m.selectedTableName),d=e.useEditorStore(m=>m.selectedDatamodelId),c=e.useDashboardStore(m=>m.dashboard.aiScopeTables),{setAIScopeTables:f}=e.useDashboardStore(m=>m.actions),h=e.useEditorStore(m=>m.actions.setRunSql),u=e.useEditorStore(m=>m.actions.setSqlGen),j=e.useEditorStore(m=>m.actions.setIsShowingVisual),p=e.useEditorStore(m=>m.actions.setCardSql),{connectionType:v,modelItems:g}=te();function z(m){var S;const R=e.createSqlGenConfig(m,o);u(R);const E=(S=g==null?void 0:g.find(M=>M.id===d))==null?void 0:S.name,k=e.getSql(R,e.fmt(s),e.fmt(r),E);k&&(p(k),h(!0))}function I(){return(c==null?void 0:c.find(m=>m.connectinonId===i&&m.tableName===x))!==void 0}function w(m){if(m===!0&&x&&i){const R={connectinonId:i,connectionType:v,databaseName:l,schemaName:a,tableName:x},k=[...c||[],R].filter((S,M,V)=>V.findIndex(H=>H.connectinonId===S.connectinonId&&H.tableName===S.tableName)===M);f(k),e.ce.success(`Added '${x}' to AI Scope`,{position:"top-right",duration:2500,richColors:!0})}else{const R=(c||[]).filter(E=>E.connectinonId!==i&&E.tableName!==x);f(R),e.ce(`Removed '${x}' from AI Scope`,{position:"top-right",duration:2e3,richColors:!0})}}function D(){var S;let m=e.getQualifiedTableName(s,r);const R=(S=g==null?void 0:g.find(M=>M.id===d))==null?void 0:S.name;d&&d!=="none"&&(m=`${e.DATAMODEL_NAMESPCACE}.${R}`);let E=m;return(M=>/[A-Z]/.test(M))(r)&&(E=E.split(".").map(V=>`"${V}"`).join(".")),E}function L(){const m=D();j(!1);const R=v==="MSSQL"?`SELECT top 10 * FROM ${m}`:`SELECT * FROM ${m} LIMIT 10`;p(R),h(!0)}function O(){const m=D();p(`SELECT COUNT(*) as count FROM ${m}`),h(!0)}return e.jsxRuntimeExports.jsxs("div",{className:"flex grow flex-col space-y-4 px-4",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center justify-center gap-1",children:[e.jsxRuntimeExports.jsx(e.Toggle,{title:`${I()?"Remove from":"Add to"} AI Scope`,pressed:I(),onPressedChange:w,variant:"outline",className:"h-9 px-2",children:e.jsxRuntimeExports.jsx(e.Bot,{className:e.cn("size-4",{"text-primary":I(),"text-muted-foreground":!I()})})}),e.jsxRuntimeExports.jsxs(e.Button,{disabled:n!=="Success",onClick:L,size:"sm",variant:"secondary",className:"flex",children:[n!=="Success"?e.jsxRuntimeExports.jsx(se,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsxRuntimeExports.jsx(ds,{className:"mr-2 size-4"}),"Top 10"]}),e.jsxRuntimeExports.jsxs(e.Button,{disabled:n!=="Success",onClick:O,size:"sm",variant:"secondary",className:"flex",children:[n!=="Success"?e.jsxRuntimeExports.jsx(se,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsxRuntimeExports.jsx(us,{className:"mr-2 size-4"}),"Count"]})]}),e.jsxRuntimeExports.jsxs(e.ScrollArea,{className:"flex-1 basis-0 overflow-y-auto border-b border-t border-muted py-3",children:[t==null?void 0:t.map(m=>e.jsxRuntimeExports.jsxs("div",{onClick:()=>z(m),className:e.cn("group mx-3 flex cursor-pointer items-center justify-between rounded px-2 py-[6px] text-sm transition-colors hover:bg-muted/50",{"bg-muted":e.isColumnInSqlGen(m,o)}),children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(Es,{column:m}),e.jsxRuntimeExports.jsx("span",{children:m.column_name})]}),e.jsxRuntimeExports.jsx("div",{onClick:R=>R.stopPropagation(),className:"flex items-center justify-end",children:e.isNumberDataType(m.data_type)&&e.jsxRuntimeExports.jsx(Gs,{column:m})})]},m.column_name)),e.jsxRuntimeExports.jsx(e.ScrollBar,{orientation:"vertical"}),e.jsxRuntimeExports.jsx(e.ScrollBar,{orientation:"horizontal"})]})]})}function te(s,r){var pe,Ae,ze,Oe,Me;let t=b.useMemo(()=>[],[]);const n=e.useSemaphorContext().authToken||s,o=e.useEditorStore(y=>y.selectedConnectionId),i=e.useEditorStore(y=>y.selectedDatamodelId),l=e.useEditorStore(y=>y.selectedDatabaseName),a=e.useEditorStore(y=>y.selectedSchemaName),x=e.useEditorStore(y=>y.selectedTableName),d=e.useEditorStore(y=>y.actions.setCurrentColumns),c=e.useEditorStore(y=>y.actions.setSelectedConnectionId),f=e.useEditorStore(y=>y.actions.setSelectedDatamodelId),h=e.useEditorStore(y=>y.actions.setSelectedDatabaseName),u=e.useEditorStore(y=>y.actions.setSelectedSchemaName),j=e.useEditorStore(y=>y.actions.setSelectedTableName),p=e.useEditorStore(y=>y.actions.setCardSql);function v(y){return o&&l&&a&&l!=="NA"?!0:o&&y==="API"?!1:!!(o&&y==="S3")}function g(y){return!!(o&&l&&l!=="NA"&&a&&x||o&&(y==="S3"||y==="API")||i&&i)}function z(y){return o&&y?!(y==="API"||y==="S3"):!1}const{data:I,isLoading:w,isError:D}=e.useQuery({queryKey:["connections"],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/connections",(n==null?void 0:n.accessToken)||""),enabled:!!(n!=null&&n.accessToken)}),{data:L,isLoading:O,isError:m}=e.useQuery({queryKey:["models",o],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/datamodels",(n==null?void 0:n.accessToken)||"",{connection_id:o}),enabled:!!(n!=null&&n.accessToken)&&!!o}),R=I==null?void 0:I.connections.find(y=>y.id===o),E=R==null?void 0:R.type,k=(R==null?void 0:R.type)==="API"||(R==null?void 0:R.type)==="S3",{data:S,isLoading:M,isFetching:V,isError:H,refetch:P}=e.useQuery({queryKey:["databases",o],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/databases",(n==null?void 0:n.accessToken)||"",{connection_id:o}),enabled:z(E)}),{data:_,isLoading:G,isFetching:N,isError:F,refetch:B}=e.useQuery({queryKey:["schemas",o,l],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/schemas",(n==null?void 0:n.accessToken)||"",{connection_id:o,database_name:l}),enabled:!!o&&!!l&&!k&&l!=="NA"}),{data:A,isLoading:T,isFetching:K,isError:q,refetch:$}=e.useQuery({queryKey:["tables",o,l,a],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/tables",(n==null?void 0:n.accessToken)||"",{connection_id:o,database_name:l,schema_name:a}),enabled:v(E)}),{data:U,isLoading:X,isFetching:re,isError:Z}=e.useQuery({queryKey:["columns",o,l,i,a,x],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/columns",(n==null?void 0:n.accessToken)||"",{connection_id:o,datamodel_id:i||"",database_name:l,schema_name:a,table_name:x}),enabled:g(E)});b.useEffect(()=>{d(t)},[U,d,t]),b.useEffect(()=>{},[k,p,j,u,h,R]);const oe=(R==null?void 0:R.type)==="API"?(pe=R==null?void 0:R.type)==null?void 0:pe.toLowerCase():x||"",ie=k?"":a||"";function ae(y){u(y),j("")}function le(y){h(y==="none"?"":y),u(""),j(""),y!=="none"&&y!==""&&f("")}function C(y){c(y)}function Q(y){f(y==="none"?"":y),y!=="none"&&y!==""&&h("")}S&&((Ae=S==null?void 0:S.databases)==null?void 0:Ae.length)>0,_&&((ze=_==null?void 0:_.schemas)==null?void 0:ze.length)>0,U&&((Oe=U==null?void 0:U.columns)==null?void 0:Oe.length)>0&&(t=U.columns.map(y=>({...y,data_type:y.data_type.toLowerCase()}))),H&&(t=[]),(Z||D)&&(t=[]);const ee=I==null?void 0:I.connections.map(y=>({id:y.id,name:y.name,type:y.type})),J=(Me=L==null?void 0:L.datamodels)==null?void 0:Me.map(y=>({id:y.id,name:y.name})),ue=S==null?void 0:S.databases.map(y=>({id:y.database_name,name:y.database_name})),ve=_==null?void 0:_.schemas.map(y=>({id:y.schema_name,name:y.schema_name})),me=A==null?void 0:A.tables.map(y=>({id:y.table_name,name:y.table_name}));return{connectionItems:ee,isConnectionsLoading:w,isConnectionsError:D,modelItems:J,isModelsLoading:O,isModelsError:m,databaseItems:ue,isDatabasesLoadingOrFetching:M||V,isDatabaseError:H,schemaItems:ve,isSchemaLoadingOrFetching:G||N,isSchemaError:F,tableItems:me,isTableLoadingOrFetching:T||K,isTableError:q,columns:t,isColumnsLoadingOrFetching:X||re,isColumnsError:Z,isNonDbConnection:k,connectionType:E,tableName:oe,schemaName:ie,handleConnectionChange:C,handleDatamodelChange:Q,handleDatabaseChange:le,handleSchemaChange:ae}}function fs({ColumnsComponent:s}){var K;const r=e.useEditorStore(q=>q.selectedConnectionId),t=e.useEditorStore(q=>q.selectedDatamodelId),n=e.useEditorStore(q=>q.selectedDatabaseName),o=e.useEditorStore(q=>q.selectedSchemaName),i=e.useEditorStore(q=>q.selectedTableName),l=e.useEditorStore(q=>q.actions.setSelectedTableName),{connectionItems:a,modelItems:x,schemaItems:d,databaseItems:c,tableItems:f,columns:h,isConnectionsLoading:u,isModelsLoading:j,isConnectionsError:p,isModelsError:v,isDatabasesLoadingOrFetching:g,isDatabaseError:z,isSchemaLoadingOrFetching:I,isSchemaError:w,isColumnsError:D,isColumnsLoadingOrFetching:L,isTableLoadingOrFetching:O,isTableError:m,connectionType:R,isNonDbConnection:E,handleConnectionChange:k,handleDatabaseChange:S,handleSchemaChange:M,handleDatamodelChange:V,tableName:H,schemaName:P}=te();function _(){return s?s(P,H,h):e.jsxRuntimeExports.jsx($s,{schemaName:P,tableName:H,columns:h,status:L?"Loading...":D?"Error":"Success"})}function G(){window.location.href="mailto:support@semaphor.cloud?subject=Help&body=I need help with..."}function N(){if(!r||R==="S3"||R==="API")return null;if(!t||t==="none")return e.jsxRuntimeExports.jsx(ce,{showNone:!0,onChange:S,isError:z,isLoading:g,items:c,value:n||"",title:"Database"})}function F(){if(r&&!E&&(!n||n==="none")&&(!t||t==="none"))return e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-3",children:[e.jsxRuntimeExports.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsxRuntimeExports.jsx(e.Separator,{})}),e.jsxRuntimeExports.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsxRuntimeExports.jsx(e.Label,{children:"OR"})}),e.jsxRuntimeExports.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsxRuntimeExports.jsx(e.Separator,{})})]})}function B(){if(!r||R==="S3"||R==="API")return null;if(!n||n==="none")return e.jsxRuntimeExports.jsx(ce,{showNone:!0,onChange:V,isError:v,isLoading:j,items:x,value:t||"",title:"Model"})}function A(){return!r||R==="S3"||R==="API"||!n||n==="none"?null:e.jsxRuntimeExports.jsx(ce,{onChange:M,isError:w,isLoading:I,items:d,value:o||"",title:"Schema"})}function T(){function q(){let $=!1;return R==="API"?($=!1,$):((R==="S3"||r&&n&&n!=="none"&&o)&&($=!0),$)}return q()?e.jsxRuntimeExports.jsx(ce,{onChange:l,isError:m,items:f,isLoading:O,value:i||"",title:"Table"}):null}return e.jsxRuntimeExports.jsxs("aside",{className:"xbg-red-100 flex grow flex-col justify-between",children:[e.jsxRuntimeExports.jsxs("section",{className:"space-y-3 px-6 py-4",children:[e.jsxRuntimeExports.jsx(ce,{items:a,title:"Connection",value:r||"",onChange:k,isLoading:u,isError:p,connectionTooltip:((K=a==null?void 0:a.find(q=>q.id===r))==null?void 0:K.type)||""}),B(),F(),N(),A(),T()]}),_(),e.jsxRuntimeExports.jsx("div",{className:"flex items-end justify-center gap-2 px-6 py-4",children:e.jsxRuntimeExports.jsxs(e.Button,{onClick:G,size:"sm",variant:"secondary",className:"w-full",children:[e.jsxRuntimeExports.jsx(os,{className:"mr-2 size-4"}),"Help"]})})]})}function Us(s){const r=s.toUpperCase().indexOf("WHERE"),t=s.toUpperCase().indexOf("GROUP BY"),n=s.toUpperCase().indexOf("LIMIT"),o=s.toUpperCase().indexOf("ORDER BY");let i=s.length;if(o!==-1&&(i=o),n!==-1&&n<i&&(i=n),r!==-1){const l=s.substring(0,r),a=s.substring(r);return`${l} {{ filters | where }} AND ${a.substring(6)}`}else if(t!==-1){const l=s.substring(0,t),a=s.substring(t);return`${l} {{ filters | where }} ${a}`}else{const l=s.substring(0,i),a=s.substring(i);return`${l} {{ filters | where }} ${a}`}}function Qs({error:s,setShowAIDialog:r,setUserInputforAI:t,setTriggerAIRun:n}){return e.jsxRuntimeExports.jsxs(e.HoverCard,{openDelay:0,children:[e.jsxRuntimeExports.jsx(e.HoverCardTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{variant:"link",className:"h-5 p-0",children:e.jsxRuntimeExports.jsx(Ue,{className:"h-4 w-4 text-red-500"})})}),e.jsxRuntimeExports.jsx(e.HoverCardContent,{align:"start",className:"w-full min-w-fit max-w-[700px]",children:e.jsxRuntimeExports.jsx("div",{className:"flex justify-between space-x-4",children:e.jsxRuntimeExports.jsxs("div",{className:"flex grow flex-col space-y-2",children:[e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"max-h-[250px] min-h-0 overflow-scroll",children:e.jsxRuntimeExports.jsx("p",{className:"overflow-auto rounded-md bg-muted p-2 text-xs leading-relaxed",children:s})}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:()=>{r(!0),t(s),n(!0)},size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(Xe,{className:"mr-2 h-4 w-4"}),"Debug with AI"]})]})})})]})}const Ks=`
191
+ */const hs=e.createLucideIcon("User",[["path",{d:"M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2",key:"975kel"}],["circle",{cx:"12",cy:"7",r:"4",key:"17ys0d"}]]);function Le(s){var r;return{...s,sheets:(r=s==null?void 0:s.sheets)==null?void 0:r.map(t=>{var n;return{...t,frames:(n=t.frames)==null?void 0:n.map(o=>{var i;return{...o,cards:(i=o.cards)==null?void 0:i.map(l=>Es(l))}})}})}}function Es(s){var r,t,n,o;return{...s,cfg:{...s.cfg,data:{...(r=s.cfg)==null?void 0:r.data,labels:[],datasets:(o=(n=(t=s.cfg)==null?void 0:t.data)==null?void 0:n.datasets)==null?void 0:o.map(i=>({...i,data:[]}))}},customCfg:Vs(s.customCfg),data:[]}}function Vs(s){var r,t;return s?{...s,data:{...s==null?void 0:s.data,labels:[],datasets:(t=(r=s==null?void 0:s.data)==null?void 0:r.datasets)==null?void 0:t.map(n=>({...n,data:[]}))}}:null}async function qs(s,r,t,n){if(!n)return null;const o=JSON.stringify(r);return await e.postRequest("https://semaphor.cloud/api/v1/lens",n,{name:s,template:o,filterValues:t,operation:"create"})}async function Se(s,r){if(!r)return null;const{id:t,template:n,filterValues:o,isDefault:i,shared:l}=s;return await e.postRequest("https://semaphor.cloud/api/v1/lens",r,{lensId:t,template:n,filterValues:o,isDefault:i,shared:l,operation:"update"})}async function Bs(s,r){return r?await e.postRequest("https://semaphor.cloud/api/v1/lens",r,{operation:"delete",lensId:s}):null}function _s(){const[s,r]=b.useState(""),[t,n]=b.useState(!1),o=e.useDashboardStore(p=>p.lenses),{setLenses:i,setSelectedLensId:l}=e.useDashboardActions(),[a,x]=b.useState(!1),[d,c]=b.useState(!1),f=e.useDashboardStore(p=>p.dashboard),h=e.useDashboardStore(p=>p.filterValues),{authToken:u}=e.useSemaphorContext();async function j(){x(!0);const p=Le(f),v=await qs(s,p,h,u==null?void 0:u.accessToken);v&&(i([...o||[],v]),l(v.id),c(!1)),x(!1)}return e.jsxRuntimeExports.jsxs(e.Dialog,{open:d,onOpenChange:c,children:[e.jsxRuntimeExports.jsx(e.DialogTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsxs(e.Button,{variant:"secondary",className:"h-7 p-2",size:"sm",children:[e.jsxRuntimeExports.jsx(e.Plus,{className:"mr-2 h-4 w-4",strokeWidth:1.5}),"Lens"]})}),e.jsxRuntimeExports.jsxs(e.DialogContent,{className:"sm:max-w-[425px]",children:[e.jsxRuntimeExports.jsxs(e.DialogHeader,{children:[e.jsxRuntimeExports.jsx(e.DialogTitle,{children:"Create Lens"}),e.jsxRuntimeExports.jsx(e.DialogDescription,{children:"Lenses are private by default and are only visible to you."})]}),e.jsxRuntimeExports.jsx("div",{className:"grid gap-4 py-4",children:e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-8 items-center gap-4",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"text-right",children:"Name"}),e.jsxRuntimeExports.jsx(e.Input,{value:s,onChange:p=>{r(p.target.value)},id:"name",className:"col-span-7 focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0"})]})}),t&&e.jsxRuntimeExports.jsx("p",{className:"text-sm",children:"The lens name already exists. Use a differnet name."}),e.jsxRuntimeExports.jsx(e.DialogFooter,{children:e.jsxRuntimeExports.jsx(e.Button,{size:"sm",variant:"outline",type:"submit",onClick:j,disabled:a,children:a?"Creating...":"Add"})})]})]})}function Hs(){const[s,r]=b.useState(!1),t=e.useDashboardStore(c=>c.lenses),n=e.useDashboardStore(c=>c.selectedLensId),{setLenses:o,setSelectedLensId:i}=e.useDashboardActions(),{authToken:l}=e.useSemaphorContext();async function a(c){i(c)}async function x(c){if(await Bs(c,l==null?void 0:l.accessToken)){const h=t==null?void 0:t.filter(u=>u.id!==c);o(h||[]),i("original")}}async function d(c){const f=t==null?void 0:t.map(j=>j.id===c.id?{...j,isDefault:!c.isDefault}:{...j,isDefault:!1});o(f||[]);const h={...c,isDefault:!c.isDefault};await Se(h,l==null?void 0:l.accessToken);const u=t==null?void 0:t.find(j=>j.isDefault);if(u&&u.id!==c.id){const j={...u,isDefault:!1};await Se(j,l==null?void 0:l.accessToken)}}return e.jsxRuntimeExports.jsxs(e.DropdownMenu,{open:s,onOpenChange:r,children:[e.jsxRuntimeExports.jsx(e.DropdownMenuTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{variant:"ghost",className:"h-7 p-2",children:e.jsxRuntimeExports.jsx(Xe,{className:"h-4 w-4",strokeWidth:1.5})})}),e.jsxRuntimeExports.jsxs(e.DropdownMenuContent,{align:"end",className:"w-60",children:[e.jsxRuntimeExports.jsx(e.DropdownMenuLabel,{className:"px-3",children:"Lenses"}),e.jsxRuntimeExports.jsx(e.DropdownMenuSeparator,{}),e.jsxRuntimeExports.jsxs(e.DropdownMenuRadioGroup,{value:n,onValueChange:a,children:[e.jsxRuntimeExports.jsx(e.DropdownMenuRadioItem,{value:"original",children:"Original"}),t==null?void 0:t.map(c=>e.jsxRuntimeExports.jsxs(e.DropdownMenuRadioItem,{className:"group flex justify-between gap-2",value:c.id,children:[e.jsxRuntimeExports.jsx("p",{children:c.name}),e.jsxRuntimeExports.jsxs("span",{className:"flex items-center gap-3",children:[e.jsxRuntimeExports.jsx(es,{onClick:f=>{f.preventDefault(),d(c)},className:e.cn("size-3.5 text-muted-foreground hover:cursor-pointer hover:text-foreground group-hover:visible",{invisible:!c.isDefault,"text-green-500":c.isDefault}),strokeWidth:1.5}),e.jsxRuntimeExports.jsx(e.Cross2Icon,{onClick:f=>{f.preventDefault(),x(c.id)},className:"invisible size-3.5 text-muted-foreground hover:cursor-pointer hover:text-foreground group-hover:visible",strokeWidth:1.5})]})]},c.id))]})]})]})}function Ps({iconClassName:s}){const[r,t]=b.useState(!1),{authToken:n}=e.useSemaphorContext(),o=e.useDashboardStore(a=>a.theme),i=e.useDashboardStore(a=>a.filterValues);async function l(){{t(!0);const a=new URLSearchParams;a.set("token",(n==null?void 0:n.accessToken)||""),a.set("theme",o||"light"),a.set("filterValues",JSON.stringify(i));const x=`https://semaphor.cloud/api/v1/generate-pdf?params=${encodeURIComponent(a.toString())}`,c=await(await fetch(x,{method:"GET",headers:{Authorization:`Bearer ${n==null?void 0:n.accessToken}`}})).blob(),f=URL.createObjectURL(c);window.open(f,"_blank"),t(!1)}}return e.jsxRuntimeExports.jsx(e.Button,{variant:"link",className:"group h-7 p-2",size:"sm",onClick:l,children:r?e.jsxRuntimeExports.jsx(se,{className:e.cn("size-3.5 animate-spin",s)}):e.jsxRuntimeExports.jsx(e.Download,{className:e.cn("size-3.5",s),strokeWidth:1.5})})}function Gs(){const{authToken:s}=e.useSemaphorContext();e.useDashboardStore(E=>E.theme);const r=e.useDashboardStore(E=>E.lenses),t=e.useDashboardStore(E=>E.selectedLensId),n=r==null?void 0:r.find(E=>E.id===t),o=e.useDashboardStore(E=>E.dashboard);e.useDashboardStore(E=>E.selectedSheetId);const i=e.useDashboardStore(E=>E.isDashboardEditing),l=e.useEditorStore(E=>E.selectedConnectionId),[a,x]=b.useState(!1),d=e.useDashboardStore(E=>E.filterValues),c=e.useDashboardStore(E=>E.isVisualEditing),f=e.useDashboardStore(E=>E.showFilters);e.useDashboardStore(E=>E.showDashboardJSON);const h=e.useDashboardStore(E=>E.onSaveFunction),u=e.useDashboardStore(E=>E.actions.setShowFilters),{addFrame:j,setSelectedFrameId:p}=e.useDashboardStore(E=>E.actions),{getSelectedSheet:v,setIsDashboardEditing:g,setShowDashboardJSON:z}=e.useDashboardStore(E=>E.actions),I=v(),{tenantId:w,endUserId:D}=b.useMemo(()=>e.getTenantAndEndUserId(s==null?void 0:s.accessToken),[s==null?void 0:s.accessToken]),L=b.useMemo(()=>w||D,[w,D]),O=()=>{if(!i||!I)return;const E={connectionId:l,id:e.v4(),title:"Title",description:"Description",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"select COUNT(*) from YOUR_TABLE",data:[]},k={id:e.v4(),cards:[E],activeCardId:E.id};j(I.id,k),p(k.id)},m=()=>{g(!0)};async function R(){if(x(!0),!t||!n)return;const E=Le(o),k=JSON.stringify(E),S={...n,template:k,filterValues:d};await Se(S,s==null?void 0:s.accessToken),e.ce.success("Lens saved"),h==null||h(E),x(!1)}return c?null:e.jsxRuntimeExports.jsxs("div",{className:"flex items-center justify-between gap-2 border-b bg-muted/50 py-2 pl-3 pr-2",role:"dashboard-controls",children:[!c&&e.jsxRuntimeExports.jsx("div",{className:"flex items-center gap-3",children:e.jsxRuntimeExports.jsx(e.Label,{children:n==null?void 0:n.name})}),e.jsxRuntimeExports.jsxs("div",{className:"flex gap-2",children:[e.jsxRuntimeExports.jsx("button",{onClick:e.invalidateToken,children:e.jsxRuntimeExports.jsx(ps,{className:"h-4 w-4",strokeWidth:1.5})}),e.jsxRuntimeExports.jsx(Ps,{}),i&&!c&&L&&e.jsxRuntimeExports.jsx(_s,{}),!c&&L&&e.jsxRuntimeExports.jsx(Hs,{}),i&&!c&&e.jsxRuntimeExports.jsxs(e.Button,{variant:"secondary",className:"h-7 p-2",size:"sm",disabled:!i,onClick:O,children:[e.jsxRuntimeExports.jsx(e.Plus,{className:"mr-2 h-4 w-4",strokeWidth:1.5}),"Frame"]}),!i&&e.jsxRuntimeExports.jsx(e.Button,{variant:"ghost",className:"h-7 p-2",onClick:m,size:"sm",children:e.jsxRuntimeExports.jsx(e.Pencil,{className:"h-4 w-4",strokeWidth:1.5})}),i&&!c&&e.jsxRuntimeExports.jsx(e.Button,{variant:"ghost",role:"close",className:"h-7 p-2",onClick:()=>{g(!1),z(!1)},size:"sm",children:e.jsxRuntimeExports.jsx(e.Cross2Icon,{className:"h-4 w-4",strokeWidth:1.5})}),i&&!c&&L&&e.jsxRuntimeExports.jsx(e.Button,{className:"h-7 p-2",variant:"ghost",disabled:a,onClick:R,size:"sm",children:e.jsxRuntimeExports.jsx(cs,{className:"h-4 w-4",strokeWidth:1.5})}),!f&&!c&&i&&e.jsxRuntimeExports.jsx(e.Button,{className:"h-7 p-2",variant:"ghost",onClick:()=>u(!0),size:"sm",children:e.jsxRuntimeExports.jsx(e.Filter,{className:"h-4 w-4",strokeWidth:1.5})}),!c&&i&&!1,!c&&!1]})]})}function ce({title:s,items:r,value:t,isLoading:n,isError:o,connectionTooltip:i,onChange:l,showNone:a=!1,className:x,showIcon:d=!0,disabled:c=!1}){const f=n?"Loading...":o?"Error":t;function h(){if(s==="Connection")return e.jsxRuntimeExports.jsx(ls,{className:"size-4 rotate-90"});if(s==="Database")return e.jsxRuntimeExports.jsx(Ke,{className:"size-4"});if(s==="Schema")return e.jsxRuntimeExports.jsx(is,{className:"size-4"});if(s==="Table")return e.jsxRuntimeExports.jsx(e.Table,{className:"size-4"});if(s==="Model")return e.jsxRuntimeExports.jsx(Pe,{className:"size-4"})}return e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[d&&e.jsxRuntimeExports.jsx("div",{className:"shrink-0",children:i?e.jsxRuntimeExports.jsxs(e.Tooltip,{children:[e.jsxRuntimeExports.jsx(e.TooltipTrigger,{children:h()}),e.jsxRuntimeExports.jsx(e.TooltipContent,{className:"text-xs",align:"start",children:i})]}):h()}),e.jsxRuntimeExports.jsxs(e.Select,{disabled:c,value:f,onValueChange:l,children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:e.cn("h-9 w-full focus:ring-1 focus:ring-offset-0",x),children:e.jsxRuntimeExports.jsx(e.SelectValue,{placeholder:n?"Loading...":o?"Error":`Select ${s}`})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[n?e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Loading..."}):e.jsxRuntimeExports.jsx(e.SelectLabel,{children:s}),e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[a&&e.jsxRuntimeExports.jsx(e.SelectItem,{value:"none",children:"None"},"none"),r&&r.map((u,j)=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:u.id,children:u.name},j))]}),(n||o)&&e.jsxRuntimeExports.jsx(e.SelectItem,{value:f,children:f})]})})]})]})}function $s({column:s}){const[r,t]=b.useState(!1),n=e.useEditorStore(u=>u.selectedTableName),o=e.useEditorStore(u=>u.selectedSchemaName),i=e.useEditorStore(u=>u.selectedDatamodelId),l=e.useEditorStore(u=>u.sqlGen),{modelItems:a}=te(),x=e.useEditorStore(u=>u.actions.setSqlGen),d=e.useEditorStore(u=>u.actions.setCardSql),c=e.useEditorStore(u=>u.actions.setRunSql);function f(u,j){var z;const p=e.createSqlGenConfig(u,l,j),v=(z=a==null?void 0:a.find(I=>I.id===i))==null?void 0:z.name;x(p);const g=e.getSql(p,e.fmt(o||""),e.fmt(n),v);g&&(d(g),c(!0)),t(!1)}function h(){return e.jsxRuntimeExports.jsxs("ul",{className:"text-xs",children:[e.jsxRuntimeExports.jsx("li",{onClick:()=>f(s,"COUNT"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Count"}),e.jsxRuntimeExports.jsx("li",{onClick:()=>f(s,"AVG"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Avg"}),e.jsxRuntimeExports.jsx("li",{onClick:()=>f(s,"SUM"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Sum"}),e.jsxRuntimeExports.jsx("li",{onClick:()=>f(s,"MAX"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Max"}),e.jsxRuntimeExports.jsx("li",{onClick:()=>f(s,"MIN"),className:"cursor-pointer p-1 px-3 transition-colors hover:bg-muted",children:"Min"})]})}return e.jsxRuntimeExports.jsxs(e.HoverCard,{openDelay:0,open:r,onOpenChange:t,children:[e.jsxRuntimeExports.jsx(e.HoverCardTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(ke,{className:"invisible size-3.5 cursor-pointer text-foreground/40 group-hover:visible"})}),e.jsxRuntimeExports.jsx(e.HoverCardContent,{align:"center",className:"w-20 rounded-md p-0 shadow-none",children:h()})]})}function fs({column:s}){return e.jsxRuntimeExports.jsxs(e.Tooltip,{children:[e.jsxRuntimeExports.jsx(e.TooltipTrigger$1,{asChild:!0,children:e.isTextDataType(s.data_type)?e.jsxRuntimeExports.jsx(be,{className:"size-3"}):e.isNumberDataType(s.data_type)?e.jsxRuntimeExports.jsx(Ze,{className:"size-3"}):e.isDateDataType(s.data_type)?e.jsxRuntimeExports.jsx(e.Calendar,{className:"size-3"}):e.isBooleanDataType(s.data_type)?e.jsxRuntimeExports.jsx(js,{className:"size-3"}):s.data_type.toLowerCase()==="json"?e.jsxRuntimeExports.jsx(Ge,{className:"size-3"}):e.jsxRuntimeExports.jsx(xs,{className:"size-3"})}),e.jsxRuntimeExports.jsx(e.TooltipContent,{children:e.jsxRuntimeExports.jsx("p",{className:"font-mono text-xs",children:s.data_type})})]})}function Us({schemaName:s,tableName:r,columns:t,status:n}){const o=e.useEditorStore(m=>m.sqlGen),i=e.useEditorStore(m=>m.selectedConnectionId),l=e.useEditorStore(m=>m.selectedDatabaseName),a=e.useEditorStore(m=>m.selectedSchemaName),x=e.useEditorStore(m=>m.selectedTableName),d=e.useEditorStore(m=>m.selectedDatamodelId),c=e.useDashboardStore(m=>m.dashboard.aiScopeTables),{setAIScopeTables:f}=e.useDashboardStore(m=>m.actions),h=e.useEditorStore(m=>m.actions.setRunSql),u=e.useEditorStore(m=>m.actions.setSqlGen),j=e.useEditorStore(m=>m.actions.setIsShowingVisual),p=e.useEditorStore(m=>m.actions.setCardSql),{connectionType:v,modelItems:g}=te();function z(m){var S;const R=e.createSqlGenConfig(m,o);u(R);const E=(S=g==null?void 0:g.find(M=>M.id===d))==null?void 0:S.name,k=e.getSql(R,e.fmt(s),e.fmt(r),E);k&&(p(k),h(!0))}function I(){return(c==null?void 0:c.find(m=>m.connectinonId===i&&m.tableName===x))!==void 0}function w(m){if(m===!0&&x&&i){const R={connectinonId:i,connectionType:v,databaseName:l,schemaName:a,tableName:x},k=[...c||[],R].filter((S,M,V)=>V.findIndex(H=>H.connectinonId===S.connectinonId&&H.tableName===S.tableName)===M);f(k),e.ce.success(`Added '${x}' to AI Scope`,{position:"top-right",duration:2500,richColors:!0})}else{const R=(c||[]).filter(E=>E.connectinonId!==i&&E.tableName!==x);f(R),e.ce(`Removed '${x}' from AI Scope`,{position:"top-right",duration:2e3,richColors:!0})}}function D(){var S;let m=e.getQualifiedTableName(s,r);const R=(S=g==null?void 0:g.find(M=>M.id===d))==null?void 0:S.name;d&&d!=="none"&&(m=`${e.DATAMODEL_NAMESPCACE}.${R}`);let E=m;return(M=>/[A-Z]/.test(M))(r)&&(E=E.split(".").map(V=>`"${V}"`).join(".")),E}function L(){const m=D();j(!1);const R=v==="MSSQL"?`SELECT top 10 * FROM ${m}`:`SELECT * FROM ${m} LIMIT 10`;p(R),h(!0)}function O(){const m=D();p(`SELECT COUNT(*) as count FROM ${m}`),h(!0)}return e.jsxRuntimeExports.jsxs("div",{className:"flex grow flex-col space-y-4 px-4",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center justify-center gap-1",children:[e.jsxRuntimeExports.jsx(e.Toggle,{title:`${I()?"Remove from":"Add to"} AI Scope`,pressed:I(),onPressedChange:w,variant:"outline",className:"h-9 px-2",children:e.jsxRuntimeExports.jsx(e.Bot,{className:e.cn("size-4",{"text-primary":I(),"text-muted-foreground":!I()})})}),e.jsxRuntimeExports.jsxs(e.Button,{disabled:n!=="Success",onClick:L,size:"sm",variant:"secondary",className:"flex",children:[n!=="Success"?e.jsxRuntimeExports.jsx(se,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsxRuntimeExports.jsx(ds,{className:"mr-2 size-4"}),"Top 10"]}),e.jsxRuntimeExports.jsxs(e.Button,{disabled:n!=="Success",onClick:O,size:"sm",variant:"secondary",className:"flex",children:[n!=="Success"?e.jsxRuntimeExports.jsx(se,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsxRuntimeExports.jsx(us,{className:"mr-2 size-4"}),"Count"]})]}),e.jsxRuntimeExports.jsxs(e.ScrollArea,{className:"flex-1 basis-0 overflow-y-auto border-b border-t border-muted py-3",children:[t==null?void 0:t.map(m=>e.jsxRuntimeExports.jsxs("div",{onClick:()=>z(m),className:e.cn("group mx-3 flex cursor-pointer items-center justify-between rounded px-2 py-[6px] text-sm transition-colors hover:bg-muted/50",{"bg-muted":e.isColumnInSqlGen(m,o)}),children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(fs,{column:m}),e.jsxRuntimeExports.jsx("span",{children:m.column_name})]}),e.jsxRuntimeExports.jsx("div",{onClick:R=>R.stopPropagation(),className:"flex items-center justify-end",children:e.isNumberDataType(m.data_type)&&e.jsxRuntimeExports.jsx($s,{column:m})})]},m.column_name)),e.jsxRuntimeExports.jsx(e.ScrollBar,{orientation:"vertical"}),e.jsxRuntimeExports.jsx(e.ScrollBar,{orientation:"horizontal"})]})]})}function te(s,r){var pe,Ae,ze,Oe,Me;let t=b.useMemo(()=>[],[]);const n=e.useSemaphorContext().authToken||s,o=e.useEditorStore(y=>y.selectedConnectionId),i=e.useEditorStore(y=>y.selectedDatamodelId),l=e.useEditorStore(y=>y.selectedDatabaseName),a=e.useEditorStore(y=>y.selectedSchemaName),x=e.useEditorStore(y=>y.selectedTableName),d=e.useEditorStore(y=>y.actions.setCurrentColumns),c=e.useEditorStore(y=>y.actions.setSelectedConnectionId),f=e.useEditorStore(y=>y.actions.setSelectedDatamodelId),h=e.useEditorStore(y=>y.actions.setSelectedDatabaseName),u=e.useEditorStore(y=>y.actions.setSelectedSchemaName),j=e.useEditorStore(y=>y.actions.setSelectedTableName),p=e.useEditorStore(y=>y.actions.setCardSql);function v(y){return o&&l&&a&&l!=="NA"?!0:o&&y==="API"?!1:!!(o&&y==="S3")}function g(y){return!!(o&&l&&l!=="NA"&&a&&x||o&&(y==="S3"||y==="API")||i&&i)}function z(y){return o&&y?!(y==="API"||y==="S3"):!1}const{data:I,isLoading:w,isError:D}=e.useQuery({queryKey:["connections"],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/connections",(n==null?void 0:n.accessToken)||""),enabled:!!(n!=null&&n.accessToken)}),{data:L,isLoading:O,isError:m}=e.useQuery({queryKey:["models",o],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/datamodels",(n==null?void 0:n.accessToken)||"",{connection_id:o}),enabled:!!(n!=null&&n.accessToken)&&!!o}),R=I==null?void 0:I.connections.find(y=>y.id===o),E=R==null?void 0:R.type,k=(R==null?void 0:R.type)==="API"||(R==null?void 0:R.type)==="S3",{data:S,isLoading:M,isFetching:V,isError:H,refetch:P}=e.useQuery({queryKey:["databases",o],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/databases",(n==null?void 0:n.accessToken)||"",{connection_id:o}),enabled:z(E)}),{data:_,isLoading:G,isFetching:N,isError:F,refetch:B}=e.useQuery({queryKey:["schemas",o,l],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/schemas",(n==null?void 0:n.accessToken)||"",{connection_id:o,database_name:l}),enabled:!!o&&!!l&&!k&&l!=="NA"}),{data:A,isLoading:T,isFetching:K,isError:q,refetch:$}=e.useQuery({queryKey:["tables",o,l,a],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/tables",(n==null?void 0:n.accessToken)||"",{connection_id:o,database_name:l,schema_name:a}),enabled:v(E)}),{data:U,isLoading:Y,isFetching:re,isError:Z}=e.useQuery({queryKey:["columns",o,l,i,a,x],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/columns",(n==null?void 0:n.accessToken)||"",{connection_id:o,datamodel_id:i||"",database_name:l,schema_name:a,table_name:x}),enabled:g(E)});b.useEffect(()=>{d(t)},[U,d,t]),b.useEffect(()=>{},[k,p,j,u,h,R]);const oe=(R==null?void 0:R.type)==="API"?(pe=R==null?void 0:R.type)==null?void 0:pe.toLowerCase():x||"",ie=k?"":a||"";function ae(y){u(y),j("")}function le(y){h(y==="none"?"":y),u(""),j(""),y!=="none"&&y!==""&&f("")}function C(y){c(y)}function Q(y){f(y==="none"?"":y),y!=="none"&&y!==""&&h("")}S&&((Ae=S==null?void 0:S.databases)==null?void 0:Ae.length)>0,_&&((ze=_==null?void 0:_.schemas)==null?void 0:ze.length)>0,U&&((Oe=U==null?void 0:U.columns)==null?void 0:Oe.length)>0&&(t=U.columns.map(y=>({...y,data_type:y.data_type.toLowerCase()}))),H&&(t=[]),(Z||D)&&(t=[]);const ee=I==null?void 0:I.connections.map(y=>({id:y.id,name:y.name,type:y.type})),J=(Me=L==null?void 0:L.datamodels)==null?void 0:Me.map(y=>({id:y.id,name:y.name})),ue=S==null?void 0:S.databases.map(y=>({id:y.database_name,name:y.database_name})),ve=_==null?void 0:_.schemas.map(y=>({id:y.schema_name,name:y.schema_name})),me=A==null?void 0:A.tables.map(y=>({id:y.table_name,name:y.table_name}));return{connectionItems:ee,isConnectionsLoading:w,isConnectionsError:D,modelItems:J,isModelsLoading:O,isModelsError:m,databaseItems:ue,isDatabasesLoadingOrFetching:M||V,isDatabaseError:H,schemaItems:ve,isSchemaLoadingOrFetching:G||N,isSchemaError:F,tableItems:me,isTableLoadingOrFetching:T||K,isTableError:q,columns:t,isColumnsLoadingOrFetching:Y||re,isColumnsError:Z,isNonDbConnection:k,connectionType:E,tableName:oe,schemaName:ie,handleConnectionChange:C,handleDatamodelChange:Q,handleDatabaseChange:le,handleSchemaChange:ae}}function gs({ColumnsComponent:s}){var K;const r=e.useEditorStore(q=>q.selectedConnectionId),t=e.useEditorStore(q=>q.selectedDatamodelId),n=e.useEditorStore(q=>q.selectedDatabaseName),o=e.useEditorStore(q=>q.selectedSchemaName),i=e.useEditorStore(q=>q.selectedTableName),l=e.useEditorStore(q=>q.actions.setSelectedTableName),{connectionItems:a,modelItems:x,schemaItems:d,databaseItems:c,tableItems:f,columns:h,isConnectionsLoading:u,isModelsLoading:j,isConnectionsError:p,isModelsError:v,isDatabasesLoadingOrFetching:g,isDatabaseError:z,isSchemaLoadingOrFetching:I,isSchemaError:w,isColumnsError:D,isColumnsLoadingOrFetching:L,isTableLoadingOrFetching:O,isTableError:m,connectionType:R,isNonDbConnection:E,handleConnectionChange:k,handleDatabaseChange:S,handleSchemaChange:M,handleDatamodelChange:V,tableName:H,schemaName:P}=te();function _(){return s?s(P,H,h):e.jsxRuntimeExports.jsx(Us,{schemaName:P,tableName:H,columns:h,status:L?"Loading...":D?"Error":"Success"})}function G(){window.location.href="mailto:support@semaphor.cloud?subject=Help&body=I need help with..."}function N(){if(!r||R==="S3"||R==="API")return null;if(!t||t==="none")return e.jsxRuntimeExports.jsx(ce,{showNone:!0,onChange:S,isError:z,isLoading:g,items:c,value:n||"",title:"Database"})}function F(){if(r&&!E&&(!n||n==="none")&&(!t||t==="none"))return e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-3",children:[e.jsxRuntimeExports.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsxRuntimeExports.jsx(e.Separator,{})}),e.jsxRuntimeExports.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsxRuntimeExports.jsx(e.Label,{children:"OR"})}),e.jsxRuntimeExports.jsx("div",{className:"col-span-1 grid place-items-center",children:e.jsxRuntimeExports.jsx(e.Separator,{})})]})}function B(){if(!r||R==="S3"||R==="API")return null;if(!n||n==="none")return e.jsxRuntimeExports.jsx(ce,{showNone:!0,onChange:V,isError:v,isLoading:j,items:x,value:t||"",title:"Model"})}function A(){return!r||R==="S3"||R==="API"||!n||n==="none"?null:e.jsxRuntimeExports.jsx(ce,{onChange:M,isError:w,isLoading:I,items:d,value:o||"",title:"Schema"})}function T(){function q(){let $=!1;return R==="API"?($=!1,$):((R==="S3"||r&&n&&n!=="none"&&o)&&($=!0),$)}return q()?e.jsxRuntimeExports.jsx(ce,{onChange:l,isError:m,items:f,isLoading:O,value:i||"",title:"Table"}):null}return e.jsxRuntimeExports.jsxs("aside",{className:"xbg-red-100 flex grow flex-col justify-between",children:[e.jsxRuntimeExports.jsxs("section",{className:"space-y-3 px-6 py-4",children:[e.jsxRuntimeExports.jsx(ce,{items:a,title:"Connection",value:r||"",onChange:k,isLoading:u,isError:p,connectionTooltip:((K=a==null?void 0:a.find(q=>q.id===r))==null?void 0:K.type)||""}),B(),F(),N(),A(),T()]}),_(),e.jsxRuntimeExports.jsx("div",{className:"flex items-end justify-center gap-2 px-6 py-4",children:e.jsxRuntimeExports.jsxs(e.Button,{onClick:G,size:"sm",variant:"secondary",className:"w-full",children:[e.jsxRuntimeExports.jsx(os,{className:"mr-2 size-4"}),"Help"]})})]})}function Qs(s){const r=s.toUpperCase().indexOf("WHERE"),t=s.toUpperCase().indexOf("GROUP BY"),n=s.toUpperCase().indexOf("LIMIT"),o=s.toUpperCase().indexOf("ORDER BY");let i=s.length;if(o!==-1&&(i=o),n!==-1&&n<i&&(i=n),r!==-1){const l=s.substring(0,r),a=s.substring(r);return`${l} {{ filters | where }} AND ${a.substring(6)}`}else if(t!==-1){const l=s.substring(0,t),a=s.substring(t);return`${l} {{ filters | where }} ${a}`}else{const l=s.substring(0,i),a=s.substring(i);return`${l} {{ filters | where }} ${a}`}}function Ks({error:s,setShowAIDialog:r,setUserInputforAI:t,setTriggerAIRun:n}){return e.jsxRuntimeExports.jsxs(e.HoverCard,{openDelay:0,children:[e.jsxRuntimeExports.jsx(e.HoverCardTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{variant:"link",className:"h-5 p-0",children:e.jsxRuntimeExports.jsx(Ue,{className:"h-4 w-4 text-red-500"})})}),e.jsxRuntimeExports.jsx(e.HoverCardContent,{align:"start",className:"w-full min-w-fit max-w-[700px]",children:e.jsxRuntimeExports.jsx("div",{className:"flex justify-between space-x-4",children:e.jsxRuntimeExports.jsxs("div",{className:"flex grow flex-col space-y-2",children:[e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"max-h-[250px] min-h-0 overflow-scroll",children:e.jsxRuntimeExports.jsx("p",{className:"overflow-auto rounded-md bg-muted p-2 text-xs leading-relaxed",children:s})}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:()=>{r(!0),t(s),n(!0)},size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(Ye,{className:"mr-2 h-4 w-4"}),"Debug with AI"]})]})})})]})}const Js=`
187
192
 
188
193
  Use the following syntax to create a chart query. Please replace the x-axis, y-axis, stack-by, label, and measure with the actual column names of the table.
189
194
 
@@ -229,7 +234,7 @@ SELECT label, measure FROM table
229
234
 
230
235
  - Label - Category
231
236
  - Measure - Number
232
- `;function Js({open:s,setOpen:r,userInput:t,setUserInput:n,triggerAIRun:o,setTriggerAIRun:i}){const l=b.useRef(null),a=b.useRef(null),{authToken:x}=e.useSemaphorContext(),[d,c]=b.useState(!1),f=e.useEditorStore(N=>N.actions.setCardSql),h=e.useDashboardStore(N=>N.dashboard.baseQueries),u=e.useEditorStore(N=>N.actions.setRunSql),j=e.useEditorStore(N=>N.actions.setCardType),[p,v]=b.useState([]),g=e.useEditorStore(N=>N.currentColumns),z=e.useEditorStore(N=>N.card.sql),I=e.useEditorStore(N=>N.selectedTableName),w=`
237
+ `;function Ws({open:s,setOpen:r,userInput:t,setUserInput:n,triggerAIRun:o,setTriggerAIRun:i}){const l=b.useRef(null),a=b.useRef(null),{authToken:x}=e.useSemaphorContext(),[d,c]=b.useState(!1),f=e.useEditorStore(N=>N.actions.setCardSql),h=e.useDashboardStore(N=>N.dashboard.baseQueries),u=e.useEditorStore(N=>N.actions.setRunSql),j=e.useEditorStore(N=>N.actions.setCardType),[p,v]=b.useState([]),g=e.useEditorStore(N=>N.currentColumns),z=e.useEditorStore(N=>N.card.sql),I=e.useEditorStore(N=>N.selectedTableName),w=`
233
238
  ${t}
234
239
 
235
240
  Database Query Dialect: ${I==="api"||I==="s3"?"DuckDb":""}
@@ -237,4 +242,4 @@ SELECT label, measure FROM table
237
242
  Table Columns: ${g==null?void 0:g.map(N=>`${N.column_name} | ${N.data_type}`).join(", ")}
238
243
  User SQL: ${z}
239
244
  ${h&&`Base Queries: ${JSON.stringify(h)} `}`,D=` When the user asks for a specific chart please use the following query structure to generate the chart query. Do not make up the column names. Use only the table columns provided above for the query. Replace x-axis, y-axis, and lables with the appropriate column names.
240
- Visual Query Syntax: ${Ks}`,{data:L,isLoading:O,isFetching:m,isError:R,refetch:E}=e.useQuery({queryKey:["ai-query"],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/ai",(x==null?void 0:x.accessToken)||"",{user_content:`userContent: ${w} ${d?D:""}`}),enabled:!1});function k(N){if(N.toLowerCase().includes("bar"))j("bar");else if(N.toLowerCase().includes("line"))j("line");else if(N.toLowerCase().includes("bubble"))j("bubble");else if(N.toLowerCase().includes("scatter"))j("scatter");else if(N.toLowerCase().includes("stacked"))j("stackedBar");else if(N.toLowerCase().includes("pie"))j("pie");else if(N.toLowerCase().includes("donut")||N.toLowerCase().includes("doughnut"))j("doughnut");else if(N.toLowerCase().includes("radar"))j("radar");else return j("bar"),!1;return!0}b.useEffect(()=>{L&&v(N=>[...N,{role:"ai",content:L.response}])},[L]),b.useEffect(()=>{const N=setTimeout(()=>{var F;a.current&&(a.current.scroll({top:a.current.scrollHeight,behavior:"smooth"}),(F=l.current)==null||F.focus())},100);return()=>clearTimeout(N)},[p]);function S(){t&&(v(N=>[...N,{role:"user",content:t}]),k(t)&&c(!0),n(""),E())}b.useEffect(()=>{o&&(S(),i(!1))},[o,i]);const M={fontFamily:"Arial, sans-serif",lineHeight:1.6,fontSize:15,width:"100%"},V={fontFamily:"monospace",fontSize:14,lineHeight:1.6},H={fontFamily:"Arial, sans-serif",lineHeight:1.6,fontSize:15,padding:"2px 0",marginLeft:20,listStyleType:"disc"},P={p:({node:N,...F})=>e.jsxRuntimeExports.jsx("p",{style:M,...F}),code:({node:N,...F})=>e.jsxRuntimeExports.jsx("code",{className:"rounded-sm bg-muted px-2 py-1 text-sm",...F}),pre:({node:N,...F})=>e.jsxRuntimeExports.jsxs("pre",{className:"space-y-2 rounded-sm bg-muted/50 p-3",style:V,children:[e.jsxRuntimeExports.jsx("code",{className:"whitespace-normal text-sm",children:F.children}),e.jsxRuntimeExports.jsxs("div",{className:"flex justify-start gap-2",children:[e.jsxRuntimeExports.jsx(e.Button,{onClick:_,size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(e.ClipboardCopyIcon,{})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:B=>{const A=_(B);A&&(r(!1),f(A),u(!0))},size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(e.PlayIcon,{})})]})]}),li:({node:N,...F})=>e.jsxRuntimeExports.jsx("li",{style:H,...F})};function _(N){const F=N.currentTarget.closest("pre");if(!F)return;const B=F.textContent||F.innerText;return navigator.clipboard.writeText(B).then(()=>console.log("Text copied to clipboard")).catch(A=>console.error("Error in copying text: ",A)),B}function G(){return p==null?void 0:p.map((N,F)=>N.role==="user"?e.jsxRuntimeExports.jsxs("div",{className:"flex items-start rounded-md bg-muted p-3 text-sm",children:[e.jsxRuntimeExports.jsx(js,{className:"mr-2 h-5 w-5"}),e.jsxRuntimeExports.jsx("div",{children:N.content})]},F):N.role==="ai"?e.jsxRuntimeExports.jsx(e.Markdown,{className:"w-full overflow-auto py-1",components:P,children:L==null?void 0:L.response.replace(/DuckDB/gi,"Semaphor")},F):e.jsxRuntimeExports.jsx("div",{},F))}return e.jsxRuntimeExports.jsxs(e.Dialog,{open:s,onOpenChange:r,children:[e.jsxRuntimeExports.jsx(e.DialogTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{size:"sm",className:"w-full justify-start border font-normal text-muted-foreground focus-visible:ring-0 focus-visible:ring-offset-0",variant:"secondary",children:"Type your question here..."})}),e.jsxRuntimeExports.jsxs(e.DialogContent,{className:"flex flex-col justify-between overflow-auto sm:max-w-[425px] md:max-h-[625px] md:min-w-[625px]",children:[e.jsxRuntimeExports.jsxs(e.DialogHeader,{children:[e.jsxRuntimeExports.jsx(e.DialogTitle,{children:"Assistant"}),e.jsxRuntimeExports.jsx(e.DialogDescription,{children:"What can I help you with?"})]}),e.jsxRuntimeExports.jsx("div",{ref:a,className:"h-[625px] w-full overflow-auto border-t border-t-muted",children:e.jsxRuntimeExports.jsx("div",{className:"space-y-4 py-2 pr-3",role:"messages",children:G()})}),e.jsxRuntimeExports.jsx("div",{children:e.jsxRuntimeExports.jsxs("div",{className:"flex w-full items-center rounded-md border",children:[e.jsxRuntimeExports.jsx(e.Textarea,{autoFocus:!0,ref:l,onKeyDown:N=>{N.key==="Enter"&&!N.shiftKey&&(N.preventDefault(),n(""),S())},placeholder:"Type your question here...",onFocus:N=>{const F=N.target,B=F.value.length;F.setSelectionRange(B,B)},className:e.cn("max-h-10 min-h-7 resize-none border-none focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0"),disabled:O||m,value:t,onChange:N=>n(N.target.value)})," ",e.jsxRuntimeExports.jsx(e.Button,{className:"h-8",size:"sm",variant:"ghost",onClick:S,children:!O&&!m?e.jsxRuntimeExports.jsx(e.PaperPlaneIcon,{}):e.jsxRuntimeExports.jsx(se,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"})})]})})]})]})}var gs={color:void 0,size:void 0,className:void 0,style:void 0,attr:void 0},Ve=b.createContext&&b.createContext(gs),Ws=["attr","size","title"];function Ys(s,r){if(s==null)return{};var t=Xs(s,r),n,o;if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(s);for(o=0;o<i.length;o++)n=i[o],!(r.indexOf(n)>=0)&&Object.prototype.propertyIsEnumerable.call(s,n)&&(t[n]=s[n])}return t}function Xs(s,r){if(s==null)return{};var t={};for(var n in s)if(Object.prototype.hasOwnProperty.call(s,n)){if(r.indexOf(n)>=0)continue;t[n]=s[n]}return t}function Ee(){return Ee=Object.assign?Object.assign.bind():function(s){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(s[n]=t[n])}return s},Ee.apply(this,arguments)}function qe(s,r){var t=Object.keys(s);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(s);r&&(n=n.filter(function(o){return Object.getOwnPropertyDescriptor(s,o).enumerable})),t.push.apply(t,n)}return t}function fe(s){for(var r=1;r<arguments.length;r++){var t=arguments[r]!=null?arguments[r]:{};r%2?qe(Object(t),!0).forEach(function(n){Zs(s,n,t[n])}):Object.getOwnPropertyDescriptors?Object.defineProperties(s,Object.getOwnPropertyDescriptors(t)):qe(Object(t)).forEach(function(n){Object.defineProperty(s,n,Object.getOwnPropertyDescriptor(t,n))})}return s}function Zs(s,r,t){return r=et(r),r in s?Object.defineProperty(s,r,{value:t,enumerable:!0,configurable:!0,writable:!0}):s[r]=t,s}function et(s){var r=st(s,"string");return typeof r=="symbol"?r:r+""}function st(s,r){if(typeof s!="object"||!s)return s;var t=s[Symbol.toPrimitive];if(t!==void 0){var n=t.call(s,r||"default");if(typeof n!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(r==="string"?String:Number)(s)}function Rs(s){return s&&s.map((r,t)=>b.createElement(r.tag,fe({key:t},r.attr),Rs(r.child)))}function Y(s){return r=>b.createElement(tt,Ee({attr:fe({},s.attr)},r),Rs(s.child))}function tt(s){var r=t=>{var{attr:n,size:o,title:i}=s,l=Ys(s,Ws),a=o||t.size||"1em",x;return t.className&&(x=t.className),s.className&&(x=(x?x+" ":"")+s.className),b.createElement("svg",Ee({stroke:"currentColor",fill:"currentColor",strokeWidth:"0"},t.attr,n,l,{className:x,style:fe(fe({color:s.color||t.color},t.style),s.style),height:a,width:a,xmlns:"http://www.w3.org/2000/svg"}),i&&b.createElement("title",null,i),s.children)};return Ve!==void 0?b.createElement(Ve.Consumer,null,t=>r(t)):r(gs)}function nt(s){return Y({tag:"svg",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 rt({sql:s}){return e.jsxRuntimeExports.jsxs(e.HoverCard,{children:[e.jsxRuntimeExports.jsx(e.HoverCardTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{variant:"link",className:"h-5 p-0",children:e.jsxRuntimeExports.jsx(e.Info,{className:"h-4 w-4 text-muted-foreground"})})}),e.jsxRuntimeExports.jsx(e.HoverCardContent,{align:"end",className:"w-full min-w-fit max-w-[700px] p-3 pt-2",children:e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"text-xs font-semibold",children:"Resolved Query"}),e.jsxRuntimeExports.jsx("div",{className:"flex grow flex-col space-y-2",children:e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"max-h-[250px] min-h-0 overflow-scroll",children:e.jsxRuntimeExports.jsx("p",{className:"overflow-auto rounded-md bg-muted p-2 font-mono text-xs leading-relaxed",children:s})})})]})})]})}function bs(s){const{theme:r}=e.useTheme(),t=e.useDashboardStore(p=>p.theme),n=e.useEditorStore(p=>p.frame),o=e.useEditorStore(p=>p.card),i=e.useEditorStore(p=>p.activeTabCardId),l=e.Le(),{refetch:a}=e.useDashboardCardQuery(o),{updateCardTab:x,setRunSql:d}=e.useEditorActions(),c=b.useRef(),f=b.useRef({}),h=n.cards.find(p=>p.id===i),u=b.useCallback(()=>{let p="";return s==="python"&&(p=(h==null?void 0:h.python)||e.PYTHON_DEFAULT_CODE),s==="sql"&&(p=(h==null?void 0:h.sql)||""),p},[s,h]);b.useEffect(()=>{if(i&&o.id&&o.id!==i){if(c.current&&l){const p=c.current.getModel();p&&(f.current[o.id]=p);let v=f.current[i];if(!v){const g=u();v=l.editor.createModel(g,s),f.current[i]=v}c.current.setModel(v)}x(i,o),d(!0)}},[i,o,x,l,d,s,u]),b.useEffect(()=>{if(!l)return;const p=window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light",v=t==="system"?p:t;l.editor.defineTheme("default",{base:v==="light"?"vs":"vs-dark",inherit:!0,rules:[],colors:{"editor.background":v==="light"?"#ffffff":e.hslStringToHex("240 10% 10%")}}),l.editor.setTheme("default")},[r,t,l]),b.useEffect(()=>{const p=c.current;p&&l&&o&&p.addCommand(l.KeyMod.Shift|l.KeyCode.Enter,function(){return a(),!1})},[l,a,o]);function j(p,v){if(c.current=p,!f.current[o.id]){const g=p.getModel(),z=u();f.current[o.id]=g||(v==null?void 0:v.editor.createModel(z,s))||p.getModel()}p.setModel(f.current[o.id])}return{handleEditorDidMount:j}}function ot(){const s=e.useEditorStore(l=>l.card.sql),r=e.useEditorStore(l=>l.sqlGen),{setCardSql:t,setSqlGen:n}=e.useEditorActions(),{handleEditorDidMount:o}=bs("sql");function i(l){t(l),e.isObjectEmpty(r)||n({})}return e.jsxRuntimeExports.jsx(e.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 it(){const s=e.useEditorStore(o=>o.card.python),{setCardPython:r}=e.useEditorActions(),{handleEditorDidMount:t}=bs("python");function n(o){r(o)}return e.jsxRuntimeExports.jsx(e.Ft,{className:"pt-3",theme:"default",onChange:n,value:s||e.PYTHON_DEFAULT_CODE,options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:13,renderLineHighlight:"none"},defaultLanguage:"python",onMount:t})}function at(){const s=e.useDashboardStore(i=>i.dashboard.filters),r=e.useDashboardStore(i=>i.filterValues),t=e.useDashboardStore(i=>i.selectedSheetId),n=s==null?void 0:s.filter(i=>i.sheetId===t||!i.sheetId),o=r==null?void 0:r.filter(i=>(n==null?void 0:n.some(l=>l.id===i.filterId))||i.filterId.endsWith(t));return e.jsxRuntimeExports.jsx(e.Ft,{theme:"default",defaultLanguage:"json",className:"mt-1 min-h-[220px]",value:JSON.stringify(o,null,2),options:{readOnly:!0,minimap:{enabled:!1},lineNumbers:"off",glyphMargin:!1,wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:12,renderLineHighlight:"none"}})}function lt(){const[s,r]=b.useState({queryKey:[],queryData:null}),t=e.useQueryClient(),[n,o]=b.useState(!1),[i,l]=b.useState(!1),[a,x]=b.useState(!1),[d,c]=b.useState(""),[f,h]=b.useState(!1),u=e.useEditorStore(C=>C.frame),j=e.useEditorStore(C=>C.card),p=e.useEditorStore(C=>C.isShowingVisual),v=e.useEditorStore(C=>C.selectedConnectionId),g=e.useEditorStore(C=>C.selectedDatabaseName),z=e.useEditorStore(C=>C.selectedDatamodelId),I=e.useEditorStore(C=>C.selectedSchemaName),w=e.useEditorStore(C=>C.selectedTableName),D=e.useEditorStore(C=>{var Q;return(Q=C==null?void 0:C.card)==null?void 0:Q.sql}),L=e.useEditorStore(C=>C.applyFilters),{setCardCustomCfg:O,setQueryResultColumns:m,setCardSql:R,setQueryError:E,setPythonStdOut:k,setCardPreferences:S,setCardType:M}=e.useEditorActions(),V=e.useEditorStore(C=>C.onSave),H=e.useEditorStore(C=>C.onClose),P=e.useEditorStore(C=>C.actions.setSqlGen),_=e.useEditorStore(C=>C.runSql),G=e.useEditorStore(C=>C.actions.setRunSql),N=e.useEditorStore(C=>C.actions.setCardCfg),F=e.useEditorStore(C=>C.actions.setIsSqlRunning),{data:B,isLoading:A,isFetching:T,isSuccess:K,isError:q,error:$,queryKey:U,refetch:X}=e.useDashboardCardQuery(j);b.useEffect(()=>{if(B&&(B.rowLimitExceeded&&e.ce.error("Row limit (10,000) exceeded. Refine your query.",{position:"top-center",richColors:!0}),k((B==null?void 0:B.output)||""),B.records.length>0)){const{dimensionKeys:C}=e.getKeys(B.records);m(C)}},[B,m,k]),b.useEffect(()=>{(A||T)&&F(!0),(q||K)&&F(!1),q?(E($.message),m([]),k("")):E("")},[A,T,B,k,q,K,F,m,E,$]),b.useEffect(()=>{_&&(t.getQueryData(U)||X(),G(!1))},[_,X,G,U,t]);function re(){const C=t.getQueryData(U);s.queryData||r({queryKey:U,queryData:C}),R(""),P({}),N(void 0),O(""),S({}),M("bar")}function Z(C,Q){if(C.length===0)return"";if(Q){const ee=C.find(J=>J.id===Q);if(ee){const J=ee.tabTitle;if(J=="All__Header")return C[0].id;if(J&&J.endsWith("__Header")){const ve=J.split("__")[0],me=C.find(pe=>pe.tabTitle===ve);return me?me.id:C[0].id}return Q}}return C[0].id}function oe(){let C=D;D&&!D.includes("{{")&&(C=Us(D),R(C));const Q={...j,lastSelectedSchema:I,lastSelectedDatamodelId:z,lastSelectedDatabase:g,lastSelectedTable:w,connectionId:v,type:p?j.type:"table",sql:C,customCfg:p?j.customCfg:null},ee=u.cards.map(ue=>ue.id===j.id?Q:ue),J={...u,cards:ee,activeCardId:Z(ee,u.activeCardId)};V==null||V(J)}function ie(){const{queryKey:C,queryData:Q}=s;C&&Q&&t.setQueryData(C,Q),H==null||H()}function ae(){return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[i&&e.jsxRuntimeExports.jsx("div",{className:"relative flex w-1/3 min-w-0 grow overflow-hidden border-l p-1 text-xs",role:"editor-filter-container",children:e.jsxRuntimeExports.jsxs("div",{className:"w-[99%]",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2 pt-3",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"ml-6 text-xs font-semibold",children:"Filters"}),i&&e.jsxRuntimeExports.jsx(e.Cross2Icon,{onClick:()=>l(!1),className:"bg-background/50 text-foreground/50 hover:cursor-pointer hover:text-foreground"})]}),e.jsxRuntimeExports.jsx(at,{})]})}),!i&&e.jsxRuntimeExports.jsx(e.Filter,{onClick:()=>l(!0),className:e.cn("absolute bottom-4 right-6 h-3 w-3 text-foreground/50 hover:cursor-pointer hover:text-foreground",{"font-bold text-red-800":L})})]})}function le(){return e.jsxRuntimeExports.jsxs(e.ResizablePanelGroup,{className:"flex grow pb-1",direction:"vertical",role:"editor-resizable-group",children:[e.jsxRuntimeExports.jsxs(e.ResizablePanel,{id:"1",order:1,defaultSize:n?20:100,className:"relative flex grow",children:[e.jsxRuntimeExports.jsx("div",{id:"sql-container",className:"relative flex w-[99%]",children:e.jsxRuntimeExports.jsx(ot,{})}),n&&e.jsxRuntimeExports.jsx("code",{className:"absolute right-6 top-3 text-xs text-muted-foreground/70",children:"sql"})]}),n&&e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx(e.ResizableHandle,{withHandle:!0,className:"border"}),e.jsxRuntimeExports.jsxs(e.ResizablePanel,{id:"2",order:2,defaultSize:80,className:"relative flex grow",children:[e.jsxRuntimeExports.jsx("div",{id:"python-container",className:"relative flex w-[99%] pt-0",children:e.jsxRuntimeExports.jsx(it,{})}),e.jsxRuntimeExports.jsx("code",{className:"absolute right-6 top-3 text-xs text-muted-foreground/70",children:"python"})]})]})]})}return e.jsxRuntimeExports.jsxs("section",{role:"editor-section",className:"flex grow flex-col justify-end",children:[e.jsxRuntimeExports.jsxs("div",{className:"relative flex grow justify-between overflow-y-scroll",children:[le(),ae()]}),e.jsxRuntimeExports.jsxs("div",{role:"editor-controls",className:"item-center flex flex-wrap justify-between gap-2 px-6 py-4",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex grow items-center gap-2",children:[e.jsxRuntimeExports.jsxs(e.Button,{title:"Shift + Enter",disabled:A||T,onClick:()=>{X()},className:"shrink-0",size:"sm",variant:"outline",children:[A||T?e.jsxRuntimeExports.jsx(se,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsxRuntimeExports.jsx(as,{className:"mr-2 h-4 w-4"}),"Run"]}),q&&e.jsxRuntimeExports.jsx(Qs,{error:$.message,setShowAIDialog:x,setTriggerAIRun:h,setUserInputforAI:c}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:re,className:"",size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(Je,{className:"mr-2 size-4"}),"Clear"]}),e.jsxRuntimeExports.jsx(e.Toggle,{pressed:n,onPressedChange:C=>o(C),className:"",size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(nt,{className:"size-4 text-foreground/70"})}),e.jsxRuntimeExports.jsx(Js,{open:a,setOpen:x,userInput:d,triggerAIRun:f,setTriggerAIRun:h,setUserInput:C=>c(C)})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[(B==null?void 0:B.sql)&&e.jsxRuntimeExports.jsx(rt,{sql:B.sql}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:ie,className:"w-full",size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(e.Cross2Icon,{className:"mr-2 size-4"}),"Close"]}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:oe,size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(e.Check,{className:"mr-2 size-4 font-bold text-green-600"}),"Accept"]})]})]})]})}function ct({data:s}){var l;const[r,t]=b.useState([]),o=Object.keys(s[0]).map(a=>({accessorKey:a,header:({column:x})=>{const d=x.getIsSorted();return e.jsxRuntimeExports.jsx("div",{className:"flex gap-2",children:e.jsxRuntimeExports.jsxs("div",{className:"flex cursor-pointer items-center",onClick:()=>x.toggleSorting(x.getIsSorted()==="asc"),children:[a,d==="asc"?e.jsxRuntimeExports.jsx(e.TriangleUpIcon,{className:"ml-2 h-5 w-5"}):d==="desc"?e.jsxRuntimeExports.jsx(e.TriangleDownIcon,{className:"ml-2 h-5 w-5"}):null]})})}})),i=e.useReactTable({data:s,columns:o,getCoreRowModel:e.getCoreRowModel(),getPaginationRowModel:e.getPaginationRowModel(),onSortingChange:t,getSortedRowModel:e.getSortedRowModel(),manualPagination:!0,state:{sorting:r}});return e.jsxRuntimeExports.jsx("div",{className:"font-mono text-xs text-foreground/95",children:e.jsxRuntimeExports.jsxs("table",{className:"w-full",children:[e.jsxRuntimeExports.jsx(e.TableHeader,{children:i.getHeaderGroups().map(a=>e.jsxRuntimeExports.jsx(e.TableRow,{children:a.headers.map(x=>e.jsxRuntimeExports.jsx(e.TableHead,{className:"sticky top-0 h-11 bg-muted font-semibold",children:x.isPlaceholder?null:e.flexRender(x.column.columnDef.header,x.getContext())},x.id))},a.id))}),e.jsxRuntimeExports.jsx(e.TableBody,{children:(l=i.getRowModel().rows)!=null&&l.length?i.getRowModel().rows.map(a=>e.jsxRuntimeExports.jsx(e.TableRow,{className:"whitespace-nowrap py-2","data-state":a.getIsSelected()&&"selected",children:a.getVisibleCells().map(x=>e.jsxRuntimeExports.jsx(e.TableCell,{className:"py-3",children:e.flexRender(x.column.columnDef.cell,x.getContext())},x.id))},a.id)):e.jsxRuntimeExports.jsx(e.TableRow,{children:e.jsxRuntimeExports.jsx(e.TableCell,{colSpan:o.length,className:"h-24 text-center",children:"No results."})})})]})})}function xt({card:s}){var g,z,I,w,D,L,O,m,R,E,k;const[r,t]=b.useState(!1),[n,o]=b.useState([]),{authToken:i}=e.useSemaphorContext(),l=e.getTokenParams(i==null?void 0:i.accessToken),a=e.useDashboardStore(S=>S.themeStyle),x={colors:((z=(g=a==null?void 0:a.chart)==null?void 0:g.dataset)==null?void 0:z.backgroundColor)||[]};(I=s.customCardPreferences)!=null&&I.inputData;const{getCard:d}=e.useCustomVisual(((w=s.customCardPreferences)==null?void 0:w.url)||""),c=((D=s.customCardPreferences)==null?void 0:D.visualType)||"single",f=e.useEditorStore(S=>S.frame);e.useEditorActions();const{data:h}=e.useDashboardCardQuery(s),u=b.useCallback((S,M)=>{o(V=>({...V,[S]:M}))},[]);if(!((L=s.customCardPreferences)!=null&&L.componentName))return null;const j=d((O=s.customCardPreferences)==null?void 0:O.componentName);function p(S){t(S)}const v=Object.keys(((m=s.customCardPreferences)==null?void 0:m.dataInputCardIds)||{}).map(S=>{var H,P,_;const M=(P=(H=s.customCardPreferences)==null?void 0:H.dataInputCardIds)==null?void 0:P[S].cardId,V=(_=f==null?void 0:f.cards)==null?void 0:_.find(G=>G.id===M);return V||null});return e.jsxRuntimeExports.jsx("div",{className:"semaphor-custom mb-3 flex grow basis-0 flex-col space-y-2 overflow-y-auto",children:e.jsxRuntimeExports.jsxs(b.Suspense,{fallback:e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{}),children:[j&&c==="single"&&e.jsxRuntimeExports.jsx(j,{params:l,theme:x,settings:(R=s.customCardPreferences)==null?void 0:R.settings,onDataChange:u,data:(h==null?void 0:h.records)||[]}),j&&c==="multiple"&&e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[Object.keys(((E=s.customCardPreferences)==null?void 0:E.dataInputCardIds)||{}).map(S=>{var H,P,_;const M=(P=(H=s.customCardPreferences)==null?void 0:H.dataInputCardIds)==null?void 0:P[S].cardId,V=(_=f==null?void 0:f.cards)==null?void 0:_.find(G=>G.id===M);if(V)return e.jsxRuntimeExports.jsx(e.MultiInputEmptyRenderer,{onLoadingStatus:p,onDataChange:u,dataInputIndex:S,card:V},V.id+S)}),e.jsxRuntimeExports.jsx("div",{className:"flex flex-col gap-2",children:e.jsxRuntimeExports.jsx(j,{theme:x,onDataChange:u,settings:v.map(S=>{var M;return(M=S==null?void 0:S.customCardPreferences)==null?void 0:M.settings}),data:v.map(S=>S!=null&&S.id?n==null?void 0:n[S.id]:[])})})]})]},(k=s.customCardPreferences)==null?void 0:k.componentName)})}function ys({className:s,...r}){var v;const t=e.useEditorStore(g=>g.card),n=((v=t.customCardPreferences)==null?void 0:v.showCardHeader)??!0,o=e.useEditorStore(g=>g.frame),i=e.useDashboardStore(g=>g.dashboard.filters);e.useEditorStore(g=>g.actions.setRunSql);const{updateFilter:l}=e.useDashboardActions(),a=i==null?void 0:i.find(g=>g.id===o.filterId),{data:x,isLoading:d,isFetching:c}=e.useDashboardCardQuery(t),{setCard:f}=e.useEditorActions(),{data:h}=e.useTopoJson(t);if(!t.id)return null;let u;x!=null&&x.records&&(x==null?void 0:x.records.length)>0&&(u=e.createChartConfig({data:x==null?void 0:x.records,cardType:t.type,cfg:t.cfg,customCfg:t.customCfg,preferences:t.preferences,topoJson:h}));function j(g){return e.jsxRuntimeExports.jsx(xt,{card:g})}function p(){var g;if(x!=null&&x.records&&(x==null?void 0:x.records.length)===0&&!d&&!c)return e.jsxRuntimeExports.jsxs("div",{className:"flex h-full flex-col items-center justify-center gap-2",children:[e.jsxRuntimeExports.jsx(e.TreePalm,{className:"size-8 text-muted-foreground"}),e.jsxRuntimeExports.jsx("p",{className:"text-sm text-muted-foreground",children:"No records to display"})]});if(t.type==="custom")return j(t);if(!["table","custom"].includes(t.type)&&u)return e.jsxRuntimeExports.jsx(e.ChartJsVisual,{cfg:u},JSON.stringify(u)+JSON.stringify(t.preferences)+((g=t==null?void 0:t.preferences)==null?void 0:g.customVisualCode));if(t.type==="table"&&(x!=null&&x.records)&&(x==null?void 0:x.records.length)>0)return e.jsxRuntimeExports.jsxs(e.ScrollArea,{className:"relative mb-2 flex h-full min-h-0 w-full flex-1 grow basis-0",children:[e.jsxRuntimeExports.jsx(e.TableVisual,{card:t,data:x==null?void 0:x.records}),e.jsxRuntimeExports.jsx(e.ScrollBar,{orientation:"horizontal"})]})}return e.jsxRuntimeExports.jsxs(e.Card,{role:"editor-visual-card",className:e.cn("relative flex h-full flex-col rounded-none",s),...r,children:[n&&e.jsxRuntimeExports.jsxs(e.CardHeader,{className:"flex flex-row items-start justify-between py-4",children:[e.jsxRuntimeExports.jsxs("div",{children:[e.jsxRuntimeExports.jsx(e.Editable,{text:t.title,onSave:g=>f({...t,title:g}),children:e.jsxRuntimeExports.jsx("div",{className:"flex items-center gap-5",children:e.jsxRuntimeExports.jsx(e.CardTitle,{className:"text-base",children:t.title||"Edit title..."})})},t.title),e.jsxRuntimeExports.jsx(e.Editable,{text:t.description||"",onSave:g=>f({...t,description:g}),children:e.jsxRuntimeExports.jsx(e.CardDescription,{children:t.description||"Edit description..."})},t.description)]}),a&&e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-3",children:[e.jsxRuntimeExports.jsx(e.Editable,{className:"my-1",text:a.title||a.column,onSave:g=>l({...a,title:g}),children:e.jsxRuntimeExports.jsx(e.Label,{children:a.title})}),e.jsxRuntimeExports.jsx(e.FilterComponent,{filter:a})]})]}),e.jsxRuntimeExports.jsx(e.CardContent,{className:"flex grow flex-col",children:p()})]})}const Be=({language:s,value:r,onChange:t})=>e.jsxRuntimeExports.jsx(e.Ft,{className:"h-full w-full overflow-hidden",theme:"default",options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:14,renderLineHighlight:"none"},defaultLanguage:s,value:r,onChange:t}),ut=({card:s})=>e.jsxRuntimeExports.jsxs(e.DialogHeader,{children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.DialogTitle,{children:"Customize Card"}),e.jsxRuntimeExports.jsxs(e.Tooltip,{children:[e.jsxRuntimeExports.jsx(e.TooltipTrigger,{children:e.jsxRuntimeExports.jsx(ss,{onClick:()=>navigator.clipboard.writeText(s.id),className:"size-3 cursor-pointer text-muted-foreground/70 transition-colors hover:text-muted-foreground"})}),e.jsxRuntimeExports.jsx(e.TooltipContent,{side:"right",align:"center",children:e.jsxRuntimeExports.jsx("p",{className:"text-xs",children:"Copy Card ID"})})]})]}),e.jsxRuntimeExports.jsxs(e.DialogDescription,{children:["See the configuration options and documentation",e.jsxRuntimeExports.jsx("a",{target:"_blank",className:"ml-1 text-blue-500 underline",href:"https://www.chartjs.org/docs/latest/samples/bar/vertical.html",children:"here."})]})]}),dt=({defaultConfig:s,customCode:r,customConfig:t,onConfigChange:n,onCodeChange:o})=>e.jsxRuntimeExports.jsxs(e.Tabs,{defaultValue:"custom-config",className:"flex w-1/2 flex-col",children:[e.jsxRuntimeExports.jsxs(e.TabsList,{className:"justify-start rounded-sm rounded-b-none border border-b-0",children:[e.jsxRuntimeExports.jsxs(e.TabsTrigger,{value:"custom-config",children:[t&&e.jsxRuntimeExports.jsx(e.CheckIcon,{className:"mr-1 h-5 w-5 text-green-600"}),t?"Custom Config":"Default Config"]}),e.jsxRuntimeExports.jsx(e.TabsTrigger,{value:"output",children:"Output"}),e.jsxRuntimeExports.jsx(e.TabsTrigger,{value:"custom-code",children:"Custom Code"})]}),e.jsxRuntimeExports.jsx(e.TabsContent,{value:"output",className:"mt-0 grow rounded-b border border-t-0 p-2",children:e.jsxRuntimeExports.jsx(e.Textarea,{readOnly:!0,value:s,className:"h-full resize-none border-none font-mono focus-visible:ring-0"})}),e.jsxRuntimeExports.jsx(e.TabsContent,{value:"custom-config",className:"mt-0 grow rounded-b border border-t-0",children:e.jsxRuntimeExports.jsx(Be,{language:"json",value:t,onChange:n})}),e.jsxRuntimeExports.jsx(e.TabsContent,{value:"custom-code",className:"mt-0 grow rounded-b border border-t-0",children:e.jsxRuntimeExports.jsx(Be,{language:"javascript",value:r,onChange:o})})]}),mt=({error:s,hasCustomConfig:r,onReset:t,onApply:n,onClose:o})=>e.jsxRuntimeExports.jsxs(e.DialogFooter,{className:"flex items-center",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"mr-2 text-red-500",children:s}),e.jsxRuntimeExports.jsx(e.Button,{disabled:!r,onClick:t,variant:"outline",children:"Reset"}),e.jsxRuntimeExports.jsx(e.Button,{onClick:n,variant:"outline",children:"Apply"}),e.jsxRuntimeExports.jsx(e.Button,{onClick:o,variant:"outline",children:"Close"})]});function pt(){const[s,r]=b.useState(!1),[t,n]=b.useState(""),[o,i]=b.useState(""),[l,a]=b.useState(""),[x,d]=b.useState(""),c=e.useEditorStore(w=>w.card),f=e.useEditorStore(w=>w.card.customCfg),{data:h}=e.useDashboardCardQuery(c),{data:u}=e.useTopoJson(c),{setCardCustomCfg:j,setCustomVisualCode:p}=e.useEditorActions(),v=w=>{var D,L;return JSON.stringify({...w,data:{...w.data,datasets:(L=(D=w.data)==null?void 0:D.datasets)==null?void 0:L.map(O=>({...O,data:[]}))}},null,2)},g=()=>{var D,L;if(!((D=h==null?void 0:h.records)!=null&&D.length))return;const w=e.createChartConfig({data:h.records,cardType:c.type,cfg:c.cfg,preferences:c.preferences,topoJson:u});w&&(n(v(w)),a(((L=c.preferences)==null?void 0:L.customVisualCode)||""),i(f?JSON.stringify(f,null,2):""))},z=()=>{try{if(l&&p(l),o){const w=JSON.parse(o);j(w),d("")}}catch{d("Invalid JSON configuration")}},I=()=>{if(f){const w=e._.merge(e._.cloneDeep(c.cfg),f);return v(w)}return t?v(JSON.parse(t)):""};return e.jsxRuntimeExports.jsxs(e.Dialog,{open:s,onOpenChange:r,children:[e.jsxRuntimeExports.jsx(e.DialogTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{onClick:g,size:"sm",variant:"outline",className:f?"border-foreground/50 dark:border-foreground/70":"",children:e.jsxRuntimeExports.jsx(e.Settings,{className:"h-4 w-4"})})}),e.jsxRuntimeExports.jsxs(e.DialogContent,{className:"max-h-[70vh] min-h-[70vh] overflow-auto sm:min-w-[900px] lg:min-w-[1200px]",children:[e.jsxRuntimeExports.jsx(ut,{card:c}),e.jsxRuntimeExports.jsxs("div",{className:"flex grow gap-2",children:[e.jsxRuntimeExports.jsx(e.ErrorBoundary,{FallbackComponent:e.FallbackEditorCard,children:e.jsxRuntimeExports.jsx(ys,{className:"w-1/2 rounded shadow-none"})}),e.jsxRuntimeExports.jsx(dt,{defaultConfig:t,customCode:l,customConfig:I(),onConfigChange:w=>i(w??""),onCodeChange:w=>a(w??"")})]}),e.jsxRuntimeExports.jsx(mt,{error:x,hasCustomConfig:!!f,onReset:()=>{i(""),j(null)},onApply:z,onClose:()=>r(!1)})]})]})}function vs(s){return Y({tag:"svg",attr:{viewBox:"0 0 1024 1024"},child:[{tag:"path",attr:{d:"M926.8 397.1l-396-288a31.81 31.81 0 0 0-37.6 0l-396 288a31.99 31.99 0 0 0-11.6 35.8l151.3 466a32 32 0 0 0 30.4 22.1h489.5c13.9 0 26.1-8.9 30.4-22.1l151.3-466c4.2-13.2-.5-27.6-11.7-35.8zM838.6 417l-98.5 32-200-144.7V199.9L838.6 417zM466 567.2l-89.1 122.3-55.2-169.2L466 567.2zm-116.3-96.8L484 373.3v140.8l-134.3-43.7zM512 599.2l93.9 128.9H418.1L512 599.2zm28.1-225.9l134.2 97.1L540.1 514V373.3zM558 567.2l144.3-46.9-55.2 169.2L558 567.2zm-74-367.3v104.4L283.9 449l-98.5-32L484 199.9zM169.3 470.8l86.5 28.1 80.4 246.4-53.8 73.9-113.1-348.4zM327.1 853l50.3-69h269.3l50.3 69H327.1zm414.5-33.8l-53.8-73.9 80.4-246.4 86.5-28.1-113.1 348.4z"},child:[]}]})(s)}function Ss(s){return Y({tag:"svg",attr:{viewBox:"0 0 256 256",fill:"currentColor"},child:[{tag:"path",attr:{d:"M128,24a8,8,0,0,0-8,8V88a8,8,0,0,0,8,8,32,32,0,1,1-27.72,16,8,8,0,0,0-2.93-10.93l-48.5-28A8,8,0,0,0,37.92,76,104,104,0,1,0,128,24ZM48.09,91.1,83,111.26A48.09,48.09,0,0,0,80,128c0,1.53.08,3,.22,4.52L41.28,143A88.16,88.16,0,0,1,48.09,91.1Zm-2.67,67.31,39-10.44A48.1,48.1,0,0,0,120,175.32v40.31A88.2,88.2,0,0,1,45.42,158.41ZM136,215.63V175.32a48,48,0,0,0,0-94.65V40.36a88,88,0,0,1,0,175.27Z"},child:[]}]})(s)}function Cs(s){return Y({tag:"svg",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 Ns(s){return Y({tag:"svg",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 ws(s){return Y({tag:"svg",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 ks(s){return Y({tag:"svg",attr:{viewBox:"0 0 24 24"},child:[{tag:"path",attr:{fill:"none",d:"M0 0h24v24H0z"},child:[]},{tag:"path",attr:{d:"M4 9h4v11H4zM4 4h4v4H4zM10 7h4v4h-4zM16 10h4v4h-4zM16 15h4v5h-4zM10 12h4v8h-4z"},child:[]}]})(s)}function Is(s){return Y({tag:"svg",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 Ds(s){return Y({tag:"svg",attr:{viewBox:"0 0 512 512"},child:[{tag:"path",attr:{d:"M217 25v14h78V25h-78zm0 32v46h14V71h50v32h14V57h-78zm32 32v14h14V89h-14zm-64 32v46h30v-46h-30zm48 0v14h46v-14h-46zm64 0v46h30v-46h-30zm-64 32v14h46v-14h-46zm-80 32v46h62v-46h-62zm80 0v14h46v-14h-46zm64 0v46h62v-46h-62zm-64 32v14h46v-14h-46zm-112 32v46h94v-46h-94zm112 0v14h46v-14h-46zm64 0v46h94v-46h-94zm-64 32v14h46v-14h-46zM89 313v46h126v-46H89zm144 0v14h46v-14h-46zm64 0v46h126v-46H297zm-64 32v14h46v-14h-46zM57 377v46h158v-46H57zm176 0v14h46v-14h-46zm64 0v46h158v-46H297zm-64 32v14h46v-14h-46zM25 441v46h190v-46H25zm208 0v14h46v-14h-46zm64 0v46h190v-46H297zm-64 32v14h46v-14h-46z"},child:[]}]})(s)}function Ls(s){const[r,t]=b.useState(null);return b.useEffect(()=>{s&&(async()=>{const i=(await Promise.resolve().then(()=>require("./lucide-react-BMo07DKI.js")))[s];t(i)})()},[s]),r}function Ts(){const{authToken:s}=e.useSemaphorContext(),{data:r,isLoading:t,isFetching:n,isError:o}=e.useQuery({queryKey:["plugins",s==null?void 0:s.accessToken],queryFn:()=>e.getPlugins(s==null?void 0:s.accessToken)});return{data:r,isLoading:t,isFetching:n,isError:o}}function jt({onChartTypeChange:s}){const[r,t]=b.useState([]),{data:n}=Ts();return b.useEffect(()=>{(async()=>{var i;if(n){const a=(await Promise.all((i=n==null?void 0:n.plugins)==null?void 0:i.map(async x=>(await e.loadManifest(x.value)).visuals.map(f=>({name:f.name,icon:f.icon,url:x.value}))))).flat();t(a)}})()},[n]),r.length===0?null:e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx(e.Separator,{className:"my-2"}),e.jsxRuntimeExports.jsx("div",{className:"grid grid-cols-4 place-items-center",children:r.map((o,i)=>e.jsxRuntimeExports.jsx(ht,{text:o.name,onClick:()=>s("custom",o),icon:o.icon},o.url+o.name+i))})]})}const ht=({text:s,icon:r,onClick:t})=>{const n=Ls(r||""),o=s.charAt(0).toUpperCase();return e.jsxRuntimeExports.jsx(e.Button,{onClick:t,title:s,variant:"ghost",children:n?e.jsxRuntimeExports.jsx(n,{className:"h-4 w-4"}):o})};function Et(){var c,f;const[s,r]=b.useState(!1),t=e.useEditorStore(h=>h.card),n=t.type,{setCardType:o,setCardPreferences:i,setChartOrientation:l}=e.useEditorStore(h=>h.actions),{setCardCustomCfg:a,setCustomCardPreferences:x}=e.useEditorActions();function d(h,u){a(null),i({}),o(h),u&&x({type:"component",visualType:"single",url:u.url,componentName:u.name,icon:u.icon}),r(!1)}return e.jsxRuntimeExports.jsxs(e.Popover,{open:s,onOpenChange:r,children:[e.jsxRuntimeExports.jsx(e.PopoverTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(ft,{className:"h-4 w-4",chartType:n,customIcon:(c=t.customCardPreferences)==null?void 0:c.icon,componentName:(f=t.customCardPreferences)==null?void 0:f.componentName})})}),e.jsxRuntimeExports.jsxs(e.PopoverContent,{className:"w-50",children:[e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-4 place-items-center",children:[e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("bar"),className:"font-normal",variant:"ghost",children:e.jsxRuntimeExports.jsx(ge,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("line"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Re,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("stackedBar"),variant:"ghost",children:e.jsxRuntimeExports.jsx(ks,{className:"size-5",strokeWidth:0})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("stackedLine"),variant:"ghost",children:e.jsxRuntimeExports.jsx(ws,{className:"size-5",strokeWidth:0})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("scatter"),variant:"ghost",children:e.jsxRuntimeExports.jsx(we,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("bubble"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ns,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("pie"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ne,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("doughnut"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ss,{className:"size-5",strokeWidth:1})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("radar"),variant:"ghost",children:e.jsxRuntimeExports.jsx(vs,{className:"size-5 font-extralight",strokeWidth:.5})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("polarArea"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Cs,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("pyramid"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ds,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("range"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ce,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("table"),variant:"ghost",children:e.jsxRuntimeExports.jsx(e.Table,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("kpi"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Is,{className:"size-6"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("text"),variant:"ghost",children:e.jsxRuntimeExports.jsx(be,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("map"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ie,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("custom"),variant:"ghost",children:e.jsxRuntimeExports.jsx(De,{className:"size-4"})})]}),e.jsxRuntimeExports.jsx(jt,{onChartTypeChange:d})]})]})}function ft({chartType:s,className:r,customIcon:t,componentName:n}){const o=Ls(t||"");switch(s){case"bar":return e.jsxRuntimeExports.jsx(ge,{className:r});case"line":return e.jsxRuntimeExports.jsx(Re,{className:r});case"pie":return e.jsxRuntimeExports.jsx(Ne,{className:r});case"radar":return e.jsxRuntimeExports.jsx(vs,{className:r});case"scatter":return e.jsxRuntimeExports.jsx(we,{className:r});case"bubble":return e.jsxRuntimeExports.jsx(Ns,{className:r});case"doughnut":return e.jsxRuntimeExports.jsx(Ss,{className:r});case"stackedBar":return e.jsxRuntimeExports.jsx(ks,{className:"size-4 text-foreground/70"});case"stackedLine":return e.jsxRuntimeExports.jsx(ws,{className:"size-4 text-foreground/70"});case"polarArea":return e.jsxRuntimeExports.jsx(Cs,{className:r});case"pyramid":return e.jsxRuntimeExports.jsx(Ds,{className:r});case"range":return e.jsxRuntimeExports.jsx(Ce,{className:r});case"kpi":return e.jsxRuntimeExports.jsx(Is,{className:r});case"text":return e.jsxRuntimeExports.jsx(be,{className:r});case"map":return e.jsxRuntimeExports.jsx(Ie,{className:r});case"custom":return t&&o?e.jsxRuntimeExports.jsx(o,{className:r}):n?n==null?void 0:n.charAt(0).toUpperCase():e.jsxRuntimeExports.jsx(De,{className:r});default:return e.jsxRuntimeExports.jsx(e.Table,{className:r})}}function gt(){var r;const s=e.useEditorStore(t=>t.card);return(r=s.customCardPreferences)==null||r.showCardHeader,e.useEditorActions(),e.jsxRuntimeExports.jsxs(e.DropdownMenu,{children:[e.jsxRuntimeExports.jsx(e.DropdownMenuTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(ke,{className:"size-4 cursor-pointer text-muted-foreground/70 transition-colors hover:text-muted-foreground"})}),e.jsxRuntimeExports.jsx(e.DropdownMenuContent,{align:"start",className:"w-40 text-muted-foreground",children:e.jsxRuntimeExports.jsxs(e.DropdownMenuItem,{onClick:()=>{navigator.clipboard.writeText(s.id),e.ce.success("Card ID copied to clipboard")},className:"cursor-pointer space-x-2",children:[e.jsxRuntimeExports.jsx(e.IdCard,{className:"size-5"}),e.jsxRuntimeExports.jsx("span",{children:"Copy Card ID"})]})})]})}function _e(){const s=e.useEditorStore(m=>m.frame),r=e.useEditorStore(m=>m.card),t=e.useEditorStore(m=>m.isShowingVisual),n=e.useEditorStore(m=>m.isSqlRunning),o=e.useEditorStore(m=>m.queryError),i=e.useEditorStore(m=>m.pythonStdOut);e.useEditorStore(m=>m.actions.setRunSql);const{setFrame:l,setCard:a,updateCardInFrame:x,setActiveTabCardId:d}=e.useEditorActions(),{data:c,isLoading:f,isFetching:h}=e.useDashboardCardQuery(r);if(!r)return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:"No Active Card"});function u(){const m={connectionId:r.connectionId,id:e.v4(),title:"Title",description:"Description",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"",data:[]};j(m)}function j(m){const R={...s,cards:[...s.cards,m],activeCardId:m.id};l(R),d(m.id)}function p(){const m={...r,id:e.v4(),title:`${r.title} Copy`,tabTitle:`${r.tabTitle||r.title} Copy`};j(m)}function v(m){const R=s.cards.filter(S=>S.id!==m),E=R[0],k={...s,cards:R,activeCardId:E.id};l(k),d(E.id),a(E)}function g(m){d(m)}const z=(m,R)=>{console.log("handleDragStart",R),m.dataTransfer.setData("tabIndex",R.toString())},I=m=>{m.preventDefault()},w=(m,R)=>{const E=m.dataTransfer.getData("tabIndex");if(E===R.toString())return;const k=Array.from(s.cards),[S]=k.splice(parseInt(E),1);k.splice(R,0,S),l({...s,cards:k})};function D(m,R){return m.cards.length===1&&(R.displayTab===!0||R.displayTab===void 0)||m.activeCardId!==R.id&&(R.displayTab===!0||R.displayTab===void 0)?null:e.jsxRuntimeExports.jsx("div",{onClick:()=>{const E=R.displayTab===void 0?!1:!R.displayTab;a({...R,displayTab:E}),x({...R,displayTab:E})},children:R.displayTab===!0||R.displayTab===void 0?e.jsxRuntimeExports.jsx(e.Eye,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"}):e.jsxRuntimeExports.jsx(We,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"})})}function L(){return e.jsxRuntimeExports.jsxs(e.Tabs,{onValueChange:g,value:s.activeCardId,className:"flex grow flex-col",children:[s.cards.map(m=>e.jsxRuntimeExports.jsx(e.TabsContent,{className:"mt-0 grow",value:m.id,children:O()},m.id)),e.jsxRuntimeExports.jsx(e.TabsList,{className:"group mx-6 justify-between",children:e.jsxRuntimeExports.jsxs("div",{className:"flex items-center",children:[s.cards.map((m,R)=>e.jsxRuntimeExports.jsx(e.Editable,{text:m.tabTitle||m.title,onSave:E=>{a({...r,tabTitle:E}),x({...r,tabTitle:E})},children:e.jsxRuntimeExports.jsxs(e.TabsTrigger,{draggable:!0,onDragStart:E=>z(E,R),onDragOver:I,onDrop:E=>w(E,R),className:"",value:m.id,children:[D(s,m),m.tabTitle||m.title,s.activeCardId===m.id&&s.cards.length>1&&e.jsxRuntimeExports.jsx(e.X,{className:"ml-2 size-3.5 text-muted-foreground hover:text-foreground",onClick:()=>v(m.id)})]})},m.id)),e.jsxRuntimeExports.jsx(e.Button,{className:"ml-1 h-8 px-2 hover:bg-muted-foreground/50",variant:"outline",onClick:u,children:e.jsxRuntimeExports.jsx(e.Plus,{className:"h-4 w-4"})}),e.jsxRuntimeExports.jsx(e.Button,{className:"invisible ml-1 h-8 px-2 hover:bg-muted-foreground/50 group-hover:visible",variant:"outline",onClick:p,children:e.jsxRuntimeExports.jsx(Qe,{className:"h-4 w-4"})})]})})]})}function O(){return r.type==="kpi"?e.jsxRuntimeExports.jsx("div",{className:"flex h-full items-center justify-center",children:e.jsxRuntimeExports.jsx("div",{className:"w-1/2 rounded-md border",children:e.jsxRuntimeExports.jsx(e.KPICard,{card:r,data:c==null?void 0:c.records})})}):r.type==="text"?e.jsxRuntimeExports.jsx("div",{className:"flex h-full items-center justify-center",children:e.jsxRuntimeExports.jsx("div",{className:"w-1/2 rounded-md border",children:e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"mx-3 my-6 h-[300px] overflow-y-auto break-words px-3",children:e.jsxRuntimeExports.jsx(e.TextCard,{isLoading:n,card:r,data:c==null?void 0:c.records})})})}):e.jsxRuntimeExports.jsx(e.ErrorBoundary,{FallbackComponent:e.FallbackEditorCard,children:e.jsxRuntimeExports.jsx(ys,{className:"grow border-none shadow-none"})})}return e.jsxRuntimeExports.jsxs("div",{className:"relative flex h-full flex-col py-3",children:[(f||h)&&e.jsxRuntimeExports.jsx(se,{className:"absolute bottom-0 left-0 right-0 top-0 z-50 m-auto h-10 w-10 animate-spin text-foreground/10"}),e.jsxRuntimeExports.jsxs("div",{className:"mb-0 flex min-h-10 items-center justify-end gap-2 px-6",children:[t&&e.jsxRuntimeExports.jsxs("div",{className:"flex grow items-center gap-2",children:[e.jsxRuntimeExports.jsx(Et,{}),!["table","custom"].includes(r.type)&&e.jsxRuntimeExports.jsx(pt,{}),e.jsxRuntimeExports.jsx(gt,{})]}),e.jsxRuntimeExports.jsx(bt,{})]}),t?L():e.jsxRuntimeExports.jsxs(e.ResizablePanelGroup,{className:"px-6",direction:"horizontal",children:[i&&e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx(e.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.jsxRuntimeExports.jsx(Rt,{})}),e.jsxRuntimeExports.jsx(e.ResizableHandle,{})]}),e.jsxRuntimeExports.jsx(e.ResizablePanel,{id:"2",order:2,minSize:10,className:"relative flex h-full min-h-0 w-full flex-1 basis-0",children:e.jsxRuntimeExports.jsxs(e.ScrollArea,{className:"relative flex h-full min-h-0 w-full flex-1 basis-0",children:[(c==null?void 0:c.records)&&(c==null?void 0:c.records.length)>0&&e.jsxRuntimeExports.jsx(ct,{data:(c==null?void 0:c.records)||[]}),o&&e.jsxRuntimeExports.jsx("span",{className:"font-mono text-xs",children:o}),e.jsxRuntimeExports.jsx(e.ScrollBar,{orientation:"horizontal"})]})})]})]})}function Rt(){const s=e.useEditorStore(t=>t.pythonStdOut);if(!s)return null;const r=s.replace(/\n/g,"<br>");return e.jsxRuntimeExports.jsxs("div",{className:"relative flex w-full flex-col border-r",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs(e.ScrollArea,{className:"overflow-y-auto px-2 pt-1 font-mono text-xs text-foreground/90",children:[e.jsxRuntimeExports.jsx("div",{dangerouslySetInnerHTML:{__html:r}}),e.jsxRuntimeExports.jsx(e.ScrollBar,{orientation:"horizontal"})]})]})}function bt(){const s=e.useEditorStore(t=>t.isShowingVisual),r=e.useEditorStore(t=>t.actions.setIsShowingVisual);return e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.Label,{htmlFor:"visualize",children:"Chart"}),e.jsxRuntimeExports.jsx(e.Switch,{checked:s,onCheckedChange:()=>r(!s),id:"visualize",className:"data-[state=checked]:bg-foreground/50"})]})}function yt({options:s,value:r,onValueChange:t}){return e.jsxRuntimeExports.jsx(e.RadioGroup,{value:r,onValueChange:t,className:"flex gap-4",defaultValue:s[0].value,children:s.map(n=>e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:n.value,id:n.value}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:n.value,children:n.label})]},n.value))})}function W({label:s,options:r,value:t,onValueChange:n,className:o}){return e.jsxRuntimeExports.jsxs(e.Select,{value:t,onValueChange:n,children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:e.cn("w-full focus:ring-0 focus:ring-offset-0",o),children:e.jsxRuntimeExports.jsx(e.SelectValue,{placeholder:s})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:s}),r.map(i=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:i.value,children:i.label},i.value))]})})]})}function de({children:s,summary:r,open:t,className:n}){return e.jsxRuntimeExports.jsxs("details",{open:t,className:e.cn("space-y-4 [&_summary>svg]:open:-rotate-180",n),children:[e.jsxRuntimeExports.jsxs("summary",{className:"flex cursor-pointer list-none items-center justify-between gap-4",children:[e.jsxRuntimeExports.jsx(e.Label,{children:r}),e.jsxRuntimeExports.jsx(e.ChevronUp,{className:"h-4 w-4"})]}),e.jsxRuntimeExports.jsx("div",{className:"transition-all ease-in-out",children:s})]})}function vt(){var p,v;const s=e.useEditorStore(g=>g.card.customCardPreferences),{data:r}=Ts(),t=(r==null?void 0:r.plugins)||[],n=e.useEditorStore(g=>g.card),o=e.useEditorStore(g=>g.frame),i=(s==null?void 0:s.visualType)||"single",{setCustomCardPreferences:l}=e.useEditorActions(),{components:a,manifest:x}=e.useCustomVisual((s==null?void 0:s.url)||""),d=(p=x==null?void 0:x.visuals)==null?void 0:p.find(g=>g.name===(s==null?void 0:s.componentName));function c(g,z){if(!s)return;const w={...(s==null?void 0:s.dataInputCardIds)||{},[g]:{cardId:z,hookRef:null}};l({...s,dataInputCardIds:w})}function f(g){var I,w;const z=(I=o==null?void 0:o.cards)==null?void 0:I.filter(D=>{var L;return((L=D==null?void 0:D.customCardPreferences)==null?void 0:L.visualType)!=="multiple"}).map(D=>({value:D.id,label:D.tabTitle||D.title}));return e.jsxRuntimeExports.jsx("div",{className:"space-y-2",children:(w=g==null?void 0:g.dataInputs)==null?void 0:w.map((D,L)=>{var O,m;return e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-10 gap-2",children:[e.jsxRuntimeExports.jsx("div",{className:"col-span-4 flex items-center",children:D}),e.jsxRuntimeExports.jsx(W,{className:"col-span-6 h-8 w-full justify-between",label:"",options:z||[],value:((m=(O=s==null?void 0:s.dataInputCardIds)==null?void 0:O[L])==null?void 0:m.cardId)||"",onValueChange:R=>c(L,R)})]},L+Math.random())})})}function h(g,z,I=[]){var w,D;return s?g==="input"?e.jsxRuntimeExports.jsx(e.Input,{className:`h-8 w-full ${e.removeRing}`,value:((w=s==null?void 0:s.settings)==null?void 0:w[z])||"",onChange:L=>{l({...s,settings:{...s==null?void 0:s.settings,[z]:L.target.value}})}},z):g==="select"?e.jsxRuntimeExports.jsx(W,{className:"h-8 w-full",label:"",options:I,value:((D=s==null?void 0:s.settings)==null?void 0:D[z])||"",onValueChange:L=>{l({...s,settings:{...s==null?void 0:s.settings,[z]:L}})}}):null:null}function u(g){const z=Object.entries((g==null?void 0:g.settings)||{});return e.jsxRuntimeExports.jsx("div",{className:"space-y-3",children:z.map(([I,w])=>e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:w.title}),h(w.ui,I,w.options)]},I))})}function j(g){s&&l({...s,visualType:g,componentName:""})}return e.jsxRuntimeExports.jsxs("div",{className:"p-6",children:[e.jsxRuntimeExports.jsx(de,{summary:"Plugin Settings",children:e.jsxRuntimeExports.jsx("div",{className:"space-y-4 text-sm",children:e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 text-sm",children:[e.jsxRuntimeExports.jsx("div",{className:"space-y-2",children:e.jsxRuntimeExports.jsx("div",{className:"px-2",children:e.jsxRuntimeExports.jsx(W,{className:"h-8 w-full",label:"",options:t,value:(s==null?void 0:s.url)||"",onValueChange:g=>l({...s||{url:"",componentName:""},url:g})})})}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&e.jsxRuntimeExports.jsx(yt,{options:[{value:"single",label:"Single Visual"},{value:"multiple",label:"Multi-Visual"}],value:i,onValueChange:j}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&s&&e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Component"}),e.jsxRuntimeExports.jsx("div",{className:"space-y-2 px-2",children:a&&e.jsxRuntimeExports.jsx(W,{className:"h-8 w-full",label:"",options:(a==null?void 0:a.filter(g=>g.type===i).map(g=>({value:g.name,label:g.name})))||[],value:s.componentName,onValueChange:g=>{console.log("changing value",g),l({...s,componentName:g})}})})]})})]})})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-4"}),((v=n==null?void 0:n.customCardPreferences)==null?void 0:v.componentName)&&e.jsxRuntimeExports.jsxs(de,{summary:"Component Settings",children:[d&&d.dataInputs&&e.jsxRuntimeExports.jsxs("div",{className:"space-y-3",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Input Mapping"}),e.jsxRuntimeExports.jsx("div",{className:"px-2",children:f(d)})]}),d&&d.settings&&e.jsxRuntimeExports.jsx("div",{className:"space-y-3",children:e.jsxRuntimeExports.jsx("div",{className:"px-2",children:u(d)})})]})]})}function ne(){const[s,r]=b.useState([]);e.useEditorStore(c=>c.card.cfg);const t=e.useEditorStore(c=>c.card.preferences),{setCardCfg:n,setFilterOnClickColumnIndex:o,setCardPreferences:i}=e.useEditorStore(c=>c.actions),l=e.useEditorStore(c=>c.queryResultColumns);e.useEditorStore(c=>{var f;return(f=c.card.preferences)==null?void 0:f.filterOnClickColumnIndex}),b.useEffect(()=>{l&&r(new Array(l.length).fill(!1))},[l]);function a(c,f){var h,u;f?t!=null&&t.onClickFilter&&((h=t==null?void 0:t.onClickFilter)==null?void 0:h.length)>0?i({...t,onClickFilter:[...t.onClickFilter,{columnIndex:c,expression:""}]}):i({...t,onClickFilter:[{columnIndex:c,expression:""}]}):(i({...t,onClickFilter:(u=t==null?void 0:t.onClickFilter)==null?void 0:u.filter(j=>j.columnIndex!==c)}),r(j=>{const p=[...j];return p[c]=!1,p}))}function x(c,f){var u;const h=(u=t==null?void 0:t.onClickFilter)==null?void 0:u.map(j=>j.columnIndex===c?{...j,expression:f.target.value}:j);i({...t,onClickFilter:h})}function d(c){var f,h,u,j;if(s!=null&&s[c]||(h=(f=t==null?void 0:t.onClickFilter)==null?void 0:f.find(p=>p.columnIndex===c))!=null&&h.expression)return e.jsxRuntimeExports.jsx(e.Input,{value:(j=(u=t==null?void 0:t.onClickFilter)==null?void 0:u.find(p=>p.columnIndex===c))==null?void 0:j.expression,onChange:p=>x(c,p),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.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"On Click"}),l==null?void 0:l.map((c,f)=>{var h,u;return e.jsxRuntimeExports.jsx("div",{className:"xbg-red-100 group flex items-center justify-between space-y-2",children:e.jsxRuntimeExports.jsxs("div",{className:"grow",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2 py-2",children:[e.jsxRuntimeExports.jsx(e.Checkbox,{checked:!!((h=t==null?void 0:t.onClickFilter)!=null&&h.find(j=>j.columnIndex===f)),onCheckedChange:j=>a(f,j)}),e.jsxRuntimeExports.jsx("label",{className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:c}),e.jsxRuntimeExports.jsx("div",{className:"flex items-center gap-2",children:((u=t==null?void 0:t.onClickFilter)==null?void 0:u.find(j=>j.columnIndex===f))&&e.jsxRuntimeExports.jsx(e.Pencil,{onClick:()=>{r(j=>{const p=[...j];return p[f]=!j[f],p})},className:"invisible size-3 cursor-pointer text-gray-400 group-hover:visible"})})]}),d(f)]})},c)})]})}function ye(){var l,a,x;const s=e.useEditorStore(d=>d.card.preferences),r=e.useEditorStore(d=>d.card.cfg),{setCardCfg:t,setCardPreferences:n,setChartOrientation:o}=e.useEditorStore(d=>d.actions);(l=r==null?void 0:r.options)!=null&&l.indexAxis;function i(d){o(d)}return e.jsxRuntimeExports.jsxs(e.RadioGroup,{value:((a=s==null?void 0:s.chartOptions)==null?void 0:a.indexAxis)||((x=r==null?void 0:r.options)==null?void 0:x.indexAxis)||"x",onValueChange:i,className:"flex gap-3",defaultValue:"x",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"x",id:"r1"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r1",children:"Vertical"})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"y",id:"r2"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r2",children:"Horizontal"})]})]})}const je="focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0";function He(s,r){var n,o,i;const t=e.getNumberAxis(s,r);return((i=(o=(n=s==null?void 0:s.chartOptions)==null?void 0:n.scales)==null?void 0:o[t])==null?void 0:i.type)||"linear"}function As(){var P,_,G,N,F,B;const[s,r]=b.useState(!1),t=e.useEditorStore(A=>{var T;return(T=A.card)==null?void 0:T.preferences}),n=e.useEditorStore(A=>{var T;return(T=A.card)==null?void 0:T.cfg}),o=e.getNumberAxis(t,n),[i,l]=b.useState(He(t)),[a,x]=b.useState(((G=(_=(P=t==null?void 0:t.chartOptions)==null?void 0:P.scales)==null?void 0:_[o])==null?void 0:G.min)||""),[d,c]=b.useState(((B=(F=(N=t==null?void 0:t.chartOptions)==null?void 0:N.scales)==null?void 0:F[o])==null?void 0:B.max)||""),[f,h]=b.useState(a||d?"custom":"auto"),[u,j]=b.useState(""),[p,v]=b.useState(0),[g,z]=b.useState(""),[I,w]=b.useState(""),[D,L]=b.useState(""),O=e.useEditorStore(A=>A.actions.setCardPreferences),{updateCardInFrame:m}=e.useEditorActions(),R=e.useEditorStore(A=>A.card),E=e.useEditorStore(A=>{var T;return(T=A.card)==null?void 0:T.type}),k=["pie","doughnut","polarArea"].includes(E);b.useEffect(()=>{var A,T,K,q,$,U,X,re,Z,oe,ie,ae,le,C;l(He(t)),x(((K=(T=(A=t==null?void 0:t.chartOptions)==null?void 0:A.scales)==null?void 0:T[o])==null?void 0:K.min)===0?0:""),c(((U=($=(q=t==null?void 0:t.chartOptions)==null?void 0:q.scales)==null?void 0:$[o])==null?void 0:U.max)||""),j(((oe=(Z=(re=(X=t==null?void 0:t.chartOptions)==null?void 0:X.scales)==null?void 0:re[o])==null?void 0:Z.ticks)==null?void 0:oe.stepSize)||""),v(((ie=t==null?void 0:t.numberAxisFormat)==null?void 0:ie.decimalPlaces)||0),z(((ae=t==null?void 0:t.numberAxisFormat)==null?void 0:ae.suffix)||""),w(((le=t==null?void 0:t.numberAxisFormat)==null?void 0:le.currency)||""),L(((C=t==null?void 0:t.numberAxisFormat)==null?void 0:C.locale)||"")},[s,t,o]);function S(A,T){return T===""||/^[0-9\b]+$/.test(T)?Number(T):Number(A)}function M(){const A=[...new Set(e.LOCALE_CURRENCY_PAIRS.map(T=>T.currency))];return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-6 items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"col-span-2 hover:cursor-pointer hover:underline",htmlFor:"currency",children:e.jsxRuntimeExports.jsx("a",{target:"_blank",href:"https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/NumberFormat",children:"Currency"})}),e.jsxRuntimeExports.jsxs(e.Select,{value:I||"none",onValueChange:T=>w(T==="none"?"":T),children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-2 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Currency"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"none",children:"None"}),A.map(T=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:T,children:T},T))]})})]}),e.jsxRuntimeExports.jsxs(e.Select,{value:D,onValueChange:T=>L(T),children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-2 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Locale"}),e.LOCALE_CURRENCY_PAIRS.map(T=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:T.locale,children:T.locale},T.locale))]})})]})]}),e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-9 items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"col-span-3",htmlFor:"format",children:"Decimals"}),e.jsxRuntimeExports.jsx(e.Input,{value:p,onChange:T=>v(Number(T.target.value)),id:"format",className:`col-span-6 h-8 w-full tracking-wide ${je}`})]})]})}function V(){return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-3 items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Label,{htmlFor:"range",children:"Range"}),e.jsxRuntimeExports.jsx(e.Input,{id:"min",value:a,onChange:A=>x(T=>S(T,A.target.value)),className:`col-span-1 h-8 w-full ${je}`}),e.jsxRuntimeExports.jsx(e.Input,{value:d,onChange:A=>c(T=>S(T,A.target.value)),id:"max",className:`col-span-1 h-8 w-full ${je}`})]}),e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-3 items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Label,{htmlFor:"step-size",children:"Step Size"}),e.jsxRuntimeExports.jsx(e.Input,{value:u,onChange:A=>j(T=>S(T,A.target.value)),id:"step-size",className:`col-span-1 h-8 w-full ${je}`})]})]})}function H(){var q;let A={};f==="custom"&&(A={min:a,max:d,ticks:{stepSize:u}});const T={...t||{},chartOptions:{...t==null?void 0:t.chartOptions,scales:{...(q=t==null?void 0:t.chartOptions)==null?void 0:q.scales,[o]:{type:i,...i==="linear"?A:{}}}},numberAxisFormat:{decimalPlaces:p,suffix:g,currency:I,locale:D}};console.log(T),O(T);const K={...R,preferences:T};m(K)}return e.jsxRuntimeExports.jsxs(e.Popover,{onOpenChange:A=>r(A),children:[e.jsxRuntimeExports.jsx(e.PopoverTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.SliderIcon,{className:"size-4 cursor-pointer text-muted-foreground hover:text-foreground"})}),e.jsxRuntimeExports.jsx(e.PopoverContent,{align:"center",className:"max-w-65",children:e.jsxRuntimeExports.jsxs("div",{className:"grid gap-4",children:[e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx("h4",{className:"font-medium leading-none",children:"Scale Options"}),e.jsxRuntimeExports.jsx("p",{className:"text-sm text-muted-foreground",children:"Set the scale for the number axis"})]}),e.jsxRuntimeExports.jsxs("div",{className:"grid gap-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-3 items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Label,{htmlFor:"scale",children:"Type"}),e.jsxRuntimeExports.jsxs(e.Select,{disabled:k,value:i,onValueChange:A=>l(A),children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-2 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{id:"type",children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Option"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"linear",children:"Linear"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"logarithmic",children:"Logarithmic"})]})})]})]}),i=="linear"&&e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-3 items-center gap-2 py-1",children:[e.jsxRuntimeExports.jsx(e.Label,{htmlFor:"scale-option",children:"Setup"}),e.jsxRuntimeExports.jsxs(e.RadioGroup,{disabled:k,id:"scale-option",value:f,onValueChange:A=>h(A),className:"col-span-2 flex gap-3",defaultValue:"x",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"auto",id:"r1"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r1",children:"Auto"})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"custom",id:"r2"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r2",children:"Custom"})]})]})]}),f==="custom"&&i=="linear"&&V(),M(),e.jsxRuntimeExports.jsx(e.SelectSeparator,{}),e.jsxRuntimeExports.jsx("div",{className:"grid grid-cols-3",children:e.jsxRuntimeExports.jsx(e.Button,{onClick:H,variant:"secondary",className:"col-span-1 col-start-3 h-8 w-full",children:"Apply"})})]})]})})]})}function St({idx:s}){var a;const r=e.useEditorStore(x=>{var d;return(d=x.card)==null?void 0:d.preferences}),t=e.useEditorStore(x=>{var d;return(d=x.card.preferences)==null?void 0:d.datasetOptions}),n=e.useEditorStore(x=>x.actions.setCardPreferences),o=(a=r==null?void 0:r.chartOptions)==null?void 0:a.indexAxis,i=t==null?void 0:t.find(x=>x.idx===s);function l(x,d){(x==="end"||x==="start")&&e.getContrastColor(e.getCanvasBackgroundColor());const c={display:x!=="none",align:x,anchor:x,clamp:!0};if(!i)n({...r,datasetOptions:[...t||[],{idx:d,datalabels:c}]});else{const f={...i};f.datalabels=c;const h=t==null?void 0:t.map(u=>u.idx===d?f:u);n({...r,datasetOptions:h})}}return e.jsxRuntimeExports.jsxs(e.Popover,{children:[e.jsxRuntimeExports.jsx(e.PopoverTrigger,{children:e.jsxRuntimeExports.jsx(ms,{className:"invisible size-4 rotate-[135deg] cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"})}),e.jsxRuntimeExports.jsx(e.PopoverContent,{className:"w-fit p-1",children:e.jsxRuntimeExports.jsxs("div",{className:"flex gap-1",children:[e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>l("none",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(e.X,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>l("start",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(ts,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>l("center",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(rs,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>l("end",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(ns,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})})]})})]})}function zs(){const s=e.useEditorStore(d=>d.card),r=e.useEditorStore(d=>{var c,f,h;return(h=(f=(c=d==null?void 0:d.card)==null?void 0:c.preferences)==null?void 0:f.chartOptions)==null?void 0:h.indexAxis}),{data:t}=e.useDashboardCardQuery(s),n=r==="y"?"Y axis":"X axis",o=r==="y"?"X axis":"Y axis",{keys:i,metricKeys:l,dimensionKeys:a}=e.getKeys((t==null?void 0:t.records)||[]);let x=l;if(["stackedBar","stackedLine"].includes(s.type)){const d=e.pivotData({dataArray:(t==null?void 0:t.records)||[],groupKey:a[0],pivotKey:a[1],valueKey:x[0]}),{metricKeys:c}=e.getKeys(d);x=c}return i.length===0?null:e.jsxRuntimeExports.jsxs("div",{className:"space-y-4",children:[e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:n}),e.jsxRuntimeExports.jsx("div",{className:"my-1 space-y-1",children:e.jsxRuntimeExports.jsx("div",{className:"rounded-md bg-muted/70 px-2 py-1 hover:bg-muted",children:e.jsxRuntimeExports.jsx("p",{children:a[0]})})})]}),e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center justify-between gap-5",children:[e.jsxRuntimeExports.jsx(e.Label,{children:o}),e.jsxRuntimeExports.jsx(As,{})]}),e.jsxRuntimeExports.jsx("div",{className:"my-1 space-y-1",children:x.map((d,c)=>e.jsxRuntimeExports.jsx(Ct,{col:d,idx:c},d))})]})]})}function Ct({col:s,idx:r}){const t=e.useEditorStore(a=>{var x;return(x=a.card)==null?void 0:x.preferences}),n=e.useEditorStore(a=>{var x;return(x=a.card.preferences)==null?void 0:x.datasetOptions}),o=n==null?void 0:n.find(a=>a.idx===r),{setCardPreferences:i}=e.useEditorStore(a=>a.actions);function l(a){if(!o)i({...t,datasetOptions:[...n||[],{idx:r,type:a==="area"?"line":a,fill:a==="area"?"origin":""}]});else{const x={...o};x.type=a==="area"?"line":a,x.fill=a==="area"?"origin":"";const d=n==null?void 0:n.map(c=>c.idx===r?x:c);i({...t,datasetOptions:d})}}return e.jsxRuntimeExports.jsxs("div",{className:"group flex items-center justify-between gap-5 rounded-md bg-muted/70 px-2 py-1 hover:bg-muted",children:[e.jsxRuntimeExports.jsx("p",{children:s}),e.jsxRuntimeExports.jsxs("div",{className:"flex gap-2",children:[e.jsxRuntimeExports.jsx(ge,{onClick:()=>l("bar"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx(Re,{onClick:()=>l("line"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx($e,{onClick:()=>l("area"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx(St,{idx:r})]})]})}function Os(){const s=e.useEditorStore(h=>h.selectedConnectionId),r=e.useEditorStore(h=>h.selectedDatamodelId),t=e.useEditorStore(h=>h.selectedDatabaseName),n=e.useEditorStore(h=>h.selectedSchemaName),o=e.useEditorStore(h=>h.selectedTableName),i=e.useDashboardStore(h=>h.dashboard.filters)||[],l=e.useDashboardStore(h=>h.actions.addFilter),a=e.useDashboardStore(h=>h.actions.removeFilter),{removeFilterValues:x}=e.useDashboardActions(),{modelItems:d,tableName:c}=te();function f(h,u="dashboard"){var L;const j=e.fmt(h.column_name),p=e.fmt(t||""),v=e.fmt(n||""),g=e.fmt(c);let z=e.getQualifiedTableName(v,g),I=`${z}.${j}`;const w=(L=d==null?void 0:d.find(O=>O.id===r))==null?void 0:L.name;r&&r!=="none"&&(I=`${e.DATAMODEL_NAMESPCACE}.${w}.${j}`,z=`${e.DATAMODEL_NAMESPCACE}.${w}`);const D=i==null?void 0:i.find(O=>O.column===I&&O.table===g&&(O.database===p||O.database===t));if(D)x(D.id),a(D.id);else{const O=e.v4();return c==="api"&&s?(l({location:u,id:O,column:I,title:h.column_name,dataType:h.data_type,table:"api",database:"",connectionId:s,operation:"in",sql:e.getDefaultFilterSql(h.data_type,z,j)}),O):(l({id:O,location:u,column:I,title:h.column_name,dataType:h.data_type,table:o||"",database:t||"",connectionId:s||"",operation:"in",sql:e.getDefaultFilterSql(h.data_type,z,j)}),O)}}return{assignFilter:f}}function xe(){const s=e.useDashboardStore(a=>a.dashboard.filters),r=e.useEditorStore(a=>a.frame),{setFrame:t}=e.useEditorActions(),{columns:n}=te(),{assignFilter:o}=Os();function i(a){const x=o(a,"frame");t({...r,filterId:x})}const l=s==null?void 0:s.find(a=>a.id===r.filterId);return e.jsxRuntimeExports.jsxs("div",{className:"space-y-3",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Card Filter"}),e.jsxRuntimeExports.jsx(Nt,{onSelect:i,columns:n}),l&&e.jsxRuntimeExports.jsx(e.FilterHeader,{filter:l})]})}function Nt({columns:s,onSelect:r}){var l;const[t,n]=Fe.useState(!1),[o,i]=Fe.useState("");return e.jsxRuntimeExports.jsxs(e.Popover,{open:t,onOpenChange:n,children:[e.jsxRuntimeExports.jsx(e.PopoverTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsxs(e.Button,{size:"sm",variant:"outline",role:"combobox","aria-expanded":t,className:"w-full justify-between font-normal",children:[o?(l=s.find(a=>a.column_name===o))==null?void 0:l.column_name:"Select Column...",e.jsxRuntimeExports.jsx(e.CaretSortIcon,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})}),e.jsxRuntimeExports.jsx(e.PopoverContent,{className:"w-[200px] p-0",children:e.jsxRuntimeExports.jsxs(e.Command,{children:[e.jsxRuntimeExports.jsx(e.CommandInput,{placeholder:"Search column",className:"h-9"}),e.jsxRuntimeExports.jsxs(e.CommandList,{children:[e.jsxRuntimeExports.jsx(e.CommandEmpty,{children:"No framework found."}),e.jsxRuntimeExports.jsx(e.CommandGroup,{children:s.map(a=>e.jsxRuntimeExports.jsxs(e.CommandItem,{value:a.column_name,onSelect:x=>{const d=x===o?"":x;i(d),n(!1),d&&r(a)},children:[a.column_name,e.jsxRuntimeExports.jsx(e.CheckIcon,{className:e.cn("ml-auto h-4 w-4",o===a.column_name?"opacity-100":"opacity-0")})]},a.column_name))})]})]})})]})}function wt({cardType:s}){return e.jsxRuntimeExports.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxRuntimeExports.jsxs(e.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:`${e.titleCase(s)} Chart`}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"x-axis - category"}),e.jsxRuntimeExports.jsx("li",{children:"y-axis1 - number"}),e.jsxRuntimeExports.jsx("li",{children:"y-axis2 - number"})]}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:r=>r.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#line-chart",children:"example"})," in the docs."]})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-2",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Settings"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ye,{}),e.jsxRuntimeExports.jsx(zs,{})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Filters"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function Te(){var o,i,l;const s=e.useEditorStore(a=>a.card.cfg),r=e.useEditorStore(a=>a.actions.setCardCfg),t=e.useEditorStore(a=>a.card.type);function n(a){var c;const x={datalabels:{display:a!=="none",align:a,anchor:a,clamp:!0}},d={...s,options:{...s==null?void 0:s.options,plugins:{...(c=s==null?void 0:s.options)==null?void 0:c.plugins,...x}}};r(d),console.log(a)}return e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxRuntimeExports.jsx("label",{className:"font-medium",children:"Data Labels"}),!["pyramid"].includes(t)&&e.jsxRuntimeExports.jsx(As,{})]}),e.jsxRuntimeExports.jsxs(e.Select,{value:(l=(i=(o=s==null?void 0:s.options)==null?void 0:o.plugins)==null?void 0:i.datalabels)==null?void 0:l.anchor,onValueChange:n,defaultValue:"none",children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{placeholder:"Select position"})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Data Labels"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"none",children:"None"}),t!=="pyramid"&&e.jsxRuntimeExports.jsx(e.SelectItem,{value:"start",children:"Start"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"center",children:"Center"}),t!=="pyramid"&&e.jsxRuntimeExports.jsx(e.SelectItem,{value:"end",children:"End"})]})})]})]})}function kt({cardType:s}){function r(t){return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:t==="bubble"?"SELECT label, [group], x-axis, y-axis, radius FROM table":"SELECT label, [group], x-axis, y-axis FROM table"}),e.jsxRuntimeExports.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"label - category"}),e.jsxRuntimeExports.jsx("li",{children:"group - category"}),e.jsxRuntimeExports.jsx("li",{children:"x-axis - category"}),e.jsxRuntimeExports.jsx("li",{children:"y-axis - category"}),t==="bubble"&&e.jsxRuntimeExports.jsx("li",{children:"radius - number"})]}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:i=>i.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#pie-chart",children:"example"})," in the docs."]})]})}return e.jsxRuntimeExports.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxRuntimeExports.jsxs(e.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:`${e.titleCase(s)} Chart`}),e.jsxRuntimeExports.jsx(e.AccordionContent,{className:"space-y-4 font-mono text-xs",children:r(s)})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-2",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Settings"}),e.jsxRuntimeExports.jsx(e.AccordionContent,{className:"px-2",children:e.jsxRuntimeExports.jsx(Te,{})})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Filters"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}const It={datasets:[{type:"line",label:"Sum_sales",data:[]},{type:"bar",label:"Sum_profit",data:[]}]},Dt={datasets:[{fill:"origin",type:"line",label:"Sum_sales",data:[]}]};function Lt(){const s=e.useEditorStore(r=>r.card.type);return e.jsxRuntimeExports.jsxs("div",{className:"space-y-6 p-6",children:[e.jsxRuntimeExports.jsx(e.Accordion,{className:" ",type:"single",collapsible:!0,children:Tt(s)}),e.jsxRuntimeExports.jsx("section",{className:"",children:["line","bar"].includes(s)&&e.jsxRuntimeExports.jsx(ye,{})}),!["kpi"].includes(s)&&e.jsxRuntimeExports.jsxs("div",{className:"space-y-4",children:[e.jsxRuntimeExports.jsx(Te,{}),e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})}function Tt(s){if(["line","bar"].includes(s))return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:e.jsxRuntimeExports.jsx("p",{children:"Chart Query"})}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:" ",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"X-axis - Category (ex. city)"}),e.jsxRuntimeExports.jsx("li",{children:"Y-axis - Number (ex. population)"})]})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-2",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:"Mixed Chart"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-2 text-xs",children:[e.jsxRuntimeExports.jsxs("p",{children:["Click ",e.jsxRuntimeExports.jsx("b",{children:"Customize"})," and change the `type` property in the dataset."]}),e.jsxRuntimeExports.jsx("pre",{children:JSON.stringify(It,null,2)})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:"Area Chart"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-2 text-xs",children:[e.jsxRuntimeExports.jsxs("p",{children:["Click ",e.jsxRuntimeExports.jsx("b",{children:"Customize"})," and add `fill` property to the dataset. See",e.jsxRuntimeExports.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.jsxRuntimeExports.jsx("pre",{children:JSON.stringify(Dt,null,2)})]})]})]});if(s==="bubble")return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:e.jsxRuntimeExports.jsxs("p",{children:["How to create a ",e.jsxRuntimeExports.jsx("span",{children:s})," chart query?"]})}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:" ",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"Label - Category (ex. city)"}),e.jsxRuntimeExports.jsx("li",{children:"Bubble Group (opt) - Category (ex. state)"}),e.jsxRuntimeExports.jsx("li",{children:"X-axis - Number (ex. avg. age)"}),e.jsxRuntimeExports.jsx("li",{children:"Y-axis - Number (ex. avg. weight)"}),e.jsxRuntimeExports.jsx("li",{children:"Radius - Number (ex. population)"})]})]})]})});if(s==="scatter")return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:e.jsxRuntimeExports.jsxs("p",{children:["How to create a ",e.jsxRuntimeExports.jsx("span",{children:s})," chart query?"]})}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:" ",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"Label - Category (ex. city)"}),e.jsxRuntimeExports.jsx("li",{children:"Group (opt) - Category (ex. state)"}),e.jsxRuntimeExports.jsx("li",{children:"X-axis - Number (ex. avg. age)"}),e.jsxRuntimeExports.jsx("li",{children:"Y-axis - Number (ex. avg. weight)"})]})]})]})});if(["pie","doughnut","polarArea"].includes(s))return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:e.jsxRuntimeExports.jsxs("p",{children:[e.jsxRuntimeExports.jsx("span",{children:s==="polarArea"?"Polar":s.charAt(0).toUpperCase()+s.slice(1)})," ","chart query"]})}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:" ",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs font-semibold",children:"SELECT label, measure FROM table"}),e.jsxRuntimeExports.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"Label - Category (ex. city)"}),e.jsxRuntimeExports.jsx("li",{children:"Measure - Number (ex. population)"})]})]})]})})}function At(){var x,d,c,f,h;const s=e.useEditorStore(u=>u.card.preferences),r=e.useEditorStore(u=>u.actions.setCardPreferences),t=e.useEditorStore(u=>u.actions.setNumberFormat);e.useEditorStore(u=>{var j,p;return(p=(j=u.card.preferences)==null?void 0:j.formatNumber)==null?void 0:p.decimalPlaces});const n=e.useEditorStore(u=>{var j,p;return(p=(j=u.card.preferences)==null?void 0:j.formatNumber)==null?void 0:p.locale}),o=e.useEditorStore(u=>{var j,p;return(p=(j=u.card.preferences)==null?void 0:j.formatNumber)==null?void 0:p.currency});e.useEditorStore(u=>u.actions.setFilterOnClickField);const i=e.useEditorStore(u=>{var j,p;return(p=(j=u.card.preferences)==null?void 0:j.formatNumber)==null?void 0:p.colorRanges})||[],l=e.useEditorStore(u=>u.actions.setColorRanges),a=[...new Set(e.LOCALE_CURRENCY_PAIRS.map(u=>u.currency))];return e.jsxRuntimeExports.jsxs("div",{children:[e.jsxRuntimeExports.jsxs("div",{className:"mb-3 flex items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Checkbox,{checked:!!((x=s==null?void 0:s.formatNumber)!=null&&x.enabled),onCheckedChange:u=>{r({...s,formatNumber:{...s==null?void 0:s.formatNumber,enabled:u}})}}),e.jsxRuntimeExports.jsx(e.Label,{children:"Format Number"})]}),((d=s==null?void 0:s.formatNumber)==null?void 0:d.enabled)===!0&&e.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-2",children:[e.jsxRuntimeExports.jsx("div",{children:e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 p-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"w-full space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Locale"}),e.jsxRuntimeExports.jsxs(e.Select,{value:n||"none",onValueChange:u=>{var j,p,v;return t(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,((p=s==null?void 0:s.formatNumber)==null?void 0:p.currency)||"",u,((v=s==null?void 0:s.formatNumber)==null?void 0:v.suffix)||"")},children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-6 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Format"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"none",children:"None"},"none"),e.LOCALE_CURRENCY_PAIRS.map(u=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:u.locale,children:u.locale},u.locale))]})})]})]}),e.jsxRuntimeExports.jsxs("div",{className:"w-full space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Currency"}),e.jsxRuntimeExports.jsxs(e.Select,{value:o||"none",onValueChange:u=>{var j,p,v;console.log("currency",u),t(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,u==="none"?"":u,((p=s==null?void 0:s.formatNumber)==null?void 0:p.locale)||"",((v=s==null?void 0:s.formatNumber)==null?void 0:v.suffix)||"")},children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-6 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Currency"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"none",children:"None"},"none"),a.map(u=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:u,children:u},u))]})})]})]})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex gap-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"w-full space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Decimals"}),e.jsxRuntimeExports.jsxs(e.Select,{value:((f=(c=s==null?void 0:s.formatNumber)==null?void 0:c.decimalPlaces)==null?void 0:f.toString())||"0",onValueChange:u=>{var j,p,v;return t(Number(u),((j=s==null?void 0:s.formatNumber)==null?void 0:j.currency)||"",((p=s==null?void 0:s.formatNumber)==null?void 0:p.locale)||"",((v=s==null?void 0:s.formatNumber)==null?void 0:v.suffix)||"")},children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-3 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:["0","1","2","3","4"].map(u=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:u,children:u},u))})]})]}),e.jsxRuntimeExports.jsxs("div",{className:"w-full space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Suffix"}),e.jsxRuntimeExports.jsx(e.Input,{value:((h=s==null?void 0:s.formatNumber)==null?void 0:h.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:u=>{var j,p,v;return t(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,((p=s==null?void 0:s.formatNumber)==null?void 0:p.currency)||"",((v=s==null?void 0:s.formatNumber)==null?void 0:v.locale)||"",u.target.value)}})]})]})]})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-3"}),e.jsxRuntimeExports.jsx(e.ColorFormat,{colorRanges:i,setColorRanges:l})]})]})}function zt(){return e.jsxRuntimeExports.jsxs("div",{className:"space-y-6 px-6 py-2",children:[e.jsxRuntimeExports.jsx(e.Accordion,{type:"single",collapsible:!0,children:e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"",children:"KPI Query"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"font-mono",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs",children:"SELECT current, previous FROM table"}),e.jsxRuntimeExports.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"current - number"}),e.jsxRuntimeExports.jsx("li",{children:"previous - number"})]}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#kpi",children:"example"})," in the docs."]})]})]})}),e.jsxRuntimeExports.jsx("section",{className:"",children:e.jsxRuntimeExports.jsx(At,{})}),e.jsxRuntimeExports.jsx("div",{}),e.jsxRuntimeExports.jsx("div",{})]})}const Ot=[{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"}],Mt=["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"],Ft=Mt.map(s=>({label:s,value:s}));function Vt(){var x,d,c,f,h,u,j,p,v,g,z,I,w,D,L,O,m,R;const s=e.useEditorStore(E=>E.card),r=(d=(x=s==null?void 0:s.preferences)==null?void 0:x.mapVisualOptions)==null?void 0:d.topoJsonUrl,[t,n]=b.useState(((f=(c=s==null?void 0:s.preferences)==null?void 0:c.mapVisualOptions)==null?void 0:f.customTopoJsonUrl)||""),{setCardPreferences:o}=e.useEditorActions(),{data:i}=e.useTopoJson(s),l=Object.keys((i==null?void 0:i.objects)||{}).map(E=>({label:E,value:E}))||[],a=[{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.jsxRuntimeExports.jsxs("div",{className:"p-6",children:[e.jsxRuntimeExports.jsx(de,{summary:"Map Query",children:e.jsxRuntimeExports.jsx("p",{className:"rounded-md bg-muted p-2 font-mono text-xs",children:"SELECT country, value FROM table"})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-4"}),e.jsxRuntimeExports.jsx(de,{open:!0,summary:"Settings",children:e.jsxRuntimeExports.jsxs("div",{className:"space-y-3 px-2",children:[e.jsxRuntimeExports.jsx(W,{className:"h-9",options:a,onValueChange:E=>{console.log("value",E),o({...s.preferences,mapVisualOptions:{topoJsonUrl:E}})},value:r||"",label:"Select Map"}),r==="custom"&&e.jsxRuntimeExports.jsx(e.Input,{onChange:E=>{n(E.target.value)},onBlur:()=>{var E;console.log("onBlur",t),o({...s.preferences,mapVisualOptions:{...(E=s.preferences)==null?void 0:E.mapVisualOptions,customTopoJsonUrl:t}})},value:t,className:`h-9 w-full ${e.removeRing}`,placeholder:"Custom URL"}),i&&e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsxs("div",{className:"space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Map Object"}),e.jsxRuntimeExports.jsx(W,{className:"h-9",options:l,value:((u=(h=s.preferences)==null?void 0:h.mapVisualOptions)==null?void 0:u.objectKey)||"",label:"Map Object",onValueChange:E=>{var k;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,objectKey:E}})}})]}),e.jsxRuntimeExports.jsxs("div",{className:"space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Projection"}),e.jsxRuntimeExports.jsx(W,{className:"h-9",options:Ot,value:((p=(j=s.preferences)==null?void 0:j.mapVisualOptions)==null?void 0:p.projection)||"",label:"Projection",onValueChange:E=>{var k;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,projection:E}})}})]}),e.jsxRuntimeExports.jsxs("div",{className:"space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Colors"}),e.jsxRuntimeExports.jsx(W,{className:"h-9",options:Ft,value:((g=(v=s.preferences)==null?void 0:v.mapVisualOptions)==null?void 0:g.colorScale)||"",label:"Select Color Scale",onValueChange:E=>{var k;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,colorScale:E}})}})]})]})]})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-4"}),e.jsxRuntimeExports.jsx(de,{className:"",summary:"Scale Options",children:e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-3",children:[e.jsxRuntimeExports.jsx(e.Input,{className:`h-9 w-full ${e.removeRing}`,type:"number",step:.1,value:((I=(z=s.preferences)==null?void 0:z.mapVisualOptions)==null?void 0:I.projectionScale)||1,onChange:E=>{var k;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,projectionScale:Number(E.target.value)}})}}),e.jsxRuntimeExports.jsx(e.Label,{children:"X"}),e.jsxRuntimeExports.jsx(e.Input,{className:`h-9 w-full ${e.removeRing}`,type:"number",step:10,value:((L=(D=(w=s.preferences)==null?void 0:w.mapVisualOptions)==null?void 0:D.projectionOffset)==null?void 0:L[0])||0,onChange:E=>{var k,S,M,V;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,projectionOffset:[Number(E.target.value),((V=(M=(S=s.preferences)==null?void 0:S.mapVisualOptions)==null?void 0:M.projectionOffset)==null?void 0:V[1])||0]}})}}),e.jsxRuntimeExports.jsx(e.Label,{children:"Y"}),e.jsxRuntimeExports.jsx(e.Input,{className:`h-9 w-full ${e.removeRing}`,type:"number",step:10,value:((R=(m=(O=s.preferences)==null?void 0:O.mapVisualOptions)==null?void 0:m.projectionOffset)==null?void 0:R[1])||0,onChange:E=>{var k,S,M,V;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,projectionOffset:[((V=(M=(S=s.preferences)==null?void 0:S.mapVisualOptions)==null?void 0:M.projectionOffset)==null?void 0:V[0])||0,Number(E.target.value)]}})}})]})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-4"}),e.jsxRuntimeExports.jsx(ne,{})]})}function qt(){var n;const s=e.useEditorStore(o=>o.card.preferences),{setCardPreferences:r}=e.useEditorStore(o=>o.actions);function t(o){r({...s,textVisualOptions:{...s==null?void 0:s.textVisualOptions,isDynamicText:o==="dynamic"}})}return e.jsxRuntimeExports.jsxs(e.RadioGroup,{value:(n=s==null?void 0:s.textVisualOptions)!=null&&n.isDynamicText?"dynamic":"static",onValueChange:t,className:"flex gap-3",defaultValue:"x",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"static",id:"r1"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r1",children:"Static"})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"dynamic",id:"r2"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r2",children:"Dynamic"})]})]})}function he({cardType:s,docContent:r,suffix:t="Chart"}){let n="pie-chart";return s==="radar"&&(n="radar-chart"),e.jsxRuntimeExports.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxRuntimeExports.jsxs(e.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:`${e.titleCase(s)} ${t}`}),e.jsxRuntimeExports.jsx(e.AccordionContent,{children:r||e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT label, measure FROM table"}),e.jsxRuntimeExports.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"label - category"}),e.jsxRuntimeExports.jsx("li",{children:"measure - number"})]}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:o=>o.stopPropagation(),className:"text-blue-700",href:`https://docs.semaphor.cloud/concepts/visuals#${n}`,children:"example"})," in the docs."]})]})})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-2",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Settings"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[s==="range"&&e.jsxRuntimeExports.jsx(ye,{}),s!=="text"&&e.jsxRuntimeExports.jsx(Te,{}),s==="text"&&e.jsxRuntimeExports.jsx(qt,{})]})]}),!["range","text"].includes(s)&&e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Filters"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function Bt(){const s=e.useEditorStore(n=>{var o,i;return(i=(o=n==null?void 0:n.card)==null?void 0:o.preferences)==null?void 0:i.sortChart}),{setSortChart:r}=e.useEditorActions();function t(){return e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Sort"}),e.jsxRuntimeExports.jsx(W,{className:"h-8",label:"Sort Chart",options:[{label:"None",value:"none"},{label:"ASC",value:"asc"},{label:"DESC",value:"desc"}],value:s||"none",onValueChange:n=>{r(n)}})]})}return e.jsxRuntimeExports.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxRuntimeExports.jsxs(e.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Stacked Chart"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT x-axis, stack-by, y-axis FROM table"}),e.jsxRuntimeExports.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"x-axis - category"}),e.jsxRuntimeExports.jsx("li",{children:"stack by - category"}),e.jsxRuntimeExports.jsx("li",{children:"y-axis - number"})]}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:n=>n.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#stacked-chart",children:"example"})," in the docs."]})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-2",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Settings"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ye,{}),t(),e.jsxRuntimeExports.jsx(zs,{})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Filters"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function _t({}){const s=e.useEditorStore(n=>{var o;return(o=n.card)==null?void 0:o.preferences}),r=e.useEditorStore(n=>n.actions.setCardPreferences),t=n=>{r({...s,allowDownload:n})};return e.jsxRuntimeExports.jsxs("div",{className:"space-y-6 px-6 py-2",children:[e.jsxRuntimeExports.jsx(e.Accordion,{defaultValue:["item-3"],type:"multiple",children:e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Filters"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.Checkbox,{onCheckedChange:t,id:"allow-download"}),e.jsxRuntimeExports.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 Ht=e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT dimension, cohort, metric FROM table"}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#pyramid-chart",children:"example"})," in the docs."]})]}),Pt=e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#range-charts",children:"example"})," in the docs."]})]}),Gt=e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT text FROM table limit 1"}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#text-visual",children:"example"})," in the docs."]})]});function $t(){const s=e.useEditorStore(t=>t.card.type);function r(t){switch(t){case"stackedBar":case"stackedLine":return e.jsxRuntimeExports.jsx(Bt,{});case"pyramid":return e.jsxRuntimeExports.jsx(he,{docContent:Ht,cardType:t});case"kpi":return e.jsxRuntimeExports.jsx(zt,{});case"line":case"bar":return e.jsxRuntimeExports.jsx(wt,{cardType:t});case"range":return e.jsxRuntimeExports.jsx(he,{docContent:Pt,cardType:t});case"pie":case"doughnut":case"polarArea":case"radar":return e.jsxRuntimeExports.jsx(he,{cardType:t});case"bubble":case"scatter":return e.jsxRuntimeExports.jsx(kt,{cardType:t});case"table":return e.jsxRuntimeExports.jsx(_t,{cardType:t});case"text":return e.jsxRuntimeExports.jsx(he,{docContent:Gt,cardType:t,suffix:"Visual"});case"map":return e.jsxRuntimeExports.jsx(Vt,{});case"custom":return e.jsxRuntimeExports.jsx(vt,{});default:return e.jsxRuntimeExports.jsx(Lt,{})}}return e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"h-full w-full text-sm",children:r(s)})}function Ut(){const s=e.useEditorStore(r=>r.isShowingVisual);return e.jsxRuntimeExports.jsxs(e.ResizablePanelGroup,{direction:"vertical",className:"min-h-[250px] min-w-full max-w-lg",children:[e.jsxRuntimeExports.jsx(e.ResizablePanel,{role:"query-section",className:"flex",minSize:20,defaultSize:40,children:e.jsxRuntimeExports.jsx(lt,{})}),e.jsxRuntimeExports.jsx(e.ResizableHandle,{withHandle:!0,className:"border"}),e.jsxRuntimeExports.jsx(e.ResizablePanel,{className:"pb-1",role:"visual-section",minSize:0,defaultSize:60,children:s?e.jsxRuntimeExports.jsxs(e.ResizablePanelGroup,{direction:"horizontal",children:[e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsx(e.ResizablePanel,{className:"flex min-w-[275px]",minSize:20,defaultSize:25,maxSize:30,children:e.jsxRuntimeExports.jsx($t,{})})}),e.jsxRuntimeExports.jsx(e.ResizableHandle,{className:"border"}),e.jsxRuntimeExports.jsx(e.ResizablePanel,{minSize:40,defaultSize:75,maxSize:100,children:e.jsxRuntimeExports.jsx(_e,{})})]}):e.jsxRuntimeExports.jsx(_e,{})})]})}function Qt({authToken:s,onSave:r,onClose:t}){e.useDashboardStore(l=>l.themeStyle);const n=e.useEditorStore(l=>l.actions.setOnSave),o=e.useEditorStore(l=>l.actions.setOnClose),i=e.useDashboardStore(l=>l.actions.setAuthToken);return b.useEffect(()=>{r&&n(r),t&&o(t)},[r,n,t,o]),b.useEffect(()=>{s&&s.accessToken&&i(s)},[s,i]),e.jsxRuntimeExports.jsx(e.ErrorBoundary,{FallbackComponent:e.Fallback,children:e.jsxRuntimeExports.jsxs(e.EditorPanel,{style:{},className:"rounded-none",role:"editor-panel",children:[e.jsxRuntimeExports.jsx(e.EditorAside,{className:"rounded-none border-r-[1.5px]",children:e.jsxRuntimeExports.jsx(fs,{})}),e.jsxRuntimeExports.jsx(e.EditorMain,{children:e.jsxRuntimeExports.jsx(Ut,{})})]})})}function Kt(){e.useDashboardStore(l=>l.selectedCardId);const s=e.useDashboardStore(l=>l.selectedSheetId),{setIsVisualEditing:r}=e.useDashboardStore(l=>l.actions),t=e.useDashboardStore(l=>l.isVisualEditing),n=e.useDashboardStore(l=>l.actions.updateFrame);function o(l){s&&(n(s,l),r(!1))}function i(){r(!1)}return e.jsxRuntimeExports.jsx("div",{role:"editor-container",className:e.cn("flex grow",{"max-h-0 overflow-hidden":!t}),children:e.jsxRuntimeExports.jsx(Qt,{onSave:o,onClose:i})})}function Jt(){const s=e.useEditorStore(i=>i.selectedDatabaseName),r=e.useEditorStore(i=>i.selectedTableName),t=e.useDashboardStore(i=>i.dashboard.filters)||[],{columns:n}=te(),{assignFilter:o}=Os();return e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"flex-1 basis-0 flex-col px-3",children:n==null?void 0:n.map(i=>{const l=t==null?void 0:t.find(a=>a.column===e.fmt(i.column_name)&&a.table===r&&a.database===s);return e.jsxRuntimeExports.jsx("div",{onClick:()=>o(i),className:e.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.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxRuntimeExports.jsx(Es,{column:i}),e.jsxRuntimeExports.jsx("span",{children:i.column_name})]})},i.column_name)})})}function Wt(){e.useDashboardStore(r=>r.showFilters);const s=e.useDashboardStore(r=>r.actions.setShowFilters);return e.jsxRuntimeExports.jsxs("section",{className:"relative flex min-w-72 grow flex-col border-l px-1",children:[e.jsxRuntimeExports.jsxs("div",{className:"mt-4 flex items-center justify-between gap-2 px-3",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"px-2 text-lg",children:"Filters"}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>s(!1),className:"h-7 w-7 p-0",variant:"ghost",children:e.jsxRuntimeExports.jsx(e.Cross2Icon,{})})]}),e.jsxRuntimeExports.jsx("div",{className:"flex grow",children:e.jsxRuntimeExports.jsx(fs,{ColumnsComponent:()=>e.jsxRuntimeExports.jsx(Jt,{})})})]})}function Yt(){const s=e.useDashboardStore(n=>n.dashboard.filters),r=e.useDashboardStore(n=>n.theme),t=s==null?void 0:s.filter(n=>n.hide);return t!=null&&t.length?e.jsxRuntimeExports.jsx("div",{className:e.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)]":r==="light","bg-[repeating-linear-gradient(45deg,_#18171d_0_3px,_#272729_3px_6px)]":r==="dark"}),children:t==null?void 0:t.map(n=>e.jsxRuntimeExports.jsxs("div",{className:"flex min-w-[250px] max-w-fit flex-col gap-1 p-2",children:[e.jsxRuntimeExports.jsx(e.FilterHeader,{filter:n}),e.jsxRuntimeExports.jsx(e.FilterComponent,{filter:n})]},n.id))}):null}function Xt(){const s=e.useDashboardStore(n=>n.showFilters),r=e.useDashboardStore(n=>n.isVisualEditing),t=e.useDashboardStore(n=>n.isDashboardEditing);return e.jsxRuntimeExports.jsxs("div",{role:"dashboard-plus-main",className:e.cn("",{"max-h-0 overflow-hidden":r,"flex grow":!r}),children:[e.jsxRuntimeExports.jsxs("section",{className:"flex grow flex-col",children:[t&&e.jsxRuntimeExports.jsx(Yt,{}),e.jsxRuntimeExports.jsx(e.DashboardTabs,{})]}),s&&e.jsxRuntimeExports.jsx("div",{role:"filter-aside-container",className:"flex",children:e.jsxRuntimeExports.jsx(Wt,{})})]})}function Zt(){const s=e.useDashboardStore(n=>n.dashboard),r=e.useDashboardStore(n=>n.actions.setDashboard),t=e.useDashboardStore(n=>n.showDashboardJSON);return e.useDashboardStore(n=>n.actions.setShowDashboardJSON),e.jsxRuntimeExports.jsx("div",{className:e.cn(" p-2",{hidden:!t}),children:e.jsxRuntimeExports.jsx(e.de,{onChange:n=>{if(n)try{JSON.parse(n),r(JSON.parse(n))}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 en({showControls:s=!1,showFooter:r=!0,...t}){return e.jsxRuntimeExports.jsx(e.ErrorBoundary,{FallbackComponent:e.Fallback,children:e.jsxRuntimeExports.jsxs(e.SemaphorContextProvider,{dashboardProps:t,children:[e.jsxRuntimeExports.jsx(e.Oe,{}),e.jsxRuntimeExports.jsxs(e.UXProvider,{children:[e.jsxRuntimeExports.jsx(Zt,{}),e.jsxRuntimeExports.jsxs(e.DashboardPanel,{...t,children:[s&&e.jsxRuntimeExports.jsx(Ps,{}),e.jsxRuntimeExports.jsx(Kt,{}),e.jsxRuntimeExports.jsx(Xt,{})]})]})]})})}exports.Box=Pe;exports.Braces=Ge;exports.ChartArea=$e;exports.ChartColumnIncreasing=ge;exports.ChartLine=Re;exports.ChartNoAxesGantt=Ce;exports.ChartPie=Ne;exports.ChartScatter=we;exports.CircleX=Ue;exports.CopyPlus=Qe;exports.DashboardPlus=en;exports.Database=Ke;exports.EllipsisVertical=ke;exports.Eraser=Je;exports.EyeClosed=We;exports.Glasses=Ye;exports.Hammer=Xe;exports.Hash=Ze;exports.House=es;exports.Key=ss;exports.ListEnd=ts;exports.ListStart=ns;exports.ListX=rs;exports.LoaderCircle=se;exports.Map=Ie;exports.MessageSquareMore=os;exports.Network=is;exports.Play=as;exports.Plug2=ls;exports.Save=cs;exports.SelectComponent=ce;exports.Shapes=De;exports.ShieldQuestion=xs;exports.Sigma=us;exports.SwatchBook=ds;exports.Tag=ms;exports.ToggleLeft=ps;exports.Type=be;exports.User=js;exports.cleanCard=hs;exports.getDashbaordStateWithoutData=Le;exports.useEditorAside=te;
245
+ Visual Query Syntax: ${Js}`,{data:L,isLoading:O,isFetching:m,isError:R,refetch:E}=e.useQuery({queryKey:["ai-query"],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/ai",(x==null?void 0:x.accessToken)||"",{user_content:`userContent: ${w} ${d?D:""}`}),enabled:!1});function k(N){if(N.toLowerCase().includes("bar"))j("bar");else if(N.toLowerCase().includes("line"))j("line");else if(N.toLowerCase().includes("bubble"))j("bubble");else if(N.toLowerCase().includes("scatter"))j("scatter");else if(N.toLowerCase().includes("stacked"))j("stackedBar");else if(N.toLowerCase().includes("pie"))j("pie");else if(N.toLowerCase().includes("donut")||N.toLowerCase().includes("doughnut"))j("doughnut");else if(N.toLowerCase().includes("radar"))j("radar");else return j("bar"),!1;return!0}b.useEffect(()=>{L&&v(N=>[...N,{role:"ai",content:L.response}])},[L]),b.useEffect(()=>{const N=setTimeout(()=>{var F;a.current&&(a.current.scroll({top:a.current.scrollHeight,behavior:"smooth"}),(F=l.current)==null||F.focus())},100);return()=>clearTimeout(N)},[p]);function S(){t&&(v(N=>[...N,{role:"user",content:t}]),k(t)&&c(!0),n(""),E())}b.useEffect(()=>{o&&(S(),i(!1))},[o,i]);const M={fontFamily:"Arial, sans-serif",lineHeight:1.6,fontSize:15,width:"100%"},V={fontFamily:"monospace",fontSize:14,lineHeight:1.6},H={fontFamily:"Arial, sans-serif",lineHeight:1.6,fontSize:15,padding:"2px 0",marginLeft:20,listStyleType:"disc"},P={p:({node:N,...F})=>e.jsxRuntimeExports.jsx("p",{style:M,...F}),code:({node:N,...F})=>e.jsxRuntimeExports.jsx("code",{className:"rounded-sm bg-muted px-2 py-1 text-sm",...F}),pre:({node:N,...F})=>e.jsxRuntimeExports.jsxs("pre",{className:"space-y-2 rounded-sm bg-muted/50 p-3",style:V,children:[e.jsxRuntimeExports.jsx("code",{className:"whitespace-normal text-sm",children:F.children}),e.jsxRuntimeExports.jsxs("div",{className:"flex justify-start gap-2",children:[e.jsxRuntimeExports.jsx(e.Button,{onClick:_,size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(e.ClipboardCopyIcon,{})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:B=>{const A=_(B);A&&(r(!1),f(A),u(!0))},size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(e.PlayIcon,{})})]})]}),li:({node:N,...F})=>e.jsxRuntimeExports.jsx("li",{style:H,...F})};function _(N){const F=N.currentTarget.closest("pre");if(!F)return;const B=F.textContent||F.innerText;return navigator.clipboard.writeText(B).then(()=>console.log("Text copied to clipboard")).catch(A=>console.error("Error in copying text: ",A)),B}function G(){return p==null?void 0:p.map((N,F)=>N.role==="user"?e.jsxRuntimeExports.jsxs("div",{className:"flex items-start rounded-md bg-muted p-3 text-sm",children:[e.jsxRuntimeExports.jsx(hs,{className:"mr-2 h-5 w-5"}),e.jsxRuntimeExports.jsx("div",{children:N.content})]},F):N.role==="ai"?e.jsxRuntimeExports.jsx(e.Markdown,{className:"w-full overflow-auto py-1",components:P,children:L==null?void 0:L.response.replace(/DuckDB/gi,"Semaphor")},F):e.jsxRuntimeExports.jsx("div",{},F))}return e.jsxRuntimeExports.jsxs(e.Dialog,{open:s,onOpenChange:r,children:[e.jsxRuntimeExports.jsx(e.DialogTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{size:"sm",className:"w-full justify-start border font-normal text-muted-foreground focus-visible:ring-0 focus-visible:ring-offset-0",variant:"secondary",children:"Type your question here..."})}),e.jsxRuntimeExports.jsxs(e.DialogContent,{className:"flex flex-col justify-between overflow-auto sm:max-w-[425px] md:max-h-[625px] md:min-w-[625px]",children:[e.jsxRuntimeExports.jsxs(e.DialogHeader,{children:[e.jsxRuntimeExports.jsx(e.DialogTitle,{children:"Assistant"}),e.jsxRuntimeExports.jsx(e.DialogDescription,{children:"What can I help you with?"})]}),e.jsxRuntimeExports.jsx("div",{ref:a,className:"h-[625px] w-full overflow-auto border-t border-t-muted",children:e.jsxRuntimeExports.jsx("div",{className:"space-y-4 py-2 pr-3",role:"messages",children:G()})}),e.jsxRuntimeExports.jsx("div",{children:e.jsxRuntimeExports.jsxs("div",{className:"flex w-full items-center rounded-md border",children:[e.jsxRuntimeExports.jsx(e.Textarea,{autoFocus:!0,ref:l,onKeyDown:N=>{N.key==="Enter"&&!N.shiftKey&&(N.preventDefault(),n(""),S())},placeholder:"Type your question here...",onFocus:N=>{const F=N.target,B=F.value.length;F.setSelectionRange(B,B)},className:e.cn("max-h-10 min-h-7 resize-none border-none focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0"),disabled:O||m,value:t,onChange:N=>n(N.target.value)})," ",e.jsxRuntimeExports.jsx(e.Button,{className:"h-8",size:"sm",variant:"ghost",onClick:S,children:!O&&!m?e.jsxRuntimeExports.jsx(e.PaperPlaneIcon,{}):e.jsxRuntimeExports.jsx(se,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"})})]})})]})]})}var Rs={color:void 0,size:void 0,className:void 0,style:void 0,attr:void 0},Ve=b.createContext&&b.createContext(Rs),Xs=["attr","size","title"];function Ys(s,r){if(s==null)return{};var t=Zs(s,r),n,o;if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(s);for(o=0;o<i.length;o++)n=i[o],!(r.indexOf(n)>=0)&&Object.prototype.propertyIsEnumerable.call(s,n)&&(t[n]=s[n])}return t}function Zs(s,r){if(s==null)return{};var t={};for(var n in s)if(Object.prototype.hasOwnProperty.call(s,n)){if(r.indexOf(n)>=0)continue;t[n]=s[n]}return t}function Ee(){return Ee=Object.assign?Object.assign.bind():function(s){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(s[n]=t[n])}return s},Ee.apply(this,arguments)}function qe(s,r){var t=Object.keys(s);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(s);r&&(n=n.filter(function(o){return Object.getOwnPropertyDescriptor(s,o).enumerable})),t.push.apply(t,n)}return t}function fe(s){for(var r=1;r<arguments.length;r++){var t=arguments[r]!=null?arguments[r]:{};r%2?qe(Object(t),!0).forEach(function(n){et(s,n,t[n])}):Object.getOwnPropertyDescriptors?Object.defineProperties(s,Object.getOwnPropertyDescriptors(t)):qe(Object(t)).forEach(function(n){Object.defineProperty(s,n,Object.getOwnPropertyDescriptor(t,n))})}return s}function et(s,r,t){return r=st(r),r in s?Object.defineProperty(s,r,{value:t,enumerable:!0,configurable:!0,writable:!0}):s[r]=t,s}function st(s){var r=tt(s,"string");return typeof r=="symbol"?r:r+""}function tt(s,r){if(typeof s!="object"||!s)return s;var t=s[Symbol.toPrimitive];if(t!==void 0){var n=t.call(s,r||"default");if(typeof n!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(r==="string"?String:Number)(s)}function bs(s){return s&&s.map((r,t)=>b.createElement(r.tag,fe({key:t},r.attr),bs(r.child)))}function X(s){return r=>b.createElement(nt,Ee({attr:fe({},s.attr)},r),bs(s.child))}function nt(s){var r=t=>{var{attr:n,size:o,title:i}=s,l=Ys(s,Xs),a=o||t.size||"1em",x;return t.className&&(x=t.className),s.className&&(x=(x?x+" ":"")+s.className),b.createElement("svg",Ee({stroke:"currentColor",fill:"currentColor",strokeWidth:"0"},t.attr,n,l,{className:x,style:fe(fe({color:s.color||t.color},t.style),s.style),height:a,width:a,xmlns:"http://www.w3.org/2000/svg"}),i&&b.createElement("title",null,i),s.children)};return Ve!==void 0?b.createElement(Ve.Consumer,null,t=>r(t)):r(Rs)}function rt(s){return X({tag:"svg",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 ot({sql:s}){return e.jsxRuntimeExports.jsxs(e.HoverCard,{children:[e.jsxRuntimeExports.jsx(e.HoverCardTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{variant:"link",className:"h-5 p-0",children:e.jsxRuntimeExports.jsx(e.Info,{className:"h-4 w-4 text-muted-foreground"})})}),e.jsxRuntimeExports.jsx(e.HoverCardContent,{align:"end",className:"w-full min-w-fit max-w-[700px] p-3 pt-2",children:e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"text-xs font-semibold",children:"Resolved Query"}),e.jsxRuntimeExports.jsx("div",{className:"flex grow flex-col space-y-2",children:e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"max-h-[250px] min-h-0 overflow-scroll",children:e.jsxRuntimeExports.jsx("p",{className:"overflow-auto rounded-md bg-muted p-2 font-mono text-xs leading-relaxed",children:s})})})]})})]})}function ys(s){const{theme:r}=e.useTheme(),t=e.useDashboardStore(p=>p.theme),n=e.useEditorStore(p=>p.frame),o=e.useEditorStore(p=>p.card),i=e.useEditorStore(p=>p.activeTabCardId),l=e.Le(),{refetch:a}=e.useDashboardCardQuery(o),{updateCardTab:x,setRunSql:d}=e.useEditorActions(),c=b.useRef(),f=b.useRef({}),h=n.cards.find(p=>p.id===i),u=b.useCallback(()=>{let p="";return s==="python"&&(p=(h==null?void 0:h.python)||e.PYTHON_DEFAULT_CODE),s==="sql"&&(p=(h==null?void 0:h.sql)||""),p},[s,h]);b.useEffect(()=>{if(i&&o.id&&o.id!==i){if(c.current&&l){const p=c.current.getModel();p&&(f.current[o.id]=p);let v=f.current[i];if(!v){const g=u();v=l.editor.createModel(g,s),f.current[i]=v}c.current.setModel(v)}x(i,o),d(!0)}},[i,o,x,l,d,s,u]),b.useEffect(()=>{if(!l)return;const p=window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light",v=t==="system"?p:t;l.editor.defineTheme("default",{base:v==="light"?"vs":"vs-dark",inherit:!0,rules:[],colors:{"editor.background":v==="light"?"#ffffff":e.hslStringToHex("240 10% 10%")}}),l.editor.setTheme("default")},[r,t,l]),b.useEffect(()=>{const p=c.current;p&&l&&o&&p.addCommand(l.KeyMod.Shift|l.KeyCode.Enter,function(){return a(),!1})},[l,a,o]);function j(p,v){if(c.current=p,!f.current[o.id]){const g=p.getModel(),z=u();f.current[o.id]=g||(v==null?void 0:v.editor.createModel(z,s))||p.getModel()}p.setModel(f.current[o.id])}return{handleEditorDidMount:j}}function it(){const s=e.useEditorStore(l=>l.card.sql),r=e.useEditorStore(l=>l.sqlGen),{setCardSql:t,setSqlGen:n}=e.useEditorActions(),{handleEditorDidMount:o}=ys("sql");function i(l){t(l),e.isObjectEmpty(r)||n({})}return e.jsxRuntimeExports.jsx(e.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 at(){const s=e.useEditorStore(o=>o.card.python),{setCardPython:r}=e.useEditorActions(),{handleEditorDidMount:t}=ys("python");function n(o){r(o)}return e.jsxRuntimeExports.jsx(e.Ft,{className:"pt-3",theme:"default",onChange:n,value:s||e.PYTHON_DEFAULT_CODE,options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:13,renderLineHighlight:"none"},defaultLanguage:"python",onMount:t})}function lt(){const s=e.useDashboardStore(i=>i.dashboard.filters),r=e.useDashboardStore(i=>i.filterValues),t=e.useDashboardStore(i=>i.selectedSheetId),n=s==null?void 0:s.filter(i=>i.sheetId===t||!i.sheetId),o=r==null?void 0:r.filter(i=>(n==null?void 0:n.some(l=>l.id===i.filterId))||i.filterId.endsWith(t));return e.jsxRuntimeExports.jsx(e.Ft,{theme:"default",defaultLanguage:"json",className:"mt-1 min-h-[220px]",value:JSON.stringify(o,null,2),options:{readOnly:!0,minimap:{enabled:!1},lineNumbers:"off",glyphMargin:!1,wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:12,renderLineHighlight:"none"}})}function ct(){const[s,r]=b.useState({queryKey:[],queryData:null}),t=e.useQueryClient(),[n,o]=b.useState(!1),[i,l]=b.useState(!1),[a,x]=b.useState(!1),[d,c]=b.useState(""),[f,h]=b.useState(!1),u=e.useEditorStore(C=>C.frame),j=e.useEditorStore(C=>C.card),p=e.useEditorStore(C=>C.isShowingVisual),v=e.useEditorStore(C=>C.selectedConnectionId),g=e.useEditorStore(C=>C.selectedDatabaseName),z=e.useEditorStore(C=>C.selectedDatamodelId),I=e.useEditorStore(C=>C.selectedSchemaName),w=e.useEditorStore(C=>C.selectedTableName),D=e.useEditorStore(C=>{var Q;return(Q=C==null?void 0:C.card)==null?void 0:Q.sql}),L=e.useEditorStore(C=>C.applyFilters),{setCardCustomCfg:O,setQueryResultColumns:m,setCardSql:R,setQueryError:E,setPythonStdOut:k,setCardPreferences:S,setCardType:M}=e.useEditorActions(),V=e.useEditorStore(C=>C.onSave),H=e.useEditorStore(C=>C.onClose),P=e.useEditorStore(C=>C.actions.setSqlGen),_=e.useEditorStore(C=>C.runSql),G=e.useEditorStore(C=>C.actions.setRunSql),N=e.useEditorStore(C=>C.actions.setCardCfg),F=e.useEditorStore(C=>C.actions.setIsSqlRunning),{data:B,isLoading:A,isFetching:T,isSuccess:K,isError:q,error:$,queryKey:U,refetch:Y}=e.useDashboardCardQuery(j);b.useEffect(()=>{if(B&&(B.rowLimitExceeded&&e.ce.error("Row limit (10,000) exceeded. Refine your query.",{position:"top-center",richColors:!0}),k((B==null?void 0:B.output)||""),B.records.length>0)){const{dimensionKeys:C}=e.getKeys(B.records);m(C)}},[B,m,k]),b.useEffect(()=>{(A||T)&&F(!0),(q||K)&&F(!1),q?(E($.message),m([]),k("")):E("")},[A,T,B,k,q,K,F,m,E,$]),b.useEffect(()=>{_&&(t.getQueryData(U)||Y(),G(!1))},[_,Y,G,U,t]);function re(){const C=t.getQueryData(U);s.queryData||r({queryKey:U,queryData:C}),R(""),P({}),N(void 0),O(""),S({}),M("bar")}function Z(C,Q){if(C.length===0)return"";if(Q){const ee=C.find(J=>J.id===Q);if(ee){const J=ee.tabTitle;if(J=="All__Header")return C[0].id;if(J&&J.endsWith("__Header")){const ve=J.split("__")[0],me=C.find(pe=>pe.tabTitle===ve);return me?me.id:C[0].id}return Q}}return C[0].id}function oe(){let C=D;D&&!D.includes("{{")&&(C=Qs(D),R(C));const Q={...j,lastSelectedSchema:I,lastSelectedDatamodelId:z,lastSelectedDatabase:g,lastSelectedTable:w,connectionId:v,type:p?j.type:"table",sql:C,customCfg:p?j.customCfg:null},ee=u.cards.map(ue=>ue.id===j.id?Q:ue),J={...u,cards:ee,activeCardId:Z(ee,u.activeCardId)};V==null||V(J)}function ie(){const{queryKey:C,queryData:Q}=s;C&&Q&&t.setQueryData(C,Q),H==null||H()}function ae(){return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[i&&e.jsxRuntimeExports.jsx("div",{className:"relative flex w-1/3 min-w-0 grow overflow-hidden border-l p-1 text-xs",role:"editor-filter-container",children:e.jsxRuntimeExports.jsxs("div",{className:"w-[99%]",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2 pt-3",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"ml-6 text-xs font-semibold",children:"Filters"}),i&&e.jsxRuntimeExports.jsx(e.Cross2Icon,{onClick:()=>l(!1),className:"bg-background/50 text-foreground/50 hover:cursor-pointer hover:text-foreground"})]}),e.jsxRuntimeExports.jsx(lt,{})]})}),!i&&e.jsxRuntimeExports.jsx(e.Filter,{onClick:()=>l(!0),className:e.cn("absolute bottom-4 right-6 h-3 w-3 text-foreground/50 hover:cursor-pointer hover:text-foreground",{"font-bold text-red-800":L})})]})}function le(){return e.jsxRuntimeExports.jsxs(e.ResizablePanelGroup,{className:"flex grow pb-1",direction:"vertical",role:"editor-resizable-group",children:[e.jsxRuntimeExports.jsxs(e.ResizablePanel,{id:"1",order:1,defaultSize:n?20:100,className:"relative flex grow",children:[e.jsxRuntimeExports.jsx("div",{id:"sql-container",className:"relative flex w-[99%]",children:e.jsxRuntimeExports.jsx(it,{})}),n&&e.jsxRuntimeExports.jsx("code",{className:"absolute right-6 top-3 text-xs text-muted-foreground/70",children:"sql"})]}),n&&e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx(e.ResizableHandle,{withHandle:!0,className:"border"}),e.jsxRuntimeExports.jsxs(e.ResizablePanel,{id:"2",order:2,defaultSize:80,className:"relative flex grow",children:[e.jsxRuntimeExports.jsx("div",{id:"python-container",className:"relative flex w-[99%] pt-0",children:e.jsxRuntimeExports.jsx(at,{})}),e.jsxRuntimeExports.jsx("code",{className:"absolute right-6 top-3 text-xs text-muted-foreground/70",children:"python"})]})]})]})}return e.jsxRuntimeExports.jsxs("section",{role:"editor-section",className:"flex grow flex-col justify-end",children:[e.jsxRuntimeExports.jsxs("div",{className:"relative flex grow justify-between overflow-y-scroll",children:[le(),ae()]}),e.jsxRuntimeExports.jsxs("div",{role:"editor-controls",className:"item-center flex flex-wrap justify-between gap-2 px-6 py-4",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex grow items-center gap-2",children:[e.jsxRuntimeExports.jsxs(e.Button,{title:"Shift + Enter",disabled:A||T,onClick:()=>{Y()},className:"shrink-0",size:"sm",variant:"outline",children:[A||T?e.jsxRuntimeExports.jsx(se,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsxRuntimeExports.jsx(as,{className:"mr-2 h-4 w-4"}),"Run"]}),q&&e.jsxRuntimeExports.jsx(Ks,{error:$.message,setShowAIDialog:x,setTriggerAIRun:h,setUserInputforAI:c}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:re,className:"",size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(Je,{className:"mr-2 size-4"}),"Clear"]}),e.jsxRuntimeExports.jsx(e.Toggle,{pressed:n,onPressedChange:C=>o(C),className:"",size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(rt,{className:"size-4 text-foreground/70"})}),e.jsxRuntimeExports.jsx(Ws,{open:a,setOpen:x,userInput:d,triggerAIRun:f,setTriggerAIRun:h,setUserInput:C=>c(C)})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[(B==null?void 0:B.sql)&&e.jsxRuntimeExports.jsx(ot,{sql:B.sql}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:ie,className:"w-full",size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(e.Cross2Icon,{className:"mr-2 size-4"}),"Close"]}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:oe,size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(e.Check,{className:"mr-2 size-4 font-bold text-green-600"}),"Accept"]})]})]})]})}function xt({data:s}){var l;const[r,t]=b.useState([]),o=Object.keys(s[0]).map(a=>({accessorKey:a,header:({column:x})=>{const d=x.getIsSorted();return e.jsxRuntimeExports.jsx("div",{className:"flex gap-2",children:e.jsxRuntimeExports.jsxs("div",{className:"flex cursor-pointer items-center",onClick:()=>x.toggleSorting(x.getIsSorted()==="asc"),children:[a,d==="asc"?e.jsxRuntimeExports.jsx(e.TriangleUpIcon,{className:"ml-2 h-5 w-5"}):d==="desc"?e.jsxRuntimeExports.jsx(e.TriangleDownIcon,{className:"ml-2 h-5 w-5"}):null]})})}})),i=e.useReactTable({data:s,columns:o,getCoreRowModel:e.getCoreRowModel(),getPaginationRowModel:e.getPaginationRowModel(),onSortingChange:t,getSortedRowModel:e.getSortedRowModel(),manualPagination:!0,state:{sorting:r}});return e.jsxRuntimeExports.jsx("div",{className:"font-mono text-xs text-foreground/95",children:e.jsxRuntimeExports.jsxs("table",{className:"w-full",children:[e.jsxRuntimeExports.jsx(e.TableHeader,{children:i.getHeaderGroups().map(a=>e.jsxRuntimeExports.jsx(e.TableRow,{children:a.headers.map(x=>e.jsxRuntimeExports.jsx(e.TableHead,{className:"sticky top-0 h-11 bg-muted font-semibold",children:x.isPlaceholder?null:e.flexRender(x.column.columnDef.header,x.getContext())},x.id))},a.id))}),e.jsxRuntimeExports.jsx(e.TableBody,{children:(l=i.getRowModel().rows)!=null&&l.length?i.getRowModel().rows.map(a=>e.jsxRuntimeExports.jsx(e.TableRow,{className:"whitespace-nowrap py-2","data-state":a.getIsSelected()&&"selected",children:a.getVisibleCells().map(x=>e.jsxRuntimeExports.jsx(e.TableCell,{className:"py-3",children:e.flexRender(x.column.columnDef.cell,x.getContext())},x.id))},a.id)):e.jsxRuntimeExports.jsx(e.TableRow,{children:e.jsxRuntimeExports.jsx(e.TableCell,{colSpan:o.length,className:"h-24 text-center",children:"No results."})})})]})})}function ut({card:s}){var g,z,I,w,D,L,O,m,R,E,k;const[r,t]=b.useState(!1),[n,o]=b.useState([]),{authToken:i}=e.useSemaphorContext(),l=e.getTokenParams(i==null?void 0:i.accessToken),a=e.useDashboardStore(S=>S.themeStyle),x={colors:((z=(g=a==null?void 0:a.chart)==null?void 0:g.dataset)==null?void 0:z.backgroundColor)||[]};(I=s.customCardPreferences)!=null&&I.inputData;const{getCard:d}=e.useCustomVisual(((w=s.customCardPreferences)==null?void 0:w.url)||""),c=((D=s.customCardPreferences)==null?void 0:D.visualType)||"single",f=e.useEditorStore(S=>S.frame);e.useEditorActions();const{data:h}=e.useDashboardCardQuery(s),u=b.useCallback((S,M)=>{o(V=>({...V,[S]:M}))},[]);if(!((L=s.customCardPreferences)!=null&&L.componentName))return null;const j=d((O=s.customCardPreferences)==null?void 0:O.componentName);function p(S){t(S)}const v=Object.keys(((m=s.customCardPreferences)==null?void 0:m.dataInputCardIds)||{}).map(S=>{var H,P,_;const M=(P=(H=s.customCardPreferences)==null?void 0:H.dataInputCardIds)==null?void 0:P[S].cardId,V=(_=f==null?void 0:f.cards)==null?void 0:_.find(G=>G.id===M);return V||null});return e.jsxRuntimeExports.jsx("div",{className:"semaphor-custom mb-3 flex grow basis-0 flex-col space-y-2 overflow-y-auto",children:e.jsxRuntimeExports.jsxs(b.Suspense,{fallback:e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{}),children:[j&&c==="single"&&e.jsxRuntimeExports.jsx(j,{params:l,theme:x,settings:(R=s.customCardPreferences)==null?void 0:R.settings,onDataChange:u,data:(h==null?void 0:h.records)||[]}),j&&c==="multiple"&&e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[Object.keys(((E=s.customCardPreferences)==null?void 0:E.dataInputCardIds)||{}).map(S=>{var H,P,_;const M=(P=(H=s.customCardPreferences)==null?void 0:H.dataInputCardIds)==null?void 0:P[S].cardId,V=(_=f==null?void 0:f.cards)==null?void 0:_.find(G=>G.id===M);if(V)return e.jsxRuntimeExports.jsx(e.MultiInputEmptyRenderer,{onLoadingStatus:p,onDataChange:u,dataInputIndex:S,card:V},V.id+S)}),e.jsxRuntimeExports.jsx("div",{className:"flex flex-col gap-2",children:e.jsxRuntimeExports.jsx(j,{theme:x,onDataChange:u,settings:v.map(S=>{var M;return(M=S==null?void 0:S.customCardPreferences)==null?void 0:M.settings}),data:v.map(S=>S!=null&&S.id?n==null?void 0:n[S.id]:[])})})]})]},(k=s.customCardPreferences)==null?void 0:k.componentName)})}function vs({className:s,...r}){var v;const t=e.useEditorStore(g=>g.card),n=((v=t.customCardPreferences)==null?void 0:v.showCardHeader)??!0,o=e.useEditorStore(g=>g.frame),i=e.useDashboardStore(g=>g.dashboard.filters);e.useEditorStore(g=>g.actions.setRunSql);const{updateFilter:l}=e.useDashboardActions(),a=i==null?void 0:i.find(g=>g.id===o.filterId),{data:x,isLoading:d,isFetching:c}=e.useDashboardCardQuery(t),{setCard:f}=e.useEditorActions(),{data:h}=e.useTopoJson(t);if(!t.id)return null;let u;x!=null&&x.records&&(x==null?void 0:x.records.length)>0&&(u=e.createChartConfig({data:x==null?void 0:x.records,cardType:t.type,cfg:t.cfg,customCfg:t.customCfg,preferences:t.preferences,topoJson:h}));function j(g){return e.jsxRuntimeExports.jsx(ut,{card:g})}function p(){var g;if(x!=null&&x.records&&(x==null?void 0:x.records.length)===0&&!d&&!c)return e.jsxRuntimeExports.jsxs("div",{className:"flex h-full flex-col items-center justify-center gap-2",children:[e.jsxRuntimeExports.jsx(e.TreePalm,{className:"size-8 text-muted-foreground"}),e.jsxRuntimeExports.jsx("p",{className:"text-sm text-muted-foreground",children:"No records to display"})]});if(t.type==="custom")return j(t);if(!["table","custom"].includes(t.type)&&u)return e.jsxRuntimeExports.jsx(e.ChartJsVisual,{cfg:u},JSON.stringify(u)+JSON.stringify(t.preferences)+((g=t==null?void 0:t.preferences)==null?void 0:g.customVisualCode));if(t.type==="table"&&(x!=null&&x.records)&&(x==null?void 0:x.records.length)>0)return e.jsxRuntimeExports.jsxs(e.ScrollArea,{className:"relative mb-2 flex h-full min-h-0 w-full flex-1 grow basis-0",children:[e.jsxRuntimeExports.jsx(e.TableVisual,{card:t,data:x==null?void 0:x.records}),e.jsxRuntimeExports.jsx(e.ScrollBar,{orientation:"horizontal"})]})}return e.jsxRuntimeExports.jsxs(e.Card,{role:"editor-visual-card",className:e.cn("relative flex h-full flex-col rounded-none",s),...r,children:[n&&e.jsxRuntimeExports.jsxs(e.CardHeader,{className:"flex flex-row items-start justify-between py-4",children:[e.jsxRuntimeExports.jsxs("div",{children:[e.jsxRuntimeExports.jsx(e.Editable,{text:t.title,onSave:g=>f({...t,title:g}),children:e.jsxRuntimeExports.jsx("div",{className:"flex items-center gap-5",children:e.jsxRuntimeExports.jsx(e.CardTitle,{className:"text-base",children:t.title||"Edit title..."})})},t.title),e.jsxRuntimeExports.jsx(e.Editable,{text:t.description||"",onSave:g=>f({...t,description:g}),children:e.jsxRuntimeExports.jsx(e.CardDescription,{children:t.description||"Edit description..."})},t.description)]}),a&&e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-3",children:[e.jsxRuntimeExports.jsx(e.Editable,{className:"my-1",text:a.title||a.column,onSave:g=>l({...a,title:g}),children:e.jsxRuntimeExports.jsx(e.Label,{children:a.title})}),e.jsxRuntimeExports.jsx(e.FilterComponent,{filter:a})]})]}),e.jsxRuntimeExports.jsx(e.CardContent,{className:"flex grow flex-col",children:p()})]})}const Be=({language:s,value:r,onChange:t})=>e.jsxRuntimeExports.jsx(e.Ft,{className:"h-full w-full overflow-hidden",theme:"default",options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:14,renderLineHighlight:"none"},defaultLanguage:s,value:r,onChange:t}),dt=({card:s})=>e.jsxRuntimeExports.jsxs(e.DialogHeader,{children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.DialogTitle,{children:"Customize Card"}),e.jsxRuntimeExports.jsxs(e.Tooltip,{children:[e.jsxRuntimeExports.jsx(e.TooltipTrigger,{children:e.jsxRuntimeExports.jsx(ss,{onClick:()=>navigator.clipboard.writeText(s.id),className:"size-3 cursor-pointer text-muted-foreground/70 transition-colors hover:text-muted-foreground"})}),e.jsxRuntimeExports.jsx(e.TooltipContent,{side:"right",align:"center",children:e.jsxRuntimeExports.jsx("p",{className:"text-xs",children:"Copy Card ID"})})]})]}),e.jsxRuntimeExports.jsxs(e.DialogDescription,{children:["See the configuration options and documentation",e.jsxRuntimeExports.jsx("a",{target:"_blank",className:"ml-1 text-blue-500 underline",href:"https://www.chartjs.org/docs/latest/samples/bar/vertical.html",children:"here."})]})]}),mt=({defaultConfig:s,customCode:r,customConfig:t,onConfigChange:n,onCodeChange:o})=>e.jsxRuntimeExports.jsxs(e.Tabs,{defaultValue:"custom-config",className:"flex w-1/2 flex-col",children:[e.jsxRuntimeExports.jsxs(e.TabsList,{className:"justify-start rounded-sm rounded-b-none border border-b-0",children:[e.jsxRuntimeExports.jsxs(e.TabsTrigger,{value:"custom-config",children:[t&&e.jsxRuntimeExports.jsx(e.CheckIcon,{className:"mr-1 h-5 w-5 text-green-600"}),t?"Custom Config":"Default Config"]}),e.jsxRuntimeExports.jsx(e.TabsTrigger,{value:"output",children:"Output"}),e.jsxRuntimeExports.jsx(e.TabsTrigger,{value:"custom-code",children:"Custom Code"})]}),e.jsxRuntimeExports.jsx(e.TabsContent,{value:"output",className:"mt-0 grow rounded-b border border-t-0 p-2",children:e.jsxRuntimeExports.jsx(e.Textarea,{readOnly:!0,value:s,className:"h-full resize-none border-none font-mono focus-visible:ring-0"})}),e.jsxRuntimeExports.jsx(e.TabsContent,{value:"custom-config",className:"mt-0 grow rounded-b border border-t-0",children:e.jsxRuntimeExports.jsx(Be,{language:"json",value:t,onChange:n})}),e.jsxRuntimeExports.jsx(e.TabsContent,{value:"custom-code",className:"mt-0 grow rounded-b border border-t-0",children:e.jsxRuntimeExports.jsx(Be,{language:"javascript",value:r,onChange:o})})]}),pt=({error:s,hasCustomConfig:r,onReset:t,onApply:n,onClose:o})=>e.jsxRuntimeExports.jsxs(e.DialogFooter,{className:"flex items-center",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"mr-2 text-red-500",children:s}),e.jsxRuntimeExports.jsx(e.Button,{disabled:!r,onClick:t,variant:"outline",children:"Reset"}),e.jsxRuntimeExports.jsx(e.Button,{onClick:n,variant:"outline",children:"Apply"}),e.jsxRuntimeExports.jsx(e.Button,{onClick:o,variant:"outline",children:"Close"})]});function jt(){const[s,r]=b.useState(!1),[t,n]=b.useState(""),[o,i]=b.useState(""),[l,a]=b.useState(""),[x,d]=b.useState(""),c=e.useEditorStore(w=>w.card),f=e.useEditorStore(w=>w.card.customCfg),{data:h}=e.useDashboardCardQuery(c),{data:u}=e.useTopoJson(c),{setCardCustomCfg:j,setCustomVisualCode:p}=e.useEditorActions(),v=w=>{var D,L;return JSON.stringify({...w,data:{...w.data,datasets:(L=(D=w.data)==null?void 0:D.datasets)==null?void 0:L.map(O=>({...O,data:[]}))}},null,2)},g=()=>{var D,L;if(!((D=h==null?void 0:h.records)!=null&&D.length))return;const w=e.createChartConfig({data:h.records,cardType:c.type,cfg:c.cfg,preferences:c.preferences,topoJson:u});w&&(n(v(w)),a(((L=c.preferences)==null?void 0:L.customVisualCode)||""),i(f?JSON.stringify(f,null,2):""))},z=()=>{try{if(l&&p(l),o){const w=JSON.parse(o);j(w),d("")}}catch{d("Invalid JSON configuration")}},I=()=>{if(f){const w=e._.merge(e._.cloneDeep(c.cfg),f);return v(w)}return t?v(JSON.parse(t)):""};return e.jsxRuntimeExports.jsxs(e.Dialog,{open:s,onOpenChange:r,children:[e.jsxRuntimeExports.jsx(e.DialogTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{onClick:g,size:"sm",variant:"outline",className:f?"border-foreground/50 dark:border-foreground/70":"",children:e.jsxRuntimeExports.jsx(e.Settings,{className:"h-4 w-4"})})}),e.jsxRuntimeExports.jsxs(e.DialogContent,{className:"max-h-[70vh] min-h-[70vh] overflow-auto sm:min-w-[900px] lg:min-w-[1200px]",children:[e.jsxRuntimeExports.jsx(dt,{card:c}),e.jsxRuntimeExports.jsxs("div",{className:"flex grow gap-2",children:[e.jsxRuntimeExports.jsx(e.ErrorBoundary,{FallbackComponent:e.FallbackEditorCard,children:e.jsxRuntimeExports.jsx(vs,{className:"w-1/2 rounded shadow-none"})}),e.jsxRuntimeExports.jsx(mt,{defaultConfig:t,customCode:l,customConfig:I(),onConfigChange:w=>i(w??""),onCodeChange:w=>a(w??"")})]}),e.jsxRuntimeExports.jsx(pt,{error:x,hasCustomConfig:!!f,onReset:()=>{i(""),j(null)},onApply:z,onClose:()=>r(!1)})]})]})}function Ss(s){return X({tag:"svg",attr:{viewBox:"0 0 1024 1024"},child:[{tag:"path",attr:{d:"M926.8 397.1l-396-288a31.81 31.81 0 0 0-37.6 0l-396 288a31.99 31.99 0 0 0-11.6 35.8l151.3 466a32 32 0 0 0 30.4 22.1h489.5c13.9 0 26.1-8.9 30.4-22.1l151.3-466c4.2-13.2-.5-27.6-11.7-35.8zM838.6 417l-98.5 32-200-144.7V199.9L838.6 417zM466 567.2l-89.1 122.3-55.2-169.2L466 567.2zm-116.3-96.8L484 373.3v140.8l-134.3-43.7zM512 599.2l93.9 128.9H418.1L512 599.2zm28.1-225.9l134.2 97.1L540.1 514V373.3zM558 567.2l144.3-46.9-55.2 169.2L558 567.2zm-74-367.3v104.4L283.9 449l-98.5-32L484 199.9zM169.3 470.8l86.5 28.1 80.4 246.4-53.8 73.9-113.1-348.4zM327.1 853l50.3-69h269.3l50.3 69H327.1zm414.5-33.8l-53.8-73.9 80.4-246.4 86.5-28.1-113.1 348.4z"},child:[]}]})(s)}function Cs(s){return X({tag:"svg",attr:{viewBox:"0 0 256 256",fill:"currentColor"},child:[{tag:"path",attr:{d:"M128,24a8,8,0,0,0-8,8V88a8,8,0,0,0,8,8,32,32,0,1,1-27.72,16,8,8,0,0,0-2.93-10.93l-48.5-28A8,8,0,0,0,37.92,76,104,104,0,1,0,128,24ZM48.09,91.1,83,111.26A48.09,48.09,0,0,0,80,128c0,1.53.08,3,.22,4.52L41.28,143A88.16,88.16,0,0,1,48.09,91.1Zm-2.67,67.31,39-10.44A48.1,48.1,0,0,0,120,175.32v40.31A88.2,88.2,0,0,1,45.42,158.41ZM136,215.63V175.32a48,48,0,0,0,0-94.65V40.36a88,88,0,0,1,0,175.27Z"},child:[]}]})(s)}function Ns(s){return X({tag:"svg",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 ws(s){return X({tag:"svg",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 ks(s){return X({tag:"svg",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 Is(s){return X({tag:"svg",attr:{viewBox:"0 0 24 24"},child:[{tag:"path",attr:{fill:"none",d:"M0 0h24v24H0z"},child:[]},{tag:"path",attr:{d:"M4 9h4v11H4zM4 4h4v4H4zM10 7h4v4h-4zM16 10h4v4h-4zM16 15h4v5h-4zM10 12h4v8h-4z"},child:[]}]})(s)}function Ds(s){return X({tag:"svg",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 Ls(s){return X({tag:"svg",attr:{viewBox:"0 0 512 512"},child:[{tag:"path",attr:{d:"M217 25v14h78V25h-78zm0 32v46h14V71h50v32h14V57h-78zm32 32v14h14V89h-14zm-64 32v46h30v-46h-30zm48 0v14h46v-14h-46zm64 0v46h30v-46h-30zm-64 32v14h46v-14h-46zm-80 32v46h62v-46h-62zm80 0v14h46v-14h-46zm64 0v46h62v-46h-62zm-64 32v14h46v-14h-46zm-112 32v46h94v-46h-94zm112 0v14h46v-14h-46zm64 0v46h94v-46h-94zm-64 32v14h46v-14h-46zM89 313v46h126v-46H89zm144 0v14h46v-14h-46zm64 0v46h126v-46H297zm-64 32v14h46v-14h-46zM57 377v46h158v-46H57zm176 0v14h46v-14h-46zm64 0v46h158v-46H297zm-64 32v14h46v-14h-46zM25 441v46h190v-46H25zm208 0v14h46v-14h-46zm64 0v46h190v-46H297zm-64 32v14h46v-14h-46z"},child:[]}]})(s)}function Ts(s){const[r,t]=b.useState(null);return b.useEffect(()=>{s&&(async()=>{const i=(await Promise.resolve().then(()=>require("./lucide-react-DEyirEfi.js")))[s];t(i)})()},[s]),r}function As(){const{authToken:s}=e.useSemaphorContext(),{data:r,isLoading:t,isFetching:n,isError:o}=e.useQuery({queryKey:["plugins",s==null?void 0:s.accessToken],queryFn:()=>e.getPlugins(s==null?void 0:s.accessToken)});return{data:r,isLoading:t,isFetching:n,isError:o}}function ht({onChartTypeChange:s}){const[r,t]=b.useState([]),{data:n}=As();return b.useEffect(()=>{(async()=>{var i;if(n){const a=(await Promise.all((i=n==null?void 0:n.plugins)==null?void 0:i.map(async x=>(await e.loadManifest(x.value)).visuals.map(f=>({name:f.name,icon:f.icon,url:x.value}))))).flat();t(a)}})()},[n]),r.length===0?null:e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx(e.Separator,{className:"my-2"}),e.jsxRuntimeExports.jsx("div",{className:"grid grid-cols-4 place-items-center",children:r.map((o,i)=>e.jsxRuntimeExports.jsx(Et,{text:o.name,onClick:()=>s("custom",o),icon:o.icon},o.url+o.name+i))})]})}const Et=({text:s,icon:r,onClick:t})=>{const n=Ts(r||""),o=s.charAt(0).toUpperCase();return e.jsxRuntimeExports.jsx(e.Button,{onClick:t,title:s,variant:"ghost",children:n?e.jsxRuntimeExports.jsx(n,{className:"h-4 w-4"}):o})};function ft(){var c,f;const[s,r]=b.useState(!1),t=e.useEditorStore(h=>h.card),n=t.type,{setCardType:o,setCardPreferences:i,setChartOrientation:l}=e.useEditorStore(h=>h.actions),{setCardCustomCfg:a,setCustomCardPreferences:x}=e.useEditorActions();function d(h,u){a(null),i({}),o(h),u&&x({type:"component",visualType:"single",url:u.url,componentName:u.name,icon:u.icon}),r(!1)}return e.jsxRuntimeExports.jsxs(e.Popover,{open:s,onOpenChange:r,children:[e.jsxRuntimeExports.jsx(e.PopoverTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.Button,{size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(gt,{className:"h-4 w-4",chartType:n,customIcon:(c=t.customCardPreferences)==null?void 0:c.icon,componentName:(f=t.customCardPreferences)==null?void 0:f.componentName})})}),e.jsxRuntimeExports.jsxs(e.PopoverContent,{className:"w-50",children:[e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-4 place-items-center",children:[e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("bar"),className:"font-normal",variant:"ghost",children:e.jsxRuntimeExports.jsx(ge,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("line"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Re,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("stackedBar"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Is,{className:"size-5",strokeWidth:0})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("stackedLine"),variant:"ghost",children:e.jsxRuntimeExports.jsx(ks,{className:"size-5",strokeWidth:0})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("scatter"),variant:"ghost",children:e.jsxRuntimeExports.jsx(we,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("bubble"),variant:"ghost",children:e.jsxRuntimeExports.jsx(ws,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("pie"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ne,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("doughnut"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Cs,{className:"size-5",strokeWidth:1})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("radar"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ss,{className:"size-5 font-extralight",strokeWidth:.5})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("polarArea"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ns,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("pyramid"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ls,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("range"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ce,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("table"),variant:"ghost",children:e.jsxRuntimeExports.jsx(e.Table,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("kpi"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ds,{className:"size-6"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("text"),variant:"ghost",children:e.jsxRuntimeExports.jsx(be,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("map"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ie,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>d("custom"),variant:"ghost",children:e.jsxRuntimeExports.jsx(De,{className:"size-4"})})]}),e.jsxRuntimeExports.jsx(ht,{onChartTypeChange:d})]})]})}function gt({chartType:s,className:r,customIcon:t,componentName:n}){const o=Ts(t||"");switch(s){case"bar":return e.jsxRuntimeExports.jsx(ge,{className:r});case"line":return e.jsxRuntimeExports.jsx(Re,{className:r});case"pie":return e.jsxRuntimeExports.jsx(Ne,{className:r});case"radar":return e.jsxRuntimeExports.jsx(Ss,{className:r});case"scatter":return e.jsxRuntimeExports.jsx(we,{className:r});case"bubble":return e.jsxRuntimeExports.jsx(ws,{className:r});case"doughnut":return e.jsxRuntimeExports.jsx(Cs,{className:r});case"stackedBar":return e.jsxRuntimeExports.jsx(Is,{className:"size-4 text-foreground/70"});case"stackedLine":return e.jsxRuntimeExports.jsx(ks,{className:"size-4 text-foreground/70"});case"polarArea":return e.jsxRuntimeExports.jsx(Ns,{className:r});case"pyramid":return e.jsxRuntimeExports.jsx(Ls,{className:r});case"range":return e.jsxRuntimeExports.jsx(Ce,{className:r});case"kpi":return e.jsxRuntimeExports.jsx(Ds,{className:r});case"text":return e.jsxRuntimeExports.jsx(be,{className:r});case"map":return e.jsxRuntimeExports.jsx(Ie,{className:r});case"custom":return t&&o?e.jsxRuntimeExports.jsx(o,{className:r}):n?n==null?void 0:n.charAt(0).toUpperCase():e.jsxRuntimeExports.jsx(De,{className:r});default:return e.jsxRuntimeExports.jsx(e.Table,{className:r})}}function Rt(){var r;const s=e.useEditorStore(t=>t.card);return(r=s.customCardPreferences)==null||r.showCardHeader,e.useEditorActions(),e.jsxRuntimeExports.jsxs(e.DropdownMenu,{children:[e.jsxRuntimeExports.jsx(e.DropdownMenuTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(ke,{className:"size-4 cursor-pointer text-muted-foreground/70 transition-colors hover:text-muted-foreground"})}),e.jsxRuntimeExports.jsx(e.DropdownMenuContent,{align:"start",className:"w-40 text-muted-foreground",children:e.jsxRuntimeExports.jsxs(e.DropdownMenuItem,{onClick:()=>{navigator.clipboard.writeText(s.id),e.ce.success("Card ID copied to clipboard")},className:"cursor-pointer space-x-2",children:[e.jsxRuntimeExports.jsx(e.IdCard,{className:"size-5"}),e.jsxRuntimeExports.jsx("span",{children:"Copy Card ID"})]})})]})}function _e(){const s=e.useEditorStore(m=>m.frame),r=e.useEditorStore(m=>m.card),t=e.useEditorStore(m=>m.isShowingVisual),n=e.useEditorStore(m=>m.isSqlRunning),o=e.useEditorStore(m=>m.queryError),i=e.useEditorStore(m=>m.pythonStdOut);e.useEditorStore(m=>m.actions.setRunSql);const{setFrame:l,setCard:a,updateCardInFrame:x,setActiveTabCardId:d}=e.useEditorActions(),{data:c,isLoading:f,isFetching:h}=e.useDashboardCardQuery(r);if(!r)return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:"No Active Card"});function u(){const m={connectionId:r.connectionId,id:e.v4(),title:"Title",description:"Description",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"",data:[]};j(m)}function j(m){const R={...s,cards:[...s.cards,m],activeCardId:m.id};l(R),d(m.id)}function p(){const m={...r,id:e.v4(),title:`${r.title} Copy`,tabTitle:`${r.tabTitle||r.title} Copy`};j(m)}function v(m){const R=s.cards.filter(S=>S.id!==m),E=R[0],k={...s,cards:R,activeCardId:E.id};l(k),d(E.id),a(E)}function g(m){d(m)}const z=(m,R)=>{console.log("handleDragStart",R),m.dataTransfer.setData("tabIndex",R.toString())},I=m=>{m.preventDefault()},w=(m,R)=>{const E=m.dataTransfer.getData("tabIndex");if(E===R.toString())return;const k=Array.from(s.cards),[S]=k.splice(parseInt(E),1);k.splice(R,0,S),l({...s,cards:k})};function D(m,R){return m.cards.length===1&&(R.displayTab===!0||R.displayTab===void 0)||m.activeCardId!==R.id&&(R.displayTab===!0||R.displayTab===void 0)?null:e.jsxRuntimeExports.jsx("div",{onClick:()=>{const E=R.displayTab===void 0?!1:!R.displayTab;a({...R,displayTab:E}),x({...R,displayTab:E})},children:R.displayTab===!0||R.displayTab===void 0?e.jsxRuntimeExports.jsx(e.Eye,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"}):e.jsxRuntimeExports.jsx(We,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"})})}function L(){return e.jsxRuntimeExports.jsxs(e.Tabs,{onValueChange:g,value:s.activeCardId,className:"flex grow flex-col",children:[s.cards.map(m=>e.jsxRuntimeExports.jsx(e.TabsContent,{className:"mt-0 grow",value:m.id,children:O()},m.id)),e.jsxRuntimeExports.jsx(e.TabsList,{className:"group mx-6 justify-between",children:e.jsxRuntimeExports.jsxs("div",{className:"flex items-center",children:[s.cards.map((m,R)=>e.jsxRuntimeExports.jsx(e.Editable,{text:m.tabTitle||m.title,onSave:E=>{a({...r,tabTitle:E}),x({...r,tabTitle:E})},children:e.jsxRuntimeExports.jsxs(e.TabsTrigger,{draggable:!0,onDragStart:E=>z(E,R),onDragOver:I,onDrop:E=>w(E,R),className:"",value:m.id,children:[D(s,m),m.tabTitle||m.title,s.activeCardId===m.id&&s.cards.length>1&&e.jsxRuntimeExports.jsx(e.X,{className:"ml-2 size-3.5 text-muted-foreground hover:text-foreground",onClick:()=>v(m.id)})]})},m.id)),e.jsxRuntimeExports.jsx(e.Button,{className:"ml-1 h-8 px-2 hover:bg-muted-foreground/50",variant:"outline",onClick:u,children:e.jsxRuntimeExports.jsx(e.Plus,{className:"h-4 w-4"})}),e.jsxRuntimeExports.jsx(e.Button,{className:"invisible ml-1 h-8 px-2 hover:bg-muted-foreground/50 group-hover:visible",variant:"outline",onClick:p,children:e.jsxRuntimeExports.jsx(Qe,{className:"h-4 w-4"})})]})})]})}function O(){return r.type==="kpi"?e.jsxRuntimeExports.jsx("div",{className:"flex h-full items-center justify-center",children:e.jsxRuntimeExports.jsx("div",{className:"w-1/2 rounded-md border",children:e.jsxRuntimeExports.jsx(e.KPICard,{card:r,data:c==null?void 0:c.records})})}):r.type==="text"?e.jsxRuntimeExports.jsx("div",{className:"flex h-full items-center justify-center",children:e.jsxRuntimeExports.jsx("div",{className:"w-1/2 rounded-md border",children:e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"mx-3 my-6 h-[300px] overflow-y-auto break-words px-3",children:e.jsxRuntimeExports.jsx(e.TextCard,{isLoading:n,card:r,data:c==null?void 0:c.records})})})}):e.jsxRuntimeExports.jsx(e.ErrorBoundary,{FallbackComponent:e.FallbackEditorCard,children:e.jsxRuntimeExports.jsx(vs,{className:"grow border-none shadow-none"})})}return e.jsxRuntimeExports.jsxs("div",{className:"relative flex h-full flex-col py-3",children:[(f||h)&&e.jsxRuntimeExports.jsx(se,{className:"absolute bottom-0 left-0 right-0 top-0 z-50 m-auto h-10 w-10 animate-spin text-foreground/10"}),e.jsxRuntimeExports.jsxs("div",{className:"mb-0 flex min-h-10 items-center justify-end gap-2 px-6",children:[t&&e.jsxRuntimeExports.jsxs("div",{className:"flex grow items-center gap-2",children:[e.jsxRuntimeExports.jsx(ft,{}),!["table","custom"].includes(r.type)&&e.jsxRuntimeExports.jsx(jt,{}),e.jsxRuntimeExports.jsx(Rt,{})]}),e.jsxRuntimeExports.jsx(yt,{})]}),t?L():e.jsxRuntimeExports.jsxs(e.ResizablePanelGroup,{className:"px-6",direction:"horizontal",children:[i&&e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx(e.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.jsxRuntimeExports.jsx(bt,{})}),e.jsxRuntimeExports.jsx(e.ResizableHandle,{})]}),e.jsxRuntimeExports.jsx(e.ResizablePanel,{id:"2",order:2,minSize:10,className:"relative flex h-full min-h-0 w-full flex-1 basis-0",children:e.jsxRuntimeExports.jsxs(e.ScrollArea,{className:"relative flex h-full min-h-0 w-full flex-1 basis-0",children:[(c==null?void 0:c.records)&&(c==null?void 0:c.records.length)>0&&e.jsxRuntimeExports.jsx(xt,{data:(c==null?void 0:c.records)||[]}),o&&e.jsxRuntimeExports.jsx("span",{className:"font-mono text-xs",children:o}),e.jsxRuntimeExports.jsx(e.ScrollBar,{orientation:"horizontal"})]})})]})]})}function bt(){const s=e.useEditorStore(t=>t.pythonStdOut);if(!s)return null;const r=s.replace(/\n/g,"<br>");return e.jsxRuntimeExports.jsxs("div",{className:"relative flex w-full flex-col border-r",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs(e.ScrollArea,{className:"overflow-y-auto px-2 pt-1 font-mono text-xs text-foreground/90",children:[e.jsxRuntimeExports.jsx("div",{dangerouslySetInnerHTML:{__html:r}}),e.jsxRuntimeExports.jsx(e.ScrollBar,{orientation:"horizontal"})]})]})}function yt(){const s=e.useEditorStore(t=>t.isShowingVisual),r=e.useEditorStore(t=>t.actions.setIsShowingVisual);return e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.Label,{htmlFor:"visualize",children:"Chart"}),e.jsxRuntimeExports.jsx(e.Switch,{checked:s,onCheckedChange:()=>r(!s),id:"visualize",className:"data-[state=checked]:bg-foreground/50"})]})}function vt({options:s,value:r,onValueChange:t}){return e.jsxRuntimeExports.jsx(e.RadioGroup,{value:r,onValueChange:t,className:"flex gap-4",defaultValue:s[0].value,children:s.map(n=>e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:n.value,id:n.value}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:n.value,children:n.label})]},n.value))})}function W({label:s,options:r,value:t,onValueChange:n,className:o}){return e.jsxRuntimeExports.jsxs(e.Select,{value:t,onValueChange:n,children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:e.cn("w-full focus:ring-0 focus:ring-offset-0",o),children:e.jsxRuntimeExports.jsx(e.SelectValue,{placeholder:s})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:s}),r.map(i=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:i.value,children:i.label},i.value))]})})]})}function de({children:s,summary:r,open:t,className:n}){return e.jsxRuntimeExports.jsxs("details",{open:t,className:e.cn("space-y-4 [&_summary>svg]:open:-rotate-180",n),children:[e.jsxRuntimeExports.jsxs("summary",{className:"flex cursor-pointer list-none items-center justify-between gap-4",children:[e.jsxRuntimeExports.jsx(e.Label,{children:r}),e.jsxRuntimeExports.jsx(e.ChevronUp,{className:"h-4 w-4"})]}),e.jsxRuntimeExports.jsx("div",{className:"transition-all ease-in-out",children:s})]})}function St(){var p,v;const s=e.useEditorStore(g=>g.card.customCardPreferences),{data:r}=As(),t=(r==null?void 0:r.plugins)||[],n=e.useEditorStore(g=>g.card),o=e.useEditorStore(g=>g.frame),i=(s==null?void 0:s.visualType)||"single",{setCustomCardPreferences:l}=e.useEditorActions(),{components:a,manifest:x}=e.useCustomVisual((s==null?void 0:s.url)||""),d=(p=x==null?void 0:x.visuals)==null?void 0:p.find(g=>g.name===(s==null?void 0:s.componentName));function c(g,z){if(!s)return;const w={...(s==null?void 0:s.dataInputCardIds)||{},[g]:{cardId:z,hookRef:null}};l({...s,dataInputCardIds:w})}function f(g){var I,w;const z=(I=o==null?void 0:o.cards)==null?void 0:I.filter(D=>{var L;return((L=D==null?void 0:D.customCardPreferences)==null?void 0:L.visualType)!=="multiple"}).map(D=>({value:D.id,label:D.tabTitle||D.title}));return e.jsxRuntimeExports.jsx("div",{className:"space-y-2",children:(w=g==null?void 0:g.dataInputs)==null?void 0:w.map((D,L)=>{var O,m;return e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-10 gap-2",children:[e.jsxRuntimeExports.jsx("div",{className:"col-span-4 flex items-center",children:D}),e.jsxRuntimeExports.jsx(W,{className:"col-span-6 h-8 w-full justify-between",label:"",options:z||[],value:((m=(O=s==null?void 0:s.dataInputCardIds)==null?void 0:O[L])==null?void 0:m.cardId)||"",onValueChange:R=>c(L,R)})]},L+Math.random())})})}function h(g,z,I=[]){var w,D;return s?g==="input"?e.jsxRuntimeExports.jsx(e.Input,{className:`h-8 w-full ${e.removeRing}`,value:((w=s==null?void 0:s.settings)==null?void 0:w[z])||"",onChange:L=>{l({...s,settings:{...s==null?void 0:s.settings,[z]:L.target.value}})}},z):g==="select"?e.jsxRuntimeExports.jsx(W,{className:"h-8 w-full",label:"",options:I,value:((D=s==null?void 0:s.settings)==null?void 0:D[z])||"",onValueChange:L=>{l({...s,settings:{...s==null?void 0:s.settings,[z]:L}})}}):null:null}function u(g){const z=Object.entries((g==null?void 0:g.settings)||{});return e.jsxRuntimeExports.jsx("div",{className:"space-y-3",children:z.map(([I,w])=>e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:w.title}),h(w.ui,I,w.options)]},I))})}function j(g){s&&l({...s,visualType:g,componentName:""})}return e.jsxRuntimeExports.jsxs("div",{className:"p-6",children:[e.jsxRuntimeExports.jsx(de,{summary:"Plugin Settings",children:e.jsxRuntimeExports.jsx("div",{className:"space-y-4 text-sm",children:e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 text-sm",children:[e.jsxRuntimeExports.jsx("div",{className:"space-y-2",children:e.jsxRuntimeExports.jsx("div",{className:"px-2",children:e.jsxRuntimeExports.jsx(W,{className:"h-8 w-full",label:"",options:t,value:(s==null?void 0:s.url)||"",onValueChange:g=>l({...s||{url:"",componentName:""},url:g})})})}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&e.jsxRuntimeExports.jsx(vt,{options:[{value:"single",label:"Single Visual"},{value:"multiple",label:"Multi-Visual"}],value:i,onValueChange:j}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&s&&e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Component"}),e.jsxRuntimeExports.jsx("div",{className:"space-y-2 px-2",children:a&&e.jsxRuntimeExports.jsx(W,{className:"h-8 w-full",label:"",options:(a==null?void 0:a.filter(g=>g.type===i).map(g=>({value:g.name,label:g.name})))||[],value:s.componentName,onValueChange:g=>{console.log("changing value",g),l({...s,componentName:g})}})})]})})]})})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-4"}),((v=n==null?void 0:n.customCardPreferences)==null?void 0:v.componentName)&&e.jsxRuntimeExports.jsxs(de,{summary:"Component Settings",children:[d&&d.dataInputs&&e.jsxRuntimeExports.jsxs("div",{className:"space-y-3",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Input Mapping"}),e.jsxRuntimeExports.jsx("div",{className:"px-2",children:f(d)})]}),d&&d.settings&&e.jsxRuntimeExports.jsx("div",{className:"space-y-3",children:e.jsxRuntimeExports.jsx("div",{className:"px-2",children:u(d)})})]})]})}function ne(){const[s,r]=b.useState([]);e.useEditorStore(c=>c.card.cfg);const t=e.useEditorStore(c=>c.card.preferences),{setCardCfg:n,setFilterOnClickColumnIndex:o,setCardPreferences:i}=e.useEditorStore(c=>c.actions),l=e.useEditorStore(c=>c.queryResultColumns);e.useEditorStore(c=>{var f;return(f=c.card.preferences)==null?void 0:f.filterOnClickColumnIndex}),b.useEffect(()=>{l&&r(new Array(l.length).fill(!1))},[l]);function a(c,f){var h,u;f?t!=null&&t.onClickFilter&&((h=t==null?void 0:t.onClickFilter)==null?void 0:h.length)>0?i({...t,onClickFilter:[...t.onClickFilter,{columnIndex:c,expression:""}]}):i({...t,onClickFilter:[{columnIndex:c,expression:""}]}):(i({...t,onClickFilter:(u=t==null?void 0:t.onClickFilter)==null?void 0:u.filter(j=>j.columnIndex!==c)}),r(j=>{const p=[...j];return p[c]=!1,p}))}function x(c,f){var u;const h=(u=t==null?void 0:t.onClickFilter)==null?void 0:u.map(j=>j.columnIndex===c?{...j,expression:f.target.value}:j);i({...t,onClickFilter:h})}function d(c){var f,h,u,j;if(s!=null&&s[c]||(h=(f=t==null?void 0:t.onClickFilter)==null?void 0:f.find(p=>p.columnIndex===c))!=null&&h.expression)return e.jsxRuntimeExports.jsx(e.Input,{value:(j=(u=t==null?void 0:t.onClickFilter)==null?void 0:u.find(p=>p.columnIndex===c))==null?void 0:j.expression,onChange:p=>x(c,p),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.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"On Click"}),l==null?void 0:l.map((c,f)=>{var h,u;return e.jsxRuntimeExports.jsx("div",{className:"xbg-red-100 group flex items-center justify-between space-y-2",children:e.jsxRuntimeExports.jsxs("div",{className:"grow",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2 py-2",children:[e.jsxRuntimeExports.jsx(e.Checkbox,{checked:!!((h=t==null?void 0:t.onClickFilter)!=null&&h.find(j=>j.columnIndex===f)),onCheckedChange:j=>a(f,j)}),e.jsxRuntimeExports.jsx("label",{className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:c}),e.jsxRuntimeExports.jsx("div",{className:"flex items-center gap-2",children:((u=t==null?void 0:t.onClickFilter)==null?void 0:u.find(j=>j.columnIndex===f))&&e.jsxRuntimeExports.jsx(e.Pencil,{onClick:()=>{r(j=>{const p=[...j];return p[f]=!j[f],p})},className:"invisible size-3 cursor-pointer text-gray-400 group-hover:visible"})})]}),d(f)]})},c)})]})}function ye(){var l,a,x;const s=e.useEditorStore(d=>d.card.preferences),r=e.useEditorStore(d=>d.card.cfg),{setCardCfg:t,setCardPreferences:n,setChartOrientation:o}=e.useEditorStore(d=>d.actions);(l=r==null?void 0:r.options)!=null&&l.indexAxis;function i(d){o(d)}return e.jsxRuntimeExports.jsxs(e.RadioGroup,{value:((a=s==null?void 0:s.chartOptions)==null?void 0:a.indexAxis)||((x=r==null?void 0:r.options)==null?void 0:x.indexAxis)||"x",onValueChange:i,className:"flex gap-3",defaultValue:"x",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"x",id:"r1"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r1",children:"Vertical"})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"y",id:"r2"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r2",children:"Horizontal"})]})]})}const je="focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0";function He(s,r){var n,o,i;const t=e.getNumberAxis(s,r);return((i=(o=(n=s==null?void 0:s.chartOptions)==null?void 0:n.scales)==null?void 0:o[t])==null?void 0:i.type)||"linear"}function zs(){var P,_,G,N,F,B;const[s,r]=b.useState(!1),t=e.useEditorStore(A=>{var T;return(T=A.card)==null?void 0:T.preferences}),n=e.useEditorStore(A=>{var T;return(T=A.card)==null?void 0:T.cfg}),o=e.getNumberAxis(t,n),[i,l]=b.useState(He(t)),[a,x]=b.useState(((G=(_=(P=t==null?void 0:t.chartOptions)==null?void 0:P.scales)==null?void 0:_[o])==null?void 0:G.min)||""),[d,c]=b.useState(((B=(F=(N=t==null?void 0:t.chartOptions)==null?void 0:N.scales)==null?void 0:F[o])==null?void 0:B.max)||""),[f,h]=b.useState(a||d?"custom":"auto"),[u,j]=b.useState(""),[p,v]=b.useState(0),[g,z]=b.useState(""),[I,w]=b.useState(""),[D,L]=b.useState(""),O=e.useEditorStore(A=>A.actions.setCardPreferences),{updateCardInFrame:m}=e.useEditorActions(),R=e.useEditorStore(A=>A.card),E=e.useEditorStore(A=>{var T;return(T=A.card)==null?void 0:T.type}),k=["pie","doughnut","polarArea"].includes(E);b.useEffect(()=>{var A,T,K,q,$,U,Y,re,Z,oe,ie,ae,le,C;l(He(t)),x(((K=(T=(A=t==null?void 0:t.chartOptions)==null?void 0:A.scales)==null?void 0:T[o])==null?void 0:K.min)===0?0:""),c(((U=($=(q=t==null?void 0:t.chartOptions)==null?void 0:q.scales)==null?void 0:$[o])==null?void 0:U.max)||""),j(((oe=(Z=(re=(Y=t==null?void 0:t.chartOptions)==null?void 0:Y.scales)==null?void 0:re[o])==null?void 0:Z.ticks)==null?void 0:oe.stepSize)||""),v(((ie=t==null?void 0:t.numberAxisFormat)==null?void 0:ie.decimalPlaces)||0),z(((ae=t==null?void 0:t.numberAxisFormat)==null?void 0:ae.suffix)||""),w(((le=t==null?void 0:t.numberAxisFormat)==null?void 0:le.currency)||""),L(((C=t==null?void 0:t.numberAxisFormat)==null?void 0:C.locale)||"")},[s,t,o]);function S(A,T){return T===""||/^[0-9\b]+$/.test(T)?Number(T):Number(A)}function M(){const A=[...new Set(e.LOCALE_CURRENCY_PAIRS.map(T=>T.currency))];return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-6 items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"col-span-2 hover:cursor-pointer hover:underline",htmlFor:"currency",children:e.jsxRuntimeExports.jsx("a",{target:"_blank",href:"https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/NumberFormat",children:"Currency"})}),e.jsxRuntimeExports.jsxs(e.Select,{value:I||"none",onValueChange:T=>w(T==="none"?"":T),children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-2 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Currency"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"none",children:"None"}),A.map(T=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:T,children:T},T))]})})]}),e.jsxRuntimeExports.jsxs(e.Select,{value:D,onValueChange:T=>L(T),children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-2 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Locale"}),e.LOCALE_CURRENCY_PAIRS.map(T=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:T.locale,children:T.locale},T.locale))]})})]})]}),e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-9 items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"col-span-3",htmlFor:"format",children:"Decimals"}),e.jsxRuntimeExports.jsx(e.Input,{value:p,onChange:T=>v(Number(T.target.value)),id:"format",className:`col-span-6 h-8 w-full tracking-wide ${je}`})]})]})}function V(){return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-3 items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Label,{htmlFor:"range",children:"Range"}),e.jsxRuntimeExports.jsx(e.Input,{id:"min",value:a,onChange:A=>x(T=>S(T,A.target.value)),className:`col-span-1 h-8 w-full ${je}`}),e.jsxRuntimeExports.jsx(e.Input,{value:d,onChange:A=>c(T=>S(T,A.target.value)),id:"max",className:`col-span-1 h-8 w-full ${je}`})]}),e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-3 items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Label,{htmlFor:"step-size",children:"Step Size"}),e.jsxRuntimeExports.jsx(e.Input,{value:u,onChange:A=>j(T=>S(T,A.target.value)),id:"step-size",className:`col-span-1 h-8 w-full ${je}`})]})]})}function H(){var q;let A={};f==="custom"&&(A={min:a,max:d,ticks:{stepSize:u}});const T={...t||{},chartOptions:{...t==null?void 0:t.chartOptions,scales:{...(q=t==null?void 0:t.chartOptions)==null?void 0:q.scales,[o]:{type:i,...i==="linear"?A:{}}}},numberAxisFormat:{decimalPlaces:p,suffix:g,currency:I,locale:D}};console.log(T),O(T);const K={...R,preferences:T};m(K)}return e.jsxRuntimeExports.jsxs(e.Popover,{onOpenChange:A=>r(A),children:[e.jsxRuntimeExports.jsx(e.PopoverTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(e.SliderIcon,{className:"size-4 cursor-pointer text-muted-foreground hover:text-foreground"})}),e.jsxRuntimeExports.jsx(e.PopoverContent,{align:"center",className:"max-w-65",children:e.jsxRuntimeExports.jsxs("div",{className:"grid gap-4",children:[e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx("h4",{className:"font-medium leading-none",children:"Scale Options"}),e.jsxRuntimeExports.jsx("p",{className:"text-sm text-muted-foreground",children:"Set the scale for the number axis"})]}),e.jsxRuntimeExports.jsxs("div",{className:"grid gap-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-3 items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Label,{htmlFor:"scale",children:"Type"}),e.jsxRuntimeExports.jsxs(e.Select,{disabled:k,value:i,onValueChange:A=>l(A),children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-2 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{id:"type",children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Option"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"linear",children:"Linear"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"logarithmic",children:"Logarithmic"})]})})]})]}),i=="linear"&&e.jsxRuntimeExports.jsxs("div",{className:"grid grid-cols-3 items-center gap-2 py-1",children:[e.jsxRuntimeExports.jsx(e.Label,{htmlFor:"scale-option",children:"Setup"}),e.jsxRuntimeExports.jsxs(e.RadioGroup,{disabled:k,id:"scale-option",value:f,onValueChange:A=>h(A),className:"col-span-2 flex gap-3",defaultValue:"x",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"auto",id:"r1"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r1",children:"Auto"})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"custom",id:"r2"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r2",children:"Custom"})]})]})]}),f==="custom"&&i=="linear"&&V(),M(),e.jsxRuntimeExports.jsx(e.SelectSeparator,{}),e.jsxRuntimeExports.jsx("div",{className:"grid grid-cols-3",children:e.jsxRuntimeExports.jsx(e.Button,{onClick:H,variant:"secondary",className:"col-span-1 col-start-3 h-8 w-full",children:"Apply"})})]})]})})]})}function Ct({idx:s}){var a;const r=e.useEditorStore(x=>{var d;return(d=x.card)==null?void 0:d.preferences}),t=e.useEditorStore(x=>{var d;return(d=x.card.preferences)==null?void 0:d.datasetOptions}),n=e.useEditorStore(x=>x.actions.setCardPreferences),o=(a=r==null?void 0:r.chartOptions)==null?void 0:a.indexAxis,i=t==null?void 0:t.find(x=>x.idx===s);function l(x,d){(x==="end"||x==="start")&&e.getContrastColor(e.getCanvasBackgroundColor());const c={display:x!=="none",align:x,anchor:x,clamp:!0};if(!i)n({...r,datasetOptions:[...t||[],{idx:d,datalabels:c}]});else{const f={...i};f.datalabels=c;const h=t==null?void 0:t.map(u=>u.idx===d?f:u);n({...r,datasetOptions:h})}}return e.jsxRuntimeExports.jsxs(e.Popover,{children:[e.jsxRuntimeExports.jsx(e.PopoverTrigger,{children:e.jsxRuntimeExports.jsx(ms,{className:"invisible size-4 rotate-[135deg] cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"})}),e.jsxRuntimeExports.jsx(e.PopoverContent,{className:"w-fit p-1",children:e.jsxRuntimeExports.jsxs("div",{className:"flex gap-1",children:[e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>l("none",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(e.X,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>l("start",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(ts,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>l("center",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(rs,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>l("end",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(ns,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})})]})})]})}function Os(){const s=e.useEditorStore(d=>d.card),r=e.useEditorStore(d=>{var c,f,h;return(h=(f=(c=d==null?void 0:d.card)==null?void 0:c.preferences)==null?void 0:f.chartOptions)==null?void 0:h.indexAxis}),{data:t}=e.useDashboardCardQuery(s),n=r==="y"?"Y axis":"X axis",o=r==="y"?"X axis":"Y axis",{keys:i,metricKeys:l,dimensionKeys:a}=e.getKeys((t==null?void 0:t.records)||[]);let x=l;if(["stackedBar","stackedLine"].includes(s.type)){const d=e.pivotData({dataArray:(t==null?void 0:t.records)||[],groupKey:a[0],pivotKey:a[1],valueKey:x[0]}),{metricKeys:c}=e.getKeys(d);x=c}return i.length===0?null:e.jsxRuntimeExports.jsxs("div",{className:"space-y-4",children:[e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:n}),e.jsxRuntimeExports.jsx("div",{className:"my-1 space-y-1",children:e.jsxRuntimeExports.jsx("div",{className:"rounded-md bg-muted/70 px-2 py-1 hover:bg-muted",children:e.jsxRuntimeExports.jsx("p",{children:a[0]})})})]}),e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center justify-between gap-5",children:[e.jsxRuntimeExports.jsx(e.Label,{children:o}),e.jsxRuntimeExports.jsx(zs,{})]}),e.jsxRuntimeExports.jsx("div",{className:"my-1 space-y-1",children:x.map((d,c)=>e.jsxRuntimeExports.jsx(Nt,{col:d,idx:c},d))})]})]})}function Nt({col:s,idx:r}){const t=e.useEditorStore(a=>{var x;return(x=a.card)==null?void 0:x.preferences}),n=e.useEditorStore(a=>{var x;return(x=a.card.preferences)==null?void 0:x.datasetOptions}),o=n==null?void 0:n.find(a=>a.idx===r),{setCardPreferences:i}=e.useEditorStore(a=>a.actions);function l(a){if(!o)i({...t,datasetOptions:[...n||[],{idx:r,type:a==="area"?"line":a,fill:a==="area"?"origin":""}]});else{const x={...o};x.type=a==="area"?"line":a,x.fill=a==="area"?"origin":"";const d=n==null?void 0:n.map(c=>c.idx===r?x:c);i({...t,datasetOptions:d})}}return e.jsxRuntimeExports.jsxs("div",{className:"group flex items-center justify-between gap-5 rounded-md bg-muted/70 px-2 py-1 hover:bg-muted",children:[e.jsxRuntimeExports.jsx("p",{children:s}),e.jsxRuntimeExports.jsxs("div",{className:"flex gap-2",children:[e.jsxRuntimeExports.jsx(ge,{onClick:()=>l("bar"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx(Re,{onClick:()=>l("line"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx($e,{onClick:()=>l("area"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx(Ct,{idx:r})]})]})}function Ms(){const s=e.useEditorStore(h=>h.selectedConnectionId),r=e.useEditorStore(h=>h.selectedDatamodelId),t=e.useEditorStore(h=>h.selectedDatabaseName),n=e.useEditorStore(h=>h.selectedSchemaName),o=e.useEditorStore(h=>h.selectedTableName),i=e.useDashboardStore(h=>h.dashboard.filters)||[],l=e.useDashboardStore(h=>h.actions.addFilter),a=e.useDashboardStore(h=>h.actions.removeFilter),{removeFilterValues:x}=e.useDashboardActions(),{modelItems:d,tableName:c}=te();function f(h,u="dashboard"){var L;const j=e.fmt(h.column_name),p=e.fmt(t||""),v=e.fmt(n||""),g=e.fmt(c);let z=e.getQualifiedTableName(v,g),I=`${z}.${j}`;const w=(L=d==null?void 0:d.find(O=>O.id===r))==null?void 0:L.name;r&&r!=="none"&&(I=`${e.DATAMODEL_NAMESPCACE}.${w}.${j}`,z=`${e.DATAMODEL_NAMESPCACE}.${w}`);const D=i==null?void 0:i.find(O=>O.column===I&&O.table===g&&(O.database===p||O.database===t));if(D)x(D.id),a(D.id);else{const O=e.v4();return c==="api"&&s?(l({location:u,id:O,column:I,title:h.column_name,dataType:h.data_type,table:"api",database:"",connectionId:s,operation:"in",sql:e.getDefaultFilterSql(h.data_type,z,j)}),O):(l({id:O,location:u,column:I,title:h.column_name,dataType:h.data_type,table:o||"",database:t||"",connectionId:s||"",operation:"in",sql:e.getDefaultFilterSql(h.data_type,z,j)}),O)}}return{assignFilter:f}}function xe(){const s=e.useDashboardStore(a=>a.dashboard.filters),r=e.useEditorStore(a=>a.frame),{setFrame:t}=e.useEditorActions(),{columns:n}=te(),{assignFilter:o}=Ms();function i(a){const x=o(a,"frame");t({...r,filterId:x})}const l=s==null?void 0:s.find(a=>a.id===r.filterId);return e.jsxRuntimeExports.jsxs("div",{className:"space-y-3",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Card Filter"}),e.jsxRuntimeExports.jsx(wt,{onSelect:i,columns:n}),l&&e.jsxRuntimeExports.jsx(e.FilterHeader,{filter:l})]})}function wt({columns:s,onSelect:r}){var l;const[t,n]=Fe.useState(!1),[o,i]=Fe.useState("");return e.jsxRuntimeExports.jsxs(e.Popover,{open:t,onOpenChange:n,children:[e.jsxRuntimeExports.jsx(e.PopoverTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsxs(e.Button,{size:"sm",variant:"outline",role:"combobox","aria-expanded":t,className:"w-full justify-between font-normal",children:[o?(l=s.find(a=>a.column_name===o))==null?void 0:l.column_name:"Select Column...",e.jsxRuntimeExports.jsx(e.CaretSortIcon,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})}),e.jsxRuntimeExports.jsx(e.PopoverContent,{className:"w-[200px] p-0",children:e.jsxRuntimeExports.jsxs(e.Command,{children:[e.jsxRuntimeExports.jsx(e.CommandInput,{placeholder:"Search column",className:"h-9"}),e.jsxRuntimeExports.jsxs(e.CommandList,{children:[e.jsxRuntimeExports.jsx(e.CommandEmpty,{children:"No framework found."}),e.jsxRuntimeExports.jsx(e.CommandGroup,{children:s.map(a=>e.jsxRuntimeExports.jsxs(e.CommandItem,{value:a.column_name,onSelect:x=>{const d=x===o?"":x;i(d),n(!1),d&&r(a)},children:[a.column_name,e.jsxRuntimeExports.jsx(e.CheckIcon,{className:e.cn("ml-auto h-4 w-4",o===a.column_name?"opacity-100":"opacity-0")})]},a.column_name))})]})]})})]})}function kt({cardType:s}){return e.jsxRuntimeExports.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxRuntimeExports.jsxs(e.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:`${e.titleCase(s)} Chart`}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"x-axis - category"}),e.jsxRuntimeExports.jsx("li",{children:"y-axis1 - number"}),e.jsxRuntimeExports.jsx("li",{children:"y-axis2 - number"})]}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:r=>r.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#line-chart",children:"example"})," in the docs."]})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-2",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Settings"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ye,{}),e.jsxRuntimeExports.jsx(Os,{})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Filters"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function Te(){var o,i,l;const s=e.useEditorStore(a=>a.card.cfg),r=e.useEditorStore(a=>a.actions.setCardCfg),t=e.useEditorStore(a=>a.card.type);function n(a){var c;const x={datalabels:{display:a!=="none",align:a,anchor:a,clamp:!0}},d={...s,options:{...s==null?void 0:s.options,plugins:{...(c=s==null?void 0:s.options)==null?void 0:c.plugins,...x}}};r(d),console.log(a)}return e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxRuntimeExports.jsx("label",{className:"font-medium",children:"Data Labels"}),!["pyramid"].includes(t)&&e.jsxRuntimeExports.jsx(zs,{})]}),e.jsxRuntimeExports.jsxs(e.Select,{value:(l=(i=(o=s==null?void 0:s.options)==null?void 0:o.plugins)==null?void 0:i.datalabels)==null?void 0:l.anchor,onValueChange:n,defaultValue:"none",children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{placeholder:"Select position"})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Data Labels"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"none",children:"None"}),t!=="pyramid"&&e.jsxRuntimeExports.jsx(e.SelectItem,{value:"start",children:"Start"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"center",children:"Center"}),t!=="pyramid"&&e.jsxRuntimeExports.jsx(e.SelectItem,{value:"end",children:"End"})]})})]})]})}function It({cardType:s}){function r(t){return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:t==="bubble"?"SELECT label, [group], x-axis, y-axis, radius FROM table":"SELECT label, [group], x-axis, y-axis FROM table"}),e.jsxRuntimeExports.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"label - category"}),e.jsxRuntimeExports.jsx("li",{children:"group - category"}),e.jsxRuntimeExports.jsx("li",{children:"x-axis - category"}),e.jsxRuntimeExports.jsx("li",{children:"y-axis - category"}),t==="bubble"&&e.jsxRuntimeExports.jsx("li",{children:"radius - number"})]}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:i=>i.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#pie-chart",children:"example"})," in the docs."]})]})}return e.jsxRuntimeExports.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxRuntimeExports.jsxs(e.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:`${e.titleCase(s)} Chart`}),e.jsxRuntimeExports.jsx(e.AccordionContent,{className:"space-y-4 font-mono text-xs",children:r(s)})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-2",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Settings"}),e.jsxRuntimeExports.jsx(e.AccordionContent,{className:"px-2",children:e.jsxRuntimeExports.jsx(Te,{})})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Filters"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}const Dt={datasets:[{type:"line",label:"Sum_sales",data:[]},{type:"bar",label:"Sum_profit",data:[]}]},Lt={datasets:[{fill:"origin",type:"line",label:"Sum_sales",data:[]}]};function Tt(){const s=e.useEditorStore(r=>r.card.type);return e.jsxRuntimeExports.jsxs("div",{className:"space-y-6 p-6",children:[e.jsxRuntimeExports.jsx(e.Accordion,{className:" ",type:"single",collapsible:!0,children:At(s)}),e.jsxRuntimeExports.jsx("section",{className:"",children:["line","bar"].includes(s)&&e.jsxRuntimeExports.jsx(ye,{})}),!["kpi"].includes(s)&&e.jsxRuntimeExports.jsxs("div",{className:"space-y-4",children:[e.jsxRuntimeExports.jsx(Te,{}),e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})}function At(s){if(["line","bar"].includes(s))return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:e.jsxRuntimeExports.jsx("p",{children:"Chart Query"})}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:" ",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"X-axis - Category (ex. city)"}),e.jsxRuntimeExports.jsx("li",{children:"Y-axis - Number (ex. population)"})]})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-2",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:"Mixed Chart"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-2 text-xs",children:[e.jsxRuntimeExports.jsxs("p",{children:["Click ",e.jsxRuntimeExports.jsx("b",{children:"Customize"})," and change the `type` property in the dataset."]}),e.jsxRuntimeExports.jsx("pre",{children:JSON.stringify(Dt,null,2)})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:"Area Chart"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-2 text-xs",children:[e.jsxRuntimeExports.jsxs("p",{children:["Click ",e.jsxRuntimeExports.jsx("b",{children:"Customize"})," and add `fill` property to the dataset. See",e.jsxRuntimeExports.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.jsxRuntimeExports.jsx("pre",{children:JSON.stringify(Lt,null,2)})]})]})]});if(s==="bubble")return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:e.jsxRuntimeExports.jsxs("p",{children:["How to create a ",e.jsxRuntimeExports.jsx("span",{children:s})," chart query?"]})}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:" ",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"Label - Category (ex. city)"}),e.jsxRuntimeExports.jsx("li",{children:"Bubble Group (opt) - Category (ex. state)"}),e.jsxRuntimeExports.jsx("li",{children:"X-axis - Number (ex. avg. age)"}),e.jsxRuntimeExports.jsx("li",{children:"Y-axis - Number (ex. avg. weight)"}),e.jsxRuntimeExports.jsx("li",{children:"Radius - Number (ex. population)"})]})]})]})});if(s==="scatter")return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:e.jsxRuntimeExports.jsxs("p",{children:["How to create a ",e.jsxRuntimeExports.jsx("span",{children:s})," chart query?"]})}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:" ",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"Label - Category (ex. city)"}),e.jsxRuntimeExports.jsx("li",{children:"Group (opt) - Category (ex. state)"}),e.jsxRuntimeExports.jsx("li",{children:"X-axis - Number (ex. avg. age)"}),e.jsxRuntimeExports.jsx("li",{children:"Y-axis - Number (ex. avg. weight)"})]})]})]})});if(["pie","doughnut","polarArea"].includes(s))return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"font-normal",children:e.jsxRuntimeExports.jsxs("p",{children:[e.jsxRuntimeExports.jsx("span",{children:s==="polarArea"?"Polar":s.charAt(0).toUpperCase()+s.slice(1)})," ","chart query"]})}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:" ",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs font-semibold",children:"SELECT label, measure FROM table"}),e.jsxRuntimeExports.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs font-normal [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"Label - Category (ex. city)"}),e.jsxRuntimeExports.jsx("li",{children:"Measure - Number (ex. population)"})]})]})]})})}function zt(){var x,d,c,f,h;const s=e.useEditorStore(u=>u.card.preferences),r=e.useEditorStore(u=>u.actions.setCardPreferences),t=e.useEditorStore(u=>u.actions.setNumberFormat);e.useEditorStore(u=>{var j,p;return(p=(j=u.card.preferences)==null?void 0:j.formatNumber)==null?void 0:p.decimalPlaces});const n=e.useEditorStore(u=>{var j,p;return(p=(j=u.card.preferences)==null?void 0:j.formatNumber)==null?void 0:p.locale}),o=e.useEditorStore(u=>{var j,p;return(p=(j=u.card.preferences)==null?void 0:j.formatNumber)==null?void 0:p.currency});e.useEditorStore(u=>u.actions.setFilterOnClickField);const i=e.useEditorStore(u=>{var j,p;return(p=(j=u.card.preferences)==null?void 0:j.formatNumber)==null?void 0:p.colorRanges})||[],l=e.useEditorStore(u=>u.actions.setColorRanges),a=[...new Set(e.LOCALE_CURRENCY_PAIRS.map(u=>u.currency))];return e.jsxRuntimeExports.jsxs("div",{children:[e.jsxRuntimeExports.jsxs("div",{className:"mb-3 flex items-center gap-2",children:[e.jsxRuntimeExports.jsx(e.Checkbox,{checked:!!((x=s==null?void 0:s.formatNumber)!=null&&x.enabled),onCheckedChange:u=>{r({...s,formatNumber:{...s==null?void 0:s.formatNumber,enabled:u}})}}),e.jsxRuntimeExports.jsx(e.Label,{children:"Format Number"})]}),((d=s==null?void 0:s.formatNumber)==null?void 0:d.enabled)===!0&&e.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-2",children:[e.jsxRuntimeExports.jsx("div",{children:e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 p-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"w-full space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Locale"}),e.jsxRuntimeExports.jsxs(e.Select,{value:n||"none",onValueChange:u=>{var j,p,v;return t(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,((p=s==null?void 0:s.formatNumber)==null?void 0:p.currency)||"",u,((v=s==null?void 0:s.formatNumber)==null?void 0:v.suffix)||"")},children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-6 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Format"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"none",children:"None"},"none"),e.LOCALE_CURRENCY_PAIRS.map(u=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:u.locale,children:u.locale},u.locale))]})})]})]}),e.jsxRuntimeExports.jsxs("div",{className:"w-full space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Currency"}),e.jsxRuntimeExports.jsxs(e.Select,{value:o||"none",onValueChange:u=>{var j,p,v;console.log("currency",u),t(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,u==="none"?"":u,((p=s==null?void 0:s.formatNumber)==null?void 0:p.locale)||"",((v=s==null?void 0:s.formatNumber)==null?void 0:v.suffix)||"")},children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-6 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:e.jsxRuntimeExports.jsxs(e.SelectGroup,{children:[e.jsxRuntimeExports.jsx(e.SelectLabel,{children:"Currency"}),e.jsxRuntimeExports.jsx(e.SelectItem,{value:"none",children:"None"},"none"),a.map(u=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:u,children:u},u))]})})]})]})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex gap-2",children:[e.jsxRuntimeExports.jsxs("div",{className:"w-full space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Decimals"}),e.jsxRuntimeExports.jsxs(e.Select,{value:((f=(c=s==null?void 0:s.formatNumber)==null?void 0:c.decimalPlaces)==null?void 0:f.toString())||"0",onValueChange:u=>{var j,p,v;return t(Number(u),((j=s==null?void 0:s.formatNumber)==null?void 0:j.currency)||"",((p=s==null?void 0:s.formatNumber)==null?void 0:p.locale)||"",((v=s==null?void 0:s.formatNumber)==null?void 0:v.suffix)||"")},children:[e.jsxRuntimeExports.jsx(e.SelectTrigger,{className:"col-span-3 h-8 w-full focus:ring-1 focus:ring-offset-0",children:e.jsxRuntimeExports.jsx(e.SelectValue,{})}),e.jsxRuntimeExports.jsx(e.SelectContent,{children:["0","1","2","3","4"].map(u=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:u,children:u},u))})]})]}),e.jsxRuntimeExports.jsxs("div",{className:"w-full space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Suffix"}),e.jsxRuntimeExports.jsx(e.Input,{value:((h=s==null?void 0:s.formatNumber)==null?void 0:h.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:u=>{var j,p,v;return t(((j=s==null?void 0:s.formatNumber)==null?void 0:j.decimalPlaces)||0,((p=s==null?void 0:s.formatNumber)==null?void 0:p.currency)||"",((v=s==null?void 0:s.formatNumber)==null?void 0:v.locale)||"",u.target.value)}})]})]})]})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-3"}),e.jsxRuntimeExports.jsx(e.ColorFormat,{colorRanges:i,setColorRanges:l})]})]})}function Ot(){return e.jsxRuntimeExports.jsxs("div",{className:"space-y-6 px-6 py-2",children:[e.jsxRuntimeExports.jsx(e.Accordion,{type:"single",collapsible:!0,children:e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{className:"",children:"KPI Query"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"font-mono",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 font-mono text-xs",children:"SELECT current, previous FROM table"}),e.jsxRuntimeExports.jsxs("ul",{className:"my-6 ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"current - number"}),e.jsxRuntimeExports.jsx("li",{children:"previous - number"})]}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#kpi",children:"example"})," in the docs."]})]})]})}),e.jsxRuntimeExports.jsx("section",{className:"",children:e.jsxRuntimeExports.jsx(zt,{})}),e.jsxRuntimeExports.jsx("div",{}),e.jsxRuntimeExports.jsx("div",{})]})}const Mt=[{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"}],Ft=["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"],Vt=Ft.map(s=>({label:s,value:s}));function qt(){var x,d,c,f,h,u,j,p,v,g,z,I,w,D,L,O,m,R;const s=e.useEditorStore(E=>E.card),r=(d=(x=s==null?void 0:s.preferences)==null?void 0:x.mapVisualOptions)==null?void 0:d.topoJsonUrl,[t,n]=b.useState(((f=(c=s==null?void 0:s.preferences)==null?void 0:c.mapVisualOptions)==null?void 0:f.customTopoJsonUrl)||""),{setCardPreferences:o}=e.useEditorActions(),{data:i}=e.useTopoJson(s),l=Object.keys((i==null?void 0:i.objects)||{}).map(E=>({label:E,value:E}))||[],a=[{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.jsxRuntimeExports.jsxs("div",{className:"p-6",children:[e.jsxRuntimeExports.jsx(de,{summary:"Map Query",children:e.jsxRuntimeExports.jsx("p",{className:"rounded-md bg-muted p-2 font-mono text-xs",children:"SELECT country, value FROM table"})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-4"}),e.jsxRuntimeExports.jsx(de,{open:!0,summary:"Settings",children:e.jsxRuntimeExports.jsxs("div",{className:"space-y-3 px-2",children:[e.jsxRuntimeExports.jsx(W,{className:"h-9",options:a,onValueChange:E=>{console.log("value",E),o({...s.preferences,mapVisualOptions:{topoJsonUrl:E}})},value:r||"",label:"Select Map"}),r==="custom"&&e.jsxRuntimeExports.jsx(e.Input,{onChange:E=>{n(E.target.value)},onBlur:()=>{var E;console.log("onBlur",t),o({...s.preferences,mapVisualOptions:{...(E=s.preferences)==null?void 0:E.mapVisualOptions,customTopoJsonUrl:t}})},value:t,className:`h-9 w-full ${e.removeRing}`,placeholder:"Custom URL"}),i&&e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsxs("div",{className:"space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Map Object"}),e.jsxRuntimeExports.jsx(W,{className:"h-9",options:l,value:((u=(h=s.preferences)==null?void 0:h.mapVisualOptions)==null?void 0:u.objectKey)||"",label:"Map Object",onValueChange:E=>{var k;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,objectKey:E}})}})]}),e.jsxRuntimeExports.jsxs("div",{className:"space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Projection"}),e.jsxRuntimeExports.jsx(W,{className:"h-9",options:Mt,value:((p=(j=s.preferences)==null?void 0:j.mapVisualOptions)==null?void 0:p.projection)||"",label:"Projection",onValueChange:E=>{var k;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,projection:E}})}})]}),e.jsxRuntimeExports.jsxs("div",{className:"space-y-1",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Colors"}),e.jsxRuntimeExports.jsx(W,{className:"h-9",options:Vt,value:((g=(v=s.preferences)==null?void 0:v.mapVisualOptions)==null?void 0:g.colorScale)||"",label:"Select Color Scale",onValueChange:E=>{var k;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,colorScale:E}})}})]})]})]})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-4"}),e.jsxRuntimeExports.jsx(de,{className:"",summary:"Scale Options",children:e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-3",children:[e.jsxRuntimeExports.jsx(e.Input,{className:`h-9 w-full ${e.removeRing}`,type:"number",step:.1,value:((I=(z=s.preferences)==null?void 0:z.mapVisualOptions)==null?void 0:I.projectionScale)||1,onChange:E=>{var k;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,projectionScale:Number(E.target.value)}})}}),e.jsxRuntimeExports.jsx(e.Label,{children:"X"}),e.jsxRuntimeExports.jsx(e.Input,{className:`h-9 w-full ${e.removeRing}`,type:"number",step:10,value:((L=(D=(w=s.preferences)==null?void 0:w.mapVisualOptions)==null?void 0:D.projectionOffset)==null?void 0:L[0])||0,onChange:E=>{var k,S,M,V;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,projectionOffset:[Number(E.target.value),((V=(M=(S=s.preferences)==null?void 0:S.mapVisualOptions)==null?void 0:M.projectionOffset)==null?void 0:V[1])||0]}})}}),e.jsxRuntimeExports.jsx(e.Label,{children:"Y"}),e.jsxRuntimeExports.jsx(e.Input,{className:`h-9 w-full ${e.removeRing}`,type:"number",step:10,value:((R=(m=(O=s.preferences)==null?void 0:O.mapVisualOptions)==null?void 0:m.projectionOffset)==null?void 0:R[1])||0,onChange:E=>{var k,S,M,V;o({...s.preferences,mapVisualOptions:{...(k=s.preferences)==null?void 0:k.mapVisualOptions,projectionOffset:[((V=(M=(S=s.preferences)==null?void 0:S.mapVisualOptions)==null?void 0:M.projectionOffset)==null?void 0:V[0])||0,Number(E.target.value)]}})}})]})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-4"}),e.jsxRuntimeExports.jsx(ne,{})]})}function Bt(){var n;const s=e.useEditorStore(o=>o.card.preferences),{setCardPreferences:r}=e.useEditorStore(o=>o.actions);function t(o){r({...s,textVisualOptions:{...s==null?void 0:s.textVisualOptions,isDynamicText:o==="dynamic"}})}return e.jsxRuntimeExports.jsxs(e.RadioGroup,{value:(n=s==null?void 0:s.textVisualOptions)!=null&&n.isDynamicText?"dynamic":"static",onValueChange:t,className:"flex gap-3",defaultValue:"x",children:[e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"static",id:"r1"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r1",children:"Static"})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.RadioGroupItem,{value:"dynamic",id:"r2"}),e.jsxRuntimeExports.jsx("label",{className:"text-sm",htmlFor:"r2",children:"Dynamic"})]})]})}function he({cardType:s,docContent:r,suffix:t="Chart"}){let n="pie-chart";return s==="radar"&&(n="radar-chart"),e.jsxRuntimeExports.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxRuntimeExports.jsxs(e.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:`${e.titleCase(s)} ${t}`}),e.jsxRuntimeExports.jsx(e.AccordionContent,{children:r||e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT label, measure FROM table"}),e.jsxRuntimeExports.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"label - category"}),e.jsxRuntimeExports.jsx("li",{children:"measure - number"})]}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:o=>o.stopPropagation(),className:"text-blue-700",href:`https://docs.semaphor.cloud/concepts/visuals#${n}`,children:"example"})," in the docs."]})]})})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-2",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Settings"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[s==="range"&&e.jsxRuntimeExports.jsx(ye,{}),s!=="text"&&e.jsxRuntimeExports.jsx(Te,{}),s==="text"&&e.jsxRuntimeExports.jsx(Bt,{})]})]}),!["range","text"].includes(s)&&e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Filters"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function _t(){const s=e.useEditorStore(n=>{var o,i;return(i=(o=n==null?void 0:n.card)==null?void 0:o.preferences)==null?void 0:i.sortChart}),{setSortChart:r}=e.useEditorActions();function t(){return e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Sort"}),e.jsxRuntimeExports.jsx(W,{className:"h-8",label:"Sort Chart",options:[{label:"None",value:"none"},{label:"ASC",value:"asc"},{label:"DESC",value:"desc"}],value:s||"none",onValueChange:n=>{r(n)}})]})}return e.jsxRuntimeExports.jsx("div",{className:"space-y-6 px-6 py-2",children:e.jsxRuntimeExports.jsxs(e.Accordion,{defaultValue:["item-2"],type:"multiple",children:[e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-1",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Stacked Chart"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT x-axis, stack-by, y-axis FROM table"}),e.jsxRuntimeExports.jsxs("ul",{className:"ml-6 list-disc text-xs [&>li]:mt-2",children:[e.jsxRuntimeExports.jsx("li",{children:"x-axis - category"}),e.jsxRuntimeExports.jsx("li",{children:"stack by - category"}),e.jsxRuntimeExports.jsx("li",{children:"y-axis - number"})]}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:n=>n.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#stacked-chart",children:"example"})," in the docs."]})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-2",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Settings"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ye,{}),t(),e.jsxRuntimeExports.jsx(Os,{})]})]}),e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Filters"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function Ht({}){const s=e.useEditorStore(n=>{var o;return(o=n.card)==null?void 0:o.preferences}),r=e.useEditorStore(n=>n.actions.setCardPreferences),t=n=>{r({...s,allowDownload:n})};return e.jsxRuntimeExports.jsxs("div",{className:"space-y-6 px-6 py-2",children:[e.jsxRuntimeExports.jsx(e.Accordion,{defaultValue:["item-3"],type:"multiple",children:e.jsxRuntimeExports.jsxs(e.AccordionItem,{value:"item-3",children:[e.jsxRuntimeExports.jsx(e.AccordionTrigger,{children:"Filters"}),e.jsxRuntimeExports.jsxs(e.AccordionContent,{className:"space-y-4 px-2",children:[e.jsxRuntimeExports.jsx(ne,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-center space-x-2",children:[e.jsxRuntimeExports.jsx(e.Checkbox,{onCheckedChange:t,id:"allow-download"}),e.jsxRuntimeExports.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 Pt=e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT dimension, cohort, metric FROM table"}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#pyramid-chart",children:"example"})," in the docs."]})]}),Gt=e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.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.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#range-charts",children:"example"})," in the docs."]})]}),$t=e.jsxRuntimeExports.jsxs("div",{className:"space-y-4 font-mono text-xs",children:[e.jsxRuntimeExports.jsx("div",{className:"rounded bg-muted px-2 py-1 text-xs",children:"SELECT text FROM table limit 1"}),e.jsxRuntimeExports.jsxs("div",{children:["See ",e.jsxRuntimeExports.jsx("a",{target:"_blank",onClick:s=>s.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#text-visual",children:"example"})," in the docs."]})]});function Ut(){const s=e.useEditorStore(t=>t.card.type);function r(t){switch(t){case"stackedBar":case"stackedLine":return e.jsxRuntimeExports.jsx(_t,{});case"pyramid":return e.jsxRuntimeExports.jsx(he,{docContent:Pt,cardType:t});case"kpi":return e.jsxRuntimeExports.jsx(Ot,{});case"line":case"bar":return e.jsxRuntimeExports.jsx(kt,{cardType:t});case"range":return e.jsxRuntimeExports.jsx(he,{docContent:Gt,cardType:t});case"pie":case"doughnut":case"polarArea":case"radar":return e.jsxRuntimeExports.jsx(he,{cardType:t});case"bubble":case"scatter":return e.jsxRuntimeExports.jsx(It,{cardType:t});case"table":return e.jsxRuntimeExports.jsx(Ht,{cardType:t});case"text":return e.jsxRuntimeExports.jsx(he,{docContent:$t,cardType:t,suffix:"Visual"});case"map":return e.jsxRuntimeExports.jsx(qt,{});case"custom":return e.jsxRuntimeExports.jsx(St,{});default:return e.jsxRuntimeExports.jsx(Tt,{})}}return e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"h-full w-full text-sm",children:r(s)})}function Qt(){const s=e.useEditorStore(r=>r.isShowingVisual);return e.jsxRuntimeExports.jsxs(e.ResizablePanelGroup,{direction:"vertical",className:"min-h-[250px] min-w-full max-w-lg",children:[e.jsxRuntimeExports.jsx(e.ResizablePanel,{role:"query-section",className:"flex",minSize:20,defaultSize:40,children:e.jsxRuntimeExports.jsx(ct,{})}),e.jsxRuntimeExports.jsx(e.ResizableHandle,{withHandle:!0,className:"border"}),e.jsxRuntimeExports.jsx(e.ResizablePanel,{className:"pb-1",role:"visual-section",minSize:0,defaultSize:60,children:s?e.jsxRuntimeExports.jsxs(e.ResizablePanelGroup,{direction:"horizontal",children:[e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:e.jsxRuntimeExports.jsx(e.ResizablePanel,{className:"flex min-w-[275px]",minSize:20,defaultSize:25,maxSize:30,children:e.jsxRuntimeExports.jsx(Ut,{})})}),e.jsxRuntimeExports.jsx(e.ResizableHandle,{className:"border"}),e.jsxRuntimeExports.jsx(e.ResizablePanel,{minSize:40,defaultSize:75,maxSize:100,children:e.jsxRuntimeExports.jsx(_e,{})})]}):e.jsxRuntimeExports.jsx(_e,{})})]})}function Kt({authToken:s,onSave:r,onClose:t}){e.useDashboardStore(l=>l.themeStyle);const n=e.useEditorStore(l=>l.actions.setOnSave),o=e.useEditorStore(l=>l.actions.setOnClose),i=e.useDashboardStore(l=>l.actions.setAuthToken);return b.useEffect(()=>{r&&n(r),t&&o(t)},[r,n,t,o]),b.useEffect(()=>{s&&s.accessToken&&i(s)},[s,i]),e.jsxRuntimeExports.jsx(e.ErrorBoundary,{FallbackComponent:e.Fallback,children:e.jsxRuntimeExports.jsxs(e.EditorPanel,{style:{},className:"rounded-none",role:"editor-panel",children:[e.jsxRuntimeExports.jsx(e.EditorAside,{className:"rounded-none border-r-[1.5px]",children:e.jsxRuntimeExports.jsx(gs,{})}),e.jsxRuntimeExports.jsx(e.EditorMain,{children:e.jsxRuntimeExports.jsx(Qt,{})})]})})}function Jt(){e.useDashboardStore(l=>l.selectedCardId);const s=e.useDashboardStore(l=>l.selectedSheetId),{setIsVisualEditing:r}=e.useDashboardStore(l=>l.actions),t=e.useDashboardStore(l=>l.isVisualEditing),n=e.useDashboardStore(l=>l.actions.updateFrame);function o(l){s&&(n(s,l),r(!1))}function i(){r(!1)}return e.jsxRuntimeExports.jsx("div",{role:"editor-container",className:e.cn("flex grow",{"max-h-0 overflow-hidden":!t}),children:e.jsxRuntimeExports.jsx(Kt,{onSave:o,onClose:i})})}function Wt(){const s=e.useEditorStore(i=>i.selectedDatabaseName),r=e.useEditorStore(i=>i.selectedTableName),t=e.useDashboardStore(i=>i.dashboard.filters)||[],{columns:n}=te(),{assignFilter:o}=Ms();return e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"flex-1 basis-0 flex-col px-3",children:n==null?void 0:n.map(i=>{const l=t==null?void 0:t.find(a=>a.column===e.fmt(i.column_name)&&a.table===r&&a.database===s);return e.jsxRuntimeExports.jsx("div",{onClick:()=>o(i),className:e.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.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxRuntimeExports.jsx(fs,{column:i}),e.jsxRuntimeExports.jsx("span",{children:i.column_name})]})},i.column_name)})})}function Xt(){e.useDashboardStore(r=>r.showFilters);const s=e.useDashboardStore(r=>r.actions.setShowFilters);return e.jsxRuntimeExports.jsxs("section",{className:"relative flex min-w-72 grow flex-col border-l px-1",children:[e.jsxRuntimeExports.jsxs("div",{className:"mt-4 flex items-center justify-between gap-2 px-3",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"px-2 text-lg",children:"Filters"}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>s(!1),className:"h-7 w-7 p-0",variant:"ghost",children:e.jsxRuntimeExports.jsx(e.Cross2Icon,{})})]}),e.jsxRuntimeExports.jsx("div",{className:"flex grow",children:e.jsxRuntimeExports.jsx(gs,{ColumnsComponent:()=>e.jsxRuntimeExports.jsx(Wt,{})})})]})}function Yt(){const s=e.useDashboardStore(n=>n.dashboard.filters),r=e.useDashboardStore(n=>n.theme),t=s==null?void 0:s.filter(n=>n.hide);return t!=null&&t.length?e.jsxRuntimeExports.jsx("div",{className:e.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)]":r==="light","bg-[repeating-linear-gradient(45deg,_#18171d_0_3px,_#272729_3px_6px)]":r==="dark"}),children:t==null?void 0:t.map(n=>e.jsxRuntimeExports.jsxs("div",{className:"flex min-w-[250px] max-w-fit flex-col gap-1 p-2",children:[e.jsxRuntimeExports.jsx(e.FilterHeader,{filter:n}),e.jsxRuntimeExports.jsx(e.FilterComponent,{filter:n})]},n.id))}):null}function Zt(){const s=e.useDashboardStore(n=>n.showFilters),r=e.useDashboardStore(n=>n.isVisualEditing),t=e.useDashboardStore(n=>n.isDashboardEditing);return e.jsxRuntimeExports.jsxs("div",{role:"dashboard-plus-main",className:e.cn("",{"max-h-0 overflow-hidden":r,"flex grow":!r}),children:[e.jsxRuntimeExports.jsxs("section",{className:"flex grow flex-col",children:[t&&e.jsxRuntimeExports.jsx(Yt,{}),e.jsxRuntimeExports.jsx(e.DashboardTabs,{})]}),s&&e.jsxRuntimeExports.jsx("div",{role:"filter-aside-container",className:"flex",children:e.jsxRuntimeExports.jsx(Xt,{})})]})}function en(){const s=e.useDashboardStore(n=>n.dashboard),r=e.useDashboardStore(n=>n.actions.setDashboard),t=e.useDashboardStore(n=>n.showDashboardJSON);return e.useDashboardStore(n=>n.actions.setShowDashboardJSON),e.jsxRuntimeExports.jsx("div",{className:e.cn(" p-2",{hidden:!t}),children:e.jsxRuntimeExports.jsx(e.de,{onChange:n=>{if(n)try{JSON.parse(n),r(JSON.parse(n))}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 sn({showControls:s=!1,showFooter:r=!0,...t}){return e.jsxRuntimeExports.jsx(e.ErrorBoundary,{FallbackComponent:e.Fallback,children:e.jsxRuntimeExports.jsxs(e.SemaphorContextProvider,{dashboardProps:t,children:[e.jsxRuntimeExports.jsx(e.Oe,{}),e.jsxRuntimeExports.jsxs(e.UXProvider,{children:[e.jsxRuntimeExports.jsx(en,{}),e.jsxRuntimeExports.jsxs(e.DashboardPanel,{...t,children:[s&&e.jsxRuntimeExports.jsx(Gs,{}),e.jsxRuntimeExports.jsx(Jt,{}),e.jsxRuntimeExports.jsx(Zt,{})]})]})]})})}exports.Box=Pe;exports.Braces=Ge;exports.ChartArea=$e;exports.ChartColumnIncreasing=ge;exports.ChartLine=Re;exports.ChartNoAxesGantt=Ce;exports.ChartPie=Ne;exports.ChartScatter=we;exports.CircleX=Ue;exports.CopyPlus=Qe;exports.DashboardPlus=sn;exports.Database=Ke;exports.EllipsisVertical=ke;exports.Eraser=Je;exports.EyeClosed=We;exports.Glasses=Xe;exports.Hammer=Ye;exports.Hash=Ze;exports.House=es;exports.Key=ss;exports.ListEnd=ts;exports.ListStart=ns;exports.ListX=rs;exports.LoaderCircle=se;exports.Map=Ie;exports.MessageSquareMore=os;exports.Network=is;exports.Play=as;exports.Plug2=ls;exports.Save=cs;exports.SelectComponent=ce;exports.Shapes=De;exports.ShieldQuestion=xs;exports.Sigma=us;exports.SwatchBook=ds;exports.Tag=ms;exports.TicketX=ps;exports.ToggleLeft=js;exports.Type=be;exports.User=hs;exports.cleanCard=Es;exports.getDashbaordStateWithoutData=Le;exports.useEditorAside=te;