semaphor 0.0.74 → 0.0.75

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
- import { J as A, L as Ge, b as z, c as Cs, u as je, j as e, M as Ns, O as Ss, P as F, Q as ws, R as ks, U as zs, V as Fs, W as Is, X as H, Y as Se, Z as ta, _ as na, $ as la, a0 as ra, a1 as Za, a2 as et, a3 as st, a4 as Bs, f as X, a5 as He, a6 as at, a7 as ia, a8 as $e, a9 as Pe, T as Ts, e as oa, g as Ds, aa as he, ab as me, ac as xe, ad as pe, ae as we, af as fe, ag as W, ah as Ls, G as o, ai as Ms, aj as Os, ak as As, w as ca, v as da, t as ue, al as tt, r as nt, N as ua, s as lt, am as rt, B as it, an as ha, ao as ot, S as Es, z as ct, n as Us, A as ma, ap as fs, aq as ie, ar as Ne, as as Ie, at as ls, au as xa, av as dt, aw as ut, ax as pa, ay as ht, az as mt, aA as xt, aB as pt, aC as ft, aD as gs, aE as gt, aF as jt, aG as _e, aH as js, aI as Me, aJ as bs, aK as Gs, aL as bt, aM as yt, aN as vt, aO as Ct, aP as Nt, aQ as St, aR as ps, aS as wt, aT as Ks, aU as kt, aV as Qs, aW as zt, aX as Ft, aY as It, aZ as fa, H as be, a_ as ga, l as Tt, C as Dt, E as Ze, d as Lt, h as Mt, a$ as Ot, i as At, o as Et, b0 as Vt, m as qt, b1 as Rt, b2 as ja, b3 as ba, b4 as es, b5 as ya, b6 as ss, b7 as Ws, b8 as _t, b9 as Ht, ba as rs, bb as is, bc as os, bd as $t, be as Pt, bf as va, K as Bt, bg as Ut, bh as Gt, bi as cs, bj as Te, bk as Kt, bl as Qt, bm as Ca, bn as Wt, bo as Jt, bp as as, bq as Yt, br as Xt, bs as Zt, bt as Js, bu as en, bv as sn, bw as an, bx as tn, by as nn, bz as ln, bA as rn, bB as on, bC as De, bD as B, bE as U, bF as Vs, bG as G, bH as cn, bI as Na, bJ as Sa, bK as dn, bL as un, bM as hn, bN as mn, bO as xn, bP as pn, bQ as fn, bR as gn, bS as jn } from "./index-FWArdRk4.js";
1
+ import { J as A, L as Ge, b as z, c as Cs, u as je, j as e, M as Ns, O as Ss, P as F, Q as ws, R as ks, U as zs, V as Fs, W as Is, X as H, Y as Se, Z as ta, _ as na, $ as la, a0 as ra, a1 as Za, a2 as et, a3 as st, a4 as Bs, f as X, a5 as He, a6 as at, a7 as ia, a8 as $e, a9 as Pe, T as Ts, e as oa, g as Ds, aa as he, ab as me, ac as xe, ad as pe, ae as we, af as fe, ag as W, ah as Ls, G as o, ai as Ms, aj as Os, ak as As, w as ca, v as da, t as ue, al as tt, r as nt, N as ua, s as lt, am as rt, B as it, an as ha, ao as ot, S as Es, z as ct, n as Us, A as ma, ap as fs, aq as ie, ar as Ne, as as Ie, at as ls, au as xa, av as dt, aw as ut, ax as pa, ay as ht, az as mt, aA as xt, aB as pt, aC as ft, aD as gs, aE as gt, aF as jt, aG as _e, aH as js, aI as Me, aJ as bs, aK as Gs, aL as bt, aM as yt, aN as vt, aO as Ct, aP as Nt, aQ as St, aR as ps, aS as wt, aT as Ks, aU as kt, aV as Qs, aW as zt, aX as Ft, aY as It, aZ as fa, H as be, a_ as ga, l as Tt, C as Dt, E as Ze, d as Lt, h as Mt, a$ as Ot, i as At, o as Et, b0 as Vt, m as qt, b1 as Rt, b2 as ja, b3 as ba, b4 as es, b5 as ya, b6 as ss, b7 as Ws, b8 as _t, b9 as Ht, ba as rs, bb as is, bc as os, bd as $t, be as Pt, bf as va, K as Bt, bg as Ut, bh as Gt, bi as cs, bj as Te, bk as Kt, bl as Qt, bm as Ca, bn as Wt, bo as Jt, bp as as, bq as Yt, br as Xt, bs as Zt, bt as Js, bu as en, bv as sn, bw as an, bx as tn, by as nn, bz as ln, bA as rn, bB as on, bC as De, bD as B, bE as U, bF as Vs, bG as G, bH as cn, bI as Na, bJ as Sa, bK as dn, bL as un, bM as hn, bN as mn, bO as xn, bP as pn, bQ as fn, bR as gn, bS as jn } from "./index-_nIuMIu4.js";
2
2
  import * as Ys from "react";
3
3
  import ge, { useState as E, useMemo as ys, useEffect as Y, useRef as Be, Suspense as bn } from "react";
4
4
  import "react-dom";
@@ -2946,7 +2946,7 @@ function Ga(s) {
2946
2946
  const [n, a] = E(null);
2947
2947
  return Y(() => {
2948
2948
  s && (async () => {
2949
- const i = (await import("./lucide-react-ywxrrj3b.js"))[s];
2949
+ const i = (await import("./lucide-react-T4U9pQPT.js"))[s];
2950
2950
  a(i);
2951
2951
  })();
2952
2952
  }, [s]), n;
@@ -1,4 +1,4 @@
1
- "use strict";const e=require("./index-Vo7AS1qw.js"),v=require("react");require("react-dom");function _s(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 Be=_s(v);/**
1
+ "use strict";const e=require("./index-VmC8M9rg.js"),v=require("react");require("react-dom");function _s(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 Be=_s(v);/**
2
2
  * @license lucide-react v0.453.0 - ISC
3
3
  *
4
4
  * This source code is licensed under the ISC license.
@@ -237,4 +237,4 @@ SELECT label, measure FROM table
237
237
  Table Columns: ${C==null?void 0:C.map(N=>`${N.column_name} | ${N.data_type}`).join(", ")}
238
238
  User SQL: ${T}
239
239
  ${h&&`Base Queries: ${JSON.stringify(h)} `}`,I=` 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: ${et}`,{data:p,isLoading:S,isFetching:f,isError:j,refetch:z}=e.useQuery({queryKey:["ai-query"],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/ai",(l==null?void 0:l.accessToken)||"",{user_content:`userContent: ${L} ${x?I:""}`}),enabled:!1});function O(N){if(N.toLowerCase().includes("bar"))m("bar");else if(N.toLowerCase().includes("line"))m("line");else if(N.toLowerCase().includes("bubble"))m("bubble");else if(N.toLowerCase().includes("scatter"))m("scatter");else if(N.toLowerCase().includes("stacked"))m("stackedBar");else if(N.toLowerCase().includes("pie"))m("pie");else if(N.toLowerCase().includes("donut")||N.toLowerCase().includes("doughnut"))m("doughnut");else if(N.toLowerCase().includes("radar"))m("radar");else return m("bar"),!1;return!0}v.useEffect(()=>{p&&w(N=>[...N,{role:"ai",content:p.response}])},[p]),v.useEffect(()=>{const N=setTimeout(()=>{var A;c.current&&(c.current.scroll({top:c.current.scrollHeight,behavior:"smooth"}),(A=i.current)==null||A.focus())},100);return()=>clearTimeout(N)},[b]);function F(){t&&(w(N=>[...N,{role:"user",content:t}]),O(t)&&d(!0),n(""),z())}v.useEffect(()=>{o&&(F(),a(!1))},[o,a]);const V={fontFamily:"Arial, sans-serif",lineHeight:1.6,fontSize:15,width:"100%"},P={fontFamily:"monospace",fontSize:14,lineHeight:1.6},_={fontFamily:"Arial, sans-serif",lineHeight:1.6,fontSize:15,padding:"2px 0",marginLeft:20,listStyleType:"disc"},K={p:({node:N,...A})=>e.jsxRuntimeExports.jsx("p",{style:V,...A}),code:({node:N,...A})=>e.jsxRuntimeExports.jsx("code",{className:"rounded-sm bg-muted px-2 py-1 text-sm",...A}),pre:({node:N,...A})=>e.jsxRuntimeExports.jsxs("pre",{className:"space-y-2 rounded-sm bg-muted/50 p-3",style:P,children:[e.jsxRuntimeExports.jsx("code",{className:"whitespace-normal text-sm",children:A.children}),e.jsxRuntimeExports.jsxs("div",{className:"flex justify-start gap-2",children:[e.jsxRuntimeExports.jsx(e.Button,{onClick:q,size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(e.ClipboardCopyIcon,{})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:H=>{const D=q(H);D&&(r(!1),g(D),u(!0))},size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(e.PlayIcon,{})})]})]}),li:({node:N,...A})=>e.jsxRuntimeExports.jsx("li",{style:_,...A})};function q(N){const A=N.currentTarget.closest("pre");if(!A)return;const H=A.textContent||A.innerText;return navigator.clipboard.writeText(H).then(()=>console.log("Text copied to clipboard")).catch(D=>console.error("Error in copying text: ",D)),H}function W(){return b==null?void 0:b.map((N,A)=>N.role==="user"?e.jsxRuntimeExports.jsxs("div",{className:"flex items-start rounded-md bg-muted p-3 text-sm",children:[e.jsxRuntimeExports.jsx(fs,{className:"mr-2 h-5 w-5"}),e.jsxRuntimeExports.jsx("div",{children:N.content})]},A):N.role==="ai"?e.jsxRuntimeExports.jsx(e.Markdown,{className:"w-full overflow-auto py-1",components:K,children:p==null?void 0:p.response.replace(/DuckDB/gi,"Semaphor")},A):e.jsxRuntimeExports.jsx("div",{},A))}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:c,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:W()})}),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:i,onKeyDown:N=>{N.key==="Enter"&&!N.shiftKey&&(N.preventDefault(),n(""),F())},placeholder:"Type your question here...",onFocus:N=>{const A=N.target,H=A.value.length;A.setSelectionRange(H,H)},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:S||f,value:t,onChange:N=>n(N.target.value)})," ",e.jsxRuntimeExports.jsx(e.Button,{className:"h-8",size:"sm",variant:"ghost",onClick:F,children:!S&&!f?e.jsxRuntimeExports.jsx(e.PaperPlaneIcon,{}):e.jsxRuntimeExports.jsx(le,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"})})]})})]})]})}var ys={color:void 0,size:void 0,className:void 0,style:void 0,attr:void 0},He=v.createContext&&v.createContext(ys),tt=["attr","size","title"];function nt(s,r){if(s==null)return{};var t=rt(s,r),n,o;if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(s);for(o=0;o<a.length;o++)n=a[o],!(r.indexOf(n)>=0)&&Object.prototype.propertyIsEnumerable.call(s,n)&&(t[n]=s[n])}return t}function rt(s,r){if(s==null)return{};var t={},n=Object.keys(s),o,a;for(a=0;a<n.length;a++)o=n[a],!(r.indexOf(o)>=0)&&(t[o]=s[o]);return t}function ge(){return ge=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},ge.apply(this,arguments)}function Pe(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 Re(s){for(var r=1;r<arguments.length;r++){var t=arguments[r]!=null?arguments[r]:{};r%2?Pe(Object(t),!0).forEach(function(n){ot(s,n,t[n])}):Object.getOwnPropertyDescriptors?Object.defineProperties(s,Object.getOwnPropertyDescriptors(t)):Pe(Object(t)).forEach(function(n){Object.defineProperty(s,n,Object.getOwnPropertyDescriptor(t,n))})}return s}function ot(s,r,t){return r=it(r),r in s?Object.defineProperty(s,r,{value:t,enumerable:!0,configurable:!0,writable:!0}):s[r]=t,s}function it(s){var r=at(s,"string");return typeof r=="symbol"?r:String(r)}function at(s,r){if(typeof s!="object"||s===null)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 Ss(s){return s&&s.map((r,t)=>v.createElement(r.tag,Re({key:t},r.attr),Ss(r.child)))}function Z(s){return r=>v.createElement(lt,ge({attr:Re({},s.attr)},r),Ss(s.child))}function lt(s){var r=t=>{var{attr:n,size:o,title:a}=s,i=nt(s,tt),c=o||t.size||"1em",l;return t.className&&(l=t.className),s.className&&(l=(l?l+" ":"")+s.className),v.createElement("svg",ge({stroke:"currentColor",fill:"currentColor",strokeWidth:"0"},t.attr,n,i,{className:l,style:Re(Re({color:s.color||t.color},t.style),s.style),height:c,width:c,xmlns:"http://www.w3.org/2000/svg"}),a&&v.createElement("title",null,a),s.children)};return He!==void 0?v.createElement(He.Consumer,null,t=>r(t)):r(ys)}function ct(s){return Z({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 xt(){const{theme:s}=e.useTheme(),r=v.useRef(),t=v.useRef(),[n,o]=v.useState(!1),[a,i]=v.useState(!1),[c,l]=v.useState(!1),[x,d]=v.useState(""),[g,h]=v.useState(!1),{authToken:u}=e.useSemaphorContext();e.useDashboardStore(E=>E.selectedSheetId);const m=e.useDashboardStore(E=>E.dashboard.baseQueries),b=e.useEditorStore(E=>E.card),w=e.useDashboardStore(E=>E.theme),C=e.useEditorStore(E=>E.isShowingVisual);e.useDashboardStore(E=>E.onAcceptChanges);const T=e.useEditorStore(E=>E.selectedConnectionId),R=e.useEditorStore(E=>E.selectedDatabaseName),L=e.useEditorStore(E=>E.selectedDatamodelId),I=e.useEditorStore(E=>E.selectedSchemaName);e.useDashboardStore(E=>E.actions.updateFrameCard);const p=e.useEditorStore(E=>E.selectedTableName),S=e.useEditorStore(E=>E.card.sql),f=e.useEditorStore(E=>E.card.python),j=e.resolveBaseQuery(S,m),z=e.useEditorStore(E=>E.selectedConnectionId),O=e.useEditorStore(E=>E.frame),F=e.useDashboardStore(E=>E.filterValues),V=e.useEditorStore(E=>E.applyFilters),{setCardCustomCfg:P,setQueryResultColumns:_,setFilterValues:K,setCardSql:q,setCardPython:W,setQueryError:N,setPythonStdOut:A,setCardPreferences:H}=e.useEditorStore(E=>E.actions),D=e.useEditorStore(E=>E.onSave),k=e.useEditorStore(E=>E.actions.setApplyFilters),$=e.useEditorStore(E=>E.onClose),M=e.useEditorStore(E=>E.actions.setCardData),G=e.useEditorStore(E=>E.actions.setSqlGen),U=e.useEditorStore(E=>E.runSql),te=e.useEditorStore(E=>E.actions.setRunSql),ee=e.useEditorStore(E=>E.actions.setIsSqlRunning),{data:B,isLoading:J,isFetching:Y,isSuccess:ne,isError:X,error:se,status:qe,refetch:ie}=e.useQuery({queryKey:[j,f],queryFn:()=>e.postRequest("https://semaphor.cloud/api/v1/query",(u==null?void 0:u.accessToken)||"",{connection_id:z,sql:j,python:f===e.PYTHON_DEFAULT_CODE?"":f,active_filters:V?F:[],cache_config:e.getCacheConfig()}),enabled:!1,retry:!1});v.useEffect(()=>{if(B&&(M(B.records),B.rowLimitExceeded&&e.Jt.error("Row limit (10,000) exceeded. Refine your query.",{position:"top-center",richColors:!0}),A((B==null?void 0:B.output)||""),B.records.length>0)){const{dimensionKeys:E}=e.getKeys(B.records);_(E)}},[B,M,_,A]),v.useEffect(()=>{U&&(ie(),te(!1))},[U,ie,te]),v.useEffect(()=>{(J||Y)&&ee(!0),(X||ne)&&ee(!1),X?(N(se.message),M([]),_([]),A("")):N("")},[J,Y,B,A,X,ne,ee,M,_,N,se]);function Ce(){q(""),M([]),G({}),P(""),H({})}const me=E=>{t.current=E};function Ne(E,y){if(E.length===0)return"";if(y){const re=E.find(Q=>Q.id===y);if(re){const Q=re.tabTitle;if(Q=="All__Header")return E[0].id;if(Q&&Q.endsWith("__Header")){const Vs=Q.split("__")[0],_e=E.find(qs=>qs.tabTitle===Vs);return _e?_e.id:E[0].id}return y}}return E[0].id}function we(){let E=S;S&&!S.includes("{{")&&(E=Ws(S),q(E));const y={...b,lastSelectedSchema:I,lastSelectedDatamodelId:L,lastSelectedDatabase:R,lastSelectedTable:p,connectionId:T,type:C?b.type:"table",sql:E,customCfg:C?b.customCfg:null},re=O.cards.map(ke=>ke.id===b.id?y:ke),Q={...O,cards:re,activeCardId:Ne(re,O.activeCardId)};D==null||D(Q)}function pe(){$==null||$()}v.useEffect(()=>{const E=r.current,y=t.current;if(E){const re=window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light",Q=w==="system"?re:w;E.editor.defineTheme("default",{base:Q==="light"?"vs":"vs-dark",inherit:!0,rules:[],colors:{"editor.background":Q==="light"?"#ffffff":e.getCssVariableValue("--semaphor-background")}}),E.editor.setTheme("default")}return y&&E&&y.addCommand(E.KeyMod.Shift|E.KeyCode.Enter,function(){return console.log("Executing query..."),ie(),!1}),()=>{}},[s,w,r.current]);function ue(E){r.current=E}function je(){return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[a&&e.jsxRuntimeExports.jsx("div",{className:"xbg-yellow-100 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(Ys,{checked:V,onCheckedChange:()=>k(!V),text:"Apply Filters"}),e.jsxRuntimeExports.jsx(Zs,{}),F&&a&&e.jsxRuntimeExports.jsx(e.Cross2Icon,{onClick:()=>i(!1),className:"bg-background/50 text-foreground/50 hover:cursor-pointer hover:text-foreground"})]}),e.jsxRuntimeExports.jsx(e.Ft,{theme:"default",onChange:E=>{if(E)try{JSON.parse(E),K(JSON.parse(E))}catch{}},defaultLanguage:"json",className:"mt-1 min-h-[220px]",value:JSON.stringify(F,null,2),options:{readOnly:!0,minimap:{enabled:!1},lineNumbers:"off",glyphMargin:!1,wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:12,renderLineHighlight:"none"}})]})}),F&&!a&&e.jsxRuntimeExports.jsx(e.Filter,{onClick:()=>i(!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":V})})]})}function he(){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",{role:"sql-container",className:"relative flex w-[99%]",children:e.jsxRuntimeExports.jsx(e.Ft,{theme:"default",className:"pt-3",onChange:E=>{q(E)},value:S,options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:14,renderLineHighlight:"none"},defaultLanguage:"sql",beforeMount:ue,onMount:me})}),n&&e.jsxRuntimeExports.jsx("code",{className:"absolute right-6 top-3 text-sm 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",{role:"python-container",className:"relative flex w-[99%] pt-0",children:e.jsxRuntimeExports.jsx(e.Ft,{className:"pt-3",theme:"default",onChange:E=>{W(E&&E.trim()||"")},value:f||e.PYTHON_DEFAULT_CODE,options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:14,renderLineHighlight:"none"},defaultLanguage:"python",beforeMount:ue,onMount:me})}),e.jsxRuntimeExports.jsx("code",{className:"absolute right-6 top-3 text-sm 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",{role:"sql-editor",className:"relative flex grow justify-between overflow-y-scroll",children:[he(),je()]}),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:J||Y,onClick:()=>{ie()},className:"shrink-0",size:"sm",variant:"outline",children:[J||Y?e.jsxRuntimeExports.jsx(le,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsxRuntimeExports.jsx(xs,{className:"mr-2 h-4 w-4"}),"Run"]}),X&&e.jsxRuntimeExports.jsx(Js,{error:se.message,setShowAIDialog:l,setTriggerAIRun:h,setUserInputforAI:d}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:Ce,className:"",size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(Xe,{className:"mr-2 size-4"}),"Clear"]}),e.jsxRuntimeExports.jsx(e.Toggle,{pressed:n,onPressedChange:E=>o(E),className:"",size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(ct,{className:"size-4 text-foreground/70"})}),e.jsxRuntimeExports.jsx(st,{open:c,setOpen:l,userInput:x,triggerAIRun:g,setTriggerAIRun:h,setUserInput:E=>d(E)})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-end gap-2",children:[e.jsxRuntimeExports.jsxs(e.Button,{onClick:we,size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(e.Check,{className:"mr-2 size-4 font-bold text-green-600"}),"Accept"]}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:pe,className:"w-full",size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(e.Cross2Icon,{className:"mr-2 size-4"}),"Close"]})]})]})]})}function ut({data:s}){var i;const[r,t]=v.useState([]),o=Object.keys(s[0]).map(c=>({accessorKey:c,header:({column:l})=>{const x=l.getIsSorted();return e.jsxRuntimeExports.jsx("div",{className:"flex gap-2",children:e.jsxRuntimeExports.jsxs("div",{className:"flex cursor-pointer items-center",onClick:()=>l.toggleSorting(l.getIsSorted()==="asc"),children:[c,x==="asc"?e.jsxRuntimeExports.jsx(e.TriangleUpIcon,{className:"ml-2 h-5 w-5"}):x==="desc"?e.jsxRuntimeExports.jsx(e.TriangleDownIcon,{className:"ml-2 h-5 w-5"}):null]})})}})),a=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.jsxs(e.Table$1,{children:[e.jsxRuntimeExports.jsx(e.TableHeader,{children:a.getHeaderGroups().map(c=>e.jsxRuntimeExports.jsx(e.TableRow,{children:c.headers.map(l=>e.jsxRuntimeExports.jsx(e.TableHead,{className:"sticky top-0 bg-muted",children:l.isPlaceholder?null:e.flexRender(l.column.columnDef.header,l.getContext())},l.id))},c.id))}),e.jsxRuntimeExports.jsx(e.TableBody,{children:(i=a.getRowModel().rows)!=null&&i.length?a.getRowModel().rows.map(c=>e.jsxRuntimeExports.jsx(e.TableRow,{className:"whitespace-nowrap py-2","data-state":c.getIsSelected()&&"selected",children:c.getVisibleCells().map(l=>e.jsxRuntimeExports.jsx(e.TableCell,{children:e.flexRender(l.column.columnDef.cell,l.getContext())},l.id))},c.id)):e.jsxRuntimeExports.jsx(e.TableRow,{children:e.jsxRuntimeExports.jsx(e.TableCell,{colSpan:o.length,className:"h-24 text-center",children:"No results."})})})]})}function dt({card:s}){var x,d,g,h,u,m,b,w,C,T;const r=e.useDashboardStore(R=>R.themeStyle),t={colors:((d=(x=r==null?void 0:r.chart)==null?void 0:x.dataset)==null?void 0:d.backgroundColor)||[]};(g=s.customCardPreferences)!=null&&g.inputData;const{getCard:n}=e.useCustomVisual(((h=s.customCardPreferences)==null?void 0:h.url)||""),o=((u=s.customCardPreferences)==null?void 0:u.visualType)||"single",a=e.useEditorStore(R=>R.frame);if(e.useEditorActions(),!((m=s.customCardPreferences)!=null&&m.componentName))return null;const i=n((b=s.customCardPreferences)==null?void 0:b.componentName),c=R=>{console.log("data",R),s.customCardPreferences},l=Object.keys(((w=s.customCardPreferences)==null?void 0:w.dataInputCardIds)||{}).map(R=>{var p,S,f;const L=(S=(p=s.customCardPreferences)==null?void 0:p.dataInputCardIds)==null?void 0:S[R].cardId,I=(f=a==null?void 0:a.cards)==null?void 0:f.find(j=>j.id===L);return I||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(v.Suspense,{fallback:e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{}),children:[i&&o==="single"&&e.jsxRuntimeExports.jsx(i,{theme:t,settings:(C=s.customCardPreferences)==null?void 0:C.settings,onDataChange:c,data:s.data}),i&&o==="multiple"&&e.jsxRuntimeExports.jsx("div",{className:"flex flex-col gap-2",children:e.jsxRuntimeExports.jsx(i,{theme:t,onDataChange:c,settings:l.map(R=>{var L;return(L=R==null?void 0:R.customCardPreferences)==null?void 0:L.settings}),data:l.map(R=>(R==null?void 0:R.data)||[])})})]},(T=s.customCardPreferences)==null?void 0:T.componentName)})}function vs({className:s,...r}){var h,u;v.useState(0);const t=e.useDashboardStore(m=>m.themeStyle),n=e.useEditorStore(m=>m.card),o=((h=n.customCardPreferences)==null?void 0:h.showCardHeader)??!0,a=e.useEditorStore(m=>m.frame),i=e.useDashboardStore(m=>m.dashboard.filters);e.useDashboardStore(m=>m.filterValues),e.useEditorStore(m=>m.actions.setRunSql);const{updateFilter:c}=e.useDashboardActions(),l=i==null?void 0:i.find(m=>m.id===a.filterId),x=e.useEditorStore(m=>m.actions.setCard);if(v.useEffect(()=>{},[n.data,n.type,n.cfg,n.customCfg,t,n.preferences]),!n.id)return null;let d;n.data&&n.data.length>0&&(d=e.createChartConfig({data:n.data,cardType:n.type,cfg:n.cfg,customCfg:n.customCfg,preferences:n.preferences}));function g(m){return e.jsxRuntimeExports.jsx(dt,{card:m})}return e.jsxRuntimeExports.jsxs(e.Card,{role:"editor-visual-card",className:e.cn("relative flex h-full flex-col rounded-none",s),...r,children:[o&&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:n.title,onSave:m=>x({...n,title:m}),children:e.jsxRuntimeExports.jsx("div",{className:"flex items-center gap-5",children:e.jsxRuntimeExports.jsx(e.CardTitle,{className:"text-base",children:n.title})})},n.title),e.jsxRuntimeExports.jsx(e.Editable,{text:n.description||"",onSave:m=>x({...n,description:m}),children:e.jsxRuntimeExports.jsxs(e.CardDescription,{children:[" ",n.description]})},n.description)]}),l&&e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-3",children:[e.jsxRuntimeExports.jsx(e.Editable,{className:"my-1",text:l.title||l.column,onSave:m=>c({...l,title:m}),children:e.jsxRuntimeExports.jsx(e.Label,{children:l.title})}),e.getFilterComponent(l)]})]}),e.jsxRuntimeExports.jsxs(e.CardContent,{className:"flex grow flex-col",children:[n.type==="custom"&&g(n),!["table","custom"].includes(n.type)&&d&&e.jsxRuntimeExports.jsx(e.ChartJsVisual,{cfg:d},JSON.stringify(d)+JSON.stringify(n.preferences)+((u=n==null?void 0:n.preferences)==null?void 0:u.customVisualCode)),n.type==="table"&&n.data&&n.data.length>0&&e.jsxRuntimeExports.jsx(e.$57acba87d6e25586$export$ccf8d8d7bbf3c2cc,{className:"flex min-h-0 flex-1 grow basis-0",children:e.jsxRuntimeExports.jsx(e.TableVisual,{card:n,data:n==null?void 0:n.data})})]})]})}function mt(){const[s,r]=v.useState(!1),[t,n]=v.useState(""),[o,a]=v.useState(""),[i,c]=v.useState(""),[l,x]=v.useState(""),d=e.useEditorStore(R=>R.card),g=e.useEditorStore(R=>R.card.customCfg),{setCardCustomCfg:h,setCustomVisualCode:u}=e.useEditorActions();function m(R){var p,S;const L={...R,data:{...R==null?void 0:R.data,datasets:(S=(p=R==null?void 0:R.data)==null?void 0:p.datasets)==null?void 0:S.map(f=>({...f,data:[]}))}};return JSON.stringify(L,null,1)}function b(){var L,I;if(!d.data||d.data.length===0)return;const R=e.createChartConfig({data:d.data,cardType:d.type,cfg:d.cfg,preferences:d.preferences});R&&(n(JSON.stringify(R,null,1)),(L=d==null?void 0:d.preferences)!=null&&L.customVisualCode&&c((I=d==null?void 0:d.preferences)==null?void 0:I.customVisualCode),g&&a(JSON.stringify(g,null,1)))}function w(){if(i&&u(i),!!o)try{const R=JSON.parse(o);return R?(h(R),x(""),a(""),R):void 0}catch(R){console.log(R),x("Invalid JSON")}}function C(){a(""),h(null)}function T(){let R;if(g){const L=e._.cloneDeep(d.cfg),I=e._.merge(L,g);return R=m(I),R}return t?(R=m(JSON.parse(t)),R):""}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:b,className:` ${g&&"border-foreground/50 dark:border-foreground/70"}`,size:"sm",variant:"outline",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.jsxs(e.DialogHeader,{className:"",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(ze,{onClick:()=>{navigator.clipboard.writeText(d.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."})]})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex grow gap-2",children:[e.jsxRuntimeExports.jsx(vs,{className:"w-1/2 rounded shadow-none"}),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:[g&&e.jsxRuntimeExports.jsx(e.CheckIcon,{className:"mr-1 h-5 w-5 text-green-600"}),g?"Custom Config":"Default Config"]}),e.jsxRuntimeExports.jsx(e.TabsTrigger,{className:"",value:"output",children:"Output"}),e.jsxRuntimeExports.jsx(e.TabsTrigger,{className:"",value:"custom-code",children:"Custom Code"})]}),e.jsxRuntimeExports.jsx(e.TabsContent,{className:"bg-red-x mt-0 grow rounded-b border border-t-0 p-2",value:"output",children:e.jsxRuntimeExports.jsx(e.Textarea,{disabled:!0,value:t,className:"h-full resize-none border-none font-mono focus-visible:ring-0 focus-visible:ring-offset-0"})}),e.jsxRuntimeExports.jsx(e.TabsContent,{className:"mt-0 grow rounded-b border border-t-0",value:"custom-config",children: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:"json",value:T(),onChange:R=>a(R)})}),e.jsxRuntimeExports.jsx(e.TabsContent,{className:"mt-0 grow rounded-b border border-t-0",value:"custom-code",children: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:"javascript",value:i,onChange:R=>c(R||"")})})]})]}),e.jsxRuntimeExports.jsxs(e.DialogFooter,{className:"flex items-center",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"mr-2 text-red-500",children:l}),e.jsxRuntimeExports.jsx(e.Button,{disabled:!g,onClick:C,variant:"outline",children:"Reset"}),e.jsxRuntimeExports.jsx(e.Button,{onClick:w,variant:"outline",children:"Apply"}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>r(!1),variant:"outline",children:"Close"})]})]})]})}function Cs(s){return Z({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 Ns(s){return Z({tag:"svg",attr:{viewBox:"0 0 256 256",fill:"currentColor"},child:[{tag:"path",attr:{d:"M137.39,24.06A16,16,0,0,0,120,40V80.67a15.86,15.86,0,0,0,13.25,15.76A32,32,0,1,1,96,129.68c-.41-8.22,1.27-15,5-20.26h0a15.86,15.86,0,0,0-1.69-20.47L71.69,60.68a16,16,0,0,0-23.63,1.1A103.6,103.6,0,0,0,55,202.05,103.24,103.24,0,0,0,128,232h1.49A104.3,104.3,0,0,0,232,129.48C232.75,75.18,191.19,28.88,137.39,24.06ZM60.32,71.94l27.61,28.19,0,.06A43.29,43.29,0,0,0,80.44,120H40.36A87.13,87.13,0,0,1,60.32,71.94ZM40.37,136h40.3A48,48,0,0,0,120,175.34v40.3A88,88,0,0,1,40.37,136Zm149.77,54.14A87.45,87.45,0,0,1,136,215.61V175.34a47.55,47.55,0,0,0,24.73-12.23A48,48,0,0,0,136,80.66L136,40c45.52,4.08,80.67,43.28,80,89.25A87.45,87.45,0,0,1,190.14,190.14Z"},child:[]}]})(s)}function ws(s){return Z({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 ks(s){return Z({tag:"svg",attr:{viewBox:"0 0 24 24",strokeWidth:"2",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round"},child:[{tag:"path",attr:{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},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 Is(s){return Z({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 Ds(s){return Z({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 Ls(s){return Z({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 Ts(s){return Z({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 As(s){const[r,t]=v.useState(null);return v.useEffect(()=>{s&&(async()=>{const a=(await Promise.resolve().then(()=>require("./lucide-react-aeDoVIV4.js")))[s];t(a)})()},[s]),r}function zs(){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 pt({onChartTypeChange:s}){const[r,t]=v.useState([]),{data:n}=zs();return v.useEffect(()=>{(async()=>{var a;if(n){const c=(await Promise.all((a=n==null?void 0:n.plugins)==null?void 0:a.map(async l=>(await e.loadManifest(l.value)).visuals.map(g=>({name:g.name,icon:g.icon,url:l.value}))))).flat();t(c)}})()},[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,a)=>e.jsxRuntimeExports.jsx(jt,{text:o.name,onClick:()=>s("custom",o),icon:o.icon},o.url+o.name+a))})]})}const jt=({text:s,icon:r,onClick:t})=>{const n=As(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 ht(){var d,g;const[s,r]=v.useState(!1),t=e.useEditorStore(h=>h.card),n=t.type,{setCardType:o,setCardPreferences:a,setChartOrientation:i}=e.useEditorStore(h=>h.actions),{setCardCustomCfg:c,setCustomCardPreferences:l}=e.useEditorActions();function x(h,u){c(null),a({}),o(h),u&&l({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(Et,{className:"h-4 w-4",chartType:n,customIcon:(d=t.customCardPreferences)==null?void 0:d.icon,componentName:(g=t.customCardPreferences)==null?void 0:g.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:()=>x("bar"),className:"font-normal",variant:"ghost",children:e.jsxRuntimeExports.jsx(be,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("line"),variant:"ghost",children:e.jsxRuntimeExports.jsx(ye,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("stackedBar"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ds,{className:"size-5",strokeWidth:0})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("stackedLine"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Is,{className:"size-5",strokeWidth:0})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("scatter"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Te,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("bubble"),variant:"ghost",children:e.jsxRuntimeExports.jsx(ks,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("pie"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Le,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("doughnut"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ns,{className:"size-5",strokeWidth:1})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("radar"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Cs,{className:"size-5 font-extralight",strokeWidth:.5})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("polarArea"),variant:"ghost",children:e.jsxRuntimeExports.jsx(ws,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("pyramid"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ts,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("range"),variant:"ghost",children:e.jsxRuntimeExports.jsx(De,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("table"),variant:"ghost",children:e.jsxRuntimeExports.jsx(e.Table,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("kpi"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ls,{className:"size-6"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("text"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Se,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("custom"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Me,{className:"size-4"})})]}),e.jsxRuntimeExports.jsx(pt,{onChartTypeChange:x})]})]})}function Et({chartType:s,className:r,customIcon:t,componentName:n}){const o=As(t||"");switch(s){case"bar":return e.jsxRuntimeExports.jsx(be,{className:r});case"line":return e.jsxRuntimeExports.jsx(ye,{className:r});case"pie":return e.jsxRuntimeExports.jsx(Le,{className:r});case"radar":return e.jsxRuntimeExports.jsx(Cs,{className:r});case"scatter":return e.jsxRuntimeExports.jsx(Te,{className:r});case"bubble":return e.jsxRuntimeExports.jsx(ks,{className:r});case"doughnut":return e.jsxRuntimeExports.jsx(Ns,{className:r});case"stackedBar":return e.jsxRuntimeExports.jsx(Ds,{className:"size-4 text-foreground/70"});case"stackedLine":return e.jsxRuntimeExports.jsx(Is,{className:"size-4 text-foreground/70"});case"polarArea":return e.jsxRuntimeExports.jsx(ws,{className:r});case"pyramid":return e.jsxRuntimeExports.jsx(Ts,{className:r});case"range":return e.jsxRuntimeExports.jsx(De,{className:r});case"kpi":return e.jsxRuntimeExports.jsx(Ls,{className:r});case"text":return e.jsxRuntimeExports.jsx(Se,{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(Me,{className:r});default:return e.jsxRuntimeExports.jsx(e.Table,{className:r})}}function ft(){var o;const s=e.useEditorStore(a=>a.card),r=((o=s.customCardPreferences)==null?void 0:o.showCardHeader)??!0,{setCustomCardPreferences:t}=e.useEditorActions(),n=a=>{s.customCardPreferences&&t({...s.customCardPreferences,showCardHeader:a===!0})};return e.jsxRuntimeExports.jsxs(e.DropdownMenu,{children:[e.jsxRuntimeExports.jsx(e.DropdownMenuTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(Ae,{className:"size-4 cursor-pointer text-muted-foreground/70 transition-colors hover:text-muted-foreground"})}),e.jsxRuntimeExports.jsxs(e.DropdownMenuContent,{align:"start",className:"w-40 text-muted-foreground",children:[e.jsxRuntimeExports.jsx(e.DropdownMenuCheckboxItem,{checked:r,onCheckedChange:n,children:"Card Header"}),e.jsxRuntimeExports.jsxs(e.DropdownMenuItem,{onClick:()=>{navigator.clipboard.writeText(s.id),e.Jt.success("Card ID copied to clipboard")},className:"cursor-pointer space-x-2",children:[e.jsxRuntimeExports.jsx(ze,{className:"size-4"}),e.jsxRuntimeExports.jsx("span",{children:"Copy Card ID"})]})]})]})}function $e(){const s=e.useEditorStore(p=>p.frame),r=e.useEditorStore(p=>p.card),t=e.useEditorStore(p=>p.card.data),n=e.useEditorStore(p=>p.isShowingVisual),o=e.useEditorStore(p=>p.isSqlRunning),a=e.useEditorStore(p=>p.queryError),i=e.useEditorStore(p=>p.pythonStdOut),c=e.useEditorStore(p=>p.actions.setRunSql);e.useEditorStore(p=>p.onSave),e.useEditorStore(p=>p.onClose),e.useEditorStore(p=>p.actions.setCardSql),e.useEditorStore(p=>p.actions.setCardType),e.useEditorStore(p=>p.actions.setSqlGen);const{setFrame:l,setCard:x,updateCardInFrame:d}=e.useEditorActions();if(!r)return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:"No Active Card"});function g(){const p={id:e.v4(),title:"Title",description:"Description",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"",data:[]};h(p)}function h(p){const S={...s,cards:[...s.cards,p],activeCardId:p.id};l(S),x(p)}function u(){const p={...r,id:e.v4(),title:`${r.title} Copy`,tabTitle:`${r.tabTitle} Copy`};h(p)}function m(p){const S=s.cards.filter(z=>z.id!==p),f=S[0],j={...s,cards:S,activeCardId:f.id};l(j),x(f)}function b(p){const S={...s,cards:s.cards.map(j=>j.id===r.id?r:j),activeCardId:p};l(S);const f=S.cards.find(j=>j.id===p);x(f),f.sql&&f.data&&f.data.length===0&&c(!0)}const w=(p,S)=>{console.log("handleDragStart",S),p.dataTransfer.setData("tabIndex",S.toString())},C=p=>{p.preventDefault()},T=(p,S)=>{const f=p.dataTransfer.getData("tabIndex");if(f===S.toString())return;const j=Array.from(s.cards),[z]=j.splice(parseInt(f),1);j.splice(S,0,z),l({...s,cards:j})};function R(p,S){return p.cards.length===1&&(S.displayTab===!0||S.displayTab===void 0)||p.activeCardId!==S.id&&(S.displayTab===!0||S.displayTab===void 0)?null:e.jsxRuntimeExports.jsx("div",{onClick:()=>{const f=S.displayTab===void 0?!1:!S.displayTab;x({...S,displayTab:f}),d({...S,displayTab:f})},children:S.displayTab===!0||S.displayTab===void 0?e.jsxRuntimeExports.jsx(es,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"}):e.jsxRuntimeExports.jsx(Ze,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"})})}function L(){return e.jsxRuntimeExports.jsxs(e.Tabs,{onValueChange:b,value:s.activeCardId,className:"flex grow flex-col",children:[s.cards.map(p=>e.jsxRuntimeExports.jsx(e.TabsContent,{className:"mt-0 grow",value:p.id,children:I()},p.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((p,S)=>e.jsxRuntimeExports.jsx(e.Editable,{text:p.tabTitle||p.title,onSave:f=>{x({...r,tabTitle:f}),d({...r,tabTitle:f})},children:e.jsxRuntimeExports.jsxs(e.TabsTrigger,{draggable:!0,onDragStart:f=>w(f,S),onDragOver:C,onDrop:f=>T(f,S),className:"",value:p.id,children:[R(s,p),p.tabTitle||p.title,s.activeCardId===p.id&&s.cards.length>1&&e.jsxRuntimeExports.jsx(e.X,{className:"ml-2 size-3.5 text-muted-foreground hover:text-foreground",onClick:()=>m(p.id)})]})},p.id)),e.jsxRuntimeExports.jsx(e.Button,{className:"ml-1 h-8 px-2 hover:bg-muted-foreground/50",variant:"outline",onClick:g,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:u,children:e.jsxRuntimeExports.jsx(Je,{className:"h-4 w-4"})})]})})]})}function I(){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,{isLoading:o,card:r})})}):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.TextCard,{isLoading:o,card:r})})}):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:[o&&e.jsxRuntimeExports.jsx(le,{className:"absolute bottom-0 left-0 right-0 top-0 z-10 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:[n&&e.jsxRuntimeExports.jsxs("div",{className:"flex grow items-center gap-2",children:[e.jsxRuntimeExports.jsx(ht,{}),!["table","custom"].includes(r.type)&&e.jsxRuntimeExports.jsx(mt,{}),e.jsxRuntimeExports.jsx(ft,{})]}),e.jsxRuntimeExports.jsx(Rt,{})]}),n?L():e.jsxRuntimeExports.jsxs("div",{className:"flex min-h-0 w-full flex-1 grow basis-0 px-6",children:[i&&e.jsxRuntimeExports.jsx(gt,{}),r.data&&r.data.length>0&&e.jsxRuntimeExports.jsx(ut,{data:t||[]}),a&&e.jsxRuntimeExports.jsx("span",{className:"font-mono text-sm",children:a})]})]})}function gt(){const s=e.useEditorStore(t=>t.pythonStdOut);if(!s)return null;const r=s.replace(/\n/g,"<br>");return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx("p",{className:"font-mono text-sm",children:"Output:"}),e.jsxRuntimeExports.jsx("div",{dangerouslySetInnerHTML:{__html:r},className:"bg-muted p-2 font-mono text-sm"}),e.jsxRuntimeExports.jsx(e.Separator,{className:"mb-2"})]})}function Rt(){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 bt({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 de({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(a=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:a.value,children:a.label},a.value))]})})]})}function Ge({children:s,summary:r}){return e.jsxRuntimeExports.jsxs("details",{className:"space-y-4 [&_summary>svg]:open:-rotate-180",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 yt(){var b,w;const s=e.useEditorStore(C=>C.card.customCardPreferences),{data:r}=zs(),t=(r==null?void 0:r.plugins)||[],n=e.useEditorStore(C=>C.card),o=e.useEditorStore(C=>C.frame),a=(s==null?void 0:s.visualType)||"single",{setCustomCardPreferences:i}=e.useEditorActions(),{components:c,manifest:l}=e.useCustomVisual((s==null?void 0:s.url)||""),x=(b=l==null?void 0:l.visuals)==null?void 0:b.find(C=>C.name===(s==null?void 0:s.componentName));function d(C,T){if(!s)return;const L={...(s==null?void 0:s.dataInputCardIds)||{},[C]:{cardId:T,hookRef:null}};i({...s,dataInputCardIds:L})}function g(C){var R,L;const T=(R=o==null?void 0:o.cards)==null?void 0:R.filter(I=>{var p;return((p=I==null?void 0:I.customCardPreferences)==null?void 0:p.visualType)!=="multiple"}).map(I=>({value:I.id,label:I.tabTitle||I.title}));return e.jsxRuntimeExports.jsx("div",{className:"space-y-2",children:(L=C==null?void 0:C.dataInputs)==null?void 0:L.map((I,p)=>{var S,f;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:I}),e.jsxRuntimeExports.jsx(de,{className:"col-span-6 h-8 w-full justify-between",label:"",options:T||[],value:((f=(S=s==null?void 0:s.dataInputCardIds)==null?void 0:S[p])==null?void 0:f.cardId)||"",onValueChange:j=>d(p,j)})]},p+Math.random())})})}function h(C,T,R=[]){var L,I;return s?C==="input"?e.jsxRuntimeExports.jsx(e.Input,{className:`h-8 w-full ${e.removeRing}`,value:((L=s==null?void 0:s.settings)==null?void 0:L[T])||"",onChange:p=>{i({...s,settings:{...s==null?void 0:s.settings,[T]:p.target.value}})}},T):C==="select"?e.jsxRuntimeExports.jsx(de,{className:"h-8 w-full",label:"",options:R,value:((I=s==null?void 0:s.settings)==null?void 0:I[T])||"",onValueChange:p=>{i({...s,settings:{...s==null?void 0:s.settings,[T]:p}})}}):null:null}function u(C){const T=Object.entries((C==null?void 0:C.settings)||{});return e.jsxRuntimeExports.jsx("div",{className:"space-y-3",children:T.map(([R,L])=>e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:L.title}),h(L.ui,R,L.options)]},R))})}function m(C){s&&i({...s,visualType:C,componentName:""})}return e.jsxRuntimeExports.jsxs("div",{className:"p-6",children:[e.jsxRuntimeExports.jsx(Ge,{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(de,{className:"h-8 w-full",label:"",options:t,value:(s==null?void 0:s.url)||"",onValueChange:C=>i({...s||{url:"",componentName:""},url:C})})})}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&e.jsxRuntimeExports.jsx(bt,{options:[{value:"single",label:"Single Visual"},{value:"multiple",label:"Multi-Visual"}],value:a,onValueChange:m}),((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:c&&e.jsxRuntimeExports.jsx(de,{className:"h-8 w-full",label:"",options:(c==null?void 0:c.filter(C=>C.type===a).map(C=>({value:C.name,label:C.name})))||[],value:s.componentName,onValueChange:C=>{console.log("changing value",C),i({...s,componentName:C})}})})]})})]})})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-4"}),((w=n==null?void 0:n.customCardPreferences)==null?void 0:w.componentName)&&e.jsxRuntimeExports.jsxs(Ge,{summary:"Component Settings",children:[x&&x.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:g(x)})]}),x&&x.settings&&e.jsxRuntimeExports.jsx("div",{className:"space-y-3",children:e.jsxRuntimeExports.jsx("div",{className:"px-2",children:u(x)})})]})]})}function ce(){const[s,r]=v.useState([]);e.useEditorStore(d=>d.card.cfg);const t=e.useEditorStore(d=>d.card.preferences),{setCardCfg:n,setFilterOnClickColumnIndex:o,setCardPreferences:a}=e.useEditorStore(d=>d.actions),i=e.useEditorStore(d=>d.queryResultColumns);e.useEditorStore(d=>{var g;return(g=d.card.preferences)==null?void 0:g.filterOnClickColumnIndex}),v.useEffect(()=>{i&&r(new Array(i.length).fill(!1))},[i]);function c(d,g){var h,u;g?t!=null&&t.onClickFilter&&((h=t==null?void 0:t.onClickFilter)==null?void 0:h.length)>0?a({...t,onClickFilter:[...t.onClickFilter,{columnIndex:d,expression:""}]}):a({...t,onClickFilter:[{columnIndex:d,expression:""}]}):(a({...t,onClickFilter:(u=t==null?void 0:t.onClickFilter)==null?void 0:u.filter(m=>m.columnIndex!==d)}),r(m=>{const b=[...m];return b[d]=!1,b}))}function l(d,g){var u;const h=(u=t==null?void 0:t.onClickFilter)==null?void 0:u.map(m=>m.columnIndex===d?{...m,expression:g.target.value}:m);a({...t,onClickFilter:h})}function x(d){var g,h,u,m;if(s!=null&&s[d]||(h=(g=t==null?void 0:t.onClickFilter)==null?void 0:g.find(b=>b.columnIndex===d))!=null&&h.expression)return e.jsxRuntimeExports.jsx(e.Input,{value:(m=(u=t==null?void 0:t.onClickFilter)==null?void 0:u.find(b=>b.columnIndex===d))==null?void 0:m.expression,onChange:b=>l(d,b),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"}),i==null?void 0:i.map((d,g)=>{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(m=>m.columnIndex===g)),onCheckedChange:m=>c(g,m)}),e.jsxRuntimeExports.jsx("label",{className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:d}),e.jsxRuntimeExports.jsx("div",{className:"flex items-center gap-2",children:((u=t==null?void 0:t.onClickFilter)==null?void 0:u.find(m=>m.columnIndex===g))&&e.jsxRuntimeExports.jsx(Fe,{onClick:()=>{r(m=>{const b=[...m];return b[g]=!m[g],b})},className:"invisible size-3 cursor-pointer text-gray-400 group-hover:visible"})})]}),x(g)]})},d)})]})}function ve(){var i,c,l;const s=e.useEditorStore(x=>x.card.preferences),r=e.useEditorStore(x=>x.card.cfg),{setCardCfg:t,setCardPreferences:n,setChartOrientation:o}=e.useEditorStore(x=>x.actions);(i=r==null?void 0:r.options)!=null&&i.indexAxis;function a(x){o(x)}return e.jsxRuntimeExports.jsxs(e.RadioGroup,{value:((c=s==null?void 0:s.chartOptions)==null?void 0:c.indexAxis)||((l=r==null?void 0:r.options)==null?void 0:l.indexAxis)||"x",onValueChange:a,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 Ee="focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0";function Ue(s,r){var n,o,a;const t=e.getNumberAxis(s,r);return((a=(o=(n=s==null?void 0:s.chartOptions)==null?void 0:n.scales)==null?void 0:o[t])==null?void 0:a.type)||"linear"}function Fs(){var K,q,W,N,A,H;const[s,r]=v.useState(!1),t=e.useEditorStore(D=>{var k;return(k=D.card)==null?void 0:k.preferences}),n=e.useEditorStore(D=>{var k;return(k=D.card)==null?void 0:k.cfg}),o=e.getNumberAxis(t,n),[a,i]=v.useState(Ue(t)),[c,l]=v.useState(((W=(q=(K=t==null?void 0:t.chartOptions)==null?void 0:K.scales)==null?void 0:q[o])==null?void 0:W.min)||""),[x,d]=v.useState(((H=(A=(N=t==null?void 0:t.chartOptions)==null?void 0:N.scales)==null?void 0:A[o])==null?void 0:H.max)||""),[g,h]=v.useState(c||x?"custom":"auto"),[u,m]=v.useState(""),[b,w]=v.useState(0),[C,T]=v.useState(""),[R,L]=v.useState(""),[I,p]=v.useState(""),S=e.useEditorStore(D=>D.actions.setCardPreferences),{updateCardInFrame:f}=e.useEditorActions(),j=e.useEditorStore(D=>D.card),z=e.useEditorStore(D=>{var k;return(k=D.card)==null?void 0:k.type}),O=["pie","doughnut","polarArea"].includes(z);v.useEffect(()=>{var D,k,$,M,G,U,te,ee,B,J,Y,ne,X,se;i(Ue(t)),l((($=(k=(D=t==null?void 0:t.chartOptions)==null?void 0:D.scales)==null?void 0:k[o])==null?void 0:$.min)===0?0:""),d(((U=(G=(M=t==null?void 0:t.chartOptions)==null?void 0:M.scales)==null?void 0:G[o])==null?void 0:U.max)||""),m(((J=(B=(ee=(te=t==null?void 0:t.chartOptions)==null?void 0:te.scales)==null?void 0:ee[o])==null?void 0:B.ticks)==null?void 0:J.stepSize)||""),w(((Y=t==null?void 0:t.numberAxisFormat)==null?void 0:Y.decimalPlaces)||0),T(((ne=t==null?void 0:t.numberAxisFormat)==null?void 0:ne.suffix)||""),L(((X=t==null?void 0:t.numberAxisFormat)==null?void 0:X.currency)||""),p(((se=t==null?void 0:t.numberAxisFormat)==null?void 0:se.locale)||"")},[s,t,o]);function F(D,k){return k===""||/^[0-9\b]+$/.test(k)?Number(k):Number(D)}function V(){const D=[...new Set(e.LOCALE_CURRENCY_PAIRS.map(k=>k.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:R||"none",onValueChange:k=>L(k==="none"?"":k),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"}),D.map(k=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:k,children:k},k))]})})]}),e.jsxRuntimeExports.jsxs(e.Select,{value:I,onValueChange:k=>p(k),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(k=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:k.locale,children:k.locale},k.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:b,onChange:k=>w(Number(k.target.value)),id:"format",className:`col-span-6 h-8 w-full tracking-wide ${Ee}`})]})]})}function P(){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:c,onChange:D=>l(k=>F(k,D.target.value)),className:`col-span-1 h-8 w-full ${Ee}`}),e.jsxRuntimeExports.jsx(e.Input,{value:x,onChange:D=>d(k=>F(k,D.target.value)),id:"max",className:`col-span-1 h-8 w-full ${Ee}`})]}),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:D=>m(k=>F(k,D.target.value)),id:"step-size",className:`col-span-1 h-8 w-full ${Ee}`})]})]})}function _(){var M;let D={};g==="custom"&&(D={min:c,max:x,ticks:{stepSize:u}});const k={...t||{},chartOptions:{...t==null?void 0:t.chartOptions,scales:{...(M=t==null?void 0:t.chartOptions)==null?void 0:M.scales,[o]:{type:a,...a==="linear"?D:{}}}},numberAxisFormat:{decimalPlaces:b,suffix:C,currency:R,locale:I}};console.log(k),S(k);const $={...j,preferences:k};f($)}return e.jsxRuntimeExports.jsxs(e.Popover,{onOpenChange:D=>r(D),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:O,value:a,onValueChange:D=>i(D),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"})]})})]})]}),a=="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:O,id:"scale-option",value:g,onValueChange:D=>h(D),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"})]})]})]}),g==="custom"&&a=="linear"&&P(),V(),e.jsxRuntimeExports.jsx(e.SelectSeparator,{}),e.jsxRuntimeExports.jsx("div",{className:"grid grid-cols-3",children:e.jsxRuntimeExports.jsx(e.Button,{onClick:_,variant:"secondary",className:"col-span-1 col-start-3 h-8 w-full",children:"Apply"})})]})]})})]})}function St({idx:s}){var c;const r=e.useEditorStore(l=>{var x;return(x=l.card)==null?void 0:x.preferences}),t=e.useEditorStore(l=>{var x;return(x=l.card.preferences)==null?void 0:x.datasetOptions}),n=e.useEditorStore(l=>l.actions.setCardPreferences),o=(c=r==null?void 0:r.chartOptions)==null?void 0:c.indexAxis,a=t==null?void 0:t.find(l=>l.idx===s);function i(l,x){(l==="end"||l==="start")&&e.getContrastColor(e.getCanvasBackgroundColor());const d={display:l!=="none",align:l,anchor:l,clamp:!0};if(!a)n({...r,datasetOptions:[...t||[],{idx:x,datalabels:d}]});else{const g={...a};g.datalabels=d;const h=t==null?void 0:t.map(u=>u.idx===x?g:u);n({...r,datasetOptions:h})}}return e.jsxRuntimeExports.jsxs(e.Popover,{children:[e.jsxRuntimeExports.jsx(e.PopoverTrigger,{children:e.jsxRuntimeExports.jsx(hs,{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:()=>i("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:()=>i("start",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(os,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>i("center",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(as,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>i("end",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(is,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})})]})})]})}function Ms(){const s=e.useEditorStore(l=>l.card),r=e.useEditorStore(l=>{var x,d,g;return(g=(d=(x=l==null?void 0:l.card)==null?void 0:x.preferences)==null?void 0:d.chartOptions)==null?void 0:g.indexAxis}),t=r==="y"?"Y axis":"X axis",n=r==="y"?"X axis":"Y axis",{keys:o,metricKeys:a,dimensionKeys:i}=e.getKeys(s.data||[]);let c=a;if(["stackedBar","stackedLine"].includes(s.type)){const l=e.pivotData({dataArray:s.data||[],groupKey:i[0],pivotKey:i[1],valueKey:c[0]}),{metricKeys:x}=e.getKeys(l);c=x}return o.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:t}),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:i[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:n}),e.jsxRuntimeExports.jsx(Fs,{})]}),e.jsxRuntimeExports.jsx("div",{className:"my-1 space-y-1",children:c.map((l,x)=>e.jsxRuntimeExports.jsx(vt,{col:l,idx:x},l))})]})]})}function vt({col:s,idx:r}){const t=e.useEditorStore(c=>{var l;return(l=c.card)==null?void 0:l.preferences}),n=e.useEditorStore(c=>{var l;return(l=c.card.preferences)==null?void 0:l.datasetOptions}),o=n==null?void 0:n.find(c=>c.idx===r),{setCardPreferences:a}=e.useEditorStore(c=>c.actions);function i(c){if(!o)a({...t,datasetOptions:[...n||[],{idx:r,type:c==="area"?"line":c,fill:c==="area"?"origin":""}]});else{const l={...o};l.type=c==="area"?"line":c,l.fill=c==="area"?"origin":"";const x=n==null?void 0:n.map(d=>d.idx===r?l:d);a({...t,datasetOptions:x})}}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(be,{onClick:()=>i("bar"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx(ye,{onClick:()=>i("line"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx(Ke,{onClick:()=>i("area"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx(e.Separator,{orientation:"vertical",className:"invisible size-4 cursor-pointer py-2 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),a=e.useDashboardStore(h=>h.dashboard.filters)||[],i=e.useDashboardStore(h=>h.actions.addFilter),c=e.useDashboardStore(h=>h.actions.removeFilter),l=e.useDashboardStore(h=>h.actions.removeFilterValue),{modelItems:x,tableName:d}=oe();function g(h,u="dashboard"){var p;const m=e.fmt(h.column_name),b=e.fmt(t||""),w=e.fmt(n||""),C=e.fmt(d);let T=e.getQualifiedTableName(w,C),R=`${T}.${m}`;const L=(p=x==null?void 0:x.find(S=>S.id===r))==null?void 0:p.name;r&&r!=="none"&&(R=`${e.DATAMODEL_NAMESPCACE}.${L}.${m}`,T=`${e.DATAMODEL_NAMESPCACE}.${L}`);const I=a==null?void 0:a.find(S=>S.column===R&&S.table===C&&(S.database===b||S.database===t));if(I)l(I.id),c(I.id);else{const S=e.v4();return d==="api"&&s?(i({location:u,id:S,column:R,title:h.column_name,dataType:h.data_type,table:"api",database:"",connectionId:s,operation:"in",sql:e.getDefaultFilterSql(h.data_type,T,m)}),S):(i({id:S,location:u,column:R,title:h.column_name,dataType:h.data_type,table:o||"",database:t||"",connectionId:s||"",operation:"in",sql:e.getDefaultFilterSql(h.data_type,T,m)}),S)}}return{assignFilter:g}}function xe(){const s=e.useDashboardStore(c=>c.dashboard.filters),r=e.useEditorStore(c=>c.frame),{setFrame:t}=e.useEditorActions(),{columns:n}=oe(),{assignFilter:o}=Os();function a(c){const l=o(c,"frame");t({...r,filterId:l})}const i=s==null?void 0:s.find(c=>c.id===r.filterId);return e.jsxRuntimeExports.jsxs("div",{className:"space-y-3",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Card Filter"}),e.jsxRuntimeExports.jsx(Ct,{onSelect:a,columns:n}),i&&e.jsxRuntimeExports.jsx(e.FilterHeader,{filter:i})]})}function Ct({columns:s,onSelect:r}){var i;const[t,n]=Be.useState(!1),[o,a]=Be.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?(i=s.find(c=>c.column_name===o))==null?void 0:i.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(c=>e.jsxRuntimeExports.jsxs(e.CommandItem,{value:c.column_name,onSelect:l=>{const x=l===o?"":l;a(x),n(!1),x&&r(c)},children:[c.column_name,e.jsxRuntimeExports.jsx(e.CheckIcon,{className:e.cn("ml-auto h-4 w-4",o===c.column_name?"opacity-100":"opacity-0")})]},c.column_name))})]})]})})]})}function Nt({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(ve,{}),e.jsxRuntimeExports.jsx(Ms,{})]})]}),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(ce,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function Ve(){var o,a,i;const s=e.useEditorStore(c=>c.card.cfg),r=e.useEditorStore(c=>c.actions.setCardCfg),t=e.useEditorStore(c=>c.card.type);function n(c){var d;const l={datalabels:{display:c!=="none",align:c,anchor:c,clamp:!0}},x={...s,options:{...s==null?void 0:s.options,plugins:{...(d=s==null?void 0:s.options)==null?void 0:d.plugins,...l}}};r(x),console.log(c)}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(Fs,{})]}),e.jsxRuntimeExports.jsxs(e.Select,{value:(i=(a=(o=s==null?void 0:s.options)==null?void 0:o.plugins)==null?void 0:a.datalabels)==null?void 0:i.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 wt({cardType:s}){function r(t){const n="SELECT label, [group], x-axis, y-axis, radius FROM table",o="SELECT label, [group], x-axis, y-axis FROM table";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"?n:o}),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:a=>a.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(Ve,{})})]}),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(ce,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}const kt={datasets:[{type:"line",label:"Sum_sales",data:[]},{type:"bar",label:"Sum_profit",data:[]}]},It={datasets:[{fill:"origin",type:"line",label:"Sum_sales",data:[]}]};function Dt(){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:Lt(s)}),e.jsxRuntimeExports.jsx("section",{className:"",children:["line","bar"].includes(s)&&e.jsxRuntimeExports.jsx(ve,{})}),!["kpi"].includes(s)&&e.jsxRuntimeExports.jsxs("div",{className:"space-y-4",children:[e.jsxRuntimeExports.jsx(Ve,{}),e.jsxRuntimeExports.jsx(ce,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})}function Lt(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(kt,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(It,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 Tt(){var l,x,d,g,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 m,b;return(b=(m=u.card.preferences)==null?void 0:m.formatNumber)==null?void 0:b.decimalPlaces});const n=e.useEditorStore(u=>{var m,b;return(b=(m=u.card.preferences)==null?void 0:m.formatNumber)==null?void 0:b.locale}),o=e.useEditorStore(u=>{var m,b;return(b=(m=u.card.preferences)==null?void 0:m.formatNumber)==null?void 0:b.currency});e.useEditorStore(u=>u.actions.setFilterOnClickField);const a=e.useEditorStore(u=>{var m,b;return(b=(m=u.card.preferences)==null?void 0:m.formatNumber)==null?void 0:b.colorRanges})||[],i=e.useEditorStore(u=>u.actions.setColorRanges),c=[...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:!!((l=s==null?void 0:s.formatNumber)!=null&&l.enabled),onCheckedChange:u=>{r({...s,formatNumber:{...s==null?void 0:s.formatNumber,enabled:u}})}}),e.jsxRuntimeExports.jsx(e.Label,{children:"Format Number"})]}),((x=s==null?void 0:s.formatNumber)==null?void 0:x.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||"en-US",onValueChange:u=>{var m,b,w;return t(((m=s==null?void 0:s.formatNumber)==null?void 0:m.decimalPlaces)||0,((b=s==null?void 0:s.formatNumber)==null?void 0:b.currency)||"",u||"en-US",((w=s==null?void 0:s.formatNumber)==null?void 0:w.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.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 m,b,w;return t(((m=s==null?void 0:s.formatNumber)==null?void 0:m.decimalPlaces)||0,u==="none"?"":u,((b=s==null?void 0:s.formatNumber)==null?void 0:b.locale)||"",((w=s==null?void 0:s.formatNumber)==null?void 0:w.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"),c.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:((g=(d=s==null?void 0:s.formatNumber)==null?void 0:d.decimalPlaces)==null?void 0:g.toString())||"0",onValueChange:u=>{var m,b,w;return t(Number(u),((m=s==null?void 0:s.formatNumber)==null?void 0:m.currency)||"",((b=s==null?void 0:s.formatNumber)==null?void 0:b.locale)||"",((w=s==null?void 0:s.formatNumber)==null?void 0:w.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 m,b,w;return t(((m=s==null?void 0:s.formatNumber)==null?void 0:m.decimalPlaces)||0,((b=s==null?void 0:s.formatNumber)==null?void 0:b.currency)||"",((w=s==null?void 0:s.formatNumber)==null?void 0:w.locale)||"",u.target.value)}})]})]})]})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-3"}),e.jsxRuntimeExports.jsx(e.ColorFormat,{colorRanges:a,setColorRanges:i})]})]})}function At(){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(Tt,{})}),e.jsxRuntimeExports.jsx("div",{}),e.jsxRuntimeExports.jsx("div",{})]})}function zt(){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 fe({cardType:s,docContent:r,suffix:t="Chart"}){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)} ${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:n=>n.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#pie-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:[s==="range"&&e.jsxRuntimeExports.jsx(ve,{}),s!=="text"&&e.jsxRuntimeExports.jsx(Ve,{}),s==="text"&&e.jsxRuntimeExports.jsx(zt,{})]})]}),!["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(ce,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function Ft(){const s=e.useEditorStore(n=>{var o,a;return(a=(o=n==null?void 0:n.card)==null?void 0:o.preferences)==null?void 0:a.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(de,{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(ve,{}),t(),e.jsxRuntimeExports.jsx(Ms,{})]})]}),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(ce,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function Mt({}){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(ce,{}),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 Ot=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."]})]}),Vt=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."]})]}),qt=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(Ft,{});case"pyramid":return e.jsxRuntimeExports.jsx(fe,{docContent:Ot,cardType:t});case"kpi":return e.jsxRuntimeExports.jsx(At,{});case"line":case"bar":return e.jsxRuntimeExports.jsx(Nt,{cardType:t});case"range":return e.jsxRuntimeExports.jsx(fe,{docContent:Vt,cardType:t});case"pie":case"doughnut":case"polarArea":case"radar":return e.jsxRuntimeExports.jsx(fe,{cardType:t});case"bubble":case"scatter":return e.jsxRuntimeExports.jsx(wt,{cardType:t});case"table":return e.jsxRuntimeExports.jsx(Mt,{cardType:t});case"text":return e.jsxRuntimeExports.jsx(fe,{docContent:qt,cardType:t,suffix:"Visual"});case"custom":return e.jsxRuntimeExports.jsx(yt,{});default:return e.jsxRuntimeExports.jsx(Dt,{})}}return e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"h-full w-full text-sm",children:r(s)})}function Bt(){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(xt,{})}),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 Ht({authToken:s,onSave:r,onClose:t}){e.useDashboardStore(i=>i.themeStyle);const n=e.useEditorStore(i=>i.actions.setOnSave),o=e.useEditorStore(i=>i.actions.setOnClose),a=e.useDashboardStore(i=>i.actions.setAuthToken);return v.useEffect(()=>{r&&n(r),t&&o(t)},[r,n,t,o]),v.useEffect(()=>{s&&s.accessToken&&a(s)},[s,a]),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(bs,{})}),e.jsxRuntimeExports.jsx(e.EditorMain,{children:e.jsxRuntimeExports.jsx(Bt,{})})]})})}function Pt(){e.useDashboardStore(i=>i.selectedCardId);const s=e.useDashboardStore(i=>i.selectedSheetId),{setIsVisualEditing:r}=e.useDashboardStore(i=>i.actions),t=e.useDashboardStore(i=>i.isVisualEditing),n=e.useDashboardStore(i=>i.actions.updateFrame);function o(i){s&&(n(s,i),r(!1))}function a(){r(!1)}return e.jsxRuntimeExports.jsx("div",{role:"editor-container",className:e.cn("flex grow",{block:t,hidden:!t}),children:e.jsxRuntimeExports.jsx(Ht,{onSave:o,onClose:a})})}function $t(){e.useEditorStore(i=>i.selectedConnectionId),e.useEditorStore(i=>i.selectedDatamodelId);const s=e.useEditorStore(i=>i.selectedDatabaseName);e.useEditorStore(i=>i.selectedSchemaName);const r=e.useEditorStore(i=>i.selectedTableName),t=e.useDashboardStore(i=>i.dashboard.filters)||[];e.useDashboardStore(i=>i.actions.addFilter),e.useDashboardStore(i=>i.actions.removeFilter),e.useDashboardStore(i=>i.actions.removeFilterValue);const{modelItems:n,columns:o}=oe(),{assignFilter:a}=Os();return e.jsxRuntimeExports.jsx("div",{className:"xbg-red-100 flex-1 basis-0 flex-col overflow-scroll px-3",children:o==null?void 0:o.map(i=>{const c=t==null?void 0:t.find(l=>l.column===e.fmt(i.column_name)&&l.table===r&&l.database===s);return e.jsxRuntimeExports.jsx("div",{onClick:()=>a(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":c}),children:e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxRuntimeExports.jsx(Rs,{column:i}),e.jsxRuntimeExports.jsx("span",{children:i.column_name})]})},i.column_name)})})}function Gt(){e.useDashboardStore(r=>r.showFilters);const s=e.useDashboardStore(r=>r.actions.setShowFilters);return e.jsxRuntimeExports.jsxs("section",{className:"relative flex grow flex-col border-l px-4",children:[e.jsxRuntimeExports.jsxs("div",{className:"mt-4 flex items-center justify-between gap-2 px-3",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"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(bs,{ColumnsComponent:()=>e.jsxRuntimeExports.jsx($t,{})})})]})}function Ut(){const s=e.useDashboardStore(t=>t.showFilters),r=e.useDashboardStore(t=>t.isVisualEditing);return e.jsxRuntimeExports.jsxs("div",{role:"dashboard-plus-main",className:e.cn("grow",{hidden:r,flex:!r}),children:[e.jsxRuntimeExports.jsx(e.DashboardTabs,{}),s&&e.jsxRuntimeExports.jsx("div",{role:"filter-aside-container",className:"flex",children:e.jsxRuntimeExports.jsx(Gt,{})})]})}function Qt(){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 Kt({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.Te,{}),e.jsxRuntimeExports.jsxs(e.UXProvider,{children:[e.jsxRuntimeExports.jsx(Qt,{}),e.jsxRuntimeExports.jsxs(e.DashboardPanel,{...t,children:[s&&e.jsxRuntimeExports.jsx(Us,{}),e.jsxRuntimeExports.jsx(Pt,{}),e.jsxRuntimeExports.jsx(Ut,{})]})]})]})})}exports.Box=Qe;exports.ChartArea=Ke;exports.ChartColumnIncreasing=be;exports.ChartLine=ye;exports.ChartNoAxesGantt=De;exports.ChartPie=Le;exports.ChartScatter=Te;exports.CircleX=We;exports.CopyPlus=Je;exports.DashboardPlus=Kt;exports.Database=Ye;exports.EllipsisVertical=Ae;exports.Eraser=Xe;exports.Eye=es;exports.EyeClosed=Ze;exports.Glasses=ss;exports.Hammer=ts;exports.Hash=ns;exports.House=rs;exports.Key=ze;exports.ListEnd=os;exports.ListStart=is;exports.ListX=as;exports.LoaderCircle=le;exports.MessageSquareMore=ls;exports.Network=cs;exports.Pencil=Fe;exports.Play=xs;exports.Plug2=us;exports.Save=ds;exports.SelectComponent=ae;exports.Shapes=Me;exports.ShieldQuestion=ms;exports.Sigma=ps;exports.SwatchBook=js;exports.Tag=hs;exports.ToggleLeft=Es;exports.Type=Se;exports.User=fs;exports.cleanCard=gs;exports.getDashbaordStateWithoutData=Oe;exports.useEditorAside=oe;
240
+ Visual Query Syntax: ${et}`,{data:p,isLoading:S,isFetching:f,isError:j,refetch:z}=e.useQuery({queryKey:["ai-query"],queryFn:()=>e.getRequest("https://semaphor.cloud/api/v1/ai",(l==null?void 0:l.accessToken)||"",{user_content:`userContent: ${L} ${x?I:""}`}),enabled:!1});function O(N){if(N.toLowerCase().includes("bar"))m("bar");else if(N.toLowerCase().includes("line"))m("line");else if(N.toLowerCase().includes("bubble"))m("bubble");else if(N.toLowerCase().includes("scatter"))m("scatter");else if(N.toLowerCase().includes("stacked"))m("stackedBar");else if(N.toLowerCase().includes("pie"))m("pie");else if(N.toLowerCase().includes("donut")||N.toLowerCase().includes("doughnut"))m("doughnut");else if(N.toLowerCase().includes("radar"))m("radar");else return m("bar"),!1;return!0}v.useEffect(()=>{p&&w(N=>[...N,{role:"ai",content:p.response}])},[p]),v.useEffect(()=>{const N=setTimeout(()=>{var A;c.current&&(c.current.scroll({top:c.current.scrollHeight,behavior:"smooth"}),(A=i.current)==null||A.focus())},100);return()=>clearTimeout(N)},[b]);function F(){t&&(w(N=>[...N,{role:"user",content:t}]),O(t)&&d(!0),n(""),z())}v.useEffect(()=>{o&&(F(),a(!1))},[o,a]);const V={fontFamily:"Arial, sans-serif",lineHeight:1.6,fontSize:15,width:"100%"},P={fontFamily:"monospace",fontSize:14,lineHeight:1.6},_={fontFamily:"Arial, sans-serif",lineHeight:1.6,fontSize:15,padding:"2px 0",marginLeft:20,listStyleType:"disc"},K={p:({node:N,...A})=>e.jsxRuntimeExports.jsx("p",{style:V,...A}),code:({node:N,...A})=>e.jsxRuntimeExports.jsx("code",{className:"rounded-sm bg-muted px-2 py-1 text-sm",...A}),pre:({node:N,...A})=>e.jsxRuntimeExports.jsxs("pre",{className:"space-y-2 rounded-sm bg-muted/50 p-3",style:P,children:[e.jsxRuntimeExports.jsx("code",{className:"whitespace-normal text-sm",children:A.children}),e.jsxRuntimeExports.jsxs("div",{className:"flex justify-start gap-2",children:[e.jsxRuntimeExports.jsx(e.Button,{onClick:q,size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(e.ClipboardCopyIcon,{})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:H=>{const D=q(H);D&&(r(!1),g(D),u(!0))},size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(e.PlayIcon,{})})]})]}),li:({node:N,...A})=>e.jsxRuntimeExports.jsx("li",{style:_,...A})};function q(N){const A=N.currentTarget.closest("pre");if(!A)return;const H=A.textContent||A.innerText;return navigator.clipboard.writeText(H).then(()=>console.log("Text copied to clipboard")).catch(D=>console.error("Error in copying text: ",D)),H}function W(){return b==null?void 0:b.map((N,A)=>N.role==="user"?e.jsxRuntimeExports.jsxs("div",{className:"flex items-start rounded-md bg-muted p-3 text-sm",children:[e.jsxRuntimeExports.jsx(fs,{className:"mr-2 h-5 w-5"}),e.jsxRuntimeExports.jsx("div",{children:N.content})]},A):N.role==="ai"?e.jsxRuntimeExports.jsx(e.Markdown,{className:"w-full overflow-auto py-1",components:K,children:p==null?void 0:p.response.replace(/DuckDB/gi,"Semaphor")},A):e.jsxRuntimeExports.jsx("div",{},A))}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:c,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:W()})}),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:i,onKeyDown:N=>{N.key==="Enter"&&!N.shiftKey&&(N.preventDefault(),n(""),F())},placeholder:"Type your question here...",onFocus:N=>{const A=N.target,H=A.value.length;A.setSelectionRange(H,H)},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:S||f,value:t,onChange:N=>n(N.target.value)})," ",e.jsxRuntimeExports.jsx(e.Button,{className:"h-8",size:"sm",variant:"ghost",onClick:F,children:!S&&!f?e.jsxRuntimeExports.jsx(e.PaperPlaneIcon,{}):e.jsxRuntimeExports.jsx(le,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"})})]})})]})]})}var ys={color:void 0,size:void 0,className:void 0,style:void 0,attr:void 0},He=v.createContext&&v.createContext(ys),tt=["attr","size","title"];function nt(s,r){if(s==null)return{};var t=rt(s,r),n,o;if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(s);for(o=0;o<a.length;o++)n=a[o],!(r.indexOf(n)>=0)&&Object.prototype.propertyIsEnumerable.call(s,n)&&(t[n]=s[n])}return t}function rt(s,r){if(s==null)return{};var t={},n=Object.keys(s),o,a;for(a=0;a<n.length;a++)o=n[a],!(r.indexOf(o)>=0)&&(t[o]=s[o]);return t}function ge(){return ge=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},ge.apply(this,arguments)}function Pe(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 Re(s){for(var r=1;r<arguments.length;r++){var t=arguments[r]!=null?arguments[r]:{};r%2?Pe(Object(t),!0).forEach(function(n){ot(s,n,t[n])}):Object.getOwnPropertyDescriptors?Object.defineProperties(s,Object.getOwnPropertyDescriptors(t)):Pe(Object(t)).forEach(function(n){Object.defineProperty(s,n,Object.getOwnPropertyDescriptor(t,n))})}return s}function ot(s,r,t){return r=it(r),r in s?Object.defineProperty(s,r,{value:t,enumerable:!0,configurable:!0,writable:!0}):s[r]=t,s}function it(s){var r=at(s,"string");return typeof r=="symbol"?r:String(r)}function at(s,r){if(typeof s!="object"||s===null)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 Ss(s){return s&&s.map((r,t)=>v.createElement(r.tag,Re({key:t},r.attr),Ss(r.child)))}function Z(s){return r=>v.createElement(lt,ge({attr:Re({},s.attr)},r),Ss(s.child))}function lt(s){var r=t=>{var{attr:n,size:o,title:a}=s,i=nt(s,tt),c=o||t.size||"1em",l;return t.className&&(l=t.className),s.className&&(l=(l?l+" ":"")+s.className),v.createElement("svg",ge({stroke:"currentColor",fill:"currentColor",strokeWidth:"0"},t.attr,n,i,{className:l,style:Re(Re({color:s.color||t.color},t.style),s.style),height:c,width:c,xmlns:"http://www.w3.org/2000/svg"}),a&&v.createElement("title",null,a),s.children)};return He!==void 0?v.createElement(He.Consumer,null,t=>r(t)):r(ys)}function ct(s){return Z({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 xt(){const{theme:s}=e.useTheme(),r=v.useRef(),t=v.useRef(),[n,o]=v.useState(!1),[a,i]=v.useState(!1),[c,l]=v.useState(!1),[x,d]=v.useState(""),[g,h]=v.useState(!1),{authToken:u}=e.useSemaphorContext();e.useDashboardStore(E=>E.selectedSheetId);const m=e.useDashboardStore(E=>E.dashboard.baseQueries),b=e.useEditorStore(E=>E.card),w=e.useDashboardStore(E=>E.theme),C=e.useEditorStore(E=>E.isShowingVisual);e.useDashboardStore(E=>E.onAcceptChanges);const T=e.useEditorStore(E=>E.selectedConnectionId),R=e.useEditorStore(E=>E.selectedDatabaseName),L=e.useEditorStore(E=>E.selectedDatamodelId),I=e.useEditorStore(E=>E.selectedSchemaName);e.useDashboardStore(E=>E.actions.updateFrameCard);const p=e.useEditorStore(E=>E.selectedTableName),S=e.useEditorStore(E=>E.card.sql),f=e.useEditorStore(E=>E.card.python),j=e.resolveBaseQuery(S,m),z=e.useEditorStore(E=>E.selectedConnectionId),O=e.useEditorStore(E=>E.frame),F=e.useDashboardStore(E=>E.filterValues),V=e.useEditorStore(E=>E.applyFilters),{setCardCustomCfg:P,setQueryResultColumns:_,setFilterValues:K,setCardSql:q,setCardPython:W,setQueryError:N,setPythonStdOut:A,setCardPreferences:H}=e.useEditorStore(E=>E.actions),D=e.useEditorStore(E=>E.onSave),k=e.useEditorStore(E=>E.actions.setApplyFilters),$=e.useEditorStore(E=>E.onClose),M=e.useEditorStore(E=>E.actions.setCardData),G=e.useEditorStore(E=>E.actions.setSqlGen),U=e.useEditorStore(E=>E.runSql),te=e.useEditorStore(E=>E.actions.setRunSql),ee=e.useEditorStore(E=>E.actions.setIsSqlRunning),{data:B,isLoading:J,isFetching:Y,isSuccess:ne,isError:X,error:se,status:qe,refetch:ie}=e.useQuery({queryKey:[j,f],queryFn:()=>e.postRequest("https://semaphor.cloud/api/v1/query",(u==null?void 0:u.accessToken)||"",{connection_id:z,sql:j,python:f===e.PYTHON_DEFAULT_CODE?"":f,active_filters:V?F:[],cache_config:e.getCacheConfig()}),enabled:!1,retry:!1});v.useEffect(()=>{if(B&&(M(B.records),B.rowLimitExceeded&&e.Jt.error("Row limit (10,000) exceeded. Refine your query.",{position:"top-center",richColors:!0}),A((B==null?void 0:B.output)||""),B.records.length>0)){const{dimensionKeys:E}=e.getKeys(B.records);_(E)}},[B,M,_,A]),v.useEffect(()=>{U&&(ie(),te(!1))},[U,ie,te]),v.useEffect(()=>{(J||Y)&&ee(!0),(X||ne)&&ee(!1),X?(N(se.message),M([]),_([]),A("")):N("")},[J,Y,B,A,X,ne,ee,M,_,N,se]);function Ce(){q(""),M([]),G({}),P(""),H({})}const me=E=>{t.current=E};function Ne(E,y){if(E.length===0)return"";if(y){const re=E.find(Q=>Q.id===y);if(re){const Q=re.tabTitle;if(Q=="All__Header")return E[0].id;if(Q&&Q.endsWith("__Header")){const Vs=Q.split("__")[0],_e=E.find(qs=>qs.tabTitle===Vs);return _e?_e.id:E[0].id}return y}}return E[0].id}function we(){let E=S;S&&!S.includes("{{")&&(E=Ws(S),q(E));const y={...b,lastSelectedSchema:I,lastSelectedDatamodelId:L,lastSelectedDatabase:R,lastSelectedTable:p,connectionId:T,type:C?b.type:"table",sql:E,customCfg:C?b.customCfg:null},re=O.cards.map(ke=>ke.id===b.id?y:ke),Q={...O,cards:re,activeCardId:Ne(re,O.activeCardId)};D==null||D(Q)}function pe(){$==null||$()}v.useEffect(()=>{const E=r.current,y=t.current;if(E){const re=window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light",Q=w==="system"?re:w;E.editor.defineTheme("default",{base:Q==="light"?"vs":"vs-dark",inherit:!0,rules:[],colors:{"editor.background":Q==="light"?"#ffffff":e.getCssVariableValue("--semaphor-background")}}),E.editor.setTheme("default")}return y&&E&&y.addCommand(E.KeyMod.Shift|E.KeyCode.Enter,function(){return console.log("Executing query..."),ie(),!1}),()=>{}},[s,w,r.current]);function ue(E){r.current=E}function je(){return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[a&&e.jsxRuntimeExports.jsx("div",{className:"xbg-yellow-100 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(Ys,{checked:V,onCheckedChange:()=>k(!V),text:"Apply Filters"}),e.jsxRuntimeExports.jsx(Zs,{}),F&&a&&e.jsxRuntimeExports.jsx(e.Cross2Icon,{onClick:()=>i(!1),className:"bg-background/50 text-foreground/50 hover:cursor-pointer hover:text-foreground"})]}),e.jsxRuntimeExports.jsx(e.Ft,{theme:"default",onChange:E=>{if(E)try{JSON.parse(E),K(JSON.parse(E))}catch{}},defaultLanguage:"json",className:"mt-1 min-h-[220px]",value:JSON.stringify(F,null,2),options:{readOnly:!0,minimap:{enabled:!1},lineNumbers:"off",glyphMargin:!1,wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:12,renderLineHighlight:"none"}})]})}),F&&!a&&e.jsxRuntimeExports.jsx(e.Filter,{onClick:()=>i(!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":V})})]})}function he(){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",{role:"sql-container",className:"relative flex w-[99%]",children:e.jsxRuntimeExports.jsx(e.Ft,{theme:"default",className:"pt-3",onChange:E=>{q(E)},value:S,options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:14,renderLineHighlight:"none"},defaultLanguage:"sql",beforeMount:ue,onMount:me})}),n&&e.jsxRuntimeExports.jsx("code",{className:"absolute right-6 top-3 text-sm 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",{role:"python-container",className:"relative flex w-[99%] pt-0",children:e.jsxRuntimeExports.jsx(e.Ft,{className:"pt-3",theme:"default",onChange:E=>{W(E&&E.trim()||"")},value:f||e.PYTHON_DEFAULT_CODE,options:{minimap:{enabled:!1},wordWrap:"on",scrollbar:{verticalScrollbarSize:0,horizontalScrollbarSize:0},fontSize:14,renderLineHighlight:"none"},defaultLanguage:"python",beforeMount:ue,onMount:me})}),e.jsxRuntimeExports.jsx("code",{className:"absolute right-6 top-3 text-sm 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",{role:"sql-editor",className:"relative flex grow justify-between overflow-y-scroll",children:[he(),je()]}),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:J||Y,onClick:()=>{ie()},className:"shrink-0",size:"sm",variant:"outline",children:[J||Y?e.jsxRuntimeExports.jsx(le,{className:"mr-2 h-4 w-4 animate-spin text-foreground/50"}):e.jsxRuntimeExports.jsx(xs,{className:"mr-2 h-4 w-4"}),"Run"]}),X&&e.jsxRuntimeExports.jsx(Js,{error:se.message,setShowAIDialog:l,setTriggerAIRun:h,setUserInputforAI:d}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:Ce,className:"",size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(Xe,{className:"mr-2 size-4"}),"Clear"]}),e.jsxRuntimeExports.jsx(e.Toggle,{pressed:n,onPressedChange:E=>o(E),className:"",size:"sm",variant:"outline",children:e.jsxRuntimeExports.jsx(ct,{className:"size-4 text-foreground/70"})}),e.jsxRuntimeExports.jsx(st,{open:c,setOpen:l,userInput:x,triggerAIRun:g,setTriggerAIRun:h,setUserInput:E=>d(E)})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex items-end gap-2",children:[e.jsxRuntimeExports.jsxs(e.Button,{onClick:we,size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(e.Check,{className:"mr-2 size-4 font-bold text-green-600"}),"Accept"]}),e.jsxRuntimeExports.jsxs(e.Button,{onClick:pe,className:"w-full",size:"sm",variant:"outline",children:[e.jsxRuntimeExports.jsx(e.Cross2Icon,{className:"mr-2 size-4"}),"Close"]})]})]})]})}function ut({data:s}){var i;const[r,t]=v.useState([]),o=Object.keys(s[0]).map(c=>({accessorKey:c,header:({column:l})=>{const x=l.getIsSorted();return e.jsxRuntimeExports.jsx("div",{className:"flex gap-2",children:e.jsxRuntimeExports.jsxs("div",{className:"flex cursor-pointer items-center",onClick:()=>l.toggleSorting(l.getIsSorted()==="asc"),children:[c,x==="asc"?e.jsxRuntimeExports.jsx(e.TriangleUpIcon,{className:"ml-2 h-5 w-5"}):x==="desc"?e.jsxRuntimeExports.jsx(e.TriangleDownIcon,{className:"ml-2 h-5 w-5"}):null]})})}})),a=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.jsxs(e.Table$1,{children:[e.jsxRuntimeExports.jsx(e.TableHeader,{children:a.getHeaderGroups().map(c=>e.jsxRuntimeExports.jsx(e.TableRow,{children:c.headers.map(l=>e.jsxRuntimeExports.jsx(e.TableHead,{className:"sticky top-0 bg-muted",children:l.isPlaceholder?null:e.flexRender(l.column.columnDef.header,l.getContext())},l.id))},c.id))}),e.jsxRuntimeExports.jsx(e.TableBody,{children:(i=a.getRowModel().rows)!=null&&i.length?a.getRowModel().rows.map(c=>e.jsxRuntimeExports.jsx(e.TableRow,{className:"whitespace-nowrap py-2","data-state":c.getIsSelected()&&"selected",children:c.getVisibleCells().map(l=>e.jsxRuntimeExports.jsx(e.TableCell,{children:e.flexRender(l.column.columnDef.cell,l.getContext())},l.id))},c.id)):e.jsxRuntimeExports.jsx(e.TableRow,{children:e.jsxRuntimeExports.jsx(e.TableCell,{colSpan:o.length,className:"h-24 text-center",children:"No results."})})})]})}function dt({card:s}){var x,d,g,h,u,m,b,w,C,T;const r=e.useDashboardStore(R=>R.themeStyle),t={colors:((d=(x=r==null?void 0:r.chart)==null?void 0:x.dataset)==null?void 0:d.backgroundColor)||[]};(g=s.customCardPreferences)!=null&&g.inputData;const{getCard:n}=e.useCustomVisual(((h=s.customCardPreferences)==null?void 0:h.url)||""),o=((u=s.customCardPreferences)==null?void 0:u.visualType)||"single",a=e.useEditorStore(R=>R.frame);if(e.useEditorActions(),!((m=s.customCardPreferences)!=null&&m.componentName))return null;const i=n((b=s.customCardPreferences)==null?void 0:b.componentName),c=R=>{console.log("data",R),s.customCardPreferences},l=Object.keys(((w=s.customCardPreferences)==null?void 0:w.dataInputCardIds)||{}).map(R=>{var p,S,f;const L=(S=(p=s.customCardPreferences)==null?void 0:p.dataInputCardIds)==null?void 0:S[R].cardId,I=(f=a==null?void 0:a.cards)==null?void 0:f.find(j=>j.id===L);return I||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(v.Suspense,{fallback:e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{}),children:[i&&o==="single"&&e.jsxRuntimeExports.jsx(i,{theme:t,settings:(C=s.customCardPreferences)==null?void 0:C.settings,onDataChange:c,data:s.data}),i&&o==="multiple"&&e.jsxRuntimeExports.jsx("div",{className:"flex flex-col gap-2",children:e.jsxRuntimeExports.jsx(i,{theme:t,onDataChange:c,settings:l.map(R=>{var L;return(L=R==null?void 0:R.customCardPreferences)==null?void 0:L.settings}),data:l.map(R=>(R==null?void 0:R.data)||[])})})]},(T=s.customCardPreferences)==null?void 0:T.componentName)})}function vs({className:s,...r}){var h,u;v.useState(0);const t=e.useDashboardStore(m=>m.themeStyle),n=e.useEditorStore(m=>m.card),o=((h=n.customCardPreferences)==null?void 0:h.showCardHeader)??!0,a=e.useEditorStore(m=>m.frame),i=e.useDashboardStore(m=>m.dashboard.filters);e.useDashboardStore(m=>m.filterValues),e.useEditorStore(m=>m.actions.setRunSql);const{updateFilter:c}=e.useDashboardActions(),l=i==null?void 0:i.find(m=>m.id===a.filterId),x=e.useEditorStore(m=>m.actions.setCard);if(v.useEffect(()=>{},[n.data,n.type,n.cfg,n.customCfg,t,n.preferences]),!n.id)return null;let d;n.data&&n.data.length>0&&(d=e.createChartConfig({data:n.data,cardType:n.type,cfg:n.cfg,customCfg:n.customCfg,preferences:n.preferences}));function g(m){return e.jsxRuntimeExports.jsx(dt,{card:m})}return e.jsxRuntimeExports.jsxs(e.Card,{role:"editor-visual-card",className:e.cn("relative flex h-full flex-col rounded-none",s),...r,children:[o&&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:n.title,onSave:m=>x({...n,title:m}),children:e.jsxRuntimeExports.jsx("div",{className:"flex items-center gap-5",children:e.jsxRuntimeExports.jsx(e.CardTitle,{className:"text-base",children:n.title})})},n.title),e.jsxRuntimeExports.jsx(e.Editable,{text:n.description||"",onSave:m=>x({...n,description:m}),children:e.jsxRuntimeExports.jsxs(e.CardDescription,{children:[" ",n.description]})},n.description)]}),l&&e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-3",children:[e.jsxRuntimeExports.jsx(e.Editable,{className:"my-1",text:l.title||l.column,onSave:m=>c({...l,title:m}),children:e.jsxRuntimeExports.jsx(e.Label,{children:l.title})}),e.getFilterComponent(l)]})]}),e.jsxRuntimeExports.jsxs(e.CardContent,{className:"flex grow flex-col",children:[n.type==="custom"&&g(n),!["table","custom"].includes(n.type)&&d&&e.jsxRuntimeExports.jsx(e.ChartJsVisual,{cfg:d},JSON.stringify(d)+JSON.stringify(n.preferences)+((u=n==null?void 0:n.preferences)==null?void 0:u.customVisualCode)),n.type==="table"&&n.data&&n.data.length>0&&e.jsxRuntimeExports.jsx(e.$57acba87d6e25586$export$ccf8d8d7bbf3c2cc,{className:"flex min-h-0 flex-1 grow basis-0",children:e.jsxRuntimeExports.jsx(e.TableVisual,{card:n,data:n==null?void 0:n.data})})]})]})}function mt(){const[s,r]=v.useState(!1),[t,n]=v.useState(""),[o,a]=v.useState(""),[i,c]=v.useState(""),[l,x]=v.useState(""),d=e.useEditorStore(R=>R.card),g=e.useEditorStore(R=>R.card.customCfg),{setCardCustomCfg:h,setCustomVisualCode:u}=e.useEditorActions();function m(R){var p,S;const L={...R,data:{...R==null?void 0:R.data,datasets:(S=(p=R==null?void 0:R.data)==null?void 0:p.datasets)==null?void 0:S.map(f=>({...f,data:[]}))}};return JSON.stringify(L,null,1)}function b(){var L,I;if(!d.data||d.data.length===0)return;const R=e.createChartConfig({data:d.data,cardType:d.type,cfg:d.cfg,preferences:d.preferences});R&&(n(JSON.stringify(R,null,1)),(L=d==null?void 0:d.preferences)!=null&&L.customVisualCode&&c((I=d==null?void 0:d.preferences)==null?void 0:I.customVisualCode),g&&a(JSON.stringify(g,null,1)))}function w(){if(i&&u(i),!!o)try{const R=JSON.parse(o);return R?(h(R),x(""),a(""),R):void 0}catch(R){console.log(R),x("Invalid JSON")}}function C(){a(""),h(null)}function T(){let R;if(g){const L=e._.cloneDeep(d.cfg),I=e._.merge(L,g);return R=m(I),R}return t?(R=m(JSON.parse(t)),R):""}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:b,className:` ${g&&"border-foreground/50 dark:border-foreground/70"}`,size:"sm",variant:"outline",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.jsxs(e.DialogHeader,{className:"",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(ze,{onClick:()=>{navigator.clipboard.writeText(d.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."})]})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex grow gap-2",children:[e.jsxRuntimeExports.jsx(vs,{className:"w-1/2 rounded shadow-none"}),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:[g&&e.jsxRuntimeExports.jsx(e.CheckIcon,{className:"mr-1 h-5 w-5 text-green-600"}),g?"Custom Config":"Default Config"]}),e.jsxRuntimeExports.jsx(e.TabsTrigger,{className:"",value:"output",children:"Output"}),e.jsxRuntimeExports.jsx(e.TabsTrigger,{className:"",value:"custom-code",children:"Custom Code"})]}),e.jsxRuntimeExports.jsx(e.TabsContent,{className:"bg-red-x mt-0 grow rounded-b border border-t-0 p-2",value:"output",children:e.jsxRuntimeExports.jsx(e.Textarea,{disabled:!0,value:t,className:"h-full resize-none border-none font-mono focus-visible:ring-0 focus-visible:ring-offset-0"})}),e.jsxRuntimeExports.jsx(e.TabsContent,{className:"mt-0 grow rounded-b border border-t-0",value:"custom-config",children: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:"json",value:T(),onChange:R=>a(R)})}),e.jsxRuntimeExports.jsx(e.TabsContent,{className:"mt-0 grow rounded-b border border-t-0",value:"custom-code",children: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:"javascript",value:i,onChange:R=>c(R||"")})})]})]}),e.jsxRuntimeExports.jsxs(e.DialogFooter,{className:"flex items-center",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"mr-2 text-red-500",children:l}),e.jsxRuntimeExports.jsx(e.Button,{disabled:!g,onClick:C,variant:"outline",children:"Reset"}),e.jsxRuntimeExports.jsx(e.Button,{onClick:w,variant:"outline",children:"Apply"}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>r(!1),variant:"outline",children:"Close"})]})]})]})}function Cs(s){return Z({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 Ns(s){return Z({tag:"svg",attr:{viewBox:"0 0 256 256",fill:"currentColor"},child:[{tag:"path",attr:{d:"M137.39,24.06A16,16,0,0,0,120,40V80.67a15.86,15.86,0,0,0,13.25,15.76A32,32,0,1,1,96,129.68c-.41-8.22,1.27-15,5-20.26h0a15.86,15.86,0,0,0-1.69-20.47L71.69,60.68a16,16,0,0,0-23.63,1.1A103.6,103.6,0,0,0,55,202.05,103.24,103.24,0,0,0,128,232h1.49A104.3,104.3,0,0,0,232,129.48C232.75,75.18,191.19,28.88,137.39,24.06ZM60.32,71.94l27.61,28.19,0,.06A43.29,43.29,0,0,0,80.44,120H40.36A87.13,87.13,0,0,1,60.32,71.94ZM40.37,136h40.3A48,48,0,0,0,120,175.34v40.3A88,88,0,0,1,40.37,136Zm149.77,54.14A87.45,87.45,0,0,1,136,215.61V175.34a47.55,47.55,0,0,0,24.73-12.23A48,48,0,0,0,136,80.66L136,40c45.52,4.08,80.67,43.28,80,89.25A87.45,87.45,0,0,1,190.14,190.14Z"},child:[]}]})(s)}function ws(s){return Z({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 ks(s){return Z({tag:"svg",attr:{viewBox:"0 0 24 24",strokeWidth:"2",stroke:"currentColor",fill:"none",strokeLinecap:"round",strokeLinejoin:"round"},child:[{tag:"path",attr:{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},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 Is(s){return Z({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 Ds(s){return Z({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 Ls(s){return Z({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 Ts(s){return Z({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 As(s){const[r,t]=v.useState(null);return v.useEffect(()=>{s&&(async()=>{const a=(await Promise.resolve().then(()=>require("./lucide-react-To70ZHfg.js")))[s];t(a)})()},[s]),r}function zs(){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 pt({onChartTypeChange:s}){const[r,t]=v.useState([]),{data:n}=zs();return v.useEffect(()=>{(async()=>{var a;if(n){const c=(await Promise.all((a=n==null?void 0:n.plugins)==null?void 0:a.map(async l=>(await e.loadManifest(l.value)).visuals.map(g=>({name:g.name,icon:g.icon,url:l.value}))))).flat();t(c)}})()},[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,a)=>e.jsxRuntimeExports.jsx(jt,{text:o.name,onClick:()=>s("custom",o),icon:o.icon},o.url+o.name+a))})]})}const jt=({text:s,icon:r,onClick:t})=>{const n=As(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 ht(){var d,g;const[s,r]=v.useState(!1),t=e.useEditorStore(h=>h.card),n=t.type,{setCardType:o,setCardPreferences:a,setChartOrientation:i}=e.useEditorStore(h=>h.actions),{setCardCustomCfg:c,setCustomCardPreferences:l}=e.useEditorActions();function x(h,u){c(null),a({}),o(h),u&&l({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(Et,{className:"h-4 w-4",chartType:n,customIcon:(d=t.customCardPreferences)==null?void 0:d.icon,componentName:(g=t.customCardPreferences)==null?void 0:g.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:()=>x("bar"),className:"font-normal",variant:"ghost",children:e.jsxRuntimeExports.jsx(be,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("line"),variant:"ghost",children:e.jsxRuntimeExports.jsx(ye,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("stackedBar"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ds,{className:"size-5",strokeWidth:0})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("stackedLine"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Is,{className:"size-5",strokeWidth:0})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("scatter"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Te,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("bubble"),variant:"ghost",children:e.jsxRuntimeExports.jsx(ks,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("pie"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Le,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("doughnut"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ns,{className:"size-5",strokeWidth:1})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("radar"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Cs,{className:"size-5 font-extralight",strokeWidth:.5})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("polarArea"),variant:"ghost",children:e.jsxRuntimeExports.jsx(ws,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("pyramid"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ts,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("range"),variant:"ghost",children:e.jsxRuntimeExports.jsx(De,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("table"),variant:"ghost",children:e.jsxRuntimeExports.jsx(e.Table,{className:"size-5"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("kpi"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Ls,{className:"size-6"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("text"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Se,{className:"size-4"})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>x("custom"),variant:"ghost",children:e.jsxRuntimeExports.jsx(Me,{className:"size-4"})})]}),e.jsxRuntimeExports.jsx(pt,{onChartTypeChange:x})]})]})}function Et({chartType:s,className:r,customIcon:t,componentName:n}){const o=As(t||"");switch(s){case"bar":return e.jsxRuntimeExports.jsx(be,{className:r});case"line":return e.jsxRuntimeExports.jsx(ye,{className:r});case"pie":return e.jsxRuntimeExports.jsx(Le,{className:r});case"radar":return e.jsxRuntimeExports.jsx(Cs,{className:r});case"scatter":return e.jsxRuntimeExports.jsx(Te,{className:r});case"bubble":return e.jsxRuntimeExports.jsx(ks,{className:r});case"doughnut":return e.jsxRuntimeExports.jsx(Ns,{className:r});case"stackedBar":return e.jsxRuntimeExports.jsx(Ds,{className:"size-4 text-foreground/70"});case"stackedLine":return e.jsxRuntimeExports.jsx(Is,{className:"size-4 text-foreground/70"});case"polarArea":return e.jsxRuntimeExports.jsx(ws,{className:r});case"pyramid":return e.jsxRuntimeExports.jsx(Ts,{className:r});case"range":return e.jsxRuntimeExports.jsx(De,{className:r});case"kpi":return e.jsxRuntimeExports.jsx(Ls,{className:r});case"text":return e.jsxRuntimeExports.jsx(Se,{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(Me,{className:r});default:return e.jsxRuntimeExports.jsx(e.Table,{className:r})}}function ft(){var o;const s=e.useEditorStore(a=>a.card),r=((o=s.customCardPreferences)==null?void 0:o.showCardHeader)??!0,{setCustomCardPreferences:t}=e.useEditorActions(),n=a=>{s.customCardPreferences&&t({...s.customCardPreferences,showCardHeader:a===!0})};return e.jsxRuntimeExports.jsxs(e.DropdownMenu,{children:[e.jsxRuntimeExports.jsx(e.DropdownMenuTrigger,{asChild:!0,children:e.jsxRuntimeExports.jsx(Ae,{className:"size-4 cursor-pointer text-muted-foreground/70 transition-colors hover:text-muted-foreground"})}),e.jsxRuntimeExports.jsxs(e.DropdownMenuContent,{align:"start",className:"w-40 text-muted-foreground",children:[e.jsxRuntimeExports.jsx(e.DropdownMenuCheckboxItem,{checked:r,onCheckedChange:n,children:"Card Header"}),e.jsxRuntimeExports.jsxs(e.DropdownMenuItem,{onClick:()=>{navigator.clipboard.writeText(s.id),e.Jt.success("Card ID copied to clipboard")},className:"cursor-pointer space-x-2",children:[e.jsxRuntimeExports.jsx(ze,{className:"size-4"}),e.jsxRuntimeExports.jsx("span",{children:"Copy Card ID"})]})]})]})}function $e(){const s=e.useEditorStore(p=>p.frame),r=e.useEditorStore(p=>p.card),t=e.useEditorStore(p=>p.card.data),n=e.useEditorStore(p=>p.isShowingVisual),o=e.useEditorStore(p=>p.isSqlRunning),a=e.useEditorStore(p=>p.queryError),i=e.useEditorStore(p=>p.pythonStdOut),c=e.useEditorStore(p=>p.actions.setRunSql);e.useEditorStore(p=>p.onSave),e.useEditorStore(p=>p.onClose),e.useEditorStore(p=>p.actions.setCardSql),e.useEditorStore(p=>p.actions.setCardType),e.useEditorStore(p=>p.actions.setSqlGen);const{setFrame:l,setCard:x,updateCardInFrame:d}=e.useEditorActions();if(!r)return e.jsxRuntimeExports.jsx(e.jsxRuntimeExports.Fragment,{children:"No Active Card"});function g(){const p={id:e.v4(),title:"Title",description:"Description",preferences:{onClickFilter:[{columnIndex:0,expression:""}]},type:"bar",sql:"",data:[]};h(p)}function h(p){const S={...s,cards:[...s.cards,p],activeCardId:p.id};l(S),x(p)}function u(){const p={...r,id:e.v4(),title:`${r.title} Copy`,tabTitle:`${r.tabTitle} Copy`};h(p)}function m(p){const S=s.cards.filter(z=>z.id!==p),f=S[0],j={...s,cards:S,activeCardId:f.id};l(j),x(f)}function b(p){const S={...s,cards:s.cards.map(j=>j.id===r.id?r:j),activeCardId:p};l(S);const f=S.cards.find(j=>j.id===p);x(f),f.sql&&f.data&&f.data.length===0&&c(!0)}const w=(p,S)=>{console.log("handleDragStart",S),p.dataTransfer.setData("tabIndex",S.toString())},C=p=>{p.preventDefault()},T=(p,S)=>{const f=p.dataTransfer.getData("tabIndex");if(f===S.toString())return;const j=Array.from(s.cards),[z]=j.splice(parseInt(f),1);j.splice(S,0,z),l({...s,cards:j})};function R(p,S){return p.cards.length===1&&(S.displayTab===!0||S.displayTab===void 0)||p.activeCardId!==S.id&&(S.displayTab===!0||S.displayTab===void 0)?null:e.jsxRuntimeExports.jsx("div",{onClick:()=>{const f=S.displayTab===void 0?!1:!S.displayTab;x({...S,displayTab:f}),d({...S,displayTab:f})},children:S.displayTab===!0||S.displayTab===void 0?e.jsxRuntimeExports.jsx(es,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"}):e.jsxRuntimeExports.jsx(Ze,{className:"mr-2 size-3.5 text-muted-foreground hover:text-foreground"})})}function L(){return e.jsxRuntimeExports.jsxs(e.Tabs,{onValueChange:b,value:s.activeCardId,className:"flex grow flex-col",children:[s.cards.map(p=>e.jsxRuntimeExports.jsx(e.TabsContent,{className:"mt-0 grow",value:p.id,children:I()},p.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((p,S)=>e.jsxRuntimeExports.jsx(e.Editable,{text:p.tabTitle||p.title,onSave:f=>{x({...r,tabTitle:f}),d({...r,tabTitle:f})},children:e.jsxRuntimeExports.jsxs(e.TabsTrigger,{draggable:!0,onDragStart:f=>w(f,S),onDragOver:C,onDrop:f=>T(f,S),className:"",value:p.id,children:[R(s,p),p.tabTitle||p.title,s.activeCardId===p.id&&s.cards.length>1&&e.jsxRuntimeExports.jsx(e.X,{className:"ml-2 size-3.5 text-muted-foreground hover:text-foreground",onClick:()=>m(p.id)})]})},p.id)),e.jsxRuntimeExports.jsx(e.Button,{className:"ml-1 h-8 px-2 hover:bg-muted-foreground/50",variant:"outline",onClick:g,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:u,children:e.jsxRuntimeExports.jsx(Je,{className:"h-4 w-4"})})]})})]})}function I(){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,{isLoading:o,card:r})})}):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.TextCard,{isLoading:o,card:r})})}):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:[o&&e.jsxRuntimeExports.jsx(le,{className:"absolute bottom-0 left-0 right-0 top-0 z-10 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:[n&&e.jsxRuntimeExports.jsxs("div",{className:"flex grow items-center gap-2",children:[e.jsxRuntimeExports.jsx(ht,{}),!["table","custom"].includes(r.type)&&e.jsxRuntimeExports.jsx(mt,{}),e.jsxRuntimeExports.jsx(ft,{})]}),e.jsxRuntimeExports.jsx(Rt,{})]}),n?L():e.jsxRuntimeExports.jsxs("div",{className:"flex min-h-0 w-full flex-1 grow basis-0 px-6",children:[i&&e.jsxRuntimeExports.jsx(gt,{}),r.data&&r.data.length>0&&e.jsxRuntimeExports.jsx(ut,{data:t||[]}),a&&e.jsxRuntimeExports.jsx("span",{className:"font-mono text-sm",children:a})]})]})}function gt(){const s=e.useEditorStore(t=>t.pythonStdOut);if(!s)return null;const r=s.replace(/\n/g,"<br>");return e.jsxRuntimeExports.jsxs(e.jsxRuntimeExports.Fragment,{children:[e.jsxRuntimeExports.jsx("p",{className:"font-mono text-sm",children:"Output:"}),e.jsxRuntimeExports.jsx("div",{dangerouslySetInnerHTML:{__html:r},className:"bg-muted p-2 font-mono text-sm"}),e.jsxRuntimeExports.jsx(e.Separator,{className:"mb-2"})]})}function Rt(){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 bt({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 de({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(a=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:a.value,children:a.label},a.value))]})})]})}function Ge({children:s,summary:r}){return e.jsxRuntimeExports.jsxs("details",{className:"space-y-4 [&_summary>svg]:open:-rotate-180",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 yt(){var b,w;const s=e.useEditorStore(C=>C.card.customCardPreferences),{data:r}=zs(),t=(r==null?void 0:r.plugins)||[],n=e.useEditorStore(C=>C.card),o=e.useEditorStore(C=>C.frame),a=(s==null?void 0:s.visualType)||"single",{setCustomCardPreferences:i}=e.useEditorActions(),{components:c,manifest:l}=e.useCustomVisual((s==null?void 0:s.url)||""),x=(b=l==null?void 0:l.visuals)==null?void 0:b.find(C=>C.name===(s==null?void 0:s.componentName));function d(C,T){if(!s)return;const L={...(s==null?void 0:s.dataInputCardIds)||{},[C]:{cardId:T,hookRef:null}};i({...s,dataInputCardIds:L})}function g(C){var R,L;const T=(R=o==null?void 0:o.cards)==null?void 0:R.filter(I=>{var p;return((p=I==null?void 0:I.customCardPreferences)==null?void 0:p.visualType)!=="multiple"}).map(I=>({value:I.id,label:I.tabTitle||I.title}));return e.jsxRuntimeExports.jsx("div",{className:"space-y-2",children:(L=C==null?void 0:C.dataInputs)==null?void 0:L.map((I,p)=>{var S,f;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:I}),e.jsxRuntimeExports.jsx(de,{className:"col-span-6 h-8 w-full justify-between",label:"",options:T||[],value:((f=(S=s==null?void 0:s.dataInputCardIds)==null?void 0:S[p])==null?void 0:f.cardId)||"",onValueChange:j=>d(p,j)})]},p+Math.random())})})}function h(C,T,R=[]){var L,I;return s?C==="input"?e.jsxRuntimeExports.jsx(e.Input,{className:`h-8 w-full ${e.removeRing}`,value:((L=s==null?void 0:s.settings)==null?void 0:L[T])||"",onChange:p=>{i({...s,settings:{...s==null?void 0:s.settings,[T]:p.target.value}})}},T):C==="select"?e.jsxRuntimeExports.jsx(de,{className:"h-8 w-full",label:"",options:R,value:((I=s==null?void 0:s.settings)==null?void 0:I[T])||"",onValueChange:p=>{i({...s,settings:{...s==null?void 0:s.settings,[T]:p}})}}):null:null}function u(C){const T=Object.entries((C==null?void 0:C.settings)||{});return e.jsxRuntimeExports.jsx("div",{className:"space-y-3",children:T.map(([R,L])=>e.jsxRuntimeExports.jsxs("div",{className:"space-y-2",children:[e.jsxRuntimeExports.jsx(e.Label,{children:L.title}),h(L.ui,R,L.options)]},R))})}function m(C){s&&i({...s,visualType:C,componentName:""})}return e.jsxRuntimeExports.jsxs("div",{className:"p-6",children:[e.jsxRuntimeExports.jsx(Ge,{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(de,{className:"h-8 w-full",label:"",options:t,value:(s==null?void 0:s.url)||"",onValueChange:C=>i({...s||{url:"",componentName:""},url:C})})})}),((s==null?void 0:s.type)==="component"||(s==null?void 0:s.type)===void 0)&&e.jsxRuntimeExports.jsx(bt,{options:[{value:"single",label:"Single Visual"},{value:"multiple",label:"Multi-Visual"}],value:a,onValueChange:m}),((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:c&&e.jsxRuntimeExports.jsx(de,{className:"h-8 w-full",label:"",options:(c==null?void 0:c.filter(C=>C.type===a).map(C=>({value:C.name,label:C.name})))||[],value:s.componentName,onValueChange:C=>{console.log("changing value",C),i({...s,componentName:C})}})})]})})]})})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-4"}),((w=n==null?void 0:n.customCardPreferences)==null?void 0:w.componentName)&&e.jsxRuntimeExports.jsxs(Ge,{summary:"Component Settings",children:[x&&x.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:g(x)})]}),x&&x.settings&&e.jsxRuntimeExports.jsx("div",{className:"space-y-3",children:e.jsxRuntimeExports.jsx("div",{className:"px-2",children:u(x)})})]})]})}function ce(){const[s,r]=v.useState([]);e.useEditorStore(d=>d.card.cfg);const t=e.useEditorStore(d=>d.card.preferences),{setCardCfg:n,setFilterOnClickColumnIndex:o,setCardPreferences:a}=e.useEditorStore(d=>d.actions),i=e.useEditorStore(d=>d.queryResultColumns);e.useEditorStore(d=>{var g;return(g=d.card.preferences)==null?void 0:g.filterOnClickColumnIndex}),v.useEffect(()=>{i&&r(new Array(i.length).fill(!1))},[i]);function c(d,g){var h,u;g?t!=null&&t.onClickFilter&&((h=t==null?void 0:t.onClickFilter)==null?void 0:h.length)>0?a({...t,onClickFilter:[...t.onClickFilter,{columnIndex:d,expression:""}]}):a({...t,onClickFilter:[{columnIndex:d,expression:""}]}):(a({...t,onClickFilter:(u=t==null?void 0:t.onClickFilter)==null?void 0:u.filter(m=>m.columnIndex!==d)}),r(m=>{const b=[...m];return b[d]=!1,b}))}function l(d,g){var u;const h=(u=t==null?void 0:t.onClickFilter)==null?void 0:u.map(m=>m.columnIndex===d?{...m,expression:g.target.value}:m);a({...t,onClickFilter:h})}function x(d){var g,h,u,m;if(s!=null&&s[d]||(h=(g=t==null?void 0:t.onClickFilter)==null?void 0:g.find(b=>b.columnIndex===d))!=null&&h.expression)return e.jsxRuntimeExports.jsx(e.Input,{value:(m=(u=t==null?void 0:t.onClickFilter)==null?void 0:u.find(b=>b.columnIndex===d))==null?void 0:m.expression,onChange:b=>l(d,b),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"}),i==null?void 0:i.map((d,g)=>{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(m=>m.columnIndex===g)),onCheckedChange:m=>c(g,m)}),e.jsxRuntimeExports.jsx("label",{className:"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",children:d}),e.jsxRuntimeExports.jsx("div",{className:"flex items-center gap-2",children:((u=t==null?void 0:t.onClickFilter)==null?void 0:u.find(m=>m.columnIndex===g))&&e.jsxRuntimeExports.jsx(Fe,{onClick:()=>{r(m=>{const b=[...m];return b[g]=!m[g],b})},className:"invisible size-3 cursor-pointer text-gray-400 group-hover:visible"})})]}),x(g)]})},d)})]})}function ve(){var i,c,l;const s=e.useEditorStore(x=>x.card.preferences),r=e.useEditorStore(x=>x.card.cfg),{setCardCfg:t,setCardPreferences:n,setChartOrientation:o}=e.useEditorStore(x=>x.actions);(i=r==null?void 0:r.options)!=null&&i.indexAxis;function a(x){o(x)}return e.jsxRuntimeExports.jsxs(e.RadioGroup,{value:((c=s==null?void 0:s.chartOptions)==null?void 0:c.indexAxis)||((l=r==null?void 0:r.options)==null?void 0:l.indexAxis)||"x",onValueChange:a,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 Ee="focus-visible:ring-0 focus-visible:ring-ring focus-visible:ring-offset-0";function Ue(s,r){var n,o,a;const t=e.getNumberAxis(s,r);return((a=(o=(n=s==null?void 0:s.chartOptions)==null?void 0:n.scales)==null?void 0:o[t])==null?void 0:a.type)||"linear"}function Fs(){var K,q,W,N,A,H;const[s,r]=v.useState(!1),t=e.useEditorStore(D=>{var k;return(k=D.card)==null?void 0:k.preferences}),n=e.useEditorStore(D=>{var k;return(k=D.card)==null?void 0:k.cfg}),o=e.getNumberAxis(t,n),[a,i]=v.useState(Ue(t)),[c,l]=v.useState(((W=(q=(K=t==null?void 0:t.chartOptions)==null?void 0:K.scales)==null?void 0:q[o])==null?void 0:W.min)||""),[x,d]=v.useState(((H=(A=(N=t==null?void 0:t.chartOptions)==null?void 0:N.scales)==null?void 0:A[o])==null?void 0:H.max)||""),[g,h]=v.useState(c||x?"custom":"auto"),[u,m]=v.useState(""),[b,w]=v.useState(0),[C,T]=v.useState(""),[R,L]=v.useState(""),[I,p]=v.useState(""),S=e.useEditorStore(D=>D.actions.setCardPreferences),{updateCardInFrame:f}=e.useEditorActions(),j=e.useEditorStore(D=>D.card),z=e.useEditorStore(D=>{var k;return(k=D.card)==null?void 0:k.type}),O=["pie","doughnut","polarArea"].includes(z);v.useEffect(()=>{var D,k,$,M,G,U,te,ee,B,J,Y,ne,X,se;i(Ue(t)),l((($=(k=(D=t==null?void 0:t.chartOptions)==null?void 0:D.scales)==null?void 0:k[o])==null?void 0:$.min)===0?0:""),d(((U=(G=(M=t==null?void 0:t.chartOptions)==null?void 0:M.scales)==null?void 0:G[o])==null?void 0:U.max)||""),m(((J=(B=(ee=(te=t==null?void 0:t.chartOptions)==null?void 0:te.scales)==null?void 0:ee[o])==null?void 0:B.ticks)==null?void 0:J.stepSize)||""),w(((Y=t==null?void 0:t.numberAxisFormat)==null?void 0:Y.decimalPlaces)||0),T(((ne=t==null?void 0:t.numberAxisFormat)==null?void 0:ne.suffix)||""),L(((X=t==null?void 0:t.numberAxisFormat)==null?void 0:X.currency)||""),p(((se=t==null?void 0:t.numberAxisFormat)==null?void 0:se.locale)||"")},[s,t,o]);function F(D,k){return k===""||/^[0-9\b]+$/.test(k)?Number(k):Number(D)}function V(){const D=[...new Set(e.LOCALE_CURRENCY_PAIRS.map(k=>k.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:R||"none",onValueChange:k=>L(k==="none"?"":k),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"}),D.map(k=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:k,children:k},k))]})})]}),e.jsxRuntimeExports.jsxs(e.Select,{value:I,onValueChange:k=>p(k),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(k=>e.jsxRuntimeExports.jsx(e.SelectItem,{value:k.locale,children:k.locale},k.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:b,onChange:k=>w(Number(k.target.value)),id:"format",className:`col-span-6 h-8 w-full tracking-wide ${Ee}`})]})]})}function P(){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:c,onChange:D=>l(k=>F(k,D.target.value)),className:`col-span-1 h-8 w-full ${Ee}`}),e.jsxRuntimeExports.jsx(e.Input,{value:x,onChange:D=>d(k=>F(k,D.target.value)),id:"max",className:`col-span-1 h-8 w-full ${Ee}`})]}),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:D=>m(k=>F(k,D.target.value)),id:"step-size",className:`col-span-1 h-8 w-full ${Ee}`})]})]})}function _(){var M;let D={};g==="custom"&&(D={min:c,max:x,ticks:{stepSize:u}});const k={...t||{},chartOptions:{...t==null?void 0:t.chartOptions,scales:{...(M=t==null?void 0:t.chartOptions)==null?void 0:M.scales,[o]:{type:a,...a==="linear"?D:{}}}},numberAxisFormat:{decimalPlaces:b,suffix:C,currency:R,locale:I}};console.log(k),S(k);const $={...j,preferences:k};f($)}return e.jsxRuntimeExports.jsxs(e.Popover,{onOpenChange:D=>r(D),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:O,value:a,onValueChange:D=>i(D),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"})]})})]})]}),a=="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:O,id:"scale-option",value:g,onValueChange:D=>h(D),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"})]})]})]}),g==="custom"&&a=="linear"&&P(),V(),e.jsxRuntimeExports.jsx(e.SelectSeparator,{}),e.jsxRuntimeExports.jsx("div",{className:"grid grid-cols-3",children:e.jsxRuntimeExports.jsx(e.Button,{onClick:_,variant:"secondary",className:"col-span-1 col-start-3 h-8 w-full",children:"Apply"})})]})]})})]})}function St({idx:s}){var c;const r=e.useEditorStore(l=>{var x;return(x=l.card)==null?void 0:x.preferences}),t=e.useEditorStore(l=>{var x;return(x=l.card.preferences)==null?void 0:x.datasetOptions}),n=e.useEditorStore(l=>l.actions.setCardPreferences),o=(c=r==null?void 0:r.chartOptions)==null?void 0:c.indexAxis,a=t==null?void 0:t.find(l=>l.idx===s);function i(l,x){(l==="end"||l==="start")&&e.getContrastColor(e.getCanvasBackgroundColor());const d={display:l!=="none",align:l,anchor:l,clamp:!0};if(!a)n({...r,datasetOptions:[...t||[],{idx:x,datalabels:d}]});else{const g={...a};g.datalabels=d;const h=t==null?void 0:t.map(u=>u.idx===x?g:u);n({...r,datasetOptions:h})}}return e.jsxRuntimeExports.jsxs(e.Popover,{children:[e.jsxRuntimeExports.jsx(e.PopoverTrigger,{children:e.jsxRuntimeExports.jsx(hs,{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:()=>i("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:()=>i("start",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(os,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>i("center",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(as,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})}),e.jsxRuntimeExports.jsx(e.Button,{onClick:()=>i("end",s),size:"sm",variant:"secondary",className:"h-7 p-1 text-xs font-normal",children:e.jsxRuntimeExports.jsx(is,{className:e.cn("h-4 w-4",{"rotate-90":o==="y"})})})]})})]})}function Ms(){const s=e.useEditorStore(l=>l.card),r=e.useEditorStore(l=>{var x,d,g;return(g=(d=(x=l==null?void 0:l.card)==null?void 0:x.preferences)==null?void 0:d.chartOptions)==null?void 0:g.indexAxis}),t=r==="y"?"Y axis":"X axis",n=r==="y"?"X axis":"Y axis",{keys:o,metricKeys:a,dimensionKeys:i}=e.getKeys(s.data||[]);let c=a;if(["stackedBar","stackedLine"].includes(s.type)){const l=e.pivotData({dataArray:s.data||[],groupKey:i[0],pivotKey:i[1],valueKey:c[0]}),{metricKeys:x}=e.getKeys(l);c=x}return o.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:t}),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:i[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:n}),e.jsxRuntimeExports.jsx(Fs,{})]}),e.jsxRuntimeExports.jsx("div",{className:"my-1 space-y-1",children:c.map((l,x)=>e.jsxRuntimeExports.jsx(vt,{col:l,idx:x},l))})]})]})}function vt({col:s,idx:r}){const t=e.useEditorStore(c=>{var l;return(l=c.card)==null?void 0:l.preferences}),n=e.useEditorStore(c=>{var l;return(l=c.card.preferences)==null?void 0:l.datasetOptions}),o=n==null?void 0:n.find(c=>c.idx===r),{setCardPreferences:a}=e.useEditorStore(c=>c.actions);function i(c){if(!o)a({...t,datasetOptions:[...n||[],{idx:r,type:c==="area"?"line":c,fill:c==="area"?"origin":""}]});else{const l={...o};l.type=c==="area"?"line":c,l.fill=c==="area"?"origin":"";const x=n==null?void 0:n.map(d=>d.idx===r?l:d);a({...t,datasetOptions:x})}}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(be,{onClick:()=>i("bar"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx(ye,{onClick:()=>i("line"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx(Ke,{onClick:()=>i("area"),className:"invisible size-4 cursor-pointer text-muted-foreground hover:text-foreground group-hover:visible"}),e.jsxRuntimeExports.jsx(e.Separator,{orientation:"vertical",className:"invisible size-4 cursor-pointer py-2 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),a=e.useDashboardStore(h=>h.dashboard.filters)||[],i=e.useDashboardStore(h=>h.actions.addFilter),c=e.useDashboardStore(h=>h.actions.removeFilter),l=e.useDashboardStore(h=>h.actions.removeFilterValue),{modelItems:x,tableName:d}=oe();function g(h,u="dashboard"){var p;const m=e.fmt(h.column_name),b=e.fmt(t||""),w=e.fmt(n||""),C=e.fmt(d);let T=e.getQualifiedTableName(w,C),R=`${T}.${m}`;const L=(p=x==null?void 0:x.find(S=>S.id===r))==null?void 0:p.name;r&&r!=="none"&&(R=`${e.DATAMODEL_NAMESPCACE}.${L}.${m}`,T=`${e.DATAMODEL_NAMESPCACE}.${L}`);const I=a==null?void 0:a.find(S=>S.column===R&&S.table===C&&(S.database===b||S.database===t));if(I)l(I.id),c(I.id);else{const S=e.v4();return d==="api"&&s?(i({location:u,id:S,column:R,title:h.column_name,dataType:h.data_type,table:"api",database:"",connectionId:s,operation:"in",sql:e.getDefaultFilterSql(h.data_type,T,m)}),S):(i({id:S,location:u,column:R,title:h.column_name,dataType:h.data_type,table:o||"",database:t||"",connectionId:s||"",operation:"in",sql:e.getDefaultFilterSql(h.data_type,T,m)}),S)}}return{assignFilter:g}}function xe(){const s=e.useDashboardStore(c=>c.dashboard.filters),r=e.useEditorStore(c=>c.frame),{setFrame:t}=e.useEditorActions(),{columns:n}=oe(),{assignFilter:o}=Os();function a(c){const l=o(c,"frame");t({...r,filterId:l})}const i=s==null?void 0:s.find(c=>c.id===r.filterId);return e.jsxRuntimeExports.jsxs("div",{className:"space-y-3",children:[e.jsxRuntimeExports.jsx(e.Label,{children:"Card Filter"}),e.jsxRuntimeExports.jsx(Ct,{onSelect:a,columns:n}),i&&e.jsxRuntimeExports.jsx(e.FilterHeader,{filter:i})]})}function Ct({columns:s,onSelect:r}){var i;const[t,n]=Be.useState(!1),[o,a]=Be.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?(i=s.find(c=>c.column_name===o))==null?void 0:i.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(c=>e.jsxRuntimeExports.jsxs(e.CommandItem,{value:c.column_name,onSelect:l=>{const x=l===o?"":l;a(x),n(!1),x&&r(c)},children:[c.column_name,e.jsxRuntimeExports.jsx(e.CheckIcon,{className:e.cn("ml-auto h-4 w-4",o===c.column_name?"opacity-100":"opacity-0")})]},c.column_name))})]})]})})]})}function Nt({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(ve,{}),e.jsxRuntimeExports.jsx(Ms,{})]})]}),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(ce,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function Ve(){var o,a,i;const s=e.useEditorStore(c=>c.card.cfg),r=e.useEditorStore(c=>c.actions.setCardCfg),t=e.useEditorStore(c=>c.card.type);function n(c){var d;const l={datalabels:{display:c!=="none",align:c,anchor:c,clamp:!0}},x={...s,options:{...s==null?void 0:s.options,plugins:{...(d=s==null?void 0:s.options)==null?void 0:d.plugins,...l}}};r(x),console.log(c)}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(Fs,{})]}),e.jsxRuntimeExports.jsxs(e.Select,{value:(i=(a=(o=s==null?void 0:s.options)==null?void 0:o.plugins)==null?void 0:a.datalabels)==null?void 0:i.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 wt({cardType:s}){function r(t){const n="SELECT label, [group], x-axis, y-axis, radius FROM table",o="SELECT label, [group], x-axis, y-axis FROM table";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"?n:o}),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:a=>a.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(Ve,{})})]}),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(ce,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}const kt={datasets:[{type:"line",label:"Sum_sales",data:[]},{type:"bar",label:"Sum_profit",data:[]}]},It={datasets:[{fill:"origin",type:"line",label:"Sum_sales",data:[]}]};function Dt(){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:Lt(s)}),e.jsxRuntimeExports.jsx("section",{className:"",children:["line","bar"].includes(s)&&e.jsxRuntimeExports.jsx(ve,{})}),!["kpi"].includes(s)&&e.jsxRuntimeExports.jsxs("div",{className:"space-y-4",children:[e.jsxRuntimeExports.jsx(Ve,{}),e.jsxRuntimeExports.jsx(ce,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})}function Lt(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(kt,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(It,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 Tt(){var l,x,d,g,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 m,b;return(b=(m=u.card.preferences)==null?void 0:m.formatNumber)==null?void 0:b.decimalPlaces});const n=e.useEditorStore(u=>{var m,b;return(b=(m=u.card.preferences)==null?void 0:m.formatNumber)==null?void 0:b.locale}),o=e.useEditorStore(u=>{var m,b;return(b=(m=u.card.preferences)==null?void 0:m.formatNumber)==null?void 0:b.currency});e.useEditorStore(u=>u.actions.setFilterOnClickField);const a=e.useEditorStore(u=>{var m,b;return(b=(m=u.card.preferences)==null?void 0:m.formatNumber)==null?void 0:b.colorRanges})||[],i=e.useEditorStore(u=>u.actions.setColorRanges),c=[...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:!!((l=s==null?void 0:s.formatNumber)!=null&&l.enabled),onCheckedChange:u=>{r({...s,formatNumber:{...s==null?void 0:s.formatNumber,enabled:u}})}}),e.jsxRuntimeExports.jsx(e.Label,{children:"Format Number"})]}),((x=s==null?void 0:s.formatNumber)==null?void 0:x.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||"en-US",onValueChange:u=>{var m,b,w;return t(((m=s==null?void 0:s.formatNumber)==null?void 0:m.decimalPlaces)||0,((b=s==null?void 0:s.formatNumber)==null?void 0:b.currency)||"",u||"en-US",((w=s==null?void 0:s.formatNumber)==null?void 0:w.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.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 m,b,w;return t(((m=s==null?void 0:s.formatNumber)==null?void 0:m.decimalPlaces)||0,u==="none"?"":u,((b=s==null?void 0:s.formatNumber)==null?void 0:b.locale)||"",((w=s==null?void 0:s.formatNumber)==null?void 0:w.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"),c.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:((g=(d=s==null?void 0:s.formatNumber)==null?void 0:d.decimalPlaces)==null?void 0:g.toString())||"0",onValueChange:u=>{var m,b,w;return t(Number(u),((m=s==null?void 0:s.formatNumber)==null?void 0:m.currency)||"",((b=s==null?void 0:s.formatNumber)==null?void 0:b.locale)||"",((w=s==null?void 0:s.formatNumber)==null?void 0:w.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 m,b,w;return t(((m=s==null?void 0:s.formatNumber)==null?void 0:m.decimalPlaces)||0,((b=s==null?void 0:s.formatNumber)==null?void 0:b.currency)||"",((w=s==null?void 0:s.formatNumber)==null?void 0:w.locale)||"",u.target.value)}})]})]})]})}),e.jsxRuntimeExports.jsx(e.Separator,{className:"my-3"}),e.jsxRuntimeExports.jsx(e.ColorFormat,{colorRanges:a,setColorRanges:i})]})]})}function At(){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(Tt,{})}),e.jsxRuntimeExports.jsx("div",{}),e.jsxRuntimeExports.jsx("div",{})]})}function zt(){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 fe({cardType:s,docContent:r,suffix:t="Chart"}){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)} ${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:n=>n.stopPropagation(),className:"text-blue-700",href:"https://docs.semaphor.cloud/concepts/visuals#pie-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:[s==="range"&&e.jsxRuntimeExports.jsx(ve,{}),s!=="text"&&e.jsxRuntimeExports.jsx(Ve,{}),s==="text"&&e.jsxRuntimeExports.jsx(zt,{})]})]}),!["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(ce,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function Ft(){const s=e.useEditorStore(n=>{var o,a;return(a=(o=n==null?void 0:n.card)==null?void 0:o.preferences)==null?void 0:a.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(de,{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(ve,{}),t(),e.jsxRuntimeExports.jsx(Ms,{})]})]}),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(ce,{}),e.jsxRuntimeExports.jsx(xe,{})]})]})]})})}function Mt({}){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(ce,{}),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 Ot=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."]})]}),Vt=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."]})]}),qt=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(Ft,{});case"pyramid":return e.jsxRuntimeExports.jsx(fe,{docContent:Ot,cardType:t});case"kpi":return e.jsxRuntimeExports.jsx(At,{});case"line":case"bar":return e.jsxRuntimeExports.jsx(Nt,{cardType:t});case"range":return e.jsxRuntimeExports.jsx(fe,{docContent:Vt,cardType:t});case"pie":case"doughnut":case"polarArea":case"radar":return e.jsxRuntimeExports.jsx(fe,{cardType:t});case"bubble":case"scatter":return e.jsxRuntimeExports.jsx(wt,{cardType:t});case"table":return e.jsxRuntimeExports.jsx(Mt,{cardType:t});case"text":return e.jsxRuntimeExports.jsx(fe,{docContent:qt,cardType:t,suffix:"Visual"});case"custom":return e.jsxRuntimeExports.jsx(yt,{});default:return e.jsxRuntimeExports.jsx(Dt,{})}}return e.jsxRuntimeExports.jsx(e.ScrollArea,{className:"h-full w-full text-sm",children:r(s)})}function Bt(){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(xt,{})}),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 Ht({authToken:s,onSave:r,onClose:t}){e.useDashboardStore(i=>i.themeStyle);const n=e.useEditorStore(i=>i.actions.setOnSave),o=e.useEditorStore(i=>i.actions.setOnClose),a=e.useDashboardStore(i=>i.actions.setAuthToken);return v.useEffect(()=>{r&&n(r),t&&o(t)},[r,n,t,o]),v.useEffect(()=>{s&&s.accessToken&&a(s)},[s,a]),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(bs,{})}),e.jsxRuntimeExports.jsx(e.EditorMain,{children:e.jsxRuntimeExports.jsx(Bt,{})})]})})}function Pt(){e.useDashboardStore(i=>i.selectedCardId);const s=e.useDashboardStore(i=>i.selectedSheetId),{setIsVisualEditing:r}=e.useDashboardStore(i=>i.actions),t=e.useDashboardStore(i=>i.isVisualEditing),n=e.useDashboardStore(i=>i.actions.updateFrame);function o(i){s&&(n(s,i),r(!1))}function a(){r(!1)}return e.jsxRuntimeExports.jsx("div",{role:"editor-container",className:e.cn("flex grow",{block:t,hidden:!t}),children:e.jsxRuntimeExports.jsx(Ht,{onSave:o,onClose:a})})}function $t(){e.useEditorStore(i=>i.selectedConnectionId),e.useEditorStore(i=>i.selectedDatamodelId);const s=e.useEditorStore(i=>i.selectedDatabaseName);e.useEditorStore(i=>i.selectedSchemaName);const r=e.useEditorStore(i=>i.selectedTableName),t=e.useDashboardStore(i=>i.dashboard.filters)||[];e.useDashboardStore(i=>i.actions.addFilter),e.useDashboardStore(i=>i.actions.removeFilter),e.useDashboardStore(i=>i.actions.removeFilterValue);const{modelItems:n,columns:o}=oe(),{assignFilter:a}=Os();return e.jsxRuntimeExports.jsx("div",{className:"xbg-red-100 flex-1 basis-0 flex-col overflow-scroll px-3",children:o==null?void 0:o.map(i=>{const c=t==null?void 0:t.find(l=>l.column===e.fmt(i.column_name)&&l.table===r&&l.database===s);return e.jsxRuntimeExports.jsx("div",{onClick:()=>a(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":c}),children:e.jsxRuntimeExports.jsxs("div",{className:"flex items-center gap-2",children:[e.jsxRuntimeExports.jsx(Rs,{column:i}),e.jsxRuntimeExports.jsx("span",{children:i.column_name})]})},i.column_name)})})}function Gt(){e.useDashboardStore(r=>r.showFilters);const s=e.useDashboardStore(r=>r.actions.setShowFilters);return e.jsxRuntimeExports.jsxs("section",{className:"relative flex grow flex-col border-l px-4",children:[e.jsxRuntimeExports.jsxs("div",{className:"mt-4 flex items-center justify-between gap-2 px-3",children:[e.jsxRuntimeExports.jsx(e.Label,{className:"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(bs,{ColumnsComponent:()=>e.jsxRuntimeExports.jsx($t,{})})})]})}function Ut(){const s=e.useDashboardStore(t=>t.showFilters),r=e.useDashboardStore(t=>t.isVisualEditing);return e.jsxRuntimeExports.jsxs("div",{role:"dashboard-plus-main",className:e.cn("grow",{hidden:r,flex:!r}),children:[e.jsxRuntimeExports.jsx(e.DashboardTabs,{}),s&&e.jsxRuntimeExports.jsx("div",{role:"filter-aside-container",className:"flex",children:e.jsxRuntimeExports.jsx(Gt,{})})]})}function Qt(){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 Kt({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.Te,{}),e.jsxRuntimeExports.jsxs(e.UXProvider,{children:[e.jsxRuntimeExports.jsx(Qt,{}),e.jsxRuntimeExports.jsxs(e.DashboardPanel,{...t,children:[s&&e.jsxRuntimeExports.jsx(Us,{}),e.jsxRuntimeExports.jsx(Pt,{}),e.jsxRuntimeExports.jsx(Ut,{})]})]})]})})}exports.Box=Qe;exports.ChartArea=Ke;exports.ChartColumnIncreasing=be;exports.ChartLine=ye;exports.ChartNoAxesGantt=De;exports.ChartPie=Le;exports.ChartScatter=Te;exports.CircleX=We;exports.CopyPlus=Je;exports.DashboardPlus=Kt;exports.Database=Ye;exports.EllipsisVertical=Ae;exports.Eraser=Xe;exports.Eye=es;exports.EyeClosed=Ze;exports.Glasses=ss;exports.Hammer=ts;exports.Hash=ns;exports.House=rs;exports.Key=ze;exports.ListEnd=os;exports.ListStart=is;exports.ListX=as;exports.LoaderCircle=le;exports.MessageSquareMore=ls;exports.Network=cs;exports.Pencil=Fe;exports.Play=xs;exports.Plug2=us;exports.Save=ds;exports.SelectComponent=ae;exports.Shapes=Me;exports.ShieldQuestion=ms;exports.Sigma=ps;exports.SwatchBook=js;exports.Tag=hs;exports.ToggleLeft=Es;exports.Type=Se;exports.User=fs;exports.cleanCard=gs;exports.getDashbaordStateWithoutData=Oe;exports.useEditorAside=oe;