@devtable/dashboard 13.27.9-beta.1 → 13.27.10
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.
- package/dist/dashboard.es.js +3 -3
- package/dist/dashboard.umd.js +3 -3
- package/dist/stats.html +1 -1
- package/dist/version.json +2 -2
- package/package.json +1 -1
package/dist/dashboard.es.js
CHANGED
|
@@ -6126,7 +6126,7 @@ class vl {
|
|
|
6126
6126
|
}), this.instanceRegistry.clear(), this.factoryRegistry.clear();
|
|
6127
6127
|
}
|
|
6128
6128
|
}
|
|
6129
|
-
const gp = "13.27.
|
|
6129
|
+
const gp = "13.27.10", Cw = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
6130
6130
|
__proto__: null,
|
|
6131
6131
|
version: gp
|
|
6132
6132
|
}, Symbol.toStringTag, { value: "Module" }));
|
|
@@ -19470,7 +19470,7 @@ const BD = {
|
|
|
19470
19470
|
} = e, o = T(() => {
|
|
19471
19471
|
const l = Pe({}, i, $a);
|
|
19472
19472
|
return l.content ? hp(l.content, s, t.payloadForViz, a) : "";
|
|
19473
|
-
}, [i, s, t.payloadForViz]);
|
|
19473
|
+
}, [a, i, s, t.payloadForViz]);
|
|
19474
19474
|
return o ? /* @__PURE__ */ r.jsx(Zi, { value: o, styles: {
|
|
19475
19475
|
root: {
|
|
19476
19476
|
border: "none",
|
|
@@ -21217,7 +21217,7 @@ const cE = D(({
|
|
|
21217
21217
|
} = e.viewport, h = T(() => {
|
|
21218
21218
|
const m = Pe({}, a, Go);
|
|
21219
21219
|
return m.content ? hp(m.content, c, s.payloadForViz, l) : "";
|
|
21220
|
-
}, [a, c, s.payloadForViz]), p = Ge(() => {
|
|
21220
|
+
}, [l, a, c, s.payloadForViz]), p = Ge(() => {
|
|
21221
21221
|
i.forEach((m) => {
|
|
21222
21222
|
n.runInteraction(m.id, {
|
|
21223
21223
|
variables: o.variableValueMap
|
package/dist/dashboard.umd.js
CHANGED
|
@@ -78,7 +78,7 @@ Check the top-level render call using <`+q+">.")}return A}}function Dg(C,A){{if(
|
|
|
78
78
|
${Object.entries(t).map(([s,i])=>`const ${s} = '${i}';`).join(`
|
|
79
79
|
`)}
|
|
80
80
|
return ${e};
|
|
81
|
-
`)(n)}catch(s){return console.error(s),console.log(e),e}}function yu(e,t,n,s){const i=Qy(t,s);return e.replaceAll(/(\{\{([^{\}]+(?=}))\}\})/g,(...l)=>{const c=l[2];if(!c)return c;const u=i[c];if(u)return u;const d=Uy(c);return Yy(d,i,n)})}function Ky(e,t){const n=dc.decode(t);n!==e&&(console.error("Inconsistent sql"),console.groupCollapsed("Inconsistent sql"),console.table({before:e,after:t,v:n}),console.groupEnd())}async function Xy({query:e,name:t,payload:n,additionals:s},i){if(!e.sql)return[];const{type:a,key:l,sql:c,pre_process:u,post_process:d}=e,h=ki(c,n),p=Im({sql:h,pre_process:u}),f=dc.encode(p);Ky(p,f);let m=await Qt.query(i)({type:a,key:l,query:f,...s},{params:{name:t}});return m=zm(d,m,Hi(n)),m}async function Jy({type:e,key:t,configString:n,name:s,additionals:i},a){try{return await Qt.httpDataSourceQuery(a)({type:e,key:t,query:n,...i},{params:{name:s}})}catch(l){if(Gt.isCancel(l))throw l;return console.error(l),l}}async function ea(){try{return(await Qt.post()("/datasource/list",{filter:{},sort:[{field:"create_time",order:"ASC"}],pagination:{page:1,pagesize:100}},{})).data}catch(e){return console.error(e),[]}}async function bu(){try{return(await Qt.post()("/sql_snippet/list",{filter:{},sort:[{field:"id",order:"ASC"}],pagination:{page:1,pagesize:1e3}},{})).data}catch(e){return console.error(e),[]}}class vu{constructor(t){N(this,"rootRef");this.rootRef=ae.observable({current:t})}async deleteItem(t){ae.runInAction(()=>{v.unset(this.rootRef.current,[t])})}getItem(t){const n=this.getValueFromRoot(t);return Promise.resolve(n)}getValueFromRoot(t){return t===null?ae.toJS(this.rootRef.current):v.get(this.rootRef.current,[t])}setItem(t,n){if(t===null)if(v.isObject(n))ae.runInAction(()=>{this.rootRef.current=n});else throw new Error("Cannot set root value to non-object");else ae.runInAction(()=>{v.set(this.rootRef.current,[t],n)});return Promise.resolve(this.getItem(t))}watchItem(t,n,s){return ae.reaction(()=>this.getValueFromRoot(t),(i,a)=>{n(i,a)},{requiresObservable:!0,fireImmediately:v.get(s,"fireImmediately",!1)})}}class Zy{constructor(){N(this,"channels",new Map);N(this,"globalChannel",new hc)}getChannel(t){const n=this.channels.get(t);if(n)return n;const s=new hc;return this.channels.set(t,s),s}}class Hy{constructor(t){N(this,"instances",new Map);this.pluginManager=t}get availableVizList(){return this.pluginManager.installedPlugins.flatMap(t=>t.manifest.viz)}resolveComponent(t){return this.pluginManager.factory.viz(t)}getOrCreateInstance(t){const n=this.instances.get(t.id);if(n)return n;const s={id:t.id,name:t.viz.type,type:t.viz.type,messageChannels:new Zy,instanceData:new vu(t.viz.conf)};return this.instances.set(t.id,s),s}}function _u(e,t,n,s){return{vizManager:n,locale:"zh",msgChannels:e.messageChannels,instanceData:e.instanceData,pluginData:new vu({}),colorPalette:{getColor(){return()=>""}},data:t,variables:s}}const eb=e=>{const{panel:t,measure:n,vizManager:s,data:i,variables:a}=e,l=s.resolveComponent(t.viz.type),c=s.getOrCreateInstance(t),u={..._u(c,i,s,a),viewport:{width:n.w,height:n.h}},d=l.viewRender;return r.jsx(d,{context:u,instance:c,...v.omit(e,["panel","vizManager","data"])})},tb=e=>{const{vizManager:t,panel:n,data:s,variables:i}=e,a=t.resolveComponent(n.viz.type),l=t.getOrCreateInstance(n),c={..._u(l,s,t,i)},u=a.configRender;return r.jsx(u,{context:c,instance:l,...v.omit(e,["panel","vizManager","data"])})},ju=(e,t)=>{const n=Rt.bezier(e),s=Rt.bezier(t);return function(i){return i<50?n(i*2/100).hex():s((i-50)*2/100).hex()}},ks=e=>{const t=Rt.bezier(e);return function(n){return t(n/100).hex()}},nb={type:"interpolation",displayName:"style.color.interpolation.palette.red_green",getColor:ju(["darkred","deeppink","lightyellow"],["lightyellow","lightgreen","teal"]),name:"red-green",category:"diverging"},rb={type:"interpolation",displayName:"style.color.interpolation.palette.yellow_blue",getColor:ju(["#8f531d","#ffd347","#e3efe3"],["#eefaee","#4ecbbf","#003f94"]),name:"yellow-blue",category:"diverging"},sb={type:"interpolation",displayName:"style.color.interpolation.palette.red",getColor:ks(["#fff7f1","darkred"]),name:"red",category:"sequential"},ib={type:"interpolation",displayName:"style.color.interpolation.palette.green",getColor:ks(["#f0ffed","darkgreen"]),name:"green",category:"sequential"},ab={type:"interpolation",displayName:"style.color.interpolation.palette.blue",getColor:ks(["#f9fcff","#48b3e9","darkblue"]),name:"blue",category:"sequential"},ob={type:"interpolation",displayName:"style.color.interpolation.palette.orange",getColor:ks(["#fff7f1","darkorange","#b60000"]),name:"orange",category:"sequential"};class lb{constructor(t){N(this,"symbol");this.symbol=Symbol(t)}}function an(e){return new lb(e)}class ta{constructor(){N(this,"parent");N(this,"factoryRegistry",new Map);N(this,"instanceRegistry",new Map)}createScoped(){const t=new ta;return t.parent=this,t}getRequired(t){return this.get(t)}get(t){if(this.instanceRegistry.has(t.symbol))return this.instanceRegistry.get(t.symbol);const n=this.factoryRegistry.get(t.symbol);if(n){const s=n(this);return this.instanceRegistry.set(t.symbol,s),s}if(this.parent)return this.parent.get(t)}provideFactory(t,n){return this.factoryRegistry.has(t.symbol)?console.warn(`Token ${t.symbol.toString()} is already registered`):this.factoryRegistry.set(t.symbol,n),this}provideValue(t,n){return this.factoryRegistry.has(t.symbol)?console.warn(`Token ${t.symbol.toString()} is already registered`):this.factoryRegistry.set(t.symbol,()=>n),this}dispose(){this.instanceRegistry.forEach(t=>{const n=v.get(t,"dispose");v.isFunction(n)&&n.bind(t)()}),this.instanceRegistry.clear(),this.factoryRegistry.clear()}}const wu="13.27.9-beta.1",cb=Object.freeze(Object.defineProperty({__proto__:null,version:wu},Symbol.toStringTag,{value:"Module"}));class ub{constructor(t){N(this,"staticColors",new Map);N(this,"interpolations",new Map);t.installedPlugins.forEach(n=>{n.manifest.color.forEach(s=>{this.register(s)})})}getStaticColors(){return Array.from(this.staticColors.values())}register(t){const n=this.encodeColor(t);t.type==="single"?(this.staticColors.has(n)&&console.warn(`the color '${t.name}' has been registered under '${t.category}', previous registered value will be overridden`),this.staticColors.set(n,t)):t.type==="interpolation"&&(this.interpolations.has(n)&&console.warn(`the interpolation '${t.name}' has been registered under '${t.category}', previous registered value will be overridden`,`the interpolation '${t.name}' has been registered under '${t.category}', previous registered value will be overridden`),this.interpolations.set(n,t))}decodeStaticColor(t){return this.staticColors.get(t)}encodeColor(t){return`\${${t.category}}.{${t.name}}`}decodeInterpolation(t){return this.interpolations.get(t)}getColorInterpolations(){return Array.from(this.interpolations.values())}}class db{constructor(){N(this,"plugins",new Map);N(this,"vizComponents",new Map);N(this,"factory",{viz:t=>{const n=this.vizComponents.get(t);if(n)return n;throw new Error(`Viz Component (${t}) not found`)}})}install(t){if(this.plugins.has(t.id))throw new Error(`Plugin (${t.id}) has been installed before`);this.plugins.set(t.id,t);for(const n of t.manifest.viz){if(this.vizComponents.has(n.name))throw new Error(`Viz Component (${n.name}) has been installed before`);this.vizComponents.set(n.name,n)}}get installedPlugins(){return Array.from(this.plugins.values())}}class hb{constructor(){N(this,"migrations",[])}version(t,n){return this.migrations.push({version:t,handler:n}),this}run(t,n,s){var l;if(t.from===t.to)return n;if(t.from>t.to)throw new Error(`Can not downgrade from version '${t.from}' to (${t.to})`);const i=this.migrations.filter(c=>c.version>t.from&&c.version<=t.to),a=v.orderBy(i,"version","asc");if(((l=v.last(a))==null?void 0:l.version)!==t.to)throw new Error(`Migration to version ${t.to} not found`);return a.reduce((c,u)=>u.handler(c,s),n)}}class Me extends hb{constructor(){super(),this.configVersions()}version(t,n){return super.version(t,(s,i)=>({version:t,...n(s,i)}))}async migrate({configData:t,panelModel:n}){const s=await t.getItem(null),i=v.get(s,"version",0),a=this.run({from:i,to:this.VERSION},s,{panelModel:n});await t.setItem(null,a)}async needMigration({configData:t}){const n=await t.getItem(null);return v.get(n,"version",0)<this.VERSION}}const Q=(e,t)=>{const[n,{setFalse:s}]=Z.useBoolean(!0),[i,a]=g.useState();g.useEffect(()=>(e.getItem(t).then(c=>{a(c),s()}),e.watchItem(t,c=>{a(c)})));const l=g.useCallback(async c=>{await e.setItem(t,c),a(c)},[e,t]);return{loading:n,value:i,set:l}},it={top:16,right:16,bottom:16,left:16},Pt=e=>Math.max(0,e-it.left-it.right),Lt=e=>Math.max(0,e-it.top-it.bottom),Dr=(e,t)=>({width:Pt(e),height:Lt(t)}),at=({width:e,height:t,children:n})=>r.jsx(o.Box,{pt:it.top,pr:it.right,pb:it.bottom,pl:it.left,sx:{width:e,height:t,overflow:"hidden",position:"relative"},children:n}),na={x_axis_data_key:"",y_axis_data_key:"",z_axis_data_key:"",xAxis3D:{type:"value",name:"X Axis Name"},yAxis3D:{type:"value",name:"Y Axis Name"},zAxis3D:{type:"value",name:"Z Axis Name"}};function pb({context:e}){const{value:t}=Q(e.instanceData,"config"),n=e.data,{width:s,height:i}=e.viewport,{x_axis_data_key:a,y_axis_data_key:l,z_axis_data_key:c,xAxis3D:u,yAxis3D:d,zAxis3D:h}=v.defaults({},t,na),p=g.useMemo(()=>as(n,a),[n,a]),{x:f,y:m,z:y}=g.useMemo(()=>({x:O(a),y:O(l),z:O(c)}),[a,l,c]),{min:_,max:k}=g.useMemo(()=>{const T=v.minBy(p,z=>z[y.columnKey]),I=v.maxBy(p,z=>z[y.columnKey]);return{min:v.get(T,y.columnKey),max:v.get(I,y.columnKey)}},[p,y]),S={tooltip:{},backgroundColor:"#fff",visualMap:{show:!0,dimension:2,min:_,max:k,inRange:{color:["#313695","#4575b4","#74add1","#abd9e9","#e0f3f8","#ffffbf","#fee090","#fdae61","#f46d43","#d73027","#a50026"]}},xAxis3D:u,yAxis3D:d,zAxis3D:h,grid3D:{viewControl:{projection:"orthographic",autoRotate:!1},light:{main:{shadow:!0,quality:"ultra",intensity:1.5}}},series:[{type:"bar3D",wireframe:{},data:p.map(T=>[T[f.columnKey],T[m.columnKey],T[y.columnKey]])}]};return t?r.jsx(at,{width:s,height:i,children:r.jsx(Ye,{echarts:Ue,option:S,style:Dr(s,i),notMerge:!0,theme:"merico-light"})}):null}const Cu=g.createContext(null),ra=Cu.Provider;function sa(){const e=g.useContext(Cu);if(!e)throw new Error("Please use DashboardModelContextProvider");return e}const le=()=>sa(),Su=()=>sa(),ku=g.createContext({searchButtonProps:{}}),ia=ku.Provider;function Tu(){return g.useContext(ku)}const Du=g.createContext(null),aa=Du.Provider;function Mu(){const e=g.useContext(Du);if(!e)throw new Error("Please use ContentModelContextProvider");return e}const se=()=>Mu(),Pe=()=>Mu(),fb={inEditMode:!1},Ts=g.createContext(fb),Iu=g.createContext({panel:null,data:{},loading:!1,errors:[],downloadPanelScreenshot:()=>{}}),oa=Iu.Provider;function zu(){const e=g.useContext(Iu);if(!e.panel)throw new Error("Please use PanelContextProvider");return e}const Ot=()=>zu(),nt=()=>zu(),gb={fullScreenPanelID:"",setFullScreenPanelID:v.noop},la=g.createContext(gb);function Eu(){const e=g.useContext(la);if(!e)throw new Error("Please use FullScreenPanelContext.Provider");return e}const mb={en:"en",zh:"zh-cn"};function ca({children:e}){const{i18n:t}=j.useTranslation(),n=g.useMemo(()=>{const s=t.language;return mb[s]??"en"},[t.language]);return r.jsx(pc.DatesProvider,{settings:{locale:n,firstDayOfWeek:1},children:e})}const U=D.observer(g.forwardRef(({label:e,required:t,description:n,value:s,onChange:i,queryID:a,clearable:l=!1,sx:c,...u},d)=>{const{panel:h}=nt(),p=g.useMemo(()=>h.dataFieldOptions(s,l,a),[s,l,a]);if(p.length===0){const f=h.explainDataKey(s);return r.jsxs(o.HoverCard,{shadow:"md",position:"bottom-start",withinPortal:!0,zIndex:320,children:[r.jsx(o.HoverCard.Target,{children:r.jsx(o.Box,{children:r.jsx(o.TextInput,{label:e,required:t,defaultValue:f.columnKey,readOnly:!0,disabled:!0})})}),r.jsx(o.HoverCard.Dropdown,{children:r.jsxs(o.Group,{position:"left",spacing:0,children:[r.jsx(o.Text,{size:"xs",color:f.queryName?"black":"red",sx:{fontFamily:"monospace"},children:f.queryName??f.queryID}),r.jsx(o.Text,{size:"xs",color:"black",sx:{fontFamily:"monospace"},children:"."}),r.jsx(o.Text,{size:"xs",color:"red",sx:{fontFamily:"monospace"},children:f.columnKey})]})})]})}return r.jsx(o.Select,{ref:d,label:e,description:n,data:p,value:s,onChange:i,required:t,sx:c,maxDropdownHeight:500,...u})}));function xb({context:e}){const{value:t,set:n}=Q(e.instanceData,"config"),s=v.defaults({},t,na),{control:i,handleSubmit:a,reset:l}=b.useForm({defaultValues:s});return g.useEffect(()=>{l(s)},[t]),t?r.jsx(o.Stack,{spacing:"xs",children:r.jsxs("form",{onSubmit:a(n),children:[r.jsx(o.Text,{children:"X Axis"}),r.jsxs(o.Group,{position:"apart",grow:!0,p:"md",sx:{position:"relative",border:"1px solid #eee"},children:[r.jsx(b.Controller,{name:"x_axis_data_key",control:i,render:({field:c})=>r.jsx(U,{label:"Data Field",required:!0,...c})}),r.jsx(b.Controller,{name:"xAxis3D.name",control:i,render:({field:c})=>r.jsx(o.TextInput,{sx:{flexGrow:1},size:"md",label:"Name",...c})})]}),r.jsx(o.Text,{mt:"lg",children:"Y Axis"}),r.jsxs(o.Group,{position:"apart",grow:!0,p:"md",sx:{position:"relative",border:"1px solid #eee"},children:[r.jsx(b.Controller,{name:"y_axis_data_key",control:i,render:({field:c})=>r.jsx(U,{label:"Data Field",required:!0,...c})}),r.jsx(b.Controller,{name:"yAxis3D.name",control:i,render:({field:c})=>r.jsx(o.TextInput,{sx:{flexGrow:1},size:"md",label:"Name",...c})})]}),r.jsx(o.Text,{mt:"lg",children:"Z Axis"}),r.jsxs(o.Group,{position:"apart",grow:!0,p:"md",sx:{position:"relative",border:"1px solid #eee"},children:[r.jsx(b.Controller,{name:"z_axis_data_key",control:i,render:({field:c})=>r.jsx(U,{label:"Data Field",required:!0,...c})}),r.jsx(b.Controller,{name:"zAxis3D.name",control:i,render:({field:c})=>r.jsx(o.TextInput,{sx:{flexGrow:1},size:"md",label:"Name",...c})})]}),r.jsx(o.Group,{position:"center",mt:"xl",grow:!0,sx:{width:"60%"},mx:"auto",children:r.jsxs(o.Button,{color:"blue",type:"submit",children:[r.jsx(R.DeviceFloppy,{size:20}),r.jsx(o.Text,{ml:"md",children:"Save"})]})})]})}):null}const yb=[{lang:"en",resources:{bar_chart_3d:{viz_name:"Bar Chart(3D)"}}},{lang:"zh",resources:{bar_chart_3d:{viz_name:"柱图(3D)"}}}];function bb(e,{panelModel:t}){try{const n=t.queryIDs[0];if(!n)throw new Error("cannot migrate when queryID is empty");const s=u=>u&&`${n}.${u}`,{x_axis_data_key:i,y_axis_data_key:a,z_axis_data_key:l,...c}=e;return{...c,x_axis_data_key:s(i),y_axis_data_key:s(a),z_axis_data_key:s(l)}}catch(n){throw console.error("[Migration failed]",n),n}}class vb extends Me{constructor(){super(...arguments);N(this,"VERSION",2)}configVersions(){this.version(1,n=>({version:1,config:n})),this.version(2,(n,s)=>{const{config:i}=n;return{...n,version:2,config:bb(i,s)}})}}const _b={displayName:"viz.bar_chart_3d.viz_name",displayGroup:"chart.groups.echarts_based_charts",migrator:new vb,name:"bar-3d",viewRender:pb,configRender:xb,createConfig(){return{version:2,config:v.cloneDeep(na)}},translation:yb},jb=({disabled:e,value:t,onChange:n})=>{const s=i=>{i&&n(i)};return r.jsxs(o.Box,{sx:{position:"relative"},children:[e&&r.jsx(o.Overlay,{opacity:.6,color:"#fff",zIndex:5,blur:2}),r.jsx(ft,{height:"500px",defaultLanguage:"javascript",value:t,onChange:s,theme:"vs-dark",options:{minimap:{enabled:!1},readOnly:e}})]})};function ot({enabled:e,func_content:t}){return(n,s)=>{if(!e)return n;try{return new Function(`return ${t}`)()(n,s)}catch(i){return console.error(`[getEchartsXAxisLabel] failed parsing custom function, error: ${i.message}`),n}}}function Xe(){return{enabled:!1,func_content:["function label(value, index) {"," // your code goes here"," // return value","}"].join(`
|
|
81
|
+
`)(n)}catch(s){return console.error(s),console.log(e),e}}function yu(e,t,n,s){const i=Qy(t,s);return e.replaceAll(/(\{\{([^{\}]+(?=}))\}\})/g,(...l)=>{const c=l[2];if(!c)return c;const u=i[c];if(u)return u;const d=Uy(c);return Yy(d,i,n)})}function Ky(e,t){const n=dc.decode(t);n!==e&&(console.error("Inconsistent sql"),console.groupCollapsed("Inconsistent sql"),console.table({before:e,after:t,v:n}),console.groupEnd())}async function Xy({query:e,name:t,payload:n,additionals:s},i){if(!e.sql)return[];const{type:a,key:l,sql:c,pre_process:u,post_process:d}=e,h=ki(c,n),p=Im({sql:h,pre_process:u}),f=dc.encode(p);Ky(p,f);let m=await Qt.query(i)({type:a,key:l,query:f,...s},{params:{name:t}});return m=zm(d,m,Hi(n)),m}async function Jy({type:e,key:t,configString:n,name:s,additionals:i},a){try{return await Qt.httpDataSourceQuery(a)({type:e,key:t,query:n,...i},{params:{name:s}})}catch(l){if(Gt.isCancel(l))throw l;return console.error(l),l}}async function ea(){try{return(await Qt.post()("/datasource/list",{filter:{},sort:[{field:"create_time",order:"ASC"}],pagination:{page:1,pagesize:100}},{})).data}catch(e){return console.error(e),[]}}async function bu(){try{return(await Qt.post()("/sql_snippet/list",{filter:{},sort:[{field:"id",order:"ASC"}],pagination:{page:1,pagesize:1e3}},{})).data}catch(e){return console.error(e),[]}}class vu{constructor(t){N(this,"rootRef");this.rootRef=ae.observable({current:t})}async deleteItem(t){ae.runInAction(()=>{v.unset(this.rootRef.current,[t])})}getItem(t){const n=this.getValueFromRoot(t);return Promise.resolve(n)}getValueFromRoot(t){return t===null?ae.toJS(this.rootRef.current):v.get(this.rootRef.current,[t])}setItem(t,n){if(t===null)if(v.isObject(n))ae.runInAction(()=>{this.rootRef.current=n});else throw new Error("Cannot set root value to non-object");else ae.runInAction(()=>{v.set(this.rootRef.current,[t],n)});return Promise.resolve(this.getItem(t))}watchItem(t,n,s){return ae.reaction(()=>this.getValueFromRoot(t),(i,a)=>{n(i,a)},{requiresObservable:!0,fireImmediately:v.get(s,"fireImmediately",!1)})}}class Zy{constructor(){N(this,"channels",new Map);N(this,"globalChannel",new hc)}getChannel(t){const n=this.channels.get(t);if(n)return n;const s=new hc;return this.channels.set(t,s),s}}class Hy{constructor(t){N(this,"instances",new Map);this.pluginManager=t}get availableVizList(){return this.pluginManager.installedPlugins.flatMap(t=>t.manifest.viz)}resolveComponent(t){return this.pluginManager.factory.viz(t)}getOrCreateInstance(t){const n=this.instances.get(t.id);if(n)return n;const s={id:t.id,name:t.viz.type,type:t.viz.type,messageChannels:new Zy,instanceData:new vu(t.viz.conf)};return this.instances.set(t.id,s),s}}function _u(e,t,n,s){return{vizManager:n,locale:"zh",msgChannels:e.messageChannels,instanceData:e.instanceData,pluginData:new vu({}),colorPalette:{getColor(){return()=>""}},data:t,variables:s}}const eb=e=>{const{panel:t,measure:n,vizManager:s,data:i,variables:a}=e,l=s.resolveComponent(t.viz.type),c=s.getOrCreateInstance(t),u={..._u(c,i,s,a),viewport:{width:n.w,height:n.h}},d=l.viewRender;return r.jsx(d,{context:u,instance:c,...v.omit(e,["panel","vizManager","data"])})},tb=e=>{const{vizManager:t,panel:n,data:s,variables:i}=e,a=t.resolveComponent(n.viz.type),l=t.getOrCreateInstance(n),c={..._u(l,s,t,i)},u=a.configRender;return r.jsx(u,{context:c,instance:l,...v.omit(e,["panel","vizManager","data"])})},ju=(e,t)=>{const n=Rt.bezier(e),s=Rt.bezier(t);return function(i){return i<50?n(i*2/100).hex():s((i-50)*2/100).hex()}},ks=e=>{const t=Rt.bezier(e);return function(n){return t(n/100).hex()}},nb={type:"interpolation",displayName:"style.color.interpolation.palette.red_green",getColor:ju(["darkred","deeppink","lightyellow"],["lightyellow","lightgreen","teal"]),name:"red-green",category:"diverging"},rb={type:"interpolation",displayName:"style.color.interpolation.palette.yellow_blue",getColor:ju(["#8f531d","#ffd347","#e3efe3"],["#eefaee","#4ecbbf","#003f94"]),name:"yellow-blue",category:"diverging"},sb={type:"interpolation",displayName:"style.color.interpolation.palette.red",getColor:ks(["#fff7f1","darkred"]),name:"red",category:"sequential"},ib={type:"interpolation",displayName:"style.color.interpolation.palette.green",getColor:ks(["#f0ffed","darkgreen"]),name:"green",category:"sequential"},ab={type:"interpolation",displayName:"style.color.interpolation.palette.blue",getColor:ks(["#f9fcff","#48b3e9","darkblue"]),name:"blue",category:"sequential"},ob={type:"interpolation",displayName:"style.color.interpolation.palette.orange",getColor:ks(["#fff7f1","darkorange","#b60000"]),name:"orange",category:"sequential"};class lb{constructor(t){N(this,"symbol");this.symbol=Symbol(t)}}function an(e){return new lb(e)}class ta{constructor(){N(this,"parent");N(this,"factoryRegistry",new Map);N(this,"instanceRegistry",new Map)}createScoped(){const t=new ta;return t.parent=this,t}getRequired(t){return this.get(t)}get(t){if(this.instanceRegistry.has(t.symbol))return this.instanceRegistry.get(t.symbol);const n=this.factoryRegistry.get(t.symbol);if(n){const s=n(this);return this.instanceRegistry.set(t.symbol,s),s}if(this.parent)return this.parent.get(t)}provideFactory(t,n){return this.factoryRegistry.has(t.symbol)?console.warn(`Token ${t.symbol.toString()} is already registered`):this.factoryRegistry.set(t.symbol,n),this}provideValue(t,n){return this.factoryRegistry.has(t.symbol)?console.warn(`Token ${t.symbol.toString()} is already registered`):this.factoryRegistry.set(t.symbol,()=>n),this}dispose(){this.instanceRegistry.forEach(t=>{const n=v.get(t,"dispose");v.isFunction(n)&&n.bind(t)()}),this.instanceRegistry.clear(),this.factoryRegistry.clear()}}const wu="13.27.10",cb=Object.freeze(Object.defineProperty({__proto__:null,version:wu},Symbol.toStringTag,{value:"Module"}));class ub{constructor(t){N(this,"staticColors",new Map);N(this,"interpolations",new Map);t.installedPlugins.forEach(n=>{n.manifest.color.forEach(s=>{this.register(s)})})}getStaticColors(){return Array.from(this.staticColors.values())}register(t){const n=this.encodeColor(t);t.type==="single"?(this.staticColors.has(n)&&console.warn(`the color '${t.name}' has been registered under '${t.category}', previous registered value will be overridden`),this.staticColors.set(n,t)):t.type==="interpolation"&&(this.interpolations.has(n)&&console.warn(`the interpolation '${t.name}' has been registered under '${t.category}', previous registered value will be overridden`,`the interpolation '${t.name}' has been registered under '${t.category}', previous registered value will be overridden`),this.interpolations.set(n,t))}decodeStaticColor(t){return this.staticColors.get(t)}encodeColor(t){return`\${${t.category}}.{${t.name}}`}decodeInterpolation(t){return this.interpolations.get(t)}getColorInterpolations(){return Array.from(this.interpolations.values())}}class db{constructor(){N(this,"plugins",new Map);N(this,"vizComponents",new Map);N(this,"factory",{viz:t=>{const n=this.vizComponents.get(t);if(n)return n;throw new Error(`Viz Component (${t}) not found`)}})}install(t){if(this.plugins.has(t.id))throw new Error(`Plugin (${t.id}) has been installed before`);this.plugins.set(t.id,t);for(const n of t.manifest.viz){if(this.vizComponents.has(n.name))throw new Error(`Viz Component (${n.name}) has been installed before`);this.vizComponents.set(n.name,n)}}get installedPlugins(){return Array.from(this.plugins.values())}}class hb{constructor(){N(this,"migrations",[])}version(t,n){return this.migrations.push({version:t,handler:n}),this}run(t,n,s){var l;if(t.from===t.to)return n;if(t.from>t.to)throw new Error(`Can not downgrade from version '${t.from}' to (${t.to})`);const i=this.migrations.filter(c=>c.version>t.from&&c.version<=t.to),a=v.orderBy(i,"version","asc");if(((l=v.last(a))==null?void 0:l.version)!==t.to)throw new Error(`Migration to version ${t.to} not found`);return a.reduce((c,u)=>u.handler(c,s),n)}}class Me extends hb{constructor(){super(),this.configVersions()}version(t,n){return super.version(t,(s,i)=>({version:t,...n(s,i)}))}async migrate({configData:t,panelModel:n}){const s=await t.getItem(null),i=v.get(s,"version",0),a=this.run({from:i,to:this.VERSION},s,{panelModel:n});await t.setItem(null,a)}async needMigration({configData:t}){const n=await t.getItem(null);return v.get(n,"version",0)<this.VERSION}}const Q=(e,t)=>{const[n,{setFalse:s}]=Z.useBoolean(!0),[i,a]=g.useState();g.useEffect(()=>(e.getItem(t).then(c=>{a(c),s()}),e.watchItem(t,c=>{a(c)})));const l=g.useCallback(async c=>{await e.setItem(t,c),a(c)},[e,t]);return{loading:n,value:i,set:l}},it={top:16,right:16,bottom:16,left:16},Pt=e=>Math.max(0,e-it.left-it.right),Lt=e=>Math.max(0,e-it.top-it.bottom),Dr=(e,t)=>({width:Pt(e),height:Lt(t)}),at=({width:e,height:t,children:n})=>r.jsx(o.Box,{pt:it.top,pr:it.right,pb:it.bottom,pl:it.left,sx:{width:e,height:t,overflow:"hidden",position:"relative"},children:n}),na={x_axis_data_key:"",y_axis_data_key:"",z_axis_data_key:"",xAxis3D:{type:"value",name:"X Axis Name"},yAxis3D:{type:"value",name:"Y Axis Name"},zAxis3D:{type:"value",name:"Z Axis Name"}};function pb({context:e}){const{value:t}=Q(e.instanceData,"config"),n=e.data,{width:s,height:i}=e.viewport,{x_axis_data_key:a,y_axis_data_key:l,z_axis_data_key:c,xAxis3D:u,yAxis3D:d,zAxis3D:h}=v.defaults({},t,na),p=g.useMemo(()=>as(n,a),[n,a]),{x:f,y:m,z:y}=g.useMemo(()=>({x:O(a),y:O(l),z:O(c)}),[a,l,c]),{min:_,max:k}=g.useMemo(()=>{const T=v.minBy(p,z=>z[y.columnKey]),I=v.maxBy(p,z=>z[y.columnKey]);return{min:v.get(T,y.columnKey),max:v.get(I,y.columnKey)}},[p,y]),S={tooltip:{},backgroundColor:"#fff",visualMap:{show:!0,dimension:2,min:_,max:k,inRange:{color:["#313695","#4575b4","#74add1","#abd9e9","#e0f3f8","#ffffbf","#fee090","#fdae61","#f46d43","#d73027","#a50026"]}},xAxis3D:u,yAxis3D:d,zAxis3D:h,grid3D:{viewControl:{projection:"orthographic",autoRotate:!1},light:{main:{shadow:!0,quality:"ultra",intensity:1.5}}},series:[{type:"bar3D",wireframe:{},data:p.map(T=>[T[f.columnKey],T[m.columnKey],T[y.columnKey]])}]};return t?r.jsx(at,{width:s,height:i,children:r.jsx(Ye,{echarts:Ue,option:S,style:Dr(s,i),notMerge:!0,theme:"merico-light"})}):null}const Cu=g.createContext(null),ra=Cu.Provider;function sa(){const e=g.useContext(Cu);if(!e)throw new Error("Please use DashboardModelContextProvider");return e}const le=()=>sa(),Su=()=>sa(),ku=g.createContext({searchButtonProps:{}}),ia=ku.Provider;function Tu(){return g.useContext(ku)}const Du=g.createContext(null),aa=Du.Provider;function Mu(){const e=g.useContext(Du);if(!e)throw new Error("Please use ContentModelContextProvider");return e}const se=()=>Mu(),Pe=()=>Mu(),fb={inEditMode:!1},Ts=g.createContext(fb),Iu=g.createContext({panel:null,data:{},loading:!1,errors:[],downloadPanelScreenshot:()=>{}}),oa=Iu.Provider;function zu(){const e=g.useContext(Iu);if(!e.panel)throw new Error("Please use PanelContextProvider");return e}const Ot=()=>zu(),nt=()=>zu(),gb={fullScreenPanelID:"",setFullScreenPanelID:v.noop},la=g.createContext(gb);function Eu(){const e=g.useContext(la);if(!e)throw new Error("Please use FullScreenPanelContext.Provider");return e}const mb={en:"en",zh:"zh-cn"};function ca({children:e}){const{i18n:t}=j.useTranslation(),n=g.useMemo(()=>{const s=t.language;return mb[s]??"en"},[t.language]);return r.jsx(pc.DatesProvider,{settings:{locale:n,firstDayOfWeek:1},children:e})}const U=D.observer(g.forwardRef(({label:e,required:t,description:n,value:s,onChange:i,queryID:a,clearable:l=!1,sx:c,...u},d)=>{const{panel:h}=nt(),p=g.useMemo(()=>h.dataFieldOptions(s,l,a),[s,l,a]);if(p.length===0){const f=h.explainDataKey(s);return r.jsxs(o.HoverCard,{shadow:"md",position:"bottom-start",withinPortal:!0,zIndex:320,children:[r.jsx(o.HoverCard.Target,{children:r.jsx(o.Box,{children:r.jsx(o.TextInput,{label:e,required:t,defaultValue:f.columnKey,readOnly:!0,disabled:!0})})}),r.jsx(o.HoverCard.Dropdown,{children:r.jsxs(o.Group,{position:"left",spacing:0,children:[r.jsx(o.Text,{size:"xs",color:f.queryName?"black":"red",sx:{fontFamily:"monospace"},children:f.queryName??f.queryID}),r.jsx(o.Text,{size:"xs",color:"black",sx:{fontFamily:"monospace"},children:"."}),r.jsx(o.Text,{size:"xs",color:"red",sx:{fontFamily:"monospace"},children:f.columnKey})]})})]})}return r.jsx(o.Select,{ref:d,label:e,description:n,data:p,value:s,onChange:i,required:t,sx:c,maxDropdownHeight:500,...u})}));function xb({context:e}){const{value:t,set:n}=Q(e.instanceData,"config"),s=v.defaults({},t,na),{control:i,handleSubmit:a,reset:l}=b.useForm({defaultValues:s});return g.useEffect(()=>{l(s)},[t]),t?r.jsx(o.Stack,{spacing:"xs",children:r.jsxs("form",{onSubmit:a(n),children:[r.jsx(o.Text,{children:"X Axis"}),r.jsxs(o.Group,{position:"apart",grow:!0,p:"md",sx:{position:"relative",border:"1px solid #eee"},children:[r.jsx(b.Controller,{name:"x_axis_data_key",control:i,render:({field:c})=>r.jsx(U,{label:"Data Field",required:!0,...c})}),r.jsx(b.Controller,{name:"xAxis3D.name",control:i,render:({field:c})=>r.jsx(o.TextInput,{sx:{flexGrow:1},size:"md",label:"Name",...c})})]}),r.jsx(o.Text,{mt:"lg",children:"Y Axis"}),r.jsxs(o.Group,{position:"apart",grow:!0,p:"md",sx:{position:"relative",border:"1px solid #eee"},children:[r.jsx(b.Controller,{name:"y_axis_data_key",control:i,render:({field:c})=>r.jsx(U,{label:"Data Field",required:!0,...c})}),r.jsx(b.Controller,{name:"yAxis3D.name",control:i,render:({field:c})=>r.jsx(o.TextInput,{sx:{flexGrow:1},size:"md",label:"Name",...c})})]}),r.jsx(o.Text,{mt:"lg",children:"Z Axis"}),r.jsxs(o.Group,{position:"apart",grow:!0,p:"md",sx:{position:"relative",border:"1px solid #eee"},children:[r.jsx(b.Controller,{name:"z_axis_data_key",control:i,render:({field:c})=>r.jsx(U,{label:"Data Field",required:!0,...c})}),r.jsx(b.Controller,{name:"zAxis3D.name",control:i,render:({field:c})=>r.jsx(o.TextInput,{sx:{flexGrow:1},size:"md",label:"Name",...c})})]}),r.jsx(o.Group,{position:"center",mt:"xl",grow:!0,sx:{width:"60%"},mx:"auto",children:r.jsxs(o.Button,{color:"blue",type:"submit",children:[r.jsx(R.DeviceFloppy,{size:20}),r.jsx(o.Text,{ml:"md",children:"Save"})]})})]})}):null}const yb=[{lang:"en",resources:{bar_chart_3d:{viz_name:"Bar Chart(3D)"}}},{lang:"zh",resources:{bar_chart_3d:{viz_name:"柱图(3D)"}}}];function bb(e,{panelModel:t}){try{const n=t.queryIDs[0];if(!n)throw new Error("cannot migrate when queryID is empty");const s=u=>u&&`${n}.${u}`,{x_axis_data_key:i,y_axis_data_key:a,z_axis_data_key:l,...c}=e;return{...c,x_axis_data_key:s(i),y_axis_data_key:s(a),z_axis_data_key:s(l)}}catch(n){throw console.error("[Migration failed]",n),n}}class vb extends Me{constructor(){super(...arguments);N(this,"VERSION",2)}configVersions(){this.version(1,n=>({version:1,config:n})),this.version(2,(n,s)=>{const{config:i}=n;return{...n,version:2,config:bb(i,s)}})}}const _b={displayName:"viz.bar_chart_3d.viz_name",displayGroup:"chart.groups.echarts_based_charts",migrator:new vb,name:"bar-3d",viewRender:pb,configRender:xb,createConfig(){return{version:2,config:v.cloneDeep(na)}},translation:yb},jb=({disabled:e,value:t,onChange:n})=>{const s=i=>{i&&n(i)};return r.jsxs(o.Box,{sx:{position:"relative"},children:[e&&r.jsx(o.Overlay,{opacity:.6,color:"#fff",zIndex:5,blur:2}),r.jsx(ft,{height:"500px",defaultLanguage:"javascript",value:t,onChange:s,theme:"vs-dark",options:{minimap:{enabled:!1},readOnly:e}})]})};function ot({enabled:e,func_content:t}){return(n,s)=>{if(!e)return n;try{return new Function(`return ${t}`)()(n,s)}catch(i){return console.error(`[getEchartsXAxisLabel] failed parsing custom function, error: ${i.message}`),n}}}function Xe(){return{enabled:!1,func_content:["function label(value, index) {"," // your code goes here"," // return value","}"].join(`
|
|
82
82
|
`)}}const Bt=g.forwardRef(({value:e,onChange:t,triggerButtonText:n},s)=>{const{t:i}=j.useTranslation(),[a,{setTrue:l,setFalse:c}]=Z.useBoolean(),[u,d]=g.useState(e);g.useEffect(()=>{d(e)},[e]);const h=k=>{d({...u,enabled:k})},p=()=>{c();const{enabled:k,func_content:S}=u,T={enabled:k,func_content:S};d(T),t(T)},f=()=>{c(),d(e)},m=k=>{d(S=>({...S,func_content:k}))},y=()=>{m(Xe().func_content)},_=n??i("chart.axis.customize_label");return r.jsxs(r.Fragment,{children:[r.jsx(o.Button,{variant:"filled",color:"grape",leftIcon:r.jsx(M.IconMathFunction,{size:16}),mt:24,onClick:l,sx:{flexGrow:0},children:_}),r.jsx(o.Modal,{size:800,title:_,opened:a,onClose:c,closeOnClickOutside:!1,withCloseButton:!1,zIndex:320,children:a&&r.jsxs(o.Stack,{children:[r.jsx(o.Checkbox,{mt:10,label:i("common.enabled"),checked:u.enabled,onChange:k=>h(k.currentTarget.checked)}),r.jsx(jb,{value:u.func_content,onChange:m,disabled:!u.enabled}),r.jsxs(o.Group,{position:"apart",children:[r.jsx(o.Button,{onClick:y,color:"red",leftIcon:r.jsx(R.Recycle,{size:20}),children:i("common.actions.reset_to_default")}),r.jsxs(o.Group,{position:"right",children:[r.jsx(o.Button,{onClick:f,variant:"subtle",children:i("common.actions.cancel")}),r.jsx(o.Button,{color:"green",leftIcon:r.jsx(M.IconDeviceFloppy,{size:16}),onClick:p,children:i("common.actions.save")})]})]})]})})]})}),On={x_axis_scroll:!1,y_axis_scroll:!1,x_axis_slider:!1,y_axis_slider:!1};function Au(){return v.cloneDeep(On)}const wb=[{lang:"en",resources:{boxplot:{viz_name:"Boxplot Chart",box:"Box",outlier:"Outlier",scatter:"Scatter",click_series:{label:"Click box, scatter or outlier"}}}},{lang:"zh",resources:{boxplot:{viz_name:"箱线图",box:"箱体",outlier:"异常点",scatter:"散点",click_series:{label:"点击箱体、散点或异常点"}}}}],Pu={id:"builtin:echarts:click-echart:series",displayName:"viz.boxplot.click_series.label",nameRender:Sb,configRender:Cb,payload:[{name:"type",description:"Always 'click'",valueType:"string"},{name:"seriesType",description:"'boxplot'",valueType:"string"},{name:"name",description:"Name of the series clicked",valueType:"string"},{name:"color",description:"Color",valueType:"string"},{name:"value",description:"Record of 'name', 'min', 'q1', 'median', 'q3', 'max'",valueType:"object"},{name:"rowData",description:"Data of the row",valueType:"object"}]};function Cb(e){return r.jsx(r.Fragment,{})}function Sb(e){const{t}=j.useTranslation();return r.jsx(o.Text,{children:t("viz.boxplot.click_series.label")})}const Ds=g.forwardRef(({sectionTitle:e,value:t,onChange:n},s)=>{const{t:i,i18n:a}=j.useTranslation(),l=u=>d=>{const h=v.cloneDeep(t);v.set(h,u,d),n(h)},c=g.useMemo(()=>[{label:i("chart.axis.overflow.truncate"),value:"truncate"},{label:i("chart.axis.overflow.break_line"),value:"break"},{label:i("chart.axis.overflow.break_word"),value:"breakAll"}],[a.language]);return r.jsxs(o.Stack,{spacing:0,children:[e&&r.jsx(o.Divider,{mb:-5,mt:5,variant:"dotted",label:e,labelPosition:"right",labelProps:{color:"dimmed"}}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(o.NumberInput,{label:i("chart.axis.overflow.max_width"),hideControls:!0,value:t.width,onChange:l("width")}),r.jsx(o.Select,{label:i("chart.axis.overflow.label"),data:c,value:t.overflow,onChange:l("overflow")}),r.jsx(o.TextInput,{label:i("chart.axis.overflow.ellipsis"),value:t.ellipsis,disabled:!0})]})]})}),Vt=g.forwardRef(({value:e,onChange:t},n)=>{const{t:s}=j.useTranslation(),i=l=>{t({...e,on_axis:l})},a=l=>{t({...e,in_tooltip:l})};return r.jsxs(o.Stack,{ref:n,spacing:0,children:[r.jsx(Ds,{sectionTitle:s("chart.axis.overflow.section_title.on_axis"),value:e.on_axis,onChange:i}),r.jsx(Ds,{sectionTitle:s("chart.axis.overflow.section_title.in_tooltip"),value:e.in_tooltip,onChange:a})]})});function lt(){return{on_axis:{width:80,overflow:"truncate",ellipsis:"..."},in_tooltip:{width:200,overflow:"break",ellipsis:"..."}}}function wt({overflow:e,width:t}){const n={truncate:"initial",break:"break-all",breakAll:"break-word"}[e],s=e==="truncate"?"nowrap":"initial",i={truncate:"ellipsis",break:"clip",breakAll:"clip"}[e];return`
|
|
83
83
|
max-width: ${t}px;
|
|
84
84
|
word-break: ${n};
|
|
@@ -273,7 +273,7 @@ Check the top-level render call using <`+q+">.")}return A}}function Dg(C,A){{if(
|
|
|
273
273
|
</tr>
|
|
274
274
|
</tbody>
|
|
275
275
|
</table>
|
|
276
|
-
`}})}function Pk(e){const{overflow:t,format:n,formatter:s,...i}=e.x_axis.axisLabel,a=Ct(t.on_axis);return ge.getXAxis({type:"value",name:e.x_axis.name??"",nameLocation:"middle",nameGap:25,axisLabel:{...i,...a,formatter:(l,c)=>{let u=l;try{u=re(l,n)}catch{}return ot(s)(u,c)}}})}const Lk={tooltip:{trigger:"axis"},grid:{top:50,left:5,right:10,bottom:20,containLabel:!0},dataZoom:[{type:"inside",xAxisIndex:[0]},{type:"inside",yAxisIndex:[0]}]};function Ok(e,t){const n=zk(e,t),s=Dk(e,n),i={xAxis:Pk(e),yAxis:ge.getYAxis({name:e.y_axis.name??"",nameLocation:"end",nameTextStyle:{align:"left"},nameGap:5}),series:[...n,...s],tooltip:Ak(e),legend:{show:!0,type:"scroll",orient:"horizontal",align:"left",right:0,top:0,left:"auto",itemGap:20,padding:[4,8,0,140],data:n.map(a=>a.name)}};return v.defaultsDeep({},i,Lk)}const ap={output:"number",mantissa:2,trimMantissa:!0,absolute:!1};function si(e,t,n){return 1-(1-e)*(t-1)/(t-n-1)}function Bk(e,t,n,s){const{x_axis:i,y_axis:a}=s,l=xn.regressionLinear()(n),{a:c,b:u,rSquared:d}=l;return{name:e,expression:r.jsxs(o.Group,{position:"center",noWrap:!0,spacing:10,children:[r.jsx(o.Text,{children:a.name}),r.jsx(o.Text,{children:"="}),r.jsx(o.Text,{weight:"bold",color:"red",children:re(u,ap)}),r.jsx(o.Text,{children:"+"}),r.jsx(o.Text,{weight:"bold",color:"red",children:re(c,ap)}),r.jsx(o.Text,{children:"×"}),r.jsx(o.Text,{children:i.name})]}),rSquared:d,adjustedRSquared:si(d,t.length,1)}}function Vk(e,t,n,s){const{x_axis:i,y_axis:a}=s,{a:l,b:c,rSquared:u}=xn.regressionExp()(n);return{name:e,expression:r.jsxs(o.Group,{position:"center",noWrap:!0,spacing:10,children:[r.jsx(o.Text,{children:a.name}),r.jsx(o.Text,{children:"="}),r.jsx(o.Text,{weight:"bold",color:"gray",children:l}),r.jsx(o.Text,{children:"×"}),r.jsxs(o.Group,{position:"left",noWrap:!0,spacing:2,children:[r.jsx(o.Text,{children:"Math.exp("}),r.jsx(o.Text,{weight:"bold",color:"gray",children:c}),r.jsx(o.Text,{children:"×"}),r.jsx(o.Text,{children:i.name}),r.jsx(o.Text,{children:")"})]})]}),rSquared:u,adjustedRSquared:si(u,t.length,1)}}function qk(e,t,n,s){const{x_axis:i,y_axis:a}=s,{a:l,b:c,rSquared:u}=xn.regressionLog()(n);return{name:e,expression:r.jsxs(o.Group,{position:"center",noWrap:!0,spacing:10,children:[r.jsx(o.Text,{children:a.name}),r.jsx(o.Text,{children:"="}),r.jsx(o.Text,{weight:"bold",color:"gray",children:l}),r.jsx(o.Text,{children:"×"}),r.jsxs(o.Group,{position:"left",noWrap:!0,spacing:2,children:[r.jsx(o.Text,{children:"Math.log("}),r.jsx(o.Text,{children:i.name}),r.jsx(o.Text,{children:")"}),r.jsx(o.Text,{children:"+"}),r.jsx(o.Text,{weight:"bold",color:"gray",children:c})]})]}),rSquared:u,adjustedRSquared:si(u,t.length,1)}}function Nk(e,t,n,s){const{x_axis:i,y_axis:a,regression:l}=s,c=xn.regressionPoly().order(l.transform.config.order)(n),{rSquared:u}=c;return console.log(c),{name:e,expression:"",rSquared:u,adjustedRSquared:si(u,t.length,1)}}function op(e,t,n){const{regression:s,x_axis:i}=n,a=O(i.data_key),l=O(s.y_axis_data_key),c=t.map(u=>[u[a.columnKey],u[l.columnKey]]);return s.transform.config.method==="linear"?Bk(e,t,c,n):s.transform.config.method==="exponential"?Vk(e,t,c,n):s.transform.config.method==="logistic"?qk(e,t,c,n):s.transform.config.method==="polynomial"?Nk(e,t,c,n):{name:e,expression:"",rSquared:0,adjustedRSquared:0}}function $k(e,t){if(!t)return[{name:"",expression:"",rSquared:0,adjustedRSquared:0}];if(!t.regression.group_by_key)return[op("",e,t)];const n=O(t.regression.group_by_key),s=v.groupBy(e,n.columnKey);return Object.entries(s).map(([i,a])=>op(i,a,t))}const Fk={marginTop:"10px","tbody th, tbody td":{padding:"7px 10px"},"tbody tr:not(:first-of-type) th":{borderTop:"1px solid #dee2e6"}};function lp({desc:e}){const{t}=j.useTranslation(),{expression:n,rSquared:s,adjustedRSquared:i}=e;return n?r.jsx(o.Table,{fontSize:14,sx:Fk,children:r.jsxs("tbody",{children:[r.jsx("tr",{children:r.jsx("td",{colSpan:2,children:r.jsx(o.Text,{align:"center",children:n})})}),r.jsxs("tr",{children:[r.jsx("td",{children:t("viz.regression_chart.r_sq")}),r.jsx("td",{style:{textAlign:"right"},children:re(s,{output:"percent",mantissa:1,absolute:!1})})]}),r.jsxs("tr",{children:[r.jsx("td",{children:t("viz.regression_chart.r_sq_adjusted")}),r.jsx("td",{style:{textAlign:"right"},children:re(i,{output:"percent",mantissa:1,absolute:!1})})]})]})}):r.jsx(o.Text,{children:"Unavailable for this regression method"})}function Gk({conf:e,queryData:t}){var s;const n=g.useMemo(()=>$k(t,e),[e,t]);return e.regression.group_by_key?(console.log(n),r.jsxs(o.Tabs,{defaultValue:(s=n[0])==null?void 0:s.name,color:"gray",children:[r.jsx(o.Tabs.List,{grow:!0,children:n.map(i=>r.jsx(o.Tabs.Tab,{value:i.name,children:i.name},i.name))}),n.map(i=>r.jsx(o.Tabs.Panel,{value:i.name,children:r.jsx(lp,{desc:i})},i.name))]})):r.jsx(lp,{desc:n[0]})}function Wk({conf:e,queryData:t}){const{t:n}=j.useTranslation();return r.jsxs(o.HoverCard,{shadow:"md",withinPortal:!0,zIndex:320,children:[r.jsx(o.HoverCard.Target,{children:r.jsx(o.Button,{size:"xs",variant:"subtle",compact:!0,leftIcon:r.jsx(M.IconInfoCircle,{size:14}),children:n("viz.regression_chart.regression_info")})}),r.jsx(o.HoverCard.Dropdown,{children:r.jsx(We,{children:r.jsx(Gk,{conf:e,queryData:t})})})]})}function Rk(e){return r.jsx(o.Group,{position:"apart",sx:{position:"absolute",top:0,left:it.left,right:it.right,height:"22px",zIndex:1},children:r.jsx(Wk,{...e})})}const Ao={x_axis:{name:"X Axis",data_key:"",axisLabel:{rotate:0,format:Ge,overflow:lt(),formatter:Xe()}},y_axis:{name:"Y Axis"},regression:{transform:{type:"ecStat:regression",config:{method:"linear",order:1,formulaOn:"end"}},plot:{type:"line",yAxisIndex:0,color:"#228be6",lineStyle:{type:"solid",width:1}},name:"regression",group_by_key:"",y_axis_data_key:"value"}};function Qk({context:e}){const{value:t}=Q(e.instanceData,"config"),{width:n,height:s}=e.viewport,i=g.useMemo(()=>{var m;const u=e.data,d=t==null?void 0:t.x_axis.data_key,h=(m=t==null?void 0:t.regression)==null?void 0:m.y_axis_data_key;if(!d||!h)return[];const p=O(d),f=O(h);return u[p.queryID].map(y=>typeof y[f.columnKey]=="number"?y:{...y,[f.columnKey]:Number(y[f.columnKey])})},[e.data,t==null?void 0:t.regression.y_axis_data_key]),a=g.useMemo(()=>Ok(v.defaultsDeep({},t,Ao),i),[t,i]),l=g.useRef(null),c=u=>{l.current=u};return!n||!s||!t?null:r.jsxs(at,{width:n,height:s,children:[r.jsx(Rk,{conf:t,queryData:i}),r.jsx(Ye,{echarts:Ue,onChartReady:c,option:a,style:Dr(n,s),notMerge:!0,theme:"merico-light"})]})}function Uk({control:e,watch:t}){const{t:n,i18n:s}=j.useTranslation();t("regression");const i=t("regression.transform.config.method"),a=t("regression.group_by_key"),l=g.useMemo(()=>[{label:n("chart.regression_line.method.linear"),value:"linear"},{label:n("chart.regression_line.method.exponential"),value:"exponential"},{label:n("chart.regression_line.method.logistic"),value:"logistic"},{label:n("chart.regression_line.method.polynomial"),value:"polynomial"}],[s.language]);return r.jsxs(o.Stack,{children:[r.jsx(o.Group,{grow:!0,noWrap:!0,children:r.jsx(b.Controller,{name:"regression.name",control:e,render:({field:c})=>r.jsx(o.TextInput,{label:n("common.name"),sx:{flex:1},...c})})}),r.jsx(b.Controller,{name:"regression.group_by_key",control:e,render:({field:c})=>r.jsx(U,{label:n("chart.series.group_by.label"),clearable:!0,sx:{flex:1},...c})}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"regression.transform.config.method",control:e,render:({field:c})=>r.jsx(o.Select,{label:n("chart.regression_line.method.label"),data:l,sx:{flex:1},...c})}),i==="polynomial"&&r.jsx(b.Controller,{name:"regression.transform.config.order",control:e,render:({field:c})=>r.jsx(o.NumberInput,{label:n("chart.regression_line.method.polynomial_order"),sx:{flex:1},...c})})]}),!a&&r.jsxs(o.Stack,{spacing:4,children:[r.jsx(o.Text,{size:"sm",children:n("chart.color.label")}),r.jsx(b.Controller,{name:"regression.plot.color",control:e,render:({field:c})=>r.jsx(Je,{...c})})]})]})}function Yk({control:e,watch:t}){return t(["x_axis"]),r.jsxs(o.Stack,{children:[r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"x_axis.name",control:e,render:({field:n})=>r.jsx(o.TextInput,{label:"X轴名称",sx:{flex:1},...n})}),r.jsx(b.Controller,{name:"x_axis.data_key",control:e,render:({field:n})=>r.jsx(U,{label:"X轴数据字段",required:!0,sx:{flex:1},...n})})]}),r.jsx(o.Divider,{variant:"dashed",labelPosition:"center",label:"格式化数据"}),r.jsx(o.Stack,{children:r.jsx(b.Controller,{name:"x_axis.axisLabel.format",control:e,render:({field:n})=>r.jsx(Dt,{...n})})}),r.jsx(o.Divider,{variant:"dashed",labelPosition:"center",label:"标签文案样式"}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"x_axis.axisLabel.rotate",control:e,render:({field:n})=>r.jsx(o.NumberInput,{label:"旋转",hideControls:!0,min:-90,max:90,rightSection:r.jsx(o.Text,{color:"dimmed",children:"度"}),sx:{width:"48%"},styles:{rightSection:{width:"4em",justifyContent:"flex-end",paddingRight:"6px"}},...n})}),r.jsx(b.Controller,{name:"x_axis.axisLabel.formatter",control:e,render:({field:n})=>r.jsx(Bt,{triggerButtonText:"自定义标签文案内容",...n})})]}),r.jsx(b.Controller,{name:"x_axis.axisLabel.overflow",control:e,render:({field:n})=>r.jsx(Vt,{...n})})]})}function Kk({control:e,watch:t}){return t(["y_axis","regression.y_axis_data_key"]),r.jsx(o.Stack,{children:r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"y_axis.name",control:e,render:({field:n})=>r.jsx(o.TextInput,{label:"Y轴名称",sx:{flex:1},...n})}),r.jsx(b.Controller,{name:"regression.y_axis_data_key",control:e,render:({field:n})=>r.jsx(U,{label:"Y轴数据字段",required:!0,sx:{flex:1},...n})})]})})}function Xk({context:e}){const{value:t,set:n}=Q(e.instanceData,"config"),s=g.useMemo(()=>v.defaults({},t,Ao),[t]),{control:i,handleSubmit:a,watch:l,getValues:c,reset:u}=b.useForm({defaultValues:s});g.useEffect(()=>{u(s)},[s]),l(["x_axis","y_axis","regression"]);const d=c(),h=g.useMemo(()=>!v.isEqual(d,t),[d,t]);return r.jsx(o.Stack,{spacing:"xs",children:r.jsxs("form",{onSubmit:a(n),children:[r.jsx(qe,{canSubmit:h}),r.jsxs(o.Tabs,{defaultValue:"X轴",orientation:"vertical",styles:{panel:{paddingTop:"6px",paddingLeft:"12px"}},children:[r.jsxs(o.Tabs.List,{children:[r.jsx(o.Tabs.Tab,{value:"X轴",children:"X轴"}),r.jsx(o.Tabs.Tab,{value:"Y轴",children:"Y轴"}),r.jsx(o.Tabs.Tab,{value:"回归",children:"回归"})]}),r.jsx(o.Tabs.Panel,{value:"X轴",children:r.jsx(Yk,{watch:l,control:i})}),r.jsx(o.Tabs.Panel,{value:"Y轴",children:r.jsx(Kk,{watch:l,control:i})}),r.jsx(o.Tabs.Panel,{value:"回归",children:r.jsx(Uk,{control:i,watch:l})})]})]})})}function Jk(e){const t={x_axis:{axisLabel:{rotate:0,format:Ge,overflow:lt(),formatter:Xe()}},regression:{group_by_key:""}};return v.defaultsDeep(t,e)}function Zk(e,{panelModel:t}){try{const n=t.queryIDs[0];if(!n)throw new Error("cannot migrate when queryID is empty");const s=c=>c&&`${n}.${c}`,{x_axis:i,regression:a,...l}=e;return{...l,x_axis:{...i,data_key:s(i.data_key)},regression:{...a,group_by_key:s(a.group_by_key),y_axis_data_key:s(a.y_axis_data_key)}}}catch(n){throw console.error("[Migration failed]",n),n}}const Hk=[{lang:"en",resources:{regression_chart:{viz_name:"Regression Chart",regression_info:"Regression Info",r_sq:"R-Sq",r_sq_adjusted:"R-Sq(Adjusted)"}}},{lang:"zh",resources:{regression_chart:{viz_name:"回归分析图",regression_info:"回归信息",r_sq:"R方",r_sq_adjusted:"R方(调整)"}}}];class eT extends Me{constructor(){super(...arguments);N(this,"VERSION",3)}configVersions(){this.version(1,n=>({version:1,config:n})),this.version(2,n=>({...n,version:2,config:Jk(n.config)})),this.version(3,(n,s)=>{const{config:i}=n;return{...n,version:3,config:Zk(i,s)}})}}const tT={displayName:"viz.regression_chart.viz_name",displayGroup:"chart.groups.merico_suite",migrator:new eT,name:"regressionChart",viewRender:Qk,configRender:Xk,createConfig(){return{version:3,config:v.cloneDeep(Ao)}},translation:Hk},ii={content:""},nT=D.observer(({context:e})=>{const t=Pe(),{panel:n}=Ot(),{value:s}=Q(e.instanceData,"config"),{variables:i,data:a}=e,l=g.useMemo(()=>{const c=v.defaults({},s,ii);return c.content?yu(c.content,i,t.payloadForViz,a):""},[s,i,t.payloadForViz]);return l?r.jsx(kr,{value:l,styles:{root:{border:"none",height:"100%"},content:{padding:0}},dashboardState:t.dashboardState,variableAggValueMap:n.variableAggValueMap}):null});function rT({context:e}){const{t}=j.useTranslation(),{value:n,set:s}=Q(e.instanceData,"config"),i=g.useMemo(()=>v.defaults({},n,ii),[n]),{control:a,handleSubmit:l,watch:c,reset:u}=b.useForm({defaultValues:i});c("content"),g.useEffect(()=>{u(i)},[i]);const d=g.useRef(null),h=()=>{var p;return(p=d.current)==null?void 0:p.click()};return r.jsx("form",{onSubmit:l(s),style:{flexGrow:1,display:"flex",flexDirection:"column"},children:r.jsxs(o.Stack,{spacing:"xs",sx:{flexGrow:1},children:[r.jsxs(o.Group,{position:"left",py:"md",pl:"md",sx:{borderBottom:"1px solid #eee",background:"#efefef",display:"none"},children:[r.jsx(o.Text,{children:t("rich_text.content.label")}),r.jsx(o.ActionIcon,{ref:d,type:"submit",mr:5,variant:"filled",color:"green",children:r.jsx(R.DeviceFloppy,{size:20})})]}),r.jsx(b.Controller,{name:"content",control:a,render:({field:p})=>r.jsx(ws,{...p,styles:{root:{flexGrow:1}},label:t("rich_text.content.label"),onSubmit:h})})]})})}const sT=[{lang:"en",resources:{rich_text:{viz_name:"Rich Text"}}},{lang:"zh",resources:{rich_text:{viz_name:"富文本"}}}];class iT extends Me{constructor(){super(...arguments);N(this,"VERSION",1)}fixMalformedConfig(n){return v.defaults({},n,ii)}configVersions(){this.version(1,n=>({version:1,config:this.fixMalformedConfig(n)}))}}const aT={displayName:"viz.rich_text.viz_name",displayGroup:"chart.groups.others",migrator:new iT,name:"richText",viewRender:nT,configRender:rT,createConfig(){return{version:1,config:v.cloneDeep(ii)}},translation:sT},Kr={static:{type:"static",color:Rt.random().css()},dynamic:{type:"dynamic",func_content:["function getColor({ rowData, params, variables }, { lodash, interpolate }) {"," // your code goes here",' // return "blue"',"}"].join(`
|
|
276
|
+
`}})}function Pk(e){const{overflow:t,format:n,formatter:s,...i}=e.x_axis.axisLabel,a=Ct(t.on_axis);return ge.getXAxis({type:"value",name:e.x_axis.name??"",nameLocation:"middle",nameGap:25,axisLabel:{...i,...a,formatter:(l,c)=>{let u=l;try{u=re(l,n)}catch{}return ot(s)(u,c)}}})}const Lk={tooltip:{trigger:"axis"},grid:{top:50,left:5,right:10,bottom:20,containLabel:!0},dataZoom:[{type:"inside",xAxisIndex:[0]},{type:"inside",yAxisIndex:[0]}]};function Ok(e,t){const n=zk(e,t),s=Dk(e,n),i={xAxis:Pk(e),yAxis:ge.getYAxis({name:e.y_axis.name??"",nameLocation:"end",nameTextStyle:{align:"left"},nameGap:5}),series:[...n,...s],tooltip:Ak(e),legend:{show:!0,type:"scroll",orient:"horizontal",align:"left",right:0,top:0,left:"auto",itemGap:20,padding:[4,8,0,140],data:n.map(a=>a.name)}};return v.defaultsDeep({},i,Lk)}const ap={output:"number",mantissa:2,trimMantissa:!0,absolute:!1};function si(e,t,n){return 1-(1-e)*(t-1)/(t-n-1)}function Bk(e,t,n,s){const{x_axis:i,y_axis:a}=s,l=xn.regressionLinear()(n),{a:c,b:u,rSquared:d}=l;return{name:e,expression:r.jsxs(o.Group,{position:"center",noWrap:!0,spacing:10,children:[r.jsx(o.Text,{children:a.name}),r.jsx(o.Text,{children:"="}),r.jsx(o.Text,{weight:"bold",color:"red",children:re(u,ap)}),r.jsx(o.Text,{children:"+"}),r.jsx(o.Text,{weight:"bold",color:"red",children:re(c,ap)}),r.jsx(o.Text,{children:"×"}),r.jsx(o.Text,{children:i.name})]}),rSquared:d,adjustedRSquared:si(d,t.length,1)}}function Vk(e,t,n,s){const{x_axis:i,y_axis:a}=s,{a:l,b:c,rSquared:u}=xn.regressionExp()(n);return{name:e,expression:r.jsxs(o.Group,{position:"center",noWrap:!0,spacing:10,children:[r.jsx(o.Text,{children:a.name}),r.jsx(o.Text,{children:"="}),r.jsx(o.Text,{weight:"bold",color:"gray",children:l}),r.jsx(o.Text,{children:"×"}),r.jsxs(o.Group,{position:"left",noWrap:!0,spacing:2,children:[r.jsx(o.Text,{children:"Math.exp("}),r.jsx(o.Text,{weight:"bold",color:"gray",children:c}),r.jsx(o.Text,{children:"×"}),r.jsx(o.Text,{children:i.name}),r.jsx(o.Text,{children:")"})]})]}),rSquared:u,adjustedRSquared:si(u,t.length,1)}}function qk(e,t,n,s){const{x_axis:i,y_axis:a}=s,{a:l,b:c,rSquared:u}=xn.regressionLog()(n);return{name:e,expression:r.jsxs(o.Group,{position:"center",noWrap:!0,spacing:10,children:[r.jsx(o.Text,{children:a.name}),r.jsx(o.Text,{children:"="}),r.jsx(o.Text,{weight:"bold",color:"gray",children:l}),r.jsx(o.Text,{children:"×"}),r.jsxs(o.Group,{position:"left",noWrap:!0,spacing:2,children:[r.jsx(o.Text,{children:"Math.log("}),r.jsx(o.Text,{children:i.name}),r.jsx(o.Text,{children:")"}),r.jsx(o.Text,{children:"+"}),r.jsx(o.Text,{weight:"bold",color:"gray",children:c})]})]}),rSquared:u,adjustedRSquared:si(u,t.length,1)}}function Nk(e,t,n,s){const{x_axis:i,y_axis:a,regression:l}=s,c=xn.regressionPoly().order(l.transform.config.order)(n),{rSquared:u}=c;return console.log(c),{name:e,expression:"",rSquared:u,adjustedRSquared:si(u,t.length,1)}}function op(e,t,n){const{regression:s,x_axis:i}=n,a=O(i.data_key),l=O(s.y_axis_data_key),c=t.map(u=>[u[a.columnKey],u[l.columnKey]]);return s.transform.config.method==="linear"?Bk(e,t,c,n):s.transform.config.method==="exponential"?Vk(e,t,c,n):s.transform.config.method==="logistic"?qk(e,t,c,n):s.transform.config.method==="polynomial"?Nk(e,t,c,n):{name:e,expression:"",rSquared:0,adjustedRSquared:0}}function $k(e,t){if(!t)return[{name:"",expression:"",rSquared:0,adjustedRSquared:0}];if(!t.regression.group_by_key)return[op("",e,t)];const n=O(t.regression.group_by_key),s=v.groupBy(e,n.columnKey);return Object.entries(s).map(([i,a])=>op(i,a,t))}const Fk={marginTop:"10px","tbody th, tbody td":{padding:"7px 10px"},"tbody tr:not(:first-of-type) th":{borderTop:"1px solid #dee2e6"}};function lp({desc:e}){const{t}=j.useTranslation(),{expression:n,rSquared:s,adjustedRSquared:i}=e;return n?r.jsx(o.Table,{fontSize:14,sx:Fk,children:r.jsxs("tbody",{children:[r.jsx("tr",{children:r.jsx("td",{colSpan:2,children:r.jsx(o.Text,{align:"center",children:n})})}),r.jsxs("tr",{children:[r.jsx("td",{children:t("viz.regression_chart.r_sq")}),r.jsx("td",{style:{textAlign:"right"},children:re(s,{output:"percent",mantissa:1,absolute:!1})})]}),r.jsxs("tr",{children:[r.jsx("td",{children:t("viz.regression_chart.r_sq_adjusted")}),r.jsx("td",{style:{textAlign:"right"},children:re(i,{output:"percent",mantissa:1,absolute:!1})})]})]})}):r.jsx(o.Text,{children:"Unavailable for this regression method"})}function Gk({conf:e,queryData:t}){var s;const n=g.useMemo(()=>$k(t,e),[e,t]);return e.regression.group_by_key?(console.log(n),r.jsxs(o.Tabs,{defaultValue:(s=n[0])==null?void 0:s.name,color:"gray",children:[r.jsx(o.Tabs.List,{grow:!0,children:n.map(i=>r.jsx(o.Tabs.Tab,{value:i.name,children:i.name},i.name))}),n.map(i=>r.jsx(o.Tabs.Panel,{value:i.name,children:r.jsx(lp,{desc:i})},i.name))]})):r.jsx(lp,{desc:n[0]})}function Wk({conf:e,queryData:t}){const{t:n}=j.useTranslation();return r.jsxs(o.HoverCard,{shadow:"md",withinPortal:!0,zIndex:320,children:[r.jsx(o.HoverCard.Target,{children:r.jsx(o.Button,{size:"xs",variant:"subtle",compact:!0,leftIcon:r.jsx(M.IconInfoCircle,{size:14}),children:n("viz.regression_chart.regression_info")})}),r.jsx(o.HoverCard.Dropdown,{children:r.jsx(We,{children:r.jsx(Gk,{conf:e,queryData:t})})})]})}function Rk(e){return r.jsx(o.Group,{position:"apart",sx:{position:"absolute",top:0,left:it.left,right:it.right,height:"22px",zIndex:1},children:r.jsx(Wk,{...e})})}const Ao={x_axis:{name:"X Axis",data_key:"",axisLabel:{rotate:0,format:Ge,overflow:lt(),formatter:Xe()}},y_axis:{name:"Y Axis"},regression:{transform:{type:"ecStat:regression",config:{method:"linear",order:1,formulaOn:"end"}},plot:{type:"line",yAxisIndex:0,color:"#228be6",lineStyle:{type:"solid",width:1}},name:"regression",group_by_key:"",y_axis_data_key:"value"}};function Qk({context:e}){const{value:t}=Q(e.instanceData,"config"),{width:n,height:s}=e.viewport,i=g.useMemo(()=>{var m;const u=e.data,d=t==null?void 0:t.x_axis.data_key,h=(m=t==null?void 0:t.regression)==null?void 0:m.y_axis_data_key;if(!d||!h)return[];const p=O(d),f=O(h);return u[p.queryID].map(y=>typeof y[f.columnKey]=="number"?y:{...y,[f.columnKey]:Number(y[f.columnKey])})},[e.data,t==null?void 0:t.regression.y_axis_data_key]),a=g.useMemo(()=>Ok(v.defaultsDeep({},t,Ao),i),[t,i]),l=g.useRef(null),c=u=>{l.current=u};return!n||!s||!t?null:r.jsxs(at,{width:n,height:s,children:[r.jsx(Rk,{conf:t,queryData:i}),r.jsx(Ye,{echarts:Ue,onChartReady:c,option:a,style:Dr(n,s),notMerge:!0,theme:"merico-light"})]})}function Uk({control:e,watch:t}){const{t:n,i18n:s}=j.useTranslation();t("regression");const i=t("regression.transform.config.method"),a=t("regression.group_by_key"),l=g.useMemo(()=>[{label:n("chart.regression_line.method.linear"),value:"linear"},{label:n("chart.regression_line.method.exponential"),value:"exponential"},{label:n("chart.regression_line.method.logistic"),value:"logistic"},{label:n("chart.regression_line.method.polynomial"),value:"polynomial"}],[s.language]);return r.jsxs(o.Stack,{children:[r.jsx(o.Group,{grow:!0,noWrap:!0,children:r.jsx(b.Controller,{name:"regression.name",control:e,render:({field:c})=>r.jsx(o.TextInput,{label:n("common.name"),sx:{flex:1},...c})})}),r.jsx(b.Controller,{name:"regression.group_by_key",control:e,render:({field:c})=>r.jsx(U,{label:n("chart.series.group_by.label"),clearable:!0,sx:{flex:1},...c})}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"regression.transform.config.method",control:e,render:({field:c})=>r.jsx(o.Select,{label:n("chart.regression_line.method.label"),data:l,sx:{flex:1},...c})}),i==="polynomial"&&r.jsx(b.Controller,{name:"regression.transform.config.order",control:e,render:({field:c})=>r.jsx(o.NumberInput,{label:n("chart.regression_line.method.polynomial_order"),sx:{flex:1},...c})})]}),!a&&r.jsxs(o.Stack,{spacing:4,children:[r.jsx(o.Text,{size:"sm",children:n("chart.color.label")}),r.jsx(b.Controller,{name:"regression.plot.color",control:e,render:({field:c})=>r.jsx(Je,{...c})})]})]})}function Yk({control:e,watch:t}){return t(["x_axis"]),r.jsxs(o.Stack,{children:[r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"x_axis.name",control:e,render:({field:n})=>r.jsx(o.TextInput,{label:"X轴名称",sx:{flex:1},...n})}),r.jsx(b.Controller,{name:"x_axis.data_key",control:e,render:({field:n})=>r.jsx(U,{label:"X轴数据字段",required:!0,sx:{flex:1},...n})})]}),r.jsx(o.Divider,{variant:"dashed",labelPosition:"center",label:"格式化数据"}),r.jsx(o.Stack,{children:r.jsx(b.Controller,{name:"x_axis.axisLabel.format",control:e,render:({field:n})=>r.jsx(Dt,{...n})})}),r.jsx(o.Divider,{variant:"dashed",labelPosition:"center",label:"标签文案样式"}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"x_axis.axisLabel.rotate",control:e,render:({field:n})=>r.jsx(o.NumberInput,{label:"旋转",hideControls:!0,min:-90,max:90,rightSection:r.jsx(o.Text,{color:"dimmed",children:"度"}),sx:{width:"48%"},styles:{rightSection:{width:"4em",justifyContent:"flex-end",paddingRight:"6px"}},...n})}),r.jsx(b.Controller,{name:"x_axis.axisLabel.formatter",control:e,render:({field:n})=>r.jsx(Bt,{triggerButtonText:"自定义标签文案内容",...n})})]}),r.jsx(b.Controller,{name:"x_axis.axisLabel.overflow",control:e,render:({field:n})=>r.jsx(Vt,{...n})})]})}function Kk({control:e,watch:t}){return t(["y_axis","regression.y_axis_data_key"]),r.jsx(o.Stack,{children:r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"y_axis.name",control:e,render:({field:n})=>r.jsx(o.TextInput,{label:"Y轴名称",sx:{flex:1},...n})}),r.jsx(b.Controller,{name:"regression.y_axis_data_key",control:e,render:({field:n})=>r.jsx(U,{label:"Y轴数据字段",required:!0,sx:{flex:1},...n})})]})})}function Xk({context:e}){const{value:t,set:n}=Q(e.instanceData,"config"),s=g.useMemo(()=>v.defaults({},t,Ao),[t]),{control:i,handleSubmit:a,watch:l,getValues:c,reset:u}=b.useForm({defaultValues:s});g.useEffect(()=>{u(s)},[s]),l(["x_axis","y_axis","regression"]);const d=c(),h=g.useMemo(()=>!v.isEqual(d,t),[d,t]);return r.jsx(o.Stack,{spacing:"xs",children:r.jsxs("form",{onSubmit:a(n),children:[r.jsx(qe,{canSubmit:h}),r.jsxs(o.Tabs,{defaultValue:"X轴",orientation:"vertical",styles:{panel:{paddingTop:"6px",paddingLeft:"12px"}},children:[r.jsxs(o.Tabs.List,{children:[r.jsx(o.Tabs.Tab,{value:"X轴",children:"X轴"}),r.jsx(o.Tabs.Tab,{value:"Y轴",children:"Y轴"}),r.jsx(o.Tabs.Tab,{value:"回归",children:"回归"})]}),r.jsx(o.Tabs.Panel,{value:"X轴",children:r.jsx(Yk,{watch:l,control:i})}),r.jsx(o.Tabs.Panel,{value:"Y轴",children:r.jsx(Kk,{watch:l,control:i})}),r.jsx(o.Tabs.Panel,{value:"回归",children:r.jsx(Uk,{control:i,watch:l})})]})]})})}function Jk(e){const t={x_axis:{axisLabel:{rotate:0,format:Ge,overflow:lt(),formatter:Xe()}},regression:{group_by_key:""}};return v.defaultsDeep(t,e)}function Zk(e,{panelModel:t}){try{const n=t.queryIDs[0];if(!n)throw new Error("cannot migrate when queryID is empty");const s=c=>c&&`${n}.${c}`,{x_axis:i,regression:a,...l}=e;return{...l,x_axis:{...i,data_key:s(i.data_key)},regression:{...a,group_by_key:s(a.group_by_key),y_axis_data_key:s(a.y_axis_data_key)}}}catch(n){throw console.error("[Migration failed]",n),n}}const Hk=[{lang:"en",resources:{regression_chart:{viz_name:"Regression Chart",regression_info:"Regression Info",r_sq:"R-Sq",r_sq_adjusted:"R-Sq(Adjusted)"}}},{lang:"zh",resources:{regression_chart:{viz_name:"回归分析图",regression_info:"回归信息",r_sq:"R方",r_sq_adjusted:"R方(调整)"}}}];class eT extends Me{constructor(){super(...arguments);N(this,"VERSION",3)}configVersions(){this.version(1,n=>({version:1,config:n})),this.version(2,n=>({...n,version:2,config:Jk(n.config)})),this.version(3,(n,s)=>{const{config:i}=n;return{...n,version:3,config:Zk(i,s)}})}}const tT={displayName:"viz.regression_chart.viz_name",displayGroup:"chart.groups.merico_suite",migrator:new eT,name:"regressionChart",viewRender:Qk,configRender:Xk,createConfig(){return{version:3,config:v.cloneDeep(Ao)}},translation:Hk},ii={content:""},nT=D.observer(({context:e})=>{const t=Pe(),{panel:n}=Ot(),{value:s}=Q(e.instanceData,"config"),{variables:i,data:a}=e,l=g.useMemo(()=>{const c=v.defaults({},s,ii);return c.content?yu(c.content,i,t.payloadForViz,a):""},[a,s,i,t.payloadForViz]);return l?r.jsx(kr,{value:l,styles:{root:{border:"none",height:"100%"},content:{padding:0}},dashboardState:t.dashboardState,variableAggValueMap:n.variableAggValueMap}):null});function rT({context:e}){const{t}=j.useTranslation(),{value:n,set:s}=Q(e.instanceData,"config"),i=g.useMemo(()=>v.defaults({},n,ii),[n]),{control:a,handleSubmit:l,watch:c,reset:u}=b.useForm({defaultValues:i});c("content"),g.useEffect(()=>{u(i)},[i]);const d=g.useRef(null),h=()=>{var p;return(p=d.current)==null?void 0:p.click()};return r.jsx("form",{onSubmit:l(s),style:{flexGrow:1,display:"flex",flexDirection:"column"},children:r.jsxs(o.Stack,{spacing:"xs",sx:{flexGrow:1},children:[r.jsxs(o.Group,{position:"left",py:"md",pl:"md",sx:{borderBottom:"1px solid #eee",background:"#efefef",display:"none"},children:[r.jsx(o.Text,{children:t("rich_text.content.label")}),r.jsx(o.ActionIcon,{ref:d,type:"submit",mr:5,variant:"filled",color:"green",children:r.jsx(R.DeviceFloppy,{size:20})})]}),r.jsx(b.Controller,{name:"content",control:a,render:({field:p})=>r.jsx(ws,{...p,styles:{root:{flexGrow:1}},label:t("rich_text.content.label"),onSubmit:h})})]})})}const sT=[{lang:"en",resources:{rich_text:{viz_name:"Rich Text"}}},{lang:"zh",resources:{rich_text:{viz_name:"富文本"}}}];class iT extends Me{constructor(){super(...arguments);N(this,"VERSION",1)}fixMalformedConfig(n){return v.defaults({},n,ii)}configVersions(){this.version(1,n=>({version:1,config:this.fixMalformedConfig(n)}))}}const aT={displayName:"viz.rich_text.viz_name",displayGroup:"chart.groups.others",migrator:new iT,name:"richText",viewRender:nT,configRender:rT,createConfig(){return{version:1,config:v.cloneDeep(ii)}},translation:sT},Kr={static:{type:"static",color:Rt.random().css()},dynamic:{type:"dynamic",func_content:["function getColor({ rowData, params, variables }, { lodash, interpolate }) {"," // your code goes here",' // return "blue"',"}"].join(`
|
|
277
277
|
`)}},cp={id:"builtin:echarts:click-scatter-chart:series",displayName:"viz.scatter_chart.click_scatter.trigger",nameRender:lT,configRender:oT,payload:[{name:"seriesType",description:'"scatter"',valueType:"string"},{name:"componentType",description:'"series"',valueType:"string"},{name:"name",description:"Name of the series clicked",valueType:"string"},{name:"color",description:"Color",valueType:"string"},{name:"value",description:"String-typed number, or series' actual value",valueType:"string"},{name:"rowData",description:"Data of the row",valueType:"object"}]};function oT(e){return r.jsx(r.Fragment,{})}function lT(e){const{t}=j.useTranslation();return r.jsx(o.Text,{children:t("viz.scatter_chart.click_scatter.trigger")})}function up(){const{on_axis:e,in_tooltip:t}=lt();return{label:e,tooltip:t}}const Po={scatter:{y_data_key:"",name_data_key:"",symbolSize:{type:"static",size:10},color:Kr.static,label_position:"right",label_overflow:up()},stats:{templates:{top:"",bottom:""}},x_axis:{name:"",data_key:"",axisLabel:{rotate:0,formatter:Xe(),overflow:lt()}},y_axes:[{name:"Y Axis",position:"left",nameAlignment:"center",label_formatter:Ge,min:"",max:"",show:!0}],tooltip:{trigger:"item",metrics:[]},reference_lines:[],reference_areas:[],dataZoom:On};function cT(e,t){if(!e.x_axis.data_key)return[];const n=O(e.x_axis.data_key);return[{source:t[n.queryID]}]}function uT(e){const t=e.y_axes.some(i=>!!i.name);let n=15;t&&(n+=20),e.dataZoom.x_axis_slider&&(n+=20);let s=5;return e.x_axis.name&&(s+=15),{top:n,bottom:s}}function dT(){return{show:!1,bottom:0,left:"center",type:"scroll"}}function ai(e,t){if(e)return t[e]??void 0}function hT({reference_areas:e,variableValueMap:t}){const n=e.map(s=>[{name:s.content.text,value:s.content.text,itemStyle:s.itemStyle,label:s.label,xAxis:ai(s.leftBottomPoint.x_data_key,t),yAxis:ai(s.leftBottomPoint.y_data_key,t)},{xAxis:ai(s.rightTopPoint.x_data_key,t),yAxis:ai(s.rightTopPoint.y_data_key,t)}]);return{type:"scatter",name:"ref_areas",silent:!0,data:[],markArea:{data:n}}}function pT({type:e,...t},n){if(!e)return 10;if(e==="static"){const{size:i}=t;return i}const{func_content:s}=t;return(i,a)=>{const l=a.data;try{return new Function(`return ${s}`)()({rowData:l,params:a,variables:n},{lodash:v,interpolate:pn.interpolate})}catch(c){return console.error(`[getEchartsSymbolSize] failed parsing custom function, error: ${c.message}`),10}}}function fT({type:e,...t},n){if(!e)return Kr.static.color;if(e==="static"){const{color:i}=t;return i}const{func_content:s}=t;return({value:i})=>{try{return new Function(`return ${s}`)()({rowData:i,variables:n},{lodash:v,interpolate:pn.interpolate})}catch(a){return console.error(`[getSeriesColor] failed parsing custom function, error: ${a.message}`),10}}}function gT(e,t,n,s){return e.map(i=>{const a=i.orientation==="horizontal",l=a?"yAxis":"xAxis",c=a?"insideEndTop":"end";return{name:i.name,type:"line",hide_in_legend:!i.show_in_legend,yAxisIndex:i.yAxisIndex,data:[],lineStyle:i.lineStyle,markLine:{data:[{name:i.name,[l]:Number(n[i.variable_key])}],silent:!0,symbol:["none","none"],lineStyle:i.lineStyle,label:{formatter:function(){return i.template?Tr(i.template,t,s):""},position:c}}}})}function mT({x_axis:e,scatter:t},n){const s=O(e.data_key),i=O(t.y_data_key),a=O(t.name_data_key);return{label:{show:!!t.label_position,position:t.label_position,...Ct(t.label_overflow.label),formatter:({value:l})=>l[a.columnKey]},type:"scatter",name:"",xAxisId:"main-x-axis",yAxisIndex:0,datasetIndex:0,itemStyle:{color:fT(t.color,n)},symbolSize:pT(t.symbolSize,n),encode:{x:s.columnKey,y:i.columnKey}}}function xT(e,t,n,s){return[mT(e,s)].concat(gT(e.reference_lines,n,s,t)).concat(hT({reference_areas:e.reference_areas,variableValueMap:s}))}function dp(e,t,n){const{x_axis:s}=n;return s.axisLabel.formatter.enabled?ot(s.axisLabel.formatter)(e,t):e}function yT(e,t){const{x_axis:n,tooltip:s}=t;if(s.trigger==="item"){const c=os(e[0].data,n.data_key);return dp(c,0,t)}const i=e.find(c=>c.axisDim==="x"&&c.axisId==="main-x-axis");if(!i)return"";const{axisValue:a,axisIndex:l}=i;return dp(a,l,t)}const bT=e=>re(e,{output:"number",trimMantissa:!0,mantissa:2,absolute:!1});function vT(e,t){const{scatter:n,tooltip:s}=e;return ge.getTooltip({trigger:s.trigger,formatter:function(i){const a=t[0]??t.default,l=Array.isArray(i)?i:[i];if(l.length===0)return"";const c=yT(l,e),u=wt(e.scatter.label_overflow.tooltip),d=l.map(({value:y})=>`
|
|
278
278
|
<th style="text-align: right; padding-right: 1em">
|
|
279
279
|
<div style="${u}">${os(y,n.name_data_key)}</div>
|
|
@@ -295,7 +295,7 @@ Check the top-level render call using <`+q+">.")}return A}}function Dg(C,A){{if(
|
|
|
295
295
|
<thead><tr>${d.join("")}</tr></thead>
|
|
296
296
|
<tbody>${p.join("")}</tbody>
|
|
297
297
|
</table>
|
|
298
|
-
`}})}function _T(e,t){const n=t.every(c=>!Number.isNaN(Number(c))),{overflow:s,...i}=e.x_axis.axisLabel,a=Ct(s.on_axis),l=t.length===0;return[ge.getXAxis({data:t,name:e.x_axis.name??"",nameGap:l?5:void 0,id:"main-x-axis",type:n?"value":"category",axisLabel:{...i,...a,formatter:ot(i.formatter)}})]}function jT(e,t){return e.y_axes.map(({nameAlignment:n,min:s,max:i,...a},l)=>{let c=a.position;return c||(c=l>0?"right":"left"),ge.getYAxis({...a,minInterval:1,min:s||void 0,max:i||void 0,position:c,axisLine:{show:!0},axisLabel:{show:!0,formatter:t[l]??t.default},nameTextStyle:{align:n},nameLocation:"end",nameGap:15,splitLine:{show:!1}})})}const wT={xAxis:[{type:"category",nameGap:25,nameLocation:"center",nameTextStyle:{fontWeight:"bold"},splitLine:{show:!1},axisTick:{show:!0,alignWithLabel:!0}}],grid:{top:10,left:20,right:15,bottom:25,containLabel:!0}};function CT(e,t,n){const s=n.reduce((u,d)=>{const h=Xt(d,t);return u[d.name]=xt(d,h),u},{}),i=e.y_axes.reduce((u,{label_formatter:d},h)=>(u[h]=function(f){let m=f;if(typeof f=="object"&&(Array.isArray(f.value)&&f.value.length===2?m=f.value[1]:m=f.value),!d)return m;try{return re(m,d)}catch(y){return console.error(y),m}},u),{default:({value:u})=>u}),a=v.uniq(Et(t,e.x_axis.data_key)),l=xT(e,t,n,s),c={xAxis:_T(e,a),yAxis:jT(e,i),series:l,dataset:cT(e,t),tooltip:vT(e,i),grid:uT(e),legend:dT(),dataZoom:Is(e.dataZoom)};return v.defaultsDeep({},c,wT)}function hp(e){return e.trim().length>0}function ST({conf:e,data:t,width:n,height:s,interactionManager:i,variables:a}){const l=Bn(t,e.x_axis.data_key),c=yt(i.triggerManager,cp.id),u=g.useCallback(p=>{const f=p.data;c.forEach(m=>{i.runInteraction(m.id,{...p,rowData:f})})},[l,c,i]),d=g.useMemo(()=>({click:u}),[u]),h=g.useMemo(()=>CT(e,t,a),[e,t]);return r.jsx(Ye,{echarts:Ue,option:h,style:{width:n,height:s},onEvents:d,notMerge:!0,theme:"merico-light"})}function kT({context:e,instance:t}){const n=bt({vizManager:e.vizManager,instance:t}),{value:s}=Q(e.instanceData,"config"),{variables:i}=e,a=g.useMemo(()=>v.defaults({},s,Po),[s]),l=e.data,{width:c,height:u}=e.viewport,{ref:d,height:h}=Te.useElementSize(),{ref:p,height:f}=Te.useElementSize(),m=g.useMemo(()=>{const{stats:{templates:_}}=a;return{top:Cs(_.top,i,l),bottom:Cs(_.bottom,i,l)}},[a,l]),y=Math.max(0,Lt(u)-h-f);return!c||!u?null:r.jsxs(at,{width:c,height:u,children:[r.jsx(o.Text,{ref:d,align:"left",size:"xs",pl:"sm",sx:{display:hp(a.stats.templates.top)?"block":"none"},children:Object.values(m.top).map(_=>_)}),r.jsx(ST,{variables:i,width:Pt(c),height:y,data:l,conf:a,interactionManager:n}),r.jsx(o.Text,{ref:p,align:"left",size:"xs",pl:"sm",sx:{display:hp(a.stats.templates.bottom)?"block":"none"},children:Object.values(m.bottom).map(_=>_)})]})}const TT=g.forwardRef(({value:e,onChange:t,xAxisOptions:n,yAxisOptions:s,variableOptions:i},a)=>{const{t:l,i18n:c}=j.useTranslation(),u=(d,h)=>{const p=v.cloneDeep(e);v.set(p,d,h),t(p)};return r.jsxs(o.Stack,{children:[r.jsx(o.Divider,{mb:-15,variant:"dashed",label:l("chart.reference_area.content.label"),labelPosition:"right"}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(o.TextInput,{label:l("chart.reference_area.content.content_text"),value:e.content.text,onChange:d=>u("content.text",d.currentTarget.value)}),r.jsx(cr,{label:l("chart.reference_area.content.text_position"),value:e.label.position,onChange:d=>u("label.position",d)})]}),r.jsx(o.Divider,{mb:-15,variant:"dashed",label:l("chart.reference_area.endpoint.labels"),labelPosition:"right"}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[n&&r.jsx(o.Select,{label:l("chart.x_axis.label"),data:n,value:e.xAxisIndex,onChange:d=>u("xAxisIndex",d)}),s&&r.jsx(o.Select,{label:l("chart.y_axis.label"),data:s,value:e.yAxisIndex,onChange:d=>u("xAxisIndex",d)})]}),r.jsxs(o.Stack,{spacing:0,children:[r.jsx(o.Text,{size:14,color:"#212529",fw:500,children:l("chart.reference_area.endpoint.left_bottom_point")}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(o.Select,{icon:r.jsx(o.Text,{children:"x"}),data:i,value:e.leftBottomPoint.x_data_key,onChange:d=>u("leftBottomPoint.x_data_key",d??""),clearable:!0}),r.jsx(o.Select,{icon:r.jsx(o.Text,{children:"y"}),data:i,value:e.leftBottomPoint.y_data_key,onChange:d=>u("leftBottomPoint.y_data_key",d??""),clearable:!0})]})]}),r.jsxs(o.Stack,{spacing:0,children:[r.jsx(o.Text,{size:14,color:"#212529",fw:500,children:l("chart.reference_area.endpoint.right_top_point")}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(o.Select,{icon:r.jsx(o.Text,{children:"x"}),data:i,value:e.rightTopPoint.x_data_key,onChange:d=>u("rightTopPoint.x_data_key",d??""),clearable:!0}),r.jsx(o.Select,{icon:r.jsx(o.Text,{children:"y"}),data:i,value:e.rightTopPoint.y_data_key,onChange:d=>u("rightTopPoint.y_data_key",d??""),clearable:!0})]})]}),r.jsx(o.Divider,{mb:-15,variant:"dashed",label:l("chart.style.label"),labelPosition:"right"}),r.jsxs(o.Stack,{spacing:4,children:[r.jsx(o.Text,{size:14,children:l("chart.color.background_color")}),r.jsx(Je,{value:e.itemStyle.color,onChange:d=>u("itemStyle.color",d)})]}),r.jsxs(o.Stack,{spacing:4,children:[r.jsx(o.Text,{size:14,children:l("chart.color.text_color")}),r.jsx(Je,{value:e.label.color,onChange:d=>u("label.color",d)})]})]})});function DT(){const e=new Date().getTime().toString();return{id:e,content:{text:e},itemStyle:{color:"rgba(0,0,0,0.05)"},label:{position:"inside",color:"rgba(0,0,0,0.5)"},leftBottomPoint:{x_data_key:"",y_data_key:""},rightTopPoint:{x_data_key:"",y_data_key:""},xAxisIndex:"0",yAxisIndex:"0"}}function MT({control:e,watch:t,variables:n}){const{t:s}=j.useTranslation(),i=()=>DT(),a=g.useMemo(()=>n.map(d=>({label:d.name,value:d.name})),[n]),l=t("y_axes"),c=g.useMemo(()=>l.map(({name:d},h)=>({label:d,value:h.toString()})),[l]),u=(d,h)=>h+1;return r.jsx(ke,{control:e,watch:t,name:"reference_areas",getItem:i,addButtonText:s("chart.reference_area.add"),deleteButtonText:s("chart.reference_area.delete"),renderTabName:u,children:({field:d,index:h})=>r.jsx(b.Controller,{name:`reference_areas.${h}`,control:e,render:({field:p})=>r.jsx(o.Stack,{children:r.jsx(TT,{variableOptions:a,yAxisOptions:c,...p})})})})}function IT({control:e,index:t,watch:n,variableOptions:s,yAxisOptions:i}){const{t:a}=j.useTranslation(),l=n(`reference_lines.${t}.orientation`);return r.jsxs(o.Stack,{my:0,p:0,sx:{position:"relative"},children:[r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:`reference_lines.${t}.name`,control:e,render:({field:c})=>r.jsx(o.TextInput,{label:a("common.name"),placeholder:a("chart.reference_line.name_placeholder"),required:!0,sx:{flex:1},...c})}),r.jsx(b.Controller,{name:`reference_lines.${t}.variable_key`,control:e,render:({field:c})=>r.jsx(o.Select,{label:a("common.data_field"),required:!0,data:s,sx:{flex:1},...c})})]}),r.jsx(b.Controller,{name:`reference_lines.${t}.template`,control:e,render:({field:c})=>r.jsx(o.TextInput,{label:a("chart.content_template.label"),placeholder:a("chart.content_template.hint"),sx:{flex:1},...c})}),r.jsxs(o.Group,{grow:!0,children:[r.jsxs(o.Stack,{children:[r.jsx(b.Controller,{name:`reference_lines.${t}.orientation`,control:e,render:({field:c})=>r.jsx(Dn,{sx:{flex:1},...c})}),l==="vertical"&&r.jsx(o.Text,{mt:-10,color:"dimmed",size:12,children:a("chart.reference_line.orientation.vertical_hint")})]}),l==="horizontal"&&r.jsx(b.Controller,{name:`reference_lines.${t}.yAxisIndex`,control:e,render:({field:{value:c,onChange:u,...d}})=>r.jsx(o.Select,{label:"Y Axis",data:i,disabled:i.length===0,...d,value:(c==null?void 0:c.toString())??"",onChange:h=>{if(!h){u(0);return}u(Number(h))},sx:{flex:1}})})]}),r.jsx(o.Divider,{mb:-10,mt:10,variant:"dashed",label:a("chart.style.label"),labelPosition:"center"}),r.jsxs(o.Group,{grow:!0,children:[r.jsx(b.Controller,{name:`reference_lines.${t}.lineStyle.type`,control:e,render:({field:c})=>r.jsx(lr,{sx:{flexGrow:1},...c})}),r.jsx(b.Controller,{name:`reference_lines.${t}.lineStyle.width`,control:e,render:({field:c})=>r.jsx(o.NumberInput,{label:a("chart.series.line.line_width"),min:1,max:10,sx:{flexGrow:1},...c})})]}),r.jsxs(o.Stack,{spacing:4,children:[r.jsx(o.Text,{size:"sm",children:a("chart.color.label")}),r.jsx(b.Controller,{name:`reference_lines.${t}.lineStyle.color`,control:e,render:({field:c})=>r.jsx(Je,{...c})})]})]})}function zT({control:e,watch:t,variables:n}){const{t:s}=j.useTranslation(),i=()=>({name:"",template:"",variable_key:"",orientation:"horizontal",lineStyle:{type:"dashed",width:1,color:Rt.random().css()},show_in_legend:!1,yAxisIndex:0}),a=g.useMemo(()=>n.map(d=>({label:d.name,value:d.name})),[n]),l=t("y_axes"),c=g.useMemo(()=>l.map(({name:d},h)=>({label:d,value:h.toString()})),[l]),u=(d,h)=>{const p=d.name.trim();return p||h+1};return r.jsx(ke,{control:e,watch:t,name:"reference_lines",getItem:i,addButtonText:s("chart.reference_line.add"),deleteButtonText:s("chart.reference_line.delete"),renderTabName:u,children:({field:d,index:h})=>r.jsx(IT,{control:e,index:h,watch:t,variableOptions:a,yAxisOptions:c})})}const ET=({value:e,onChange:t})=>{const n=s=>{s&&t(s)};return r.jsx(o.Box,{children:r.jsx(ft,{height:"500px",defaultLanguage:"javascript",value:e,onChange:n,theme:"vs-dark",options:{minimap:{enabled:!1}}})})},AT=({value:e,onChange:t})=>{const{t:n}=j.useTranslation(),[s,{setTrue:i,setFalse:a}]=Z.useBoolean(),[l,c]=g.useState(e),u=()=>{a();const{type:f,func_content:m}=l,y={type:f,func_content:m};c(y),t(y)},d=()=>{a(),c(e)},h=f=>{c(m=>({...m,func_content:f}))},p=()=>{h(Kr.dynamic.func_content)};return r.jsxs(r.Fragment,{children:[r.jsx(o.Box,{sx:{width:"50%"},children:r.jsx(o.Button,{color:"grape",variant:"filled",leftIcon:r.jsx(M.IconMathFunction,{size:16}),mt:24,onClick:i,sx:{flexGrow:0},children:n("viz.scatter_chart.color.dynamic.setup")})}),r.jsx(o.Modal,{size:800,title:n("viz.scatter_chart.color.dynamic.setup_title"),opened:s,onClose:a,closeOnClickOutside:!1,withCloseButton:!1,zIndex:320,children:s&&r.jsxs(o.Stack,{children:[r.jsx(ET,{value:l.func_content,onChange:h}),r.jsxs(o.Group,{position:"apart",children:[r.jsx(o.Button,{onClick:p,color:"red",leftIcon:r.jsx(R.Recycle,{size:20}),children:n("common.actions.reset_to_default")}),r.jsxs(o.Group,{position:"right",children:[r.jsx(o.Button,{onClick:d,variant:"subtle",children:n("common.actions.cancel")}),r.jsx(o.Button,{color:"green",leftIcon:r.jsx(M.IconDeviceFloppy,{size:16}),onClick:u,children:n("common.actions.save")})]})]})]})})]})},PT=({value:e,onChange:t})=>e.type!=="dynamic"?null:r.jsx(AT,{value:e,onChange:t}),LT=({value:e,onChange:t})=>{if(e.type!=="static")return null;const n=s=>{t({...e,color:s})};return r.jsx(o.ColorInput,{label:" ",format:"rgb",value:e.color,onChange:n})},OT=g.forwardRef(({label:e="Color",value:t,onChange:n},s)=>{const{t:i,i18n:a}=j.useTranslation(),l=g.useMemo(()=>[{label:i("viz.scatter_chart.color.type.static"),value:"static"},{label:i("viz.scatter_chart.color.type.dynamic"),value:"dynamic"}],[a.language]),c=u=>{n({...Kr[u]})};return r.jsxs(o.SimpleGrid,{cols:2,children:[r.jsx(o.Select,{ref:s,label:e,data:l,value:t.type,onChange:c,sx:{flexGrow:1}}),r.jsx(LT,{value:t,onChange:n}),r.jsx(PT,{value:t,onChange:n})]})}),BT=g.forwardRef(({value:e,onChange:t},n)=>{const{t:s}=j.useTranslation(),i=l=>{t({...e,label:l})},a=l=>{t({...e,tooltip:l})};return r.jsxs(o.Stack,{ref:n,spacing:0,children:[r.jsx(Ds,{sectionTitle:s("chart.axis.overflow.section_title.on_axis"),value:e.label,onChange:i}),r.jsx(Ds,{sectionTitle:s("chart.axis.overflow.section_title.in_tooltip"),value:e.tooltip,onChange:a})]})});function VT({control:e,watch:t}){const{t:n}=j.useTranslation();return t(["scatter"]),r.jsxs(o.Stack,{children:[r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"scatter.name_data_key",control:e,render:({field:s})=>r.jsx(U,{label:n("common.name_data_field"),required:!0,sx:{flex:1},...s})}),r.jsx(b.Controller,{name:"scatter.y_data_key",control:e,render:({field:s})=>r.jsx(U,{label:n("common.value_data_field"),required:!0,sx:{flex:1},...s})})]}),r.jsx(o.Divider,{mb:-15,label:n("chart.style.label"),labelPosition:"center"}),r.jsx(b.Controller,{name:"scatter.symbolSize",control:e,render:({field:s})=>r.jsx(So,{...s})}),r.jsx(b.Controller,{name:"scatter.color",control:e,render:({field:s})=>r.jsx(OT,{...s})}),r.jsx(o.Divider,{mb:-15,label:n("chart.label.label"),labelPosition:"center"}),r.jsx(o.Group,{grow:!0,noWrap:!0,children:r.jsx(b.Controller,{name:"scatter.label_position",control:e,render:({field:s})=>r.jsx(cr,{label:n("chart.label_position.label"),withOffOption:!0,...s,onChange:i=>{i&&s.onChange(i)}})})}),r.jsx(b.Controller,{name:"scatter.label_overflow",control:e,render:({field:s})=>r.jsx(BT,{...s})})]})}function qT({control:e,watch:t}){const{t:n}=j.useTranslation();return t("stats"),r.jsx(o.Stack,{children:r.jsxs(o.Stack,{spacing:0,children:[r.jsx(b.Controller,{name:"stats.templates.top",control:e,render:({field:s})=>r.jsx(is,{label:n("chart.stats.template.above_chart"),py:"md",sx:{flexGrow:1},...s})}),r.jsx(b.Controller,{name:"stats.templates.bottom",control:e,render:({field:s})=>r.jsx(is,{label:n("chart.stats.template.under_chart"),py:"md",sx:{flexGrow:1},...s})})]})})}const NT=({control:e,index:t})=>{const{t:n}=j.useTranslation();return r.jsx(o.Stack,{children:r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:`tooltip.metrics.${t}.name`,control:e,render:({field:s})=>r.jsx(o.TextInput,{label:n("common.name"),required:!0,sx:{flex:1},...s})}),r.jsx(b.Controller,{name:`tooltip.metrics.${t}.data_key`,control:e,render:({field:s})=>r.jsx(U,{label:n("common.data_field"),required:!0,sx:{flex:1},...s})})]})})},$T=({control:e,watch:t})=>{const{t:n}=j.useTranslation(),s=()=>({id:Date.now().toString(),data_key:"",name:""}),i=(a,l)=>{const c=a.name.trim();return c||l+1};return r.jsxs(r.Fragment,{children:[r.jsxs(o.Group,{spacing:2,sx:{cursor:"default",userSelect:"none"},children:[r.jsx(R.InfoCircle,{size:14,color:"#888"}),r.jsx(o.Text,{size:14,color:"#888",children:n("chart.tooltip.additional_metrics.description")})]}),r.jsx(ke,{control:e,watch:t,name:"tooltip.metrics",getItem:s,addButtonText:n("chart.tooltip.additional_metrics.add"),deleteButtonText:n("chart.tooltip.additional_metrics.delete"),renderTabName:i,children:({field:a,index:l})=>r.jsx(NT,{control:e,index:l})})]})};function FT({control:e,watch:t}){const{t:n,i18n:s}=j.useTranslation();t("tooltip.trigger");const i=g.useMemo(()=>[{label:n("chart.tooltip.trigger.scatter_point"),value:"item"},{label:n("chart.tooltip.trigger.x_axis"),value:"axis"}],[s.language]);return r.jsxs(o.Stack,{children:[r.jsx(b.Controller,{name:"tooltip.trigger",control:e,render:({field:a})=>r.jsx(o.Select,{label:n("chart.tooltip.trigger.label"),data:i,sx:{flexGrow:1},...a})}),r.jsx(o.Divider,{variant:"dashed"}),r.jsx($T,{control:e,watch:t})]})}function GT({control:e,watch:t}){const{t:n}=j.useTranslation();return t(["x_axis"]),r.jsxs(o.Stack,{children:[r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"x_axis.data_key",control:e,render:({field:s})=>r.jsx(U,{label:n("common.data_field"),required:!0,sx:{flex:1},...s})}),r.jsx(b.Controller,{name:"x_axis.name",control:e,render:({field:s})=>r.jsx(o.TextInput,{label:n("common.name"),sx:{flex:1},...s})})]}),r.jsx(o.Divider,{mb:-15,label:n("chart.axis.tick_label"),labelPosition:"center"}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"x_axis.axisLabel.rotate",control:e,render:({field:s})=>r.jsx(cn,{sx:{width:"48%"},...s})}),r.jsx(b.Controller,{name:"x_axis.axisLabel.formatter",control:e,render:({field:s})=>r.jsx(Bt,{...s})})]}),r.jsx(b.Controller,{name:"x_axis.axisLabel.overflow",control:e,render:({field:s})=>r.jsx(Vt,{...s})})]})}function WT({control:e,index:t}){const{t:n}=j.useTranslation();return r.jsxs(o.Stack,{my:0,p:"0",sx:{position:"relative"},children:[r.jsx(o.Divider,{mb:-15,mt:15,variant:"dashed",label:n("chart.y_axis.y_axis_name"),labelPosition:"center"}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:`y_axes.${t}.name`,control:e,render:({field:s})=>r.jsx(o.TextInput,{label:n("common.name"),required:!0,sx:{flex:1},...s})}),r.jsx(b.Controller,{name:`y_axes.${t}.nameAlignment`,control:e,render:({field:s})=>r.jsx(Mn,{sx:{flex:1},...s})})]}),r.jsx(o.Divider,{mb:-15,variant:"dashed",label:n("chart.y_axis.layout"),labelPosition:"center"}),r.jsx(o.Group,{grow:!0,noWrap:!0,children:r.jsx(b.Controller,{name:`y_axes.${t}.position`,control:e,render:({field:s})=>r.jsx(Fh,{sx:{flex:1},...s})})}),r.jsxs(o.Stack,{children:[r.jsx(o.Divider,{mb:-15,variant:"dashed",label:n("chart.y_axis.label_format"),labelPosition:"center"}),r.jsx(b.Controller,{name:`y_axes.${t}.label_formatter`,control:e,render:({field:s})=>r.jsx(Dt,{...s})})]}),r.jsxs(o.Stack,{children:[r.jsx(o.Divider,{mb:-15,variant:"dashed",label:n("chart.y_axis.value_range"),labelPosition:"center"}),r.jsxs(o.Group,{grow:!0,children:[r.jsx(b.Controller,{name:`y_axes.${t}.min`,control:e,render:({field:s})=>r.jsx(o.TextInput,{label:n("chart.y_axis.value_min"),...s})}),r.jsx(b.Controller,{name:`y_axes.${t}.max`,control:e,render:({field:s})=>r.jsx(o.TextInput,{label:n("chart.y_axis.value_max"),...s})})]})]})]})}function RT({control:e,watch:t}){const{t:n}=j.useTranslation(),s=()=>({name:"",label_formatter:Ge,min:"",max:"",show:!0,position:"right",nameAlignment:"right"}),i=(l,c)=>{const u=l.name.trim();return u||c+1},a=({field:l,index:c,fields:u})=>u.length<=1;return r.jsx(ke,{control:e,watch:t,name:"y_axes",getItem:s,addButtonText:n("chart.y_axis.add"),deleteButtonText:n("chart.y_axis.delete"),renderTabName:i,deleteDisalbed:a,children:({field:l,index:c})=>r.jsx(WT,{control:e,index:c})})}function QT(e){return e||{templates:{top:"",bottom:""}}}function UT({reference_lines:e=[],stats:t,...n}){return{reference_lines:e,stats:QT(t),...n}}function YT({context:e}){const{t}=j.useTranslation(),{value:n,set:s}=Q(e.instanceData,"config"),{variables:i}=e,a=g.useMemo(()=>v.defaultsDeep({},n,Po),[n]),l=g.useMemo(()=>UT(a),[a]);g.useEffect(()=>{!v.isEqual(a,l)&&(console.log("config malformed, resetting to defaults",a,l),s(l))},[a,l]);const{control:c,handleSubmit:u,watch:d,getValues:h,reset:p}=b.useForm({defaultValues:l});g.useEffect(()=>{p(l)},[l]);const f=h(),m=g.useMemo(()=>!v.isEqual(f,a),[f,a]);return d(["dataZoom"]),r.jsx(o.Stack,{spacing:"xs",children:r.jsxs("form",{onSubmit:u(s),children:[r.jsx(qe,{canSubmit:m}),r.jsxs(o.Tabs,{defaultValue:"X Axis",orientation:"vertical",styles:{tab:{paddingLeft:"6px",paddingRight:"6px"},panel:{paddingTop:"6px",paddingLeft:"12px"}},children:[r.jsxs(o.Tabs.List,{children:[r.jsx(o.Tabs.Tab,{value:"X Axis",children:t("chart.x_axis.label")}),r.jsx(o.Tabs.Tab,{value:"Y Axes",children:t("chart.y_axis.labels")}),r.jsx(o.Tabs.Tab,{value:"Scatter",children:t("chart.series.scatter.label")}),r.jsx(o.Tabs.Tab,{value:"Tooltip",children:t("chart.tooltip.label")}),r.jsx(o.Tabs.Tab,{value:"Stats",children:t("chart.stats.label")}),r.jsx(o.Tabs.Tab,{value:"Reference Lines",children:t("chart.reference_line.labels")}),r.jsx(o.Tabs.Tab,{value:"Reference Areas",children:t("chart.reference_area.labels")}),r.jsx(o.Tabs.Tab,{value:"Zooming",children:t("chart.zooming.label")})]}),r.jsx(o.Tabs.Panel,{value:"X Axis",children:r.jsx(GT,{control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Y Axes",children:r.jsx(RT,{control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Scatter",children:r.jsx(VT,{control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Tooltip",children:r.jsx(FT,{control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Stats",children:r.jsx(qT,{control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Reference Lines",children:r.jsx(zT,{variables:i,control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Reference Areas",children:r.jsx(MT,{variables:i,control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Zooming",children:r.jsx(b.Controller,{name:"dataZoom",control:c,render:({field:y})=>r.jsx(Zs,{...y})})})]})]})})}const KT=[{lang:"en",resources:{scatter_chart:{viz_name:"Scatter Chart",color:{type:{static:"Static",dynamic:"Dynamic"},dynamic:{setup:"Setup",setup_title:"Setup dynamic color"}},click_scatter:{trigger:"Click Scatter"}}}},{lang:"zh",resources:{scatter_chart:{viz_name:"散点图",color:{type:{static:"具体颜色",dynamic:"动态计算颜色"},dynamic:{setup:"设置",setup_title:"设置动态计算颜色的逻辑"}},click_scatter:{trigger:"点击散点"}}}}];function XT(e){const{dataZoom:t=On,...n}=e;return{...n,dataZoom:t}}function JT(e){const t={scatter:{label_overflow:up()}};return v.defaultsDeep(t,e)}function ZT(e){const{color:t}=e.scatter;return typeof t=="string"?{...e,scatter:{...e.scatter,color:{...Kr.static,color:t}}}:e}function HT(e){const t=e.reference_lines.map(n=>{const{lineStyle:s={type:"dashed",width:1,color:Rt.random().css()},show_in_legend:i=!1,yAxisIndex:a=0}=n;return{...n,lineStyle:s,show_in_legend:i,yAxisIndex:a}});return{...e,reference_lines:t}}function eD(e){const t={tooltip:{trigger:"item"}};return v.defaultsDeep({},e,t)}function tD(e,{panelModel:t}){try{const n=t.queryIDs[0];if(!n)throw new Error("cannot migrate when queryID is empty");const s=u=>u&&`${n}.${u}`,{x_axis:i,scatter:a,tooltip:l,...c}=e;return{...c,x_axis:{...i,data_key:s(i.data_key)},scatter:{...a,y_data_key:s(a.y_data_key),name_data_key:s(a.name_data_key)},tooltip:{...l,metrics:l.metrics.map(u=>({...u,data_key:s(u.data_key)}))}}}catch(n){throw console.error("[Migration failed]",n),n}}function nD(e){const t={x_axis:{axisLabel:{overflow:lt()}}};return v.defaultsDeep(t,e)}class rD extends Me{constructor(){super(...arguments);N(this,"VERSION",10)}configVersions(){this.version(1,n=>({version:1,config:n})),this.version(2,n=>{const{tooltip:s={metrics:[]},...i}=n.config;return{...n,version:2,config:{...i,tooltip:s}}}),this.version(3,n=>({...n,version:3,config:XT(n.config)})),this.version(4,n=>{const{config:s}=n;return{...n,version:5,config:JT(s)}}),this.version(6,n=>{const{config:s}=n;return{...n,version:6,config:ZT(s)}}),this.version(7,n=>{const{config:s}=n;return{...n,version:7,config:HT(s)}}),this.version(8,n=>{const{config:s}=n;return{...n,version:8,config:eD(s)}}),this.version(9,(n,s)=>{const{config:i}=n;return{...n,version:9,config:tD(i,s)}}),this.version(10,(n,s)=>{const{config:i}=n;return{...n,version:10,config:nD(i)}})}}const sD={displayName:"viz.scatter_chart.viz_name",displayGroup:"chart.groups.echarts_based_charts",migrator:new rD,name:"scatterChart",viewRender:kT,configRender:YT,createConfig(){return{version:10,config:v.cloneDeep(Po)}},triggers:[cp],translation:KT},Lo={content:"Use double curly brackets to wrap js code: {{ new Date().getTime() }}",vertical_align:"center"};function iD(e){if("variables"in e)return e;const{align:t,size:n,weight:s,color:i,content:{prefix:a="",data_field:l="value",formatter:c={output:"number",mantissa:0},postfix:u=""}={}}=e;return{align:t,template:`${a} \${value} ${u}`,variables:[{name:"value",data_field:l,aggregation:{type:"none",config:{}},formatter:c,color:i,weight:s,size:n}]}}function aD(e){return v.omit(e,["variables"])}function oD(e){const{align:t,...n}=e;return{horizontal_align:t,vertical_align:"center",...n}}function lD(e){const t=v.cloneDeep(e),n=v.get(t,"color.valueRange");return n!==void 0&&v.set(t,"color.valueRange",n.map(s=>Number(s))),t}function cD(e,t){return!t||t==="left"?e:`<p style="text-align: ${t}">${e}</p>`}function uD(e,t){const{horizontal_align:n,template:s,...i}=e;let a=pu(s,t);return a=cD(a,n),{content:a,...i}}function dD(e,t){const{content:n,...s}=e;return{content:pu(n,t),...s}}class hD extends Me{constructor(){super(...arguments);N(this,"VERSION",5)}configVersions(){this.version(1,n=>({version:1,config:iD(n)})),this.version(2,(n,{panelModel:s})=>{const{config:i}=n;return(i.variables||[]).forEach(l=>{s.variables.find(c=>c.name===l.name)||s.addVariable(lD(l))}),{...n,version:2,config:aD(i)}}),this.version(3,n=>{const{config:s}=n;return{...n,version:3,config:oD(s)}}),this.version(4,(n,{panelModel:s})=>{const{config:i}=n;return{...n,version:4,config:uD(i,s)}}),this.version(5,(n,{panelModel:s})=>{const{config:i}=n;return{...n,version:5,config:dD(i,s)}})}}const pp={id:"builtin:stats:click-stats",displayName:"viz.stats.click_stats.trigger",nameRender:fD,configRender:pD,payload:[{name:"variables",description:"Panel variables",valueType:"object"}]};function pD(e){return r.jsx(r.Fragment,{})}function fD(e){const{t}=j.useTranslation();return r.jsx(o.Text,{children:t("viz.stats.click_stats.trigger")})}const gD={top:"flex-start",center:"center",bottom:"flex-end"};function mD(e){const t={flexGrow:1};return e>0&&(t.cursor="pointer",t["&:hover"]={textDecoration:"underline"}),t}const xD=D.observer(({context:e,instance:t})=>{const n=bt({vizManager:e.vizManager,instance:t}),s=yt(n.triggerManager,pp.id),i=Pe(),{value:a=Lo}=Q(e.instanceData,"config"),{panel:l}=Ot(),{data:c,variables:u}=e,{width:d,height:h}=e.viewport,p=g.useMemo(()=>{const m=v.defaults({},a,Lo);return m.content?yu(m.content,u,i.payloadForViz,c):""},[a,u,i.payloadForViz]),f=g.useCallback(()=>{s.forEach(m=>{n.runInteraction(m.id,{variables:l.variableValueMap})})},[l.variableValueMap,s,n]);return r.jsx(o.Flex,{className:"viz-stats",sx:{width:d,height:h},align:gD[a.vertical_align],direction:"row",children:r.jsx(o.Box,{className:"viz-stats--clickable-wrapper",sx:mD(s.length),onClick:f,children:r.jsx(kr,{value:p,styles:{root:{border:"none",maxWidth:d,maxHeight:h,"&.mantine-RichTextEditor-root":{overflow:"auto !important"}},content:{"&.mantine-RichTextEditor-content .ProseMirror":{padding:0}}},dashboardState:i.dashboardState,variableAggValueMap:l.variableAggValueMap})})})});function yD({conf:e,setConf:t}){const{t:n}=j.useTranslation(),s=g.useMemo(()=>v.defaults({},e),[e]),{control:i,handleSubmit:a,watch:l,getValues:c,reset:u}=b.useForm({defaultValues:s});g.useEffect(()=>{u(s)},[s]),l(["content","vertical_align"]);const d=c(),h=g.useMemo(()=>!v.isEqual(d,e),[d,e]);return r.jsx("form",{onSubmit:a(t),children:r.jsxs(o.Stack,{spacing:"xs",children:[r.jsx(qe,{canSubmit:h}),r.jsx(b.Controller,{control:i,name:"vertical_align",render:({field:p})=>r.jsx($u,{...p})}),r.jsx(b.Controller,{name:"content",control:i,render:({field:p})=>r.jsx(ws,{...p,styles:{root:{flexGrow:1,minHeight:"240px"}},label:n("rich_text.content.label"),autoSubmit:!0})})]})})}function bD(e){const{value:t,set:n}=Q(e.context.instanceData,"config");return t?r.jsx(yD,{conf:t,setConf:n}):null}const vD=[{lang:"en",resources:{stats:{viz_name:"Stats",click_stats:{trigger:"Click stats text"}}}},{lang:"zh",resources:{stats:{viz_name:"数据指标",click_stats:{trigger:"点击文字"}}}}],_D={createConfig(){return{version:5,config:Lo}},displayName:"viz.stats.viz_name",displayGroup:"chart.groups.others",migrator:new hD,name:"stats",viewRender:xD,configRender:bD,triggers:[pp],translation:vD},Oo={label_key:"",value_key:"",group_key:"",levels:[]};function jD(e){const t=new Set(e.map(s=>s.parent_id)),n=new Set(e.map(s=>s.id));return t.forEach(s=>{s===null||n.has(s)||e.push({id:s,name:s,parent_id:null})}),e}function wD(e){const t=jD(e).map(i=>({...i,children:[]})),n=v.keyBy(t,i=>i.id),s=[];return t.forEach(i=>{if(!i.parent_id||!n[i.parent_id]){s.push(i);return}n[i.parent_id].children.push(i)}),s}function CD(e,t){const{label_key:n,value_key:s,group_key:i}=e;if(!n||!s)return[];const a=O(n),l=O(s),c=O(i),u=t[a.queryID].map(d=>({...d,id:d[a.columnKey],parent_id:d[c.columnKey],name:d[a.columnKey],value:d[l.columnKey]?Number(d[l.columnKey]):d[l.columnKey]}));return i?wD(u):u}const SD=e=>({treePathInfo:t,name:n,value:s})=>{if(t.length===1||!e)return n;try{const i=t[t.length-2].value;if(s/i<e)return" "}catch{return n}};function kD(e){const{levels:t}=e;return t.map(n=>{const{show_label_tolerance:s,...i}=n.label;return{...n,label:{...i,formatter:SD(s)}}})}function TD(){return({treePathInfo:e,name:t,value:n,color:s,marker:i,...a})=>{const l=e.slice(0,e.length-1),c=[`<tr>
|
|
298
|
+
`}})}function _T(e,t){const n=t.every(c=>!Number.isNaN(Number(c))),{overflow:s,...i}=e.x_axis.axisLabel,a=Ct(s.on_axis),l=t.length===0;return[ge.getXAxis({data:t,name:e.x_axis.name??"",nameGap:l?5:void 0,id:"main-x-axis",type:n?"value":"category",axisLabel:{...i,...a,formatter:ot(i.formatter)}})]}function jT(e,t){return e.y_axes.map(({nameAlignment:n,min:s,max:i,...a},l)=>{let c=a.position;return c||(c=l>0?"right":"left"),ge.getYAxis({...a,minInterval:1,min:s||void 0,max:i||void 0,position:c,axisLine:{show:!0},axisLabel:{show:!0,formatter:t[l]??t.default},nameTextStyle:{align:n},nameLocation:"end",nameGap:15,splitLine:{show:!1}})})}const wT={xAxis:[{type:"category",nameGap:25,nameLocation:"center",nameTextStyle:{fontWeight:"bold"},splitLine:{show:!1},axisTick:{show:!0,alignWithLabel:!0}}],grid:{top:10,left:20,right:15,bottom:25,containLabel:!0}};function CT(e,t,n){const s=n.reduce((u,d)=>{const h=Xt(d,t);return u[d.name]=xt(d,h),u},{}),i=e.y_axes.reduce((u,{label_formatter:d},h)=>(u[h]=function(f){let m=f;if(typeof f=="object"&&(Array.isArray(f.value)&&f.value.length===2?m=f.value[1]:m=f.value),!d)return m;try{return re(m,d)}catch(y){return console.error(y),m}},u),{default:({value:u})=>u}),a=v.uniq(Et(t,e.x_axis.data_key)),l=xT(e,t,n,s),c={xAxis:_T(e,a),yAxis:jT(e,i),series:l,dataset:cT(e,t),tooltip:vT(e,i),grid:uT(e),legend:dT(),dataZoom:Is(e.dataZoom)};return v.defaultsDeep({},c,wT)}function hp(e){return e.trim().length>0}function ST({conf:e,data:t,width:n,height:s,interactionManager:i,variables:a}){const l=Bn(t,e.x_axis.data_key),c=yt(i.triggerManager,cp.id),u=g.useCallback(p=>{const f=p.data;c.forEach(m=>{i.runInteraction(m.id,{...p,rowData:f})})},[l,c,i]),d=g.useMemo(()=>({click:u}),[u]),h=g.useMemo(()=>CT(e,t,a),[e,t]);return r.jsx(Ye,{echarts:Ue,option:h,style:{width:n,height:s},onEvents:d,notMerge:!0,theme:"merico-light"})}function kT({context:e,instance:t}){const n=bt({vizManager:e.vizManager,instance:t}),{value:s}=Q(e.instanceData,"config"),{variables:i}=e,a=g.useMemo(()=>v.defaults({},s,Po),[s]),l=e.data,{width:c,height:u}=e.viewport,{ref:d,height:h}=Te.useElementSize(),{ref:p,height:f}=Te.useElementSize(),m=g.useMemo(()=>{const{stats:{templates:_}}=a;return{top:Cs(_.top,i,l),bottom:Cs(_.bottom,i,l)}},[a,l]),y=Math.max(0,Lt(u)-h-f);return!c||!u?null:r.jsxs(at,{width:c,height:u,children:[r.jsx(o.Text,{ref:d,align:"left",size:"xs",pl:"sm",sx:{display:hp(a.stats.templates.top)?"block":"none"},children:Object.values(m.top).map(_=>_)}),r.jsx(ST,{variables:i,width:Pt(c),height:y,data:l,conf:a,interactionManager:n}),r.jsx(o.Text,{ref:p,align:"left",size:"xs",pl:"sm",sx:{display:hp(a.stats.templates.bottom)?"block":"none"},children:Object.values(m.bottom).map(_=>_)})]})}const TT=g.forwardRef(({value:e,onChange:t,xAxisOptions:n,yAxisOptions:s,variableOptions:i},a)=>{const{t:l,i18n:c}=j.useTranslation(),u=(d,h)=>{const p=v.cloneDeep(e);v.set(p,d,h),t(p)};return r.jsxs(o.Stack,{children:[r.jsx(o.Divider,{mb:-15,variant:"dashed",label:l("chart.reference_area.content.label"),labelPosition:"right"}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(o.TextInput,{label:l("chart.reference_area.content.content_text"),value:e.content.text,onChange:d=>u("content.text",d.currentTarget.value)}),r.jsx(cr,{label:l("chart.reference_area.content.text_position"),value:e.label.position,onChange:d=>u("label.position",d)})]}),r.jsx(o.Divider,{mb:-15,variant:"dashed",label:l("chart.reference_area.endpoint.labels"),labelPosition:"right"}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[n&&r.jsx(o.Select,{label:l("chart.x_axis.label"),data:n,value:e.xAxisIndex,onChange:d=>u("xAxisIndex",d)}),s&&r.jsx(o.Select,{label:l("chart.y_axis.label"),data:s,value:e.yAxisIndex,onChange:d=>u("xAxisIndex",d)})]}),r.jsxs(o.Stack,{spacing:0,children:[r.jsx(o.Text,{size:14,color:"#212529",fw:500,children:l("chart.reference_area.endpoint.left_bottom_point")}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(o.Select,{icon:r.jsx(o.Text,{children:"x"}),data:i,value:e.leftBottomPoint.x_data_key,onChange:d=>u("leftBottomPoint.x_data_key",d??""),clearable:!0}),r.jsx(o.Select,{icon:r.jsx(o.Text,{children:"y"}),data:i,value:e.leftBottomPoint.y_data_key,onChange:d=>u("leftBottomPoint.y_data_key",d??""),clearable:!0})]})]}),r.jsxs(o.Stack,{spacing:0,children:[r.jsx(o.Text,{size:14,color:"#212529",fw:500,children:l("chart.reference_area.endpoint.right_top_point")}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(o.Select,{icon:r.jsx(o.Text,{children:"x"}),data:i,value:e.rightTopPoint.x_data_key,onChange:d=>u("rightTopPoint.x_data_key",d??""),clearable:!0}),r.jsx(o.Select,{icon:r.jsx(o.Text,{children:"y"}),data:i,value:e.rightTopPoint.y_data_key,onChange:d=>u("rightTopPoint.y_data_key",d??""),clearable:!0})]})]}),r.jsx(o.Divider,{mb:-15,variant:"dashed",label:l("chart.style.label"),labelPosition:"right"}),r.jsxs(o.Stack,{spacing:4,children:[r.jsx(o.Text,{size:14,children:l("chart.color.background_color")}),r.jsx(Je,{value:e.itemStyle.color,onChange:d=>u("itemStyle.color",d)})]}),r.jsxs(o.Stack,{spacing:4,children:[r.jsx(o.Text,{size:14,children:l("chart.color.text_color")}),r.jsx(Je,{value:e.label.color,onChange:d=>u("label.color",d)})]})]})});function DT(){const e=new Date().getTime().toString();return{id:e,content:{text:e},itemStyle:{color:"rgba(0,0,0,0.05)"},label:{position:"inside",color:"rgba(0,0,0,0.5)"},leftBottomPoint:{x_data_key:"",y_data_key:""},rightTopPoint:{x_data_key:"",y_data_key:""},xAxisIndex:"0",yAxisIndex:"0"}}function MT({control:e,watch:t,variables:n}){const{t:s}=j.useTranslation(),i=()=>DT(),a=g.useMemo(()=>n.map(d=>({label:d.name,value:d.name})),[n]),l=t("y_axes"),c=g.useMemo(()=>l.map(({name:d},h)=>({label:d,value:h.toString()})),[l]),u=(d,h)=>h+1;return r.jsx(ke,{control:e,watch:t,name:"reference_areas",getItem:i,addButtonText:s("chart.reference_area.add"),deleteButtonText:s("chart.reference_area.delete"),renderTabName:u,children:({field:d,index:h})=>r.jsx(b.Controller,{name:`reference_areas.${h}`,control:e,render:({field:p})=>r.jsx(o.Stack,{children:r.jsx(TT,{variableOptions:a,yAxisOptions:c,...p})})})})}function IT({control:e,index:t,watch:n,variableOptions:s,yAxisOptions:i}){const{t:a}=j.useTranslation(),l=n(`reference_lines.${t}.orientation`);return r.jsxs(o.Stack,{my:0,p:0,sx:{position:"relative"},children:[r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:`reference_lines.${t}.name`,control:e,render:({field:c})=>r.jsx(o.TextInput,{label:a("common.name"),placeholder:a("chart.reference_line.name_placeholder"),required:!0,sx:{flex:1},...c})}),r.jsx(b.Controller,{name:`reference_lines.${t}.variable_key`,control:e,render:({field:c})=>r.jsx(o.Select,{label:a("common.data_field"),required:!0,data:s,sx:{flex:1},...c})})]}),r.jsx(b.Controller,{name:`reference_lines.${t}.template`,control:e,render:({field:c})=>r.jsx(o.TextInput,{label:a("chart.content_template.label"),placeholder:a("chart.content_template.hint"),sx:{flex:1},...c})}),r.jsxs(o.Group,{grow:!0,children:[r.jsxs(o.Stack,{children:[r.jsx(b.Controller,{name:`reference_lines.${t}.orientation`,control:e,render:({field:c})=>r.jsx(Dn,{sx:{flex:1},...c})}),l==="vertical"&&r.jsx(o.Text,{mt:-10,color:"dimmed",size:12,children:a("chart.reference_line.orientation.vertical_hint")})]}),l==="horizontal"&&r.jsx(b.Controller,{name:`reference_lines.${t}.yAxisIndex`,control:e,render:({field:{value:c,onChange:u,...d}})=>r.jsx(o.Select,{label:"Y Axis",data:i,disabled:i.length===0,...d,value:(c==null?void 0:c.toString())??"",onChange:h=>{if(!h){u(0);return}u(Number(h))},sx:{flex:1}})})]}),r.jsx(o.Divider,{mb:-10,mt:10,variant:"dashed",label:a("chart.style.label"),labelPosition:"center"}),r.jsxs(o.Group,{grow:!0,children:[r.jsx(b.Controller,{name:`reference_lines.${t}.lineStyle.type`,control:e,render:({field:c})=>r.jsx(lr,{sx:{flexGrow:1},...c})}),r.jsx(b.Controller,{name:`reference_lines.${t}.lineStyle.width`,control:e,render:({field:c})=>r.jsx(o.NumberInput,{label:a("chart.series.line.line_width"),min:1,max:10,sx:{flexGrow:1},...c})})]}),r.jsxs(o.Stack,{spacing:4,children:[r.jsx(o.Text,{size:"sm",children:a("chart.color.label")}),r.jsx(b.Controller,{name:`reference_lines.${t}.lineStyle.color`,control:e,render:({field:c})=>r.jsx(Je,{...c})})]})]})}function zT({control:e,watch:t,variables:n}){const{t:s}=j.useTranslation(),i=()=>({name:"",template:"",variable_key:"",orientation:"horizontal",lineStyle:{type:"dashed",width:1,color:Rt.random().css()},show_in_legend:!1,yAxisIndex:0}),a=g.useMemo(()=>n.map(d=>({label:d.name,value:d.name})),[n]),l=t("y_axes"),c=g.useMemo(()=>l.map(({name:d},h)=>({label:d,value:h.toString()})),[l]),u=(d,h)=>{const p=d.name.trim();return p||h+1};return r.jsx(ke,{control:e,watch:t,name:"reference_lines",getItem:i,addButtonText:s("chart.reference_line.add"),deleteButtonText:s("chart.reference_line.delete"),renderTabName:u,children:({field:d,index:h})=>r.jsx(IT,{control:e,index:h,watch:t,variableOptions:a,yAxisOptions:c})})}const ET=({value:e,onChange:t})=>{const n=s=>{s&&t(s)};return r.jsx(o.Box,{children:r.jsx(ft,{height:"500px",defaultLanguage:"javascript",value:e,onChange:n,theme:"vs-dark",options:{minimap:{enabled:!1}}})})},AT=({value:e,onChange:t})=>{const{t:n}=j.useTranslation(),[s,{setTrue:i,setFalse:a}]=Z.useBoolean(),[l,c]=g.useState(e),u=()=>{a();const{type:f,func_content:m}=l,y={type:f,func_content:m};c(y),t(y)},d=()=>{a(),c(e)},h=f=>{c(m=>({...m,func_content:f}))},p=()=>{h(Kr.dynamic.func_content)};return r.jsxs(r.Fragment,{children:[r.jsx(o.Box,{sx:{width:"50%"},children:r.jsx(o.Button,{color:"grape",variant:"filled",leftIcon:r.jsx(M.IconMathFunction,{size:16}),mt:24,onClick:i,sx:{flexGrow:0},children:n("viz.scatter_chart.color.dynamic.setup")})}),r.jsx(o.Modal,{size:800,title:n("viz.scatter_chart.color.dynamic.setup_title"),opened:s,onClose:a,closeOnClickOutside:!1,withCloseButton:!1,zIndex:320,children:s&&r.jsxs(o.Stack,{children:[r.jsx(ET,{value:l.func_content,onChange:h}),r.jsxs(o.Group,{position:"apart",children:[r.jsx(o.Button,{onClick:p,color:"red",leftIcon:r.jsx(R.Recycle,{size:20}),children:n("common.actions.reset_to_default")}),r.jsxs(o.Group,{position:"right",children:[r.jsx(o.Button,{onClick:d,variant:"subtle",children:n("common.actions.cancel")}),r.jsx(o.Button,{color:"green",leftIcon:r.jsx(M.IconDeviceFloppy,{size:16}),onClick:u,children:n("common.actions.save")})]})]})]})})]})},PT=({value:e,onChange:t})=>e.type!=="dynamic"?null:r.jsx(AT,{value:e,onChange:t}),LT=({value:e,onChange:t})=>{if(e.type!=="static")return null;const n=s=>{t({...e,color:s})};return r.jsx(o.ColorInput,{label:" ",format:"rgb",value:e.color,onChange:n})},OT=g.forwardRef(({label:e="Color",value:t,onChange:n},s)=>{const{t:i,i18n:a}=j.useTranslation(),l=g.useMemo(()=>[{label:i("viz.scatter_chart.color.type.static"),value:"static"},{label:i("viz.scatter_chart.color.type.dynamic"),value:"dynamic"}],[a.language]),c=u=>{n({...Kr[u]})};return r.jsxs(o.SimpleGrid,{cols:2,children:[r.jsx(o.Select,{ref:s,label:e,data:l,value:t.type,onChange:c,sx:{flexGrow:1}}),r.jsx(LT,{value:t,onChange:n}),r.jsx(PT,{value:t,onChange:n})]})}),BT=g.forwardRef(({value:e,onChange:t},n)=>{const{t:s}=j.useTranslation(),i=l=>{t({...e,label:l})},a=l=>{t({...e,tooltip:l})};return r.jsxs(o.Stack,{ref:n,spacing:0,children:[r.jsx(Ds,{sectionTitle:s("chart.axis.overflow.section_title.on_axis"),value:e.label,onChange:i}),r.jsx(Ds,{sectionTitle:s("chart.axis.overflow.section_title.in_tooltip"),value:e.tooltip,onChange:a})]})});function VT({control:e,watch:t}){const{t:n}=j.useTranslation();return t(["scatter"]),r.jsxs(o.Stack,{children:[r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"scatter.name_data_key",control:e,render:({field:s})=>r.jsx(U,{label:n("common.name_data_field"),required:!0,sx:{flex:1},...s})}),r.jsx(b.Controller,{name:"scatter.y_data_key",control:e,render:({field:s})=>r.jsx(U,{label:n("common.value_data_field"),required:!0,sx:{flex:1},...s})})]}),r.jsx(o.Divider,{mb:-15,label:n("chart.style.label"),labelPosition:"center"}),r.jsx(b.Controller,{name:"scatter.symbolSize",control:e,render:({field:s})=>r.jsx(So,{...s})}),r.jsx(b.Controller,{name:"scatter.color",control:e,render:({field:s})=>r.jsx(OT,{...s})}),r.jsx(o.Divider,{mb:-15,label:n("chart.label.label"),labelPosition:"center"}),r.jsx(o.Group,{grow:!0,noWrap:!0,children:r.jsx(b.Controller,{name:"scatter.label_position",control:e,render:({field:s})=>r.jsx(cr,{label:n("chart.label_position.label"),withOffOption:!0,...s,onChange:i=>{i&&s.onChange(i)}})})}),r.jsx(b.Controller,{name:"scatter.label_overflow",control:e,render:({field:s})=>r.jsx(BT,{...s})})]})}function qT({control:e,watch:t}){const{t:n}=j.useTranslation();return t("stats"),r.jsx(o.Stack,{children:r.jsxs(o.Stack,{spacing:0,children:[r.jsx(b.Controller,{name:"stats.templates.top",control:e,render:({field:s})=>r.jsx(is,{label:n("chart.stats.template.above_chart"),py:"md",sx:{flexGrow:1},...s})}),r.jsx(b.Controller,{name:"stats.templates.bottom",control:e,render:({field:s})=>r.jsx(is,{label:n("chart.stats.template.under_chart"),py:"md",sx:{flexGrow:1},...s})})]})})}const NT=({control:e,index:t})=>{const{t:n}=j.useTranslation();return r.jsx(o.Stack,{children:r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:`tooltip.metrics.${t}.name`,control:e,render:({field:s})=>r.jsx(o.TextInput,{label:n("common.name"),required:!0,sx:{flex:1},...s})}),r.jsx(b.Controller,{name:`tooltip.metrics.${t}.data_key`,control:e,render:({field:s})=>r.jsx(U,{label:n("common.data_field"),required:!0,sx:{flex:1},...s})})]})})},$T=({control:e,watch:t})=>{const{t:n}=j.useTranslation(),s=()=>({id:Date.now().toString(),data_key:"",name:""}),i=(a,l)=>{const c=a.name.trim();return c||l+1};return r.jsxs(r.Fragment,{children:[r.jsxs(o.Group,{spacing:2,sx:{cursor:"default",userSelect:"none"},children:[r.jsx(R.InfoCircle,{size:14,color:"#888"}),r.jsx(o.Text,{size:14,color:"#888",children:n("chart.tooltip.additional_metrics.description")})]}),r.jsx(ke,{control:e,watch:t,name:"tooltip.metrics",getItem:s,addButtonText:n("chart.tooltip.additional_metrics.add"),deleteButtonText:n("chart.tooltip.additional_metrics.delete"),renderTabName:i,children:({field:a,index:l})=>r.jsx(NT,{control:e,index:l})})]})};function FT({control:e,watch:t}){const{t:n,i18n:s}=j.useTranslation();t("tooltip.trigger");const i=g.useMemo(()=>[{label:n("chart.tooltip.trigger.scatter_point"),value:"item"},{label:n("chart.tooltip.trigger.x_axis"),value:"axis"}],[s.language]);return r.jsxs(o.Stack,{children:[r.jsx(b.Controller,{name:"tooltip.trigger",control:e,render:({field:a})=>r.jsx(o.Select,{label:n("chart.tooltip.trigger.label"),data:i,sx:{flexGrow:1},...a})}),r.jsx(o.Divider,{variant:"dashed"}),r.jsx($T,{control:e,watch:t})]})}function GT({control:e,watch:t}){const{t:n}=j.useTranslation();return t(["x_axis"]),r.jsxs(o.Stack,{children:[r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"x_axis.data_key",control:e,render:({field:s})=>r.jsx(U,{label:n("common.data_field"),required:!0,sx:{flex:1},...s})}),r.jsx(b.Controller,{name:"x_axis.name",control:e,render:({field:s})=>r.jsx(o.TextInput,{label:n("common.name"),sx:{flex:1},...s})})]}),r.jsx(o.Divider,{mb:-15,label:n("chart.axis.tick_label"),labelPosition:"center"}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:"x_axis.axisLabel.rotate",control:e,render:({field:s})=>r.jsx(cn,{sx:{width:"48%"},...s})}),r.jsx(b.Controller,{name:"x_axis.axisLabel.formatter",control:e,render:({field:s})=>r.jsx(Bt,{...s})})]}),r.jsx(b.Controller,{name:"x_axis.axisLabel.overflow",control:e,render:({field:s})=>r.jsx(Vt,{...s})})]})}function WT({control:e,index:t}){const{t:n}=j.useTranslation();return r.jsxs(o.Stack,{my:0,p:"0",sx:{position:"relative"},children:[r.jsx(o.Divider,{mb:-15,mt:15,variant:"dashed",label:n("chart.y_axis.y_axis_name"),labelPosition:"center"}),r.jsxs(o.Group,{grow:!0,noWrap:!0,children:[r.jsx(b.Controller,{name:`y_axes.${t}.name`,control:e,render:({field:s})=>r.jsx(o.TextInput,{label:n("common.name"),required:!0,sx:{flex:1},...s})}),r.jsx(b.Controller,{name:`y_axes.${t}.nameAlignment`,control:e,render:({field:s})=>r.jsx(Mn,{sx:{flex:1},...s})})]}),r.jsx(o.Divider,{mb:-15,variant:"dashed",label:n("chart.y_axis.layout"),labelPosition:"center"}),r.jsx(o.Group,{grow:!0,noWrap:!0,children:r.jsx(b.Controller,{name:`y_axes.${t}.position`,control:e,render:({field:s})=>r.jsx(Fh,{sx:{flex:1},...s})})}),r.jsxs(o.Stack,{children:[r.jsx(o.Divider,{mb:-15,variant:"dashed",label:n("chart.y_axis.label_format"),labelPosition:"center"}),r.jsx(b.Controller,{name:`y_axes.${t}.label_formatter`,control:e,render:({field:s})=>r.jsx(Dt,{...s})})]}),r.jsxs(o.Stack,{children:[r.jsx(o.Divider,{mb:-15,variant:"dashed",label:n("chart.y_axis.value_range"),labelPosition:"center"}),r.jsxs(o.Group,{grow:!0,children:[r.jsx(b.Controller,{name:`y_axes.${t}.min`,control:e,render:({field:s})=>r.jsx(o.TextInput,{label:n("chart.y_axis.value_min"),...s})}),r.jsx(b.Controller,{name:`y_axes.${t}.max`,control:e,render:({field:s})=>r.jsx(o.TextInput,{label:n("chart.y_axis.value_max"),...s})})]})]})]})}function RT({control:e,watch:t}){const{t:n}=j.useTranslation(),s=()=>({name:"",label_formatter:Ge,min:"",max:"",show:!0,position:"right",nameAlignment:"right"}),i=(l,c)=>{const u=l.name.trim();return u||c+1},a=({field:l,index:c,fields:u})=>u.length<=1;return r.jsx(ke,{control:e,watch:t,name:"y_axes",getItem:s,addButtonText:n("chart.y_axis.add"),deleteButtonText:n("chart.y_axis.delete"),renderTabName:i,deleteDisalbed:a,children:({field:l,index:c})=>r.jsx(WT,{control:e,index:c})})}function QT(e){return e||{templates:{top:"",bottom:""}}}function UT({reference_lines:e=[],stats:t,...n}){return{reference_lines:e,stats:QT(t),...n}}function YT({context:e}){const{t}=j.useTranslation(),{value:n,set:s}=Q(e.instanceData,"config"),{variables:i}=e,a=g.useMemo(()=>v.defaultsDeep({},n,Po),[n]),l=g.useMemo(()=>UT(a),[a]);g.useEffect(()=>{!v.isEqual(a,l)&&(console.log("config malformed, resetting to defaults",a,l),s(l))},[a,l]);const{control:c,handleSubmit:u,watch:d,getValues:h,reset:p}=b.useForm({defaultValues:l});g.useEffect(()=>{p(l)},[l]);const f=h(),m=g.useMemo(()=>!v.isEqual(f,a),[f,a]);return d(["dataZoom"]),r.jsx(o.Stack,{spacing:"xs",children:r.jsxs("form",{onSubmit:u(s),children:[r.jsx(qe,{canSubmit:m}),r.jsxs(o.Tabs,{defaultValue:"X Axis",orientation:"vertical",styles:{tab:{paddingLeft:"6px",paddingRight:"6px"},panel:{paddingTop:"6px",paddingLeft:"12px"}},children:[r.jsxs(o.Tabs.List,{children:[r.jsx(o.Tabs.Tab,{value:"X Axis",children:t("chart.x_axis.label")}),r.jsx(o.Tabs.Tab,{value:"Y Axes",children:t("chart.y_axis.labels")}),r.jsx(o.Tabs.Tab,{value:"Scatter",children:t("chart.series.scatter.label")}),r.jsx(o.Tabs.Tab,{value:"Tooltip",children:t("chart.tooltip.label")}),r.jsx(o.Tabs.Tab,{value:"Stats",children:t("chart.stats.label")}),r.jsx(o.Tabs.Tab,{value:"Reference Lines",children:t("chart.reference_line.labels")}),r.jsx(o.Tabs.Tab,{value:"Reference Areas",children:t("chart.reference_area.labels")}),r.jsx(o.Tabs.Tab,{value:"Zooming",children:t("chart.zooming.label")})]}),r.jsx(o.Tabs.Panel,{value:"X Axis",children:r.jsx(GT,{control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Y Axes",children:r.jsx(RT,{control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Scatter",children:r.jsx(VT,{control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Tooltip",children:r.jsx(FT,{control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Stats",children:r.jsx(qT,{control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Reference Lines",children:r.jsx(zT,{variables:i,control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Reference Areas",children:r.jsx(MT,{variables:i,control:c,watch:d})}),r.jsx(o.Tabs.Panel,{value:"Zooming",children:r.jsx(b.Controller,{name:"dataZoom",control:c,render:({field:y})=>r.jsx(Zs,{...y})})})]})]})})}const KT=[{lang:"en",resources:{scatter_chart:{viz_name:"Scatter Chart",color:{type:{static:"Static",dynamic:"Dynamic"},dynamic:{setup:"Setup",setup_title:"Setup dynamic color"}},click_scatter:{trigger:"Click Scatter"}}}},{lang:"zh",resources:{scatter_chart:{viz_name:"散点图",color:{type:{static:"具体颜色",dynamic:"动态计算颜色"},dynamic:{setup:"设置",setup_title:"设置动态计算颜色的逻辑"}},click_scatter:{trigger:"点击散点"}}}}];function XT(e){const{dataZoom:t=On,...n}=e;return{...n,dataZoom:t}}function JT(e){const t={scatter:{label_overflow:up()}};return v.defaultsDeep(t,e)}function ZT(e){const{color:t}=e.scatter;return typeof t=="string"?{...e,scatter:{...e.scatter,color:{...Kr.static,color:t}}}:e}function HT(e){const t=e.reference_lines.map(n=>{const{lineStyle:s={type:"dashed",width:1,color:Rt.random().css()},show_in_legend:i=!1,yAxisIndex:a=0}=n;return{...n,lineStyle:s,show_in_legend:i,yAxisIndex:a}});return{...e,reference_lines:t}}function eD(e){const t={tooltip:{trigger:"item"}};return v.defaultsDeep({},e,t)}function tD(e,{panelModel:t}){try{const n=t.queryIDs[0];if(!n)throw new Error("cannot migrate when queryID is empty");const s=u=>u&&`${n}.${u}`,{x_axis:i,scatter:a,tooltip:l,...c}=e;return{...c,x_axis:{...i,data_key:s(i.data_key)},scatter:{...a,y_data_key:s(a.y_data_key),name_data_key:s(a.name_data_key)},tooltip:{...l,metrics:l.metrics.map(u=>({...u,data_key:s(u.data_key)}))}}}catch(n){throw console.error("[Migration failed]",n),n}}function nD(e){const t={x_axis:{axisLabel:{overflow:lt()}}};return v.defaultsDeep(t,e)}class rD extends Me{constructor(){super(...arguments);N(this,"VERSION",10)}configVersions(){this.version(1,n=>({version:1,config:n})),this.version(2,n=>{const{tooltip:s={metrics:[]},...i}=n.config;return{...n,version:2,config:{...i,tooltip:s}}}),this.version(3,n=>({...n,version:3,config:XT(n.config)})),this.version(4,n=>{const{config:s}=n;return{...n,version:5,config:JT(s)}}),this.version(6,n=>{const{config:s}=n;return{...n,version:6,config:ZT(s)}}),this.version(7,n=>{const{config:s}=n;return{...n,version:7,config:HT(s)}}),this.version(8,n=>{const{config:s}=n;return{...n,version:8,config:eD(s)}}),this.version(9,(n,s)=>{const{config:i}=n;return{...n,version:9,config:tD(i,s)}}),this.version(10,(n,s)=>{const{config:i}=n;return{...n,version:10,config:nD(i)}})}}const sD={displayName:"viz.scatter_chart.viz_name",displayGroup:"chart.groups.echarts_based_charts",migrator:new rD,name:"scatterChart",viewRender:kT,configRender:YT,createConfig(){return{version:10,config:v.cloneDeep(Po)}},triggers:[cp],translation:KT},Lo={content:"Use double curly brackets to wrap js code: {{ new Date().getTime() }}",vertical_align:"center"};function iD(e){if("variables"in e)return e;const{align:t,size:n,weight:s,color:i,content:{prefix:a="",data_field:l="value",formatter:c={output:"number",mantissa:0},postfix:u=""}={}}=e;return{align:t,template:`${a} \${value} ${u}`,variables:[{name:"value",data_field:l,aggregation:{type:"none",config:{}},formatter:c,color:i,weight:s,size:n}]}}function aD(e){return v.omit(e,["variables"])}function oD(e){const{align:t,...n}=e;return{horizontal_align:t,vertical_align:"center",...n}}function lD(e){const t=v.cloneDeep(e),n=v.get(t,"color.valueRange");return n!==void 0&&v.set(t,"color.valueRange",n.map(s=>Number(s))),t}function cD(e,t){return!t||t==="left"?e:`<p style="text-align: ${t}">${e}</p>`}function uD(e,t){const{horizontal_align:n,template:s,...i}=e;let a=pu(s,t);return a=cD(a,n),{content:a,...i}}function dD(e,t){const{content:n,...s}=e;return{content:pu(n,t),...s}}class hD extends Me{constructor(){super(...arguments);N(this,"VERSION",5)}configVersions(){this.version(1,n=>({version:1,config:iD(n)})),this.version(2,(n,{panelModel:s})=>{const{config:i}=n;return(i.variables||[]).forEach(l=>{s.variables.find(c=>c.name===l.name)||s.addVariable(lD(l))}),{...n,version:2,config:aD(i)}}),this.version(3,n=>{const{config:s}=n;return{...n,version:3,config:oD(s)}}),this.version(4,(n,{panelModel:s})=>{const{config:i}=n;return{...n,version:4,config:uD(i,s)}}),this.version(5,(n,{panelModel:s})=>{const{config:i}=n;return{...n,version:5,config:dD(i,s)}})}}const pp={id:"builtin:stats:click-stats",displayName:"viz.stats.click_stats.trigger",nameRender:fD,configRender:pD,payload:[{name:"variables",description:"Panel variables",valueType:"object"}]};function pD(e){return r.jsx(r.Fragment,{})}function fD(e){const{t}=j.useTranslation();return r.jsx(o.Text,{children:t("viz.stats.click_stats.trigger")})}const gD={top:"flex-start",center:"center",bottom:"flex-end"};function mD(e){const t={flexGrow:1};return e>0&&(t.cursor="pointer",t["&:hover"]={textDecoration:"underline"}),t}const xD=D.observer(({context:e,instance:t})=>{const n=bt({vizManager:e.vizManager,instance:t}),s=yt(n.triggerManager,pp.id),i=Pe(),{value:a=Lo}=Q(e.instanceData,"config"),{panel:l}=Ot(),{data:c,variables:u}=e,{width:d,height:h}=e.viewport,p=g.useMemo(()=>{const m=v.defaults({},a,Lo);return m.content?yu(m.content,u,i.payloadForViz,c):""},[c,a,u,i.payloadForViz]),f=g.useCallback(()=>{s.forEach(m=>{n.runInteraction(m.id,{variables:l.variableValueMap})})},[l.variableValueMap,s,n]);return r.jsx(o.Flex,{className:"viz-stats",sx:{width:d,height:h},align:gD[a.vertical_align],direction:"row",children:r.jsx(o.Box,{className:"viz-stats--clickable-wrapper",sx:mD(s.length),onClick:f,children:r.jsx(kr,{value:p,styles:{root:{border:"none",maxWidth:d,maxHeight:h,"&.mantine-RichTextEditor-root":{overflow:"auto !important"}},content:{"&.mantine-RichTextEditor-content .ProseMirror":{padding:0}}},dashboardState:i.dashboardState,variableAggValueMap:l.variableAggValueMap})})})});function yD({conf:e,setConf:t}){const{t:n}=j.useTranslation(),s=g.useMemo(()=>v.defaults({},e),[e]),{control:i,handleSubmit:a,watch:l,getValues:c,reset:u}=b.useForm({defaultValues:s});g.useEffect(()=>{u(s)},[s]),l(["content","vertical_align"]);const d=c(),h=g.useMemo(()=>!v.isEqual(d,e),[d,e]);return r.jsx("form",{onSubmit:a(t),children:r.jsxs(o.Stack,{spacing:"xs",children:[r.jsx(qe,{canSubmit:h}),r.jsx(b.Controller,{control:i,name:"vertical_align",render:({field:p})=>r.jsx($u,{...p})}),r.jsx(b.Controller,{name:"content",control:i,render:({field:p})=>r.jsx(ws,{...p,styles:{root:{flexGrow:1,minHeight:"240px"}},label:n("rich_text.content.label"),autoSubmit:!0})})]})})}function bD(e){const{value:t,set:n}=Q(e.context.instanceData,"config");return t?r.jsx(yD,{conf:t,setConf:n}):null}const vD=[{lang:"en",resources:{stats:{viz_name:"Stats",click_stats:{trigger:"Click stats text"}}}},{lang:"zh",resources:{stats:{viz_name:"数据指标",click_stats:{trigger:"点击文字"}}}}],_D={createConfig(){return{version:5,config:Lo}},displayName:"viz.stats.viz_name",displayGroup:"chart.groups.others",migrator:new hD,name:"stats",viewRender:xD,configRender:bD,triggers:[pp],translation:vD},Oo={label_key:"",value_key:"",group_key:"",levels:[]};function jD(e){const t=new Set(e.map(s=>s.parent_id)),n=new Set(e.map(s=>s.id));return t.forEach(s=>{s===null||n.has(s)||e.push({id:s,name:s,parent_id:null})}),e}function wD(e){const t=jD(e).map(i=>({...i,children:[]})),n=v.keyBy(t,i=>i.id),s=[];return t.forEach(i=>{if(!i.parent_id||!n[i.parent_id]){s.push(i);return}n[i.parent_id].children.push(i)}),s}function CD(e,t){const{label_key:n,value_key:s,group_key:i}=e;if(!n||!s)return[];const a=O(n),l=O(s),c=O(i),u=t[a.queryID].map(d=>({...d,id:d[a.columnKey],parent_id:d[c.columnKey],name:d[a.columnKey],value:d[l.columnKey]?Number(d[l.columnKey]):d[l.columnKey]}));return i?wD(u):u}const SD=e=>({treePathInfo:t,name:n,value:s})=>{if(t.length===1||!e)return n;try{const i=t[t.length-2].value;if(s/i<e)return" "}catch{return n}};function kD(e){const{levels:t}=e;return t.map(n=>{const{show_label_tolerance:s,...i}=n.label;return{...n,label:{...i,formatter:SD(s)}}})}function TD(){return({treePathInfo:e,name:t,value:n,color:s,marker:i,...a})=>{const l=e.slice(0,e.length-1),c=[`<tr>
|
|
299
299
|
<th style="text-align: right; padding: 0 1em;">Value</th>
|
|
300
300
|
<td style="text-align: left; padding: 0 1em;">${n}</td>
|
|
301
301
|
</tr>
|