@iyulab/u-widgets 0.9.1 → 0.9.2
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/u-widgets-charts.js +263 -256
- package/dist/u-widgets-charts.js.map +1 -1
- package/package.json +1 -1
package/dist/u-widgets-charts.js
CHANGED
|
@@ -1,82 +1,86 @@
|
|
|
1
|
-
import { css as
|
|
1
|
+
import { css as E, LitElement as P, nothing as T, html as R } from "lit";
|
|
2
2
|
import { property as $, customElement as B } from "lit/decorators.js";
|
|
3
3
|
import { a as W, f as q, t as G } from "./tokens-SjA7YdRs.js";
|
|
4
4
|
import * as O from "echarts/core";
|
|
5
5
|
import { BarChart as H, LineChart as U, PieChart as Y, ScatterChart as J, RadarChart as Q, HeatmapChart as X, BoxplotChart as Z, FunnelChart as K, TreemapChart as ee } from "echarts/charts";
|
|
6
|
-
import { GridComponent as te, TooltipComponent as re, LegendComponent as ie, RadarComponent as se, MarkLineComponent as ne, VisualMapComponent as
|
|
7
|
-
import { CanvasRenderer as
|
|
8
|
-
function M(e,
|
|
9
|
-
for (const
|
|
10
|
-
const t = e[
|
|
6
|
+
import { GridComponent as te, TooltipComponent as re, LegendComponent as ie, RadarComponent as se, MarkLineComponent as ne, VisualMapComponent as oe } from "echarts/components";
|
|
7
|
+
import { CanvasRenderer as ae } from "echarts/renderers";
|
|
8
|
+
function M(e, r) {
|
|
9
|
+
for (const i of r) {
|
|
10
|
+
const t = e[i.field];
|
|
11
11
|
if (t == null) continue;
|
|
12
12
|
const n = Number(t);
|
|
13
13
|
if (Number.isNaN(n)) continue;
|
|
14
|
-
const s =
|
|
15
|
-
if (s &&
|
|
14
|
+
const s = i.above === void 0 || n > i.above, f = i.below === void 0 || n < i.below;
|
|
15
|
+
if (s && f) return i;
|
|
16
16
|
}
|
|
17
17
|
}
|
|
18
18
|
function le(e) {
|
|
19
|
-
const
|
|
20
|
-
if (!
|
|
19
|
+
const r = e.widget, i = e.data, t = e.mapping ? W(e.mapping) : void 0, n = e.options ?? {};
|
|
20
|
+
if (!i) return {};
|
|
21
21
|
let s;
|
|
22
|
-
switch (
|
|
22
|
+
switch (r) {
|
|
23
23
|
case "chart.bar":
|
|
24
|
-
s = N(
|
|
24
|
+
s = N(i, t, "bar", n);
|
|
25
25
|
break;
|
|
26
26
|
case "chart.line":
|
|
27
|
-
s = N(
|
|
27
|
+
s = N(i, t, "line", n);
|
|
28
28
|
break;
|
|
29
29
|
case "chart.area":
|
|
30
|
-
s = N(
|
|
30
|
+
s = N(i, t, "line", { ...n, _area: !0 });
|
|
31
31
|
break;
|
|
32
32
|
case "chart.pie":
|
|
33
|
-
s = ue(
|
|
33
|
+
s = ue(i, t, n);
|
|
34
34
|
break;
|
|
35
35
|
case "chart.scatter":
|
|
36
|
-
s = ce(
|
|
36
|
+
s = ce(i, t, n);
|
|
37
37
|
break;
|
|
38
38
|
case "chart.radar":
|
|
39
|
-
s = fe(
|
|
39
|
+
s = fe(i, t);
|
|
40
40
|
break;
|
|
41
41
|
case "chart.heatmap":
|
|
42
|
-
s = ye(
|
|
42
|
+
s = ye(i, t, n);
|
|
43
43
|
break;
|
|
44
44
|
case "chart.box":
|
|
45
|
-
s = he(
|
|
45
|
+
s = he(i, t);
|
|
46
46
|
break;
|
|
47
47
|
case "chart.funnel":
|
|
48
|
-
s = me(
|
|
48
|
+
s = me(i, t);
|
|
49
49
|
break;
|
|
50
50
|
case "chart.waterfall":
|
|
51
|
-
s = de(
|
|
51
|
+
s = de(i, t);
|
|
52
52
|
break;
|
|
53
53
|
case "chart.treemap":
|
|
54
|
-
s =
|
|
54
|
+
s = pe(i);
|
|
55
55
|
break;
|
|
56
56
|
case "chart.histogram":
|
|
57
|
-
s =
|
|
57
|
+
s = be(i, t, n);
|
|
58
58
|
break;
|
|
59
59
|
default:
|
|
60
60
|
return {};
|
|
61
61
|
}
|
|
62
|
-
n.legend === !1 && s.legend && (s.legend = { ...s.legend, show: !1 }), n.grid === !1
|
|
63
|
-
|
|
64
|
-
|
|
62
|
+
if (n.legend === !1 && s.legend && (s.legend = { ...s.legend, show: !1 }), n.grid === !1) {
|
|
63
|
+
const y = (u) => !u || typeof u != "object" ? u : Array.isArray(u) ? u.map(y) : { ...u, splitLine: { show: !1 } };
|
|
64
|
+
s.xAxis && (s.xAxis = y(s.xAxis)), s.yAxis && (s.yAxis = y(s.yAxis));
|
|
65
|
+
}
|
|
66
|
+
n.animate === !1 && (s.animation = !1), Array.isArray(n.colors) && n.colors.length > 0 && (s.color = n.colors);
|
|
67
|
+
const f = n.locale;
|
|
68
|
+
z(s, "xAxis", n.xFormat, f), z(s, "yAxis", n.yFormat, f);
|
|
65
69
|
const h = n.echarts;
|
|
66
70
|
return h && typeof h == "object" && (s = V(s, h)), s;
|
|
67
71
|
}
|
|
68
|
-
function N(e,
|
|
72
|
+
function N(e, r, i, t) {
|
|
69
73
|
if (!Array.isArray(e)) return {};
|
|
70
|
-
const n =
|
|
74
|
+
const n = r?.x ?? C(e), s = r?.y ?? [_(e)].filter(Boolean);
|
|
71
75
|
if (!n || s.length === 0) return {};
|
|
72
|
-
const
|
|
76
|
+
const f = e.map((o) => String(o[n] ?? "")), h = !!t.horizontal, y = Array.isArray(t.series) ? t.series : [], u = t.conditionalStyles, m = s.map((o, l) => {
|
|
73
77
|
const c = {
|
|
74
|
-
name:
|
|
75
|
-
type:
|
|
76
|
-
data: e.map((
|
|
77
|
-
const w =
|
|
78
|
-
if (
|
|
79
|
-
const v = M(
|
|
78
|
+
name: o,
|
|
79
|
+
type: i,
|
|
80
|
+
data: e.map((b) => {
|
|
81
|
+
const w = b[o] ?? null;
|
|
82
|
+
if (u?.length) {
|
|
83
|
+
const v = M(b, u);
|
|
80
84
|
if (v) {
|
|
81
85
|
const F = { value: w, itemStyle: { color: v.color } };
|
|
82
86
|
return v.symbol && (F.symbol = v.symbol), v.symbolSize && (F.symbolSize = v.symbolSize), F;
|
|
@@ -86,156 +90,156 @@ function N(e, i, r, t) {
|
|
|
86
90
|
})
|
|
87
91
|
};
|
|
88
92
|
t._area && (c.areaStyle = {}), t.smooth && (c.smooth = !0), t.step && (c.step = t.step === !0 ? "end" : t.step);
|
|
89
|
-
const
|
|
90
|
-
return
|
|
91
|
-
}),
|
|
92
|
-
t.histogram && (
|
|
93
|
-
|
|
93
|
+
const a = y[l];
|
|
94
|
+
return a && (a.color && (c.itemStyle = { color: a.color }, c.lineStyle = { ...c.lineStyle ?? {}, color: a.color }), a.lineStyle && (c.lineStyle = { ...c.lineStyle ?? {}, ...a.lineStyle }), a.symbol !== void 0 && (c.symbol = a.symbol), a.label && (c.name = a.label), a.type && (c.type = a.type), a.yAxisIndex !== void 0 && (c.yAxisIndex = a.yAxisIndex)), c;
|
|
95
|
+
}), g = { type: "category", data: f }, x = { type: "value" };
|
|
96
|
+
t.histogram && (g.axisTick = { alignWithLabel: !0 }, m.forEach((o) => {
|
|
97
|
+
o.barCategoryGap = "0%";
|
|
94
98
|
}));
|
|
95
|
-
const A = !h &&
|
|
96
|
-
let
|
|
99
|
+
const A = !h && m.some((o) => o.yAxisIndex >= 1);
|
|
100
|
+
let d;
|
|
97
101
|
if (A) {
|
|
98
|
-
const
|
|
99
|
-
|
|
102
|
+
const o = Array.isArray(t.yAxis) && t.yAxis.length >= 2 ? t.yAxis[1] : { type: "value" };
|
|
103
|
+
d = [x, o];
|
|
100
104
|
} else
|
|
101
|
-
|
|
102
|
-
const
|
|
103
|
-
xAxis: h ?
|
|
104
|
-
yAxis:
|
|
105
|
-
series:
|
|
105
|
+
d = h ? g : x;
|
|
106
|
+
const p = {
|
|
107
|
+
xAxis: h ? x : g,
|
|
108
|
+
yAxis: d,
|
|
109
|
+
series: m,
|
|
106
110
|
tooltip: { trigger: "axis" }
|
|
107
111
|
};
|
|
108
112
|
if (s.length > 1) {
|
|
109
|
-
const
|
|
110
|
-
|
|
113
|
+
const o = m.map((l) => l.name);
|
|
114
|
+
p.legend = { data: o };
|
|
111
115
|
}
|
|
112
|
-
t.stack &&
|
|
113
|
-
|
|
116
|
+
t.stack && p.series.forEach((o) => {
|
|
117
|
+
o.stack = "total";
|
|
114
118
|
});
|
|
115
119
|
const S = t.referenceLines;
|
|
116
|
-
return Array.isArray(S) && S.length > 0 &&
|
|
120
|
+
return Array.isArray(S) && S.length > 0 && m.length > 0 && (m[0].markLine = {
|
|
117
121
|
silent: !0,
|
|
118
122
|
symbol: "none",
|
|
119
|
-
data: S.map((
|
|
123
|
+
data: S.map((o) => {
|
|
120
124
|
const l = {};
|
|
121
|
-
|
|
125
|
+
o.axis === "x" ? l.xAxis = o.value : l.yAxis = o.value, o.label && (l.name = o.label);
|
|
122
126
|
const c = {};
|
|
123
|
-
return
|
|
127
|
+
return o.color && (c.color = o.color), o.style && (c.type = o.style), Object.keys(c).length > 0 && (l.lineStyle = c), o.label && (l.label = { formatter: o.label, position: "end" }), l;
|
|
124
128
|
})
|
|
125
|
-
}),
|
|
129
|
+
}), p;
|
|
126
130
|
}
|
|
127
|
-
function ce(e,
|
|
131
|
+
function ce(e, r, i) {
|
|
128
132
|
if (!Array.isArray(e)) return {};
|
|
129
|
-
const t = I(e), n =
|
|
133
|
+
const t = I(e), n = r?.x ?? t[0], s = (r?.y ?? [t[1]])[0], f = r?.color, h = r?.size, y = r?.opacity;
|
|
130
134
|
if (!n || !s) return {};
|
|
131
|
-
const
|
|
135
|
+
const u = {
|
|
132
136
|
xAxis: { type: "value" },
|
|
133
137
|
yAxis: { type: "value" },
|
|
134
138
|
tooltip: { trigger: "item" }
|
|
135
139
|
};
|
|
136
|
-
let
|
|
137
|
-
if (
|
|
138
|
-
for (const
|
|
139
|
-
const l = Number(
|
|
140
|
-
l <
|
|
140
|
+
let m = 1 / 0, g = -1 / 0;
|
|
141
|
+
if (y)
|
|
142
|
+
for (const o of e) {
|
|
143
|
+
const l = Number(o[y] ?? 0);
|
|
144
|
+
l < m && (m = l), l > g && (g = l);
|
|
141
145
|
}
|
|
142
|
-
const
|
|
143
|
-
const l = [Number(
|
|
144
|
-
if (h && l.push(Number(
|
|
145
|
-
const c = M(
|
|
146
|
+
const x = g - m || 1, A = i.conditionalStyles, d = (o) => {
|
|
147
|
+
const l = [Number(o[n] ?? 0), Number(o[s] ?? 0)];
|
|
148
|
+
if (h && l.push(Number(o[h] ?? 0)), A?.length) {
|
|
149
|
+
const c = M(o, A);
|
|
146
150
|
if (c) {
|
|
147
|
-
const
|
|
148
|
-
if (
|
|
149
|
-
const w = Number(
|
|
150
|
-
|
|
151
|
+
const a = { color: c.color };
|
|
152
|
+
if (y) {
|
|
153
|
+
const w = Number(o[y] ?? 0);
|
|
154
|
+
a.opacity = Math.round((0.1 + 0.9 * ((w - m) / x)) * 100) / 100;
|
|
151
155
|
}
|
|
152
|
-
const
|
|
153
|
-
return c.symbol && (
|
|
156
|
+
const b = { value: l, itemStyle: a };
|
|
157
|
+
return c.symbol && (b.symbol = c.symbol), c.symbolSize && (b.symbolSize = c.symbolSize), b;
|
|
154
158
|
}
|
|
155
159
|
}
|
|
156
|
-
if (
|
|
157
|
-
const
|
|
158
|
-
return { value: l, itemStyle: { opacity: Math.round(
|
|
160
|
+
if (y) {
|
|
161
|
+
const a = 0.1 + 0.9 * ((Number(o[y] ?? 0) - m) / x);
|
|
162
|
+
return { value: l, itemStyle: { opacity: Math.round(a * 100) / 100 } };
|
|
159
163
|
}
|
|
160
164
|
return l;
|
|
161
|
-
},
|
|
162
|
-
const c = (Array.isArray(
|
|
165
|
+
}, p = h ? (o) => {
|
|
166
|
+
const c = (Array.isArray(o) ? o : o.value)[2] ?? 0;
|
|
163
167
|
return Math.max(4, Math.min(60, Math.sqrt(c) * 4));
|
|
164
168
|
} : void 0;
|
|
165
|
-
if (
|
|
166
|
-
const
|
|
169
|
+
if (f) {
|
|
170
|
+
const o = /* @__PURE__ */ new Map();
|
|
167
171
|
for (const c of e) {
|
|
168
|
-
const
|
|
169
|
-
|
|
172
|
+
const a = String(c[f] ?? "unknown");
|
|
173
|
+
o.has(a) || o.set(a, []), o.get(a).push(d(c));
|
|
170
174
|
}
|
|
171
175
|
const l = [];
|
|
172
|
-
for (const [c,
|
|
173
|
-
const
|
|
174
|
-
|
|
176
|
+
for (const [c, a] of o) {
|
|
177
|
+
const b = { name: c, type: "scatter", data: a };
|
|
178
|
+
p && (b.symbolSize = p), l.push(b);
|
|
175
179
|
}
|
|
176
|
-
|
|
180
|
+
u.series = l, u.legend = { data: Array.from(o.keys()) };
|
|
177
181
|
} else {
|
|
178
|
-
const l = { type: "scatter", data: e.map((c) =>
|
|
179
|
-
|
|
182
|
+
const l = { type: "scatter", data: e.map((c) => d(c)) };
|
|
183
|
+
p && (l.symbolSize = p), u.series = [l];
|
|
180
184
|
}
|
|
181
|
-
const S =
|
|
185
|
+
const S = i.referenceLines;
|
|
182
186
|
if (Array.isArray(S) && S.length > 0) {
|
|
183
|
-
const
|
|
184
|
-
|
|
187
|
+
const o = u.series[0];
|
|
188
|
+
o.markLine = {
|
|
185
189
|
silent: !0,
|
|
186
190
|
symbol: "none",
|
|
187
191
|
data: S.map((l) => {
|
|
188
192
|
const c = {};
|
|
189
193
|
l.axis === "x" ? c.xAxis = l.value : c.yAxis = l.value, l.label && (c.name = l.label);
|
|
190
|
-
const
|
|
191
|
-
return l.color && (
|
|
194
|
+
const a = {};
|
|
195
|
+
return l.color && (a.color = l.color), l.style && (a.type = l.style), Object.keys(a).length > 0 && (c.lineStyle = a), l.label && (c.label = { formatter: l.label, position: "end" }), c;
|
|
192
196
|
})
|
|
193
197
|
};
|
|
194
198
|
}
|
|
195
|
-
return
|
|
199
|
+
return u;
|
|
196
200
|
}
|
|
197
|
-
function ue(e,
|
|
201
|
+
function ue(e, r, i) {
|
|
198
202
|
if (!Array.isArray(e)) return {};
|
|
199
|
-
const t =
|
|
203
|
+
const t = r?.label ?? C(e), n = r?.value ?? _(e);
|
|
200
204
|
if (!t || !n) return {};
|
|
201
|
-
const s = e.map((
|
|
202
|
-
name: String(
|
|
203
|
-
value: Number(
|
|
205
|
+
const s = e.map((m) => ({
|
|
206
|
+
name: String(m[t] ?? ""),
|
|
207
|
+
value: Number(m[n] ?? 0)
|
|
204
208
|
})), h = {
|
|
205
209
|
type: "pie",
|
|
206
|
-
radius:
|
|
210
|
+
radius: i.donut ? ["40%", "70%"] : "50%",
|
|
207
211
|
data: s,
|
|
208
212
|
label: { overflow: "truncate", width: 80 }
|
|
209
213
|
};
|
|
210
|
-
|
|
211
|
-
const
|
|
214
|
+
i.showLabel === !1 && (h.label = { show: !1 });
|
|
215
|
+
const y = {
|
|
212
216
|
tooltip: { trigger: "item" },
|
|
213
217
|
legend: { orient: "vertical", left: "left" },
|
|
214
218
|
series: [h]
|
|
215
|
-
},
|
|
216
|
-
if (
|
|
217
|
-
const
|
|
218
|
-
|
|
219
|
+
}, u = i.center;
|
|
220
|
+
if (i.donut && u && (u.label || u.value)) {
|
|
221
|
+
const m = [];
|
|
222
|
+
u.label && m.push({
|
|
219
223
|
type: "text",
|
|
220
|
-
top:
|
|
221
|
-
style: { text:
|
|
222
|
-
}),
|
|
224
|
+
top: u.value ? -16 : 0,
|
|
225
|
+
style: { text: u.label, fontSize: 13, fill: "#999", textAlign: "center" }
|
|
226
|
+
}), u.value && m.push({
|
|
223
227
|
type: "text",
|
|
224
|
-
top:
|
|
225
|
-
style: { text:
|
|
226
|
-
}),
|
|
228
|
+
top: u.label ? 8 : 0,
|
|
229
|
+
style: { text: u.value, fontSize: 20, fontWeight: "bold", fill: "#333", textAlign: "center" }
|
|
230
|
+
}), y.graphic = [{ type: "group", left: "center", top: "middle", children: m }];
|
|
227
231
|
}
|
|
228
|
-
return
|
|
232
|
+
return y;
|
|
229
233
|
}
|
|
230
|
-
function fe(e,
|
|
234
|
+
function fe(e, r, i) {
|
|
231
235
|
if (!Array.isArray(e)) return {};
|
|
232
|
-
const t =
|
|
236
|
+
const t = r?.axis ?? C(e), n = r?.y ?? I(e);
|
|
233
237
|
if (!t || n.length === 0) return {};
|
|
234
238
|
const s = e.map((h) => ({
|
|
235
239
|
name: String(h[t] ?? "")
|
|
236
|
-
})),
|
|
240
|
+
})), f = n.map((h) => ({
|
|
237
241
|
name: h,
|
|
238
|
-
value: e.map((
|
|
242
|
+
value: e.map((y) => Number(y[h] ?? 0))
|
|
239
243
|
}));
|
|
240
244
|
return {
|
|
241
245
|
tooltip: {},
|
|
@@ -244,38 +248,38 @@ function fe(e, i, r) {
|
|
|
244
248
|
series: [
|
|
245
249
|
{
|
|
246
250
|
type: "radar",
|
|
247
|
-
data:
|
|
251
|
+
data: f
|
|
248
252
|
}
|
|
249
253
|
]
|
|
250
254
|
};
|
|
251
255
|
}
|
|
252
|
-
function ye(e,
|
|
256
|
+
function ye(e, r, i) {
|
|
253
257
|
if (!Array.isArray(e)) return {};
|
|
254
|
-
const t = e[0] ?? {}, n = Object.keys(t), s = n.filter((
|
|
255
|
-
if (!h || !
|
|
256
|
-
const
|
|
257
|
-
for (const
|
|
258
|
-
const
|
|
259
|
-
|
|
258
|
+
const t = e[0] ?? {}, n = Object.keys(t), s = n.filter((a) => typeof t[a] == "string"), f = n.filter((a) => typeof t[a] == "number"), h = r?.x ?? s[0], y = r?.y?.[0] ?? s.find((a) => a !== h), u = r?.value ?? f[0];
|
|
259
|
+
if (!h || !y || !u) return {};
|
|
260
|
+
const m = [], g = [], x = /* @__PURE__ */ new Set(), A = /* @__PURE__ */ new Set();
|
|
261
|
+
for (const a of e) {
|
|
262
|
+
const b = String(a[h] ?? ""), w = String(a[y] ?? "");
|
|
263
|
+
x.has(b) || (x.add(b), m.push(b)), A.has(w) || (A.add(w), g.push(w));
|
|
260
264
|
}
|
|
261
|
-
const
|
|
262
|
-
|
|
263
|
-
const
|
|
264
|
-
|
|
265
|
+
const d = /* @__PURE__ */ new Map();
|
|
266
|
+
m.forEach((a, b) => d.set(a, b));
|
|
267
|
+
const p = /* @__PURE__ */ new Map();
|
|
268
|
+
g.forEach((a, b) => p.set(a, b));
|
|
265
269
|
const S = [];
|
|
266
|
-
let
|
|
267
|
-
for (const
|
|
268
|
-
const
|
|
269
|
-
S.push([
|
|
270
|
+
let o = 1 / 0, l = -1 / 0;
|
|
271
|
+
for (const a of e) {
|
|
272
|
+
const b = d.get(String(a[h] ?? "")) ?? 0, w = p.get(String(a[y] ?? "")) ?? 0, v = a[u] != null ? Number(a[u]) : null;
|
|
273
|
+
S.push([b, w, v]), v != null && (v < o && (o = v), v > l && (l = v));
|
|
270
274
|
}
|
|
271
|
-
isFinite(
|
|
272
|
-
const c =
|
|
275
|
+
isFinite(o) || (o = 0, l = 1);
|
|
276
|
+
const c = i.colorRange ?? ["#313695", "#4575b4", "#74add1", "#abd9e9", "#fee090", "#fdae61", "#f46d43", "#d73027"];
|
|
273
277
|
return {
|
|
274
|
-
xAxis: { type: "category", data:
|
|
275
|
-
yAxis: { type: "category", data:
|
|
278
|
+
xAxis: { type: "category", data: m, splitArea: { show: !0 } },
|
|
279
|
+
yAxis: { type: "category", data: g, splitArea: { show: !0 } },
|
|
276
280
|
visualMap: {
|
|
277
|
-
min:
|
|
278
|
-
max:
|
|
281
|
+
min: i.min != null ? Number(i.min) : o,
|
|
282
|
+
max: i.max != null ? Number(i.max) : l,
|
|
279
283
|
calculable: !0,
|
|
280
284
|
orient: "horizontal",
|
|
281
285
|
left: "center",
|
|
@@ -284,58 +288,58 @@ function ye(e, i, r) {
|
|
|
284
288
|
},
|
|
285
289
|
tooltip: {
|
|
286
290
|
trigger: "item",
|
|
287
|
-
formatter: (
|
|
288
|
-
const
|
|
289
|
-
return
|
|
291
|
+
formatter: (a) => {
|
|
292
|
+
const b = a.data;
|
|
293
|
+
return b ? `${m[b[0]]} × ${g[b[1]]}: ${b[2] != null ? b[2] : "-"}` : "";
|
|
290
294
|
}
|
|
291
295
|
},
|
|
292
296
|
grid: { bottom: 60 },
|
|
293
297
|
series: [{
|
|
294
298
|
type: "heatmap",
|
|
295
299
|
data: S,
|
|
296
|
-
label: { show:
|
|
300
|
+
label: { show: i.showLabel !== !1 }
|
|
297
301
|
}]
|
|
298
302
|
};
|
|
299
303
|
}
|
|
300
|
-
function he(e,
|
|
304
|
+
function he(e, r, i) {
|
|
301
305
|
if (!Array.isArray(e) || e.length === 0) return {};
|
|
302
|
-
const t = e[0] ?? {}, n = Object.keys(t), s = n.filter((
|
|
303
|
-
let
|
|
304
|
-
if (
|
|
305
|
-
|
|
306
|
+
const t = e[0] ?? {}, n = Object.keys(t), s = n.filter((x) => typeof t[x] == "string"), f = n.filter((x) => typeof t[x] == "number"), h = r?.x ?? s[0];
|
|
307
|
+
let y;
|
|
308
|
+
if (r?.y && r.y.length >= 5)
|
|
309
|
+
y = r.y.slice(0, 5);
|
|
306
310
|
else {
|
|
307
|
-
const A = ["min", "q1", "median", "q3", "max"].filter((
|
|
308
|
-
|
|
311
|
+
const A = ["min", "q1", "median", "q3", "max"].filter((d) => f.includes(d));
|
|
312
|
+
y = A.length === 5 ? A : f.slice(0, 5);
|
|
309
313
|
}
|
|
310
|
-
if (
|
|
311
|
-
const
|
|
312
|
-
(
|
|
313
|
-
),
|
|
314
|
+
if (y.length < 5) return {};
|
|
315
|
+
const u = h ? e.map((x) => String(x[h] ?? "")) : void 0, m = e.map(
|
|
316
|
+
(x) => y.map((A) => Number(x[A] ?? 0))
|
|
317
|
+
), g = {
|
|
314
318
|
tooltip: { trigger: "item" },
|
|
315
319
|
series: [{
|
|
316
320
|
type: "boxplot",
|
|
317
|
-
data:
|
|
321
|
+
data: m
|
|
318
322
|
}]
|
|
319
323
|
};
|
|
320
|
-
return
|
|
324
|
+
return u ? (g.xAxis = { type: "category", data: u }, g.yAxis = { type: "value" }) : (g.xAxis = { type: "category" }, g.yAxis = { type: "value" }), g;
|
|
321
325
|
}
|
|
322
326
|
function C(e) {
|
|
323
327
|
if (e.length === 0) return;
|
|
324
|
-
const
|
|
325
|
-
return Object.keys(
|
|
328
|
+
const r = e[0];
|
|
329
|
+
return Object.keys(r).find((i) => typeof r[i] == "string");
|
|
326
330
|
}
|
|
327
331
|
function _(e) {
|
|
328
332
|
if (e.length === 0) return;
|
|
329
|
-
const
|
|
330
|
-
return Object.keys(
|
|
333
|
+
const r = e[0];
|
|
334
|
+
return Object.keys(r).find((i) => typeof r[i] == "number");
|
|
331
335
|
}
|
|
332
|
-
function me(e,
|
|
336
|
+
function me(e, r, i) {
|
|
333
337
|
if (!Array.isArray(e)) return {};
|
|
334
|
-
const t =
|
|
338
|
+
const t = r?.label ?? C(e), n = r?.value ?? _(e);
|
|
335
339
|
if (!t || !n) return {};
|
|
336
|
-
const s = e.map((
|
|
337
|
-
name: String(
|
|
338
|
-
value: Number(
|
|
340
|
+
const s = e.map((f) => ({
|
|
341
|
+
name: String(f[t] ?? ""),
|
|
342
|
+
value: Number(f[n] ?? 0)
|
|
339
343
|
}));
|
|
340
344
|
return {
|
|
341
345
|
tooltip: { trigger: "item", formatter: "{b}: {c} ({d}%)" },
|
|
@@ -349,19 +353,19 @@ function me(e, i, r) {
|
|
|
349
353
|
}]
|
|
350
354
|
};
|
|
351
355
|
}
|
|
352
|
-
function de(e,
|
|
356
|
+
function de(e, r, i) {
|
|
353
357
|
if (!Array.isArray(e)) return {};
|
|
354
|
-
const t = e, n =
|
|
358
|
+
const t = e, n = r?.x ?? C(t), s = (r?.y ?? [_(t)])[0];
|
|
355
359
|
if (!n || !s) return {};
|
|
356
|
-
const
|
|
357
|
-
let
|
|
358
|
-
for (const
|
|
359
|
-
const
|
|
360
|
-
|
|
360
|
+
const f = [], h = [], y = [], u = [];
|
|
361
|
+
let m = 0;
|
|
362
|
+
for (const g of t) {
|
|
363
|
+
const x = String(g[n] ?? ""), A = Number(g[s] ?? 0);
|
|
364
|
+
f.push(x), A >= 0 ? (h.push(m), y.push(A), u.push(null)) : (h.push(m + A), y.push(null), u.push(Math.abs(A))), m += A;
|
|
361
365
|
}
|
|
362
366
|
return {
|
|
363
367
|
tooltip: { trigger: "axis", axisPointer: { type: "shadow" } },
|
|
364
|
-
xAxis: { type: "category", data:
|
|
368
|
+
xAxis: { type: "category", data: f },
|
|
365
369
|
yAxis: { type: "value" },
|
|
366
370
|
series: [
|
|
367
371
|
{
|
|
@@ -376,25 +380,25 @@ function de(e, i, r) {
|
|
|
376
380
|
name: "Positive",
|
|
377
381
|
type: "bar",
|
|
378
382
|
stack: "waterfall",
|
|
379
|
-
data:
|
|
383
|
+
data: y
|
|
380
384
|
},
|
|
381
385
|
{
|
|
382
386
|
name: "Negative",
|
|
383
387
|
type: "bar",
|
|
384
388
|
stack: "waterfall",
|
|
385
|
-
data:
|
|
389
|
+
data: u
|
|
386
390
|
}
|
|
387
391
|
]
|
|
388
392
|
};
|
|
389
393
|
}
|
|
390
|
-
function
|
|
394
|
+
function pe(e, r) {
|
|
391
395
|
if (!Array.isArray(e)) return {};
|
|
392
|
-
const
|
|
396
|
+
const i = e.map((t) => j(t));
|
|
393
397
|
return {
|
|
394
398
|
tooltip: { trigger: "item" },
|
|
395
399
|
series: [{
|
|
396
400
|
type: "treemap",
|
|
397
|
-
data:
|
|
401
|
+
data: i,
|
|
398
402
|
leafDepth: 1,
|
|
399
403
|
roam: !1,
|
|
400
404
|
label: { show: !0, formatter: "{b}" }
|
|
@@ -402,80 +406,80 @@ function be(e, i) {
|
|
|
402
406
|
};
|
|
403
407
|
}
|
|
404
408
|
function j(e) {
|
|
405
|
-
const
|
|
409
|
+
const r = {
|
|
406
410
|
name: String(e.name ?? ""),
|
|
407
411
|
value: Number(e.value ?? 0)
|
|
408
412
|
};
|
|
409
|
-
return Array.isArray(e.children) && (
|
|
413
|
+
return Array.isArray(e.children) && (r.children = e.children.map((i) => j(i))), r;
|
|
410
414
|
}
|
|
411
|
-
function
|
|
415
|
+
function be(e, r, i) {
|
|
412
416
|
let t;
|
|
413
417
|
if (!Array.isArray(e) || e.length === 0) return {};
|
|
414
418
|
if (typeof e[0] == "number")
|
|
415
419
|
t = e;
|
|
416
420
|
else {
|
|
417
|
-
const
|
|
418
|
-
if (!
|
|
419
|
-
t = e.map((
|
|
421
|
+
const d = r?.value ?? _(e);
|
|
422
|
+
if (!d) return {};
|
|
423
|
+
t = e.map((p) => Number(p[d] ?? 0));
|
|
420
424
|
}
|
|
421
425
|
if (t.length === 0) return {};
|
|
422
|
-
const n = typeof
|
|
423
|
-
for (let
|
|
424
|
-
const
|
|
425
|
-
|
|
426
|
+
const n = typeof i.bins == "number" ? i.bins : Math.ceil(Math.log2(t.length) + 1), s = Math.min(...t), y = (Math.max(...t) - s) / n || 1, u = new Array(n).fill(0), m = [];
|
|
427
|
+
for (let d = 0; d < n; d++) {
|
|
428
|
+
const p = s + d * y, S = s + (d + 1) * y, o = (l) => Number.isInteger(l) ? String(l) : l.toFixed(1);
|
|
429
|
+
m.push(`${o(p)}–${o(S)}`);
|
|
426
430
|
}
|
|
427
|
-
for (const
|
|
428
|
-
let
|
|
429
|
-
|
|
431
|
+
for (const d of t) {
|
|
432
|
+
let p = Math.floor((d - s) / y);
|
|
433
|
+
p >= n && (p = n - 1), u[p]++;
|
|
430
434
|
}
|
|
431
|
-
const
|
|
435
|
+
const g = {
|
|
432
436
|
type: "bar",
|
|
433
|
-
data:
|
|
437
|
+
data: u,
|
|
434
438
|
barCategoryGap: "0%"
|
|
435
|
-
},
|
|
436
|
-
xAxis: { type: "category", data:
|
|
439
|
+
}, x = {
|
|
440
|
+
xAxis: { type: "category", data: m, axisTick: { alignWithLabel: !0 } },
|
|
437
441
|
yAxis: { type: "value" },
|
|
438
|
-
series: [
|
|
442
|
+
series: [g],
|
|
439
443
|
tooltip: { trigger: "axis" }
|
|
440
|
-
}, A =
|
|
441
|
-
return Array.isArray(A) && A.length > 0 && (
|
|
444
|
+
}, A = i.referenceLines;
|
|
445
|
+
return Array.isArray(A) && A.length > 0 && (g.markLine = {
|
|
442
446
|
silent: !0,
|
|
443
447
|
symbol: "none",
|
|
444
|
-
data: A.map((
|
|
445
|
-
const
|
|
446
|
-
|
|
448
|
+
data: A.map((d) => {
|
|
449
|
+
const p = {};
|
|
450
|
+
d.axis === "x" ? p.xAxis = d.value : p.yAxis = d.value, d.label && (p.name = d.label);
|
|
447
451
|
const S = {};
|
|
448
|
-
return
|
|
452
|
+
return d.color && (S.color = d.color), d.style && (S.type = d.style), Object.keys(S).length > 0 && (p.lineStyle = S), d.label && (p.label = { formatter: d.label, position: "end" }), p;
|
|
449
453
|
})
|
|
450
|
-
}),
|
|
454
|
+
}), x;
|
|
451
455
|
}
|
|
452
456
|
function I(e) {
|
|
453
457
|
if (e.length === 0) return [];
|
|
454
|
-
const
|
|
455
|
-
return Object.keys(
|
|
458
|
+
const r = e[0];
|
|
459
|
+
return Object.keys(r).filter((i) => typeof r[i] == "number");
|
|
456
460
|
}
|
|
457
|
-
function V(e,
|
|
458
|
-
const
|
|
459
|
-
for (const t of Object.keys(
|
|
460
|
-
const n = e[t], s =
|
|
461
|
-
|
|
461
|
+
function V(e, r) {
|
|
462
|
+
const i = { ...e };
|
|
463
|
+
for (const t of Object.keys(r)) {
|
|
464
|
+
const n = e[t], s = r[t];
|
|
465
|
+
L(n) && L(s) ? i[t] = V(n, s) : i[t] = s;
|
|
462
466
|
}
|
|
463
|
-
return
|
|
467
|
+
return i;
|
|
464
468
|
}
|
|
465
|
-
function
|
|
469
|
+
function L(e) {
|
|
466
470
|
return e != null && typeof e == "object" && !Array.isArray(e);
|
|
467
471
|
}
|
|
468
|
-
function
|
|
469
|
-
return (
|
|
472
|
+
function ge(e, r) {
|
|
473
|
+
return (i) => {
|
|
470
474
|
let t;
|
|
471
475
|
if (e.type) {
|
|
472
476
|
const n = e.type === "currency" && e.currency ? `currency:${e.currency}` : e.type;
|
|
473
|
-
t = q(
|
|
477
|
+
t = q(i, n, r), e.type === "percent" && (t = typeof i == "number" ? new Intl.NumberFormat(r, { maximumFractionDigits: e.decimals ?? 2 }).format(i) + "%" : String(i) + "%");
|
|
474
478
|
} else
|
|
475
|
-
t = String(
|
|
479
|
+
t = String(i);
|
|
476
480
|
if (e.decimals !== void 0 && e.type === "number") {
|
|
477
|
-
const n = Number(
|
|
478
|
-
isNaN(n) || (t = new Intl.NumberFormat(
|
|
481
|
+
const n = Number(i);
|
|
482
|
+
isNaN(n) || (t = new Intl.NumberFormat(r, {
|
|
479
483
|
minimumFractionDigits: e.decimals,
|
|
480
484
|
maximumFractionDigits: e.decimals
|
|
481
485
|
}).format(n));
|
|
@@ -483,20 +487,20 @@ function xe(e, i) {
|
|
|
483
487
|
return e.prefix && (t = e.prefix + t), e.suffix && (t = t + e.suffix), t;
|
|
484
488
|
};
|
|
485
489
|
}
|
|
486
|
-
function
|
|
487
|
-
if (!
|
|
488
|
-
const n =
|
|
490
|
+
function z(e, r, i, t) {
|
|
491
|
+
if (!i || !e[r]) return;
|
|
492
|
+
const n = ge(i, t), s = e[r];
|
|
489
493
|
if (Array.isArray(s))
|
|
490
|
-
e[
|
|
491
|
-
else if (
|
|
492
|
-
const
|
|
493
|
-
e[
|
|
494
|
+
e[r] = s.map((f) => f.type === "value" ? { ...f, axisLabel: { ...f.axisLabel ?? {}, formatter: n } } : f);
|
|
495
|
+
else if (L(s)) {
|
|
496
|
+
const f = s;
|
|
497
|
+
e[r] = { ...f, axisLabel: { ...f.axisLabel ?? {}, formatter: n } };
|
|
494
498
|
}
|
|
495
499
|
}
|
|
496
|
-
var
|
|
497
|
-
for (var n = t > 1 ? void 0 : t ? Ae(
|
|
498
|
-
(
|
|
499
|
-
return t && n &&
|
|
500
|
+
var xe = Object.defineProperty, Ae = Object.getOwnPropertyDescriptor, D = (e, r, i, t) => {
|
|
501
|
+
for (var n = t > 1 ? void 0 : t ? Ae(r, i) : r, s = e.length - 1, f; s >= 0; s--)
|
|
502
|
+
(f = e[s]) && (n = (t ? f(r, i, n) : f(n)) || n);
|
|
503
|
+
return t && n && xe(r, i, n), n;
|
|
500
504
|
};
|
|
501
505
|
O.use([
|
|
502
506
|
H,
|
|
@@ -513,15 +517,15 @@ O.use([
|
|
|
513
517
|
ie,
|
|
514
518
|
se,
|
|
515
519
|
ne,
|
|
516
|
-
|
|
517
|
-
|
|
520
|
+
oe,
|
|
521
|
+
ae
|
|
518
522
|
]);
|
|
519
|
-
let k = class extends
|
|
523
|
+
let k = class extends P {
|
|
520
524
|
constructor() {
|
|
521
525
|
super(...arguments), this.spec = null, this._chart = null, this._container = null, this._resizeObserver = null;
|
|
522
526
|
}
|
|
523
527
|
render() {
|
|
524
|
-
if (!this.spec) return
|
|
528
|
+
if (!this.spec) return T;
|
|
525
529
|
const e = this.spec.title ?? `${this.spec.widget} chart`;
|
|
526
530
|
return R`<div class="chart-container" part="chart" role="img" aria-label=${e}></div>`;
|
|
527
531
|
}
|
|
@@ -543,7 +547,7 @@ let k = class extends T {
|
|
|
543
547
|
}
|
|
544
548
|
_onChartClick(e) {
|
|
545
549
|
if (!this.spec) return;
|
|
546
|
-
const
|
|
550
|
+
const r = {
|
|
547
551
|
type: "select",
|
|
548
552
|
widget: this.spec.widget,
|
|
549
553
|
id: this.spec.id,
|
|
@@ -556,7 +560,7 @@ let k = class extends T {
|
|
|
556
560
|
};
|
|
557
561
|
this.dispatchEvent(
|
|
558
562
|
new CustomEvent("u-widget-internal", {
|
|
559
|
-
detail:
|
|
563
|
+
detail: r,
|
|
560
564
|
bubbles: !0,
|
|
561
565
|
composed: !0
|
|
562
566
|
})
|
|
@@ -568,38 +572,41 @@ let k = class extends T {
|
|
|
568
572
|
if (!(Array.isArray(
|
|
569
573
|
this.spec.options?.colors
|
|
570
574
|
) && this.spec.options.colors.length > 0)) {
|
|
571
|
-
const
|
|
572
|
-
|
|
575
|
+
const t = this._readThemeColors();
|
|
576
|
+
t.length > 0 && (e.color = t);
|
|
573
577
|
}
|
|
574
|
-
this._readCSSVar("--u-widget-bg") && (e.backgroundColor = "transparent"), this._applyThemeStyle(e), this._chart.setOption(e, !0);
|
|
578
|
+
!!!this.spec.options?.echarts?.backgroundColor && this._readCSSVar("--u-widget-bg") && (e.backgroundColor = "transparent"), this._applyThemeStyle(e), this._chart.setOption(e, !0);
|
|
575
579
|
}
|
|
576
580
|
_applyThemeStyle(e) {
|
|
577
|
-
const
|
|
578
|
-
if (!
|
|
579
|
-
e.textStyle = { ...e.textStyle, color:
|
|
581
|
+
const r = this._readCSSVar("--u-widget-text"), i = this._readCSSVar("--u-widget-text-secondary"), t = this._readCSSVar("--u-widget-border");
|
|
582
|
+
if (!r) return;
|
|
583
|
+
e.textStyle = { ...e.textStyle, color: r };
|
|
580
584
|
const n = (s) => {
|
|
581
585
|
if (!s || typeof s != "object") return s;
|
|
582
586
|
if (Array.isArray(s)) return s.map(n);
|
|
583
|
-
const u =
|
|
587
|
+
const f = s, h = f.axisLine ?? {}, y = h.lineStyle ?? {}, u = f.splitLine ?? {}, m = u.lineStyle ?? {};
|
|
584
588
|
return {
|
|
585
|
-
...
|
|
586
|
-
axisLabel: { ...
|
|
587
|
-
axisLine: { lineStyle: { color: t ||
|
|
588
|
-
splitLine: { lineStyle: { color: t } }
|
|
589
|
+
...f,
|
|
590
|
+
axisLabel: { ...f.axisLabel ?? {}, color: i || r },
|
|
591
|
+
axisLine: { ...h, lineStyle: { ...y, color: t || i } },
|
|
592
|
+
splitLine: { ...u, lineStyle: { ...m, color: t } }
|
|
589
593
|
};
|
|
590
594
|
};
|
|
591
|
-
e.xAxis && (e.xAxis = n(e.xAxis)), e.yAxis && (e.yAxis = n(e.yAxis)), e.legend && typeof e.legend == "object"
|
|
595
|
+
if (e.xAxis && (e.xAxis = n(e.xAxis)), e.yAxis && (e.yAxis = n(e.yAxis)), e.legend && typeof e.legend == "object") {
|
|
596
|
+
const s = e.legend;
|
|
597
|
+
e.legend = { ...s, textStyle: { ...s.textStyle ?? {}, color: r } };
|
|
598
|
+
}
|
|
592
599
|
}
|
|
593
600
|
_readThemeColors() {
|
|
594
601
|
const e = [];
|
|
595
|
-
for (let
|
|
596
|
-
const
|
|
597
|
-
if (
|
|
602
|
+
for (let r = 1; r <= 10; r++) {
|
|
603
|
+
const i = this._readCSSVar(`--u-widget-chart-color-${r}`);
|
|
604
|
+
if (i) e.push(i);
|
|
598
605
|
else break;
|
|
599
606
|
}
|
|
600
607
|
if (e.length === 0) {
|
|
601
|
-
const
|
|
602
|
-
|
|
608
|
+
const r = this._readCSSVar("--u-widget-primary");
|
|
609
|
+
r && e.push(r);
|
|
603
610
|
}
|
|
604
611
|
return e;
|
|
605
612
|
}
|
|
@@ -616,7 +623,7 @@ let k = class extends T {
|
|
|
616
623
|
};
|
|
617
624
|
k.styles = [
|
|
618
625
|
G,
|
|
619
|
-
|
|
626
|
+
E`
|
|
620
627
|
:host {
|
|
621
628
|
display: block;
|
|
622
629
|
container: uw-chart / inline-size;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"u-widgets-charts.js","sources":["../src/renderers/echarts-adapter.ts","../src/elements/uw-chart.ts"],"sourcesContent":["import type { UWidgetSpec, NormalizedMapping, ReferenceLineOption, AxisFormatOption } from '../core/types.js';\nimport { formatValue } from '../core/format.js';\nimport { normalizeMapping } from '../core/normalize.js';\n\ninterface ConditionalStyleRule {\n field: string;\n above?: number;\n below?: number;\n color: string;\n symbol?: string;\n symbolSize?: number;\n}\n\nfunction matchConditionalStyle(\n row: Record<string, unknown>,\n rules: ConditionalStyleRule[],\n): ConditionalStyleRule | undefined {\n for (const rule of rules) {\n const raw = row[rule.field];\n if (raw === undefined || raw === null) continue;\n const val = Number(raw);\n if (Number.isNaN(val)) continue;\n const aboveOk = rule.above === undefined || val > rule.above;\n const belowOk = rule.below === undefined || val < rule.below;\n if (aboveOk && belowOk) return rule;\n }\n return undefined;\n}\n\n/**\n * Translate a u-widget spec into an ECharts option object.\n * This is a pure function with no DOM or ECharts dependency.\n *\n * Supports `options.echarts` passthrough: any key-value pairs in\n * `options.echarts` are deep-merged (one level) into the generated\n * ECharts option, allowing full customization.\n */\nexport function toEChartsOption(spec: UWidgetSpec): Record<string, unknown> {\n const widget = spec.widget;\n const data = spec.data;\n const mapping = spec.mapping ? normalizeMapping(spec.mapping) : undefined;\n const options = spec.options ?? {};\n\n if (!data) return {};\n\n let result: Record<string, unknown>;\n\n switch (widget) {\n case 'chart.bar':\n result = buildCartesian(data, mapping, 'bar', options);\n break;\n case 'chart.line':\n result = buildCartesian(data, mapping, 'line', options);\n break;\n case 'chart.area':\n result = buildCartesian(data, mapping, 'line', { ...options, _area: true });\n break;\n case 'chart.pie':\n result = buildPie(data, mapping, options);\n break;\n case 'chart.scatter':\n result = buildScatter(data, mapping, options);\n break;\n case 'chart.radar':\n result = buildRadar(data, mapping, options);\n break;\n case 'chart.heatmap':\n result = buildHeatmap(data, mapping, options);\n break;\n case 'chart.box':\n result = buildBoxplot(data, mapping, options);\n break;\n case 'chart.funnel':\n result = buildFunnel(data, mapping, options);\n break;\n case 'chart.waterfall':\n result = buildWaterfall(data, mapping, options);\n break;\n case 'chart.treemap':\n result = buildTreemap(data, options);\n break;\n case 'chart.histogram':\n result = buildHistogram(data, mapping, options);\n break;\n default:\n return {};\n }\n\n // Apply chart-level options\n if (options.legend === false && result.legend) {\n result.legend = { ...result.legend as Record<string, unknown>, show: false };\n }\n\n if (options.grid === false) {\n // Hide grid lines on axes\n if (result.xAxis && typeof result.xAxis === 'object' && !Array.isArray(result.xAxis)) {\n result.xAxis = { ...result.xAxis as Record<string, unknown>, splitLine: { show: false } };\n }\n if (result.yAxis && typeof result.yAxis === 'object' && !Array.isArray(result.yAxis)) {\n result.yAxis = { ...result.yAxis as Record<string, unknown>, splitLine: { show: false } };\n }\n }\n\n if (options.animate === false) {\n result.animation = false;\n }\n\n if (Array.isArray(options.colors) && options.colors.length > 0) {\n result.color = options.colors;\n }\n\n // Apply axis format options\n const locale = options.locale as string | undefined;\n applyAxisFormat(result, 'xAxis', options.xFormat as AxisFormatOption | undefined, locale);\n applyAxisFormat(result, 'yAxis', options.yFormat as AxisFormatOption | undefined, locale);\n\n // Apply echarts passthrough: deep-merge\n const passthrough = options.echarts as Record<string, unknown> | undefined;\n if (passthrough && typeof passthrough === 'object') {\n result = deepMerge(result, passthrough);\n }\n\n return result;\n}\n\nfunction buildCartesian(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n type: string,\n options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n const xField = mapping?.x ?? guessStringField(data);\n const yFields = mapping?.y ?? [guessNumberField(data)].filter(Boolean) as string[];\n\n if (!xField || yFields.length === 0) return {};\n\n const categories = data.map((row) => String(row[xField] ?? ''));\n const horizontal = !!options.horizontal;\n\n const seriesOverrides = Array.isArray(options.series) ? options.series as Record<string, unknown>[] : [];\n const condStyles = options.conditionalStyles as ConditionalStyleRule[] | undefined;\n\n const seriesItems = yFields.map((field, i) => {\n const s: Record<string, unknown> = {\n name: field,\n type,\n data: data.map((row) => {\n const val = row[field] ?? null;\n if (condStyles?.length) {\n const match = matchConditionalStyle(row, condStyles);\n if (match) {\n const item: Record<string, unknown> = { value: val, itemStyle: { color: match.color } };\n if (match.symbol) item.symbol = match.symbol;\n if (match.symbolSize) item.symbolSize = match.symbolSize;\n return item;\n }\n }\n return val;\n }),\n };\n if (options._area) s.areaStyle = {};\n if (options.smooth) s.smooth = true;\n if (options.step) s.step = options.step === true ? 'end' : options.step;\n\n // Apply per-series overrides from options.series[i]\n const override = seriesOverrides[i];\n if (override) {\n if (override.color) {\n s.itemStyle = { color: override.color };\n s.lineStyle = { ...(s.lineStyle as Record<string, unknown> ?? {}), color: override.color };\n }\n if (override.lineStyle) {\n s.lineStyle = { ...(s.lineStyle as Record<string, unknown> ?? {}), ...(override.lineStyle as Record<string, unknown>) };\n }\n if (override.symbol !== undefined) s.symbol = override.symbol;\n if (override.label) s.name = override.label as string;\n if (override.type) s.type = override.type as string;\n if (override.yAxisIndex !== undefined) s.yAxisIndex = override.yAxisIndex;\n }\n return s;\n });\n\n const catAxis: Record<string, unknown> = { type: 'category', data: categories };\n const valAxis: Record<string, unknown> = { type: 'value' };\n\n // Histogram mode: remove gaps between bars\n if (options.histogram) {\n catAxis.axisTick = { alignWithLabel: true };\n seriesItems.forEach((s) => { s.barCategoryGap = '0%'; });\n }\n\n // Detect if any series requires a secondary Y axis\n const needsDualYAxis = !horizontal && seriesItems.some((s) => (s.yAxisIndex as number) >= 1);\n let yAxisConfig: unknown;\n if (needsDualYAxis) {\n const secondAxis = Array.isArray(options.yAxis) && (options.yAxis as unknown[]).length >= 2\n ? (options.yAxis as Record<string, unknown>[])[1]\n : { type: 'value' };\n yAxisConfig = [valAxis, secondAxis];\n } else {\n yAxisConfig = horizontal ? catAxis : valAxis;\n }\n\n const result: Record<string, unknown> = {\n xAxis: horizontal ? valAxis : catAxis,\n yAxis: yAxisConfig,\n series: seriesItems,\n tooltip: { trigger: 'axis' },\n };\n\n if (yFields.length > 1) {\n const legendNames = seriesItems.map((s) => s.name as string);\n result.legend = { data: legendNames };\n }\n\n if (options.stack) {\n (result.series as Record<string, unknown>[]).forEach((s) => {\n s.stack = 'total';\n });\n }\n\n // Reference lines → ECharts markLine on first series\n const refLines = options.referenceLines as ReferenceLineOption[] | undefined;\n if (Array.isArray(refLines) && refLines.length > 0 && seriesItems.length > 0) {\n seriesItems[0].markLine = {\n silent: true,\n symbol: 'none',\n data: refLines.map((rl) => {\n const item: Record<string, unknown> = {};\n if (rl.axis === 'x') {\n item.xAxis = rl.value;\n } else {\n item.yAxis = rl.value;\n }\n if (rl.label) item.name = rl.label;\n const lineStyle: Record<string, unknown> = {};\n if (rl.color) lineStyle.color = rl.color;\n if (rl.style) lineStyle.type = rl.style;\n if (Object.keys(lineStyle).length > 0) item.lineStyle = lineStyle;\n if (rl.label) item.label = { formatter: rl.label, position: 'end' };\n return item;\n }),\n };\n }\n\n return result;\n}\n\nfunction buildScatter(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n // For scatter, prefer two numeric fields for x/y\n const numFields = getNumberFields(data);\n const xField = mapping?.x ?? numFields[0];\n const yField = (mapping?.y ?? [numFields[1]])[0];\n const colorField = mapping?.color;\n const sizeField = mapping?.size;\n const opacityField = mapping?.opacity;\n\n if (!xField || !yField) return {};\n\n const result: Record<string, unknown> = {\n xAxis: { type: 'value' },\n yAxis: { type: 'value' },\n tooltip: { trigger: 'item' },\n };\n\n // Pre-compute opacity normalization range if needed\n let opacityMin = Infinity;\n let opacityMax = -Infinity;\n if (opacityField) {\n for (const row of data) {\n const v = Number(row[opacityField] ?? 0);\n if (v < opacityMin) opacityMin = v;\n if (v > opacityMax) opacityMax = v;\n }\n }\n const opacityRange = opacityMax - opacityMin || 1;\n\n const condStyles = options.conditionalStyles as ConditionalStyleRule[] | undefined;\n\n // Helper: build a data point — plain array or object with itemStyle for opacity/conditionalStyles\n const toPoint = (row: Record<string, unknown>): unknown => {\n const pt = [Number(row[xField] ?? 0), Number(row[yField] ?? 0)];\n if (sizeField) pt.push(Number(row[sizeField] ?? 0));\n\n if (condStyles?.length) {\n const match = matchConditionalStyle(row, condStyles);\n if (match) {\n const style: Record<string, unknown> = { color: match.color };\n if (opacityField) {\n const raw = Number(row[opacityField] ?? 0);\n style.opacity = Math.round((0.1 + 0.9 * ((raw - opacityMin) / opacityRange)) * 100) / 100;\n }\n const item: Record<string, unknown> = { value: pt, itemStyle: style };\n if (match.symbol) item.symbol = match.symbol;\n if (match.symbolSize) item.symbolSize = match.symbolSize;\n return item;\n }\n }\n\n if (opacityField) {\n const raw = Number(row[opacityField] ?? 0);\n const norm = 0.1 + 0.9 * ((raw - opacityMin) / opacityRange);\n return { value: pt, itemStyle: { opacity: Math.round(norm * 100) / 100 } };\n }\n return pt;\n };\n\n // symbolSize function that maps the third value to pixel radius\n const symbolSizeFn = sizeField\n ? (val: number[] | { value: number[] }) => {\n const arr = Array.isArray(val) ? val : val.value;\n const raw = arr[2] ?? 0;\n // Clamp to [4, 60] range — square root scale for area perception\n return Math.max(4, Math.min(60, Math.sqrt(raw) * 4));\n }\n : undefined;\n\n if (colorField) {\n // Group data by color field → separate series per group\n const groups = new Map<string, unknown[]>();\n for (const row of data) {\n const key = String(row[colorField] ?? 'unknown');\n if (!groups.has(key)) groups.set(key, []);\n groups.get(key)!.push(toPoint(row));\n }\n const seriesItems: Record<string, unknown>[] = [];\n for (const [name, points] of groups) {\n const series: Record<string, unknown> = { name, type: 'scatter', data: points };\n if (symbolSizeFn) series.symbolSize = symbolSizeFn;\n seriesItems.push(series);\n }\n result.series = seriesItems;\n result.legend = { data: Array.from(groups.keys()) };\n } else {\n // Single series — all points same color\n const points = data.map((row) => toPoint(row));\n const series: Record<string, unknown> = { type: 'scatter', data: points };\n if (symbolSizeFn) series.symbolSize = symbolSizeFn;\n result.series = [series];\n }\n\n // Reference lines\n const refLines = options.referenceLines as ReferenceLineOption[] | undefined;\n if (Array.isArray(refLines) && refLines.length > 0) {\n const firstSeries = (result.series as Record<string, unknown>[])[0];\n firstSeries.markLine = {\n silent: true,\n symbol: 'none',\n data: refLines.map((rl) => {\n const item: Record<string, unknown> = {};\n if (rl.axis === 'x') item.xAxis = rl.value;\n else item.yAxis = rl.value;\n if (rl.label) item.name = rl.label;\n const lineStyle: Record<string, unknown> = {};\n if (rl.color) lineStyle.color = rl.color;\n if (rl.style) lineStyle.type = rl.style;\n if (Object.keys(lineStyle).length > 0) item.lineStyle = lineStyle;\n if (rl.label) item.label = { formatter: rl.label, position: 'end' };\n return item;\n }),\n };\n }\n\n return result;\n}\n\nfunction buildPie(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n const labelField = mapping?.label ?? guessStringField(data);\n const valueField = mapping?.value ?? guessNumberField(data);\n\n if (!labelField || !valueField) return {};\n\n const pieData = data.map((row) => ({\n name: String(row[labelField] ?? ''),\n value: Number(row[valueField] ?? 0),\n }));\n\n const radius = options.donut ? ['40%', '70%'] : '50%';\n const seriesItem: Record<string, unknown> = {\n type: 'pie',\n radius,\n data: pieData,\n label: { overflow: 'truncate', width: 80 },\n };\n\n if (options.showLabel === false) {\n seriesItem.label = { show: false };\n }\n\n const result: Record<string, unknown> = {\n tooltip: { trigger: 'item' },\n legend: { orient: 'vertical', left: 'left' },\n series: [seriesItem],\n };\n\n // Donut center label\n const center = options.center as { label?: string; value?: string } | undefined;\n if (options.donut && center && (center.label || center.value)) {\n const children: Record<string, unknown>[] = [];\n if (center.label) {\n children.push({\n type: 'text',\n top: center.value ? -16 : 0,\n style: { text: center.label, fontSize: 13, fill: '#999', textAlign: 'center' },\n });\n }\n if (center.value) {\n children.push({\n type: 'text',\n top: center.label ? 8 : 0,\n style: { text: center.value, fontSize: 20, fontWeight: 'bold', fill: '#333', textAlign: 'center' },\n });\n }\n result.graphic = [{ type: 'group', left: 'center', top: 'middle', children }];\n }\n\n return result;\n}\n\nfunction buildRadar(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n _options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n const axisField = mapping?.axis ?? guessStringField(data);\n const yFields = mapping?.y ?? getNumberFields(data);\n\n if (!axisField || yFields.length === 0) return {};\n\n const indicator = data.map((row) => ({\n name: String(row[axisField] ?? ''),\n }));\n\n const series = yFields.map((field) => ({\n name: field,\n value: data.map((row) => Number(row[field] ?? 0)),\n }));\n\n return {\n tooltip: {},\n legend: { data: yFields },\n radar: { indicator },\n series: [\n {\n type: 'radar',\n data: series,\n },\n ],\n };\n}\n\nfunction buildHeatmap(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n // Determine x, y (category), value (number) fields\n const first = data[0] ?? {};\n const keys = Object.keys(first);\n const stringFields = keys.filter((k) => typeof first[k] === 'string');\n const numberFields = keys.filter((k) => typeof first[k] === 'number');\n\n const xField = mapping?.x ?? stringFields[0];\n // For heatmap, y is a category field (string), not a numeric series\n const yField = mapping?.y?.[0] ?? stringFields.find((k) => k !== xField);\n const valueField = mapping?.value ?? numberFields[0];\n\n if (!xField || !yField || !valueField) return {};\n\n // Extract unique categories preserving order of appearance\n const xCats: string[] = [];\n const yCats: string[] = [];\n const xSet = new Set<string>();\n const ySet = new Set<string>();\n\n for (const row of data) {\n const x = String(row[xField] ?? '');\n const y = String(row[yField] ?? '');\n if (!xSet.has(x)) { xSet.add(x); xCats.push(x); }\n if (!ySet.has(y)) { ySet.add(y); yCats.push(y); }\n }\n\n // Build index maps for O(1) lookup\n const xIndex = new Map<string, number>();\n xCats.forEach((v, i) => xIndex.set(v, i));\n const yIndex = new Map<string, number>();\n yCats.forEach((v, i) => yIndex.set(v, i));\n\n // Build [xIndex, yIndex, value] data\n const heatData: (number | null)[][] = [];\n let minVal = Infinity;\n let maxVal = -Infinity;\n\n for (const row of data) {\n const xi = xIndex.get(String(row[xField] ?? '')) ?? 0;\n const yi = yIndex.get(String(row[yField] ?? '')) ?? 0;\n const v = row[valueField] != null ? Number(row[valueField]) : null;\n heatData.push([xi, yi, v]);\n if (v != null) {\n if (v < minVal) minVal = v;\n if (v > maxVal) maxVal = v;\n }\n }\n\n // Handle edge case of empty/no-value data\n if (!isFinite(minVal)) { minVal = 0; maxVal = 1; }\n\n // Determine color range from options or use defaults\n const colorRange = (options.colorRange as string[]) ?? ['#313695', '#4575b4', '#74add1', '#abd9e9', '#fee090', '#fdae61', '#f46d43', '#d73027'];\n\n return {\n xAxis: { type: 'category', data: xCats, splitArea: { show: true } },\n yAxis: { type: 'category', data: yCats, splitArea: { show: true } },\n visualMap: {\n min: options.min != null ? Number(options.min) : minVal,\n max: options.max != null ? Number(options.max) : maxVal,\n calculable: true,\n orient: 'horizontal',\n left: 'center',\n bottom: 0,\n inRange: { color: colorRange },\n },\n tooltip: {\n trigger: 'item',\n formatter: (params: Record<string, unknown>) => {\n const d = params.data as number[];\n if (!d) return '';\n return `${xCats[d[0]]} × ${yCats[d[1]]}: ${d[2] != null ? d[2] : '-'}`;\n },\n },\n grid: { bottom: 60 },\n series: [{\n type: 'heatmap',\n data: heatData,\n label: { show: options.showLabel !== false },\n }],\n };\n}\n\nfunction buildBoxplot(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n _options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data) || data.length === 0) return {};\n\n const first = data[0] ?? {};\n const keys = Object.keys(first);\n const stringFields = keys.filter((k) => typeof first[k] === 'string');\n const numberFields = keys.filter((k) => typeof first[k] === 'number');\n\n // Category field (x)\n const xField = mapping?.x ?? stringFields[0];\n\n // Stat fields: use mapping.y if provided (5 fields: min, q1, median, q3, max)\n // Otherwise, try well-known names, then fall back to first 5 number fields\n let statFields: string[];\n if (mapping?.y && mapping.y.length >= 5) {\n statFields = mapping.y.slice(0, 5);\n } else {\n const wellKnown = ['min', 'q1', 'median', 'q3', 'max'];\n const matched = wellKnown.filter((name) => numberFields.includes(name));\n statFields = matched.length === 5 ? matched : numberFields.slice(0, 5);\n }\n\n if (statFields.length < 5) return {};\n\n const categories = xField ? data.map((row) => String(row[xField] ?? '')) : undefined;\n\n const boxData = data.map((row) =>\n statFields.map((f) => Number(row[f] ?? 0)),\n );\n\n const result: Record<string, unknown> = {\n tooltip: { trigger: 'item' },\n series: [{\n type: 'boxplot',\n data: boxData,\n }],\n };\n\n if (categories) {\n result.xAxis = { type: 'category', data: categories };\n result.yAxis = { type: 'value' };\n } else {\n result.xAxis = { type: 'category' };\n result.yAxis = { type: 'value' };\n }\n\n return result;\n}\n\n// ── Helpers ──\n\nfunction guessStringField(data: Record<string, unknown>[]): string | undefined {\n if (data.length === 0) return undefined;\n const first = data[0];\n return Object.keys(first).find((k) => typeof first[k] === 'string');\n}\n\nfunction guessNumberField(data: Record<string, unknown>[]): string | undefined {\n if (data.length === 0) return undefined;\n const first = data[0];\n return Object.keys(first).find((k) => typeof first[k] === 'number');\n}\n\nfunction buildFunnel(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n _options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n const labelField = mapping?.label ?? guessStringField(data as Record<string, unknown>[]);\n const valueField = (mapping?.value ?? guessNumberField(data as Record<string, unknown>[]));\n\n if (!labelField || !valueField) return {};\n\n const seriesData = (data as Record<string, unknown>[]).map((row) => ({\n name: String(row[labelField] ?? ''),\n value: Number(row[valueField] ?? 0),\n }));\n\n return {\n tooltip: { trigger: 'item', formatter: '{b}: {c} ({d}%)' },\n legend: { orient: 'vertical', left: 'left' },\n series: [{\n type: 'funnel',\n data: seriesData,\n sort: 'descending',\n gap: 2,\n label: { show: true, position: 'inside' },\n }],\n };\n}\n\nfunction buildWaterfall(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n _options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n const records = data as Record<string, unknown>[];\n const xField = mapping?.x ?? guessStringField(records);\n const yField = (mapping?.y ?? [guessNumberField(records)])[0];\n\n if (!xField || !yField) return {};\n\n const categories: string[] = [];\n const baseValues: number[] = [];\n const positiveValues: (number | null)[] = [];\n const negativeValues: (number | null)[] = [];\n\n let running = 0;\n for (const row of records) {\n const label = String(row[xField] ?? '');\n const value = Number(row[yField] ?? 0);\n categories.push(label);\n\n if (value >= 0) {\n baseValues.push(running);\n positiveValues.push(value);\n negativeValues.push(null);\n } else {\n baseValues.push(running + value);\n positiveValues.push(null);\n negativeValues.push(Math.abs(value));\n }\n running += value;\n }\n\n return {\n tooltip: { trigger: 'axis', axisPointer: { type: 'shadow' } },\n xAxis: { type: 'category', data: categories },\n yAxis: { type: 'value' },\n series: [\n {\n name: 'Base',\n type: 'bar',\n stack: 'waterfall',\n itemStyle: { borderColor: 'transparent', color: 'transparent' },\n emphasis: { itemStyle: { borderColor: 'transparent', color: 'transparent' } },\n data: baseValues,\n },\n {\n name: 'Positive',\n type: 'bar',\n stack: 'waterfall',\n data: positiveValues,\n },\n {\n name: 'Negative',\n type: 'bar',\n stack: 'waterfall',\n data: negativeValues,\n },\n ],\n };\n}\n\nfunction buildTreemap(\n data: unknown,\n _options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n // Treemap data uses name/value/children directly — pass through to ECharts\n const seriesData = (data as Record<string, unknown>[]).map((item) => toTreeNode(item));\n\n return {\n tooltip: { trigger: 'item' },\n series: [{\n type: 'treemap',\n data: seriesData,\n leafDepth: 1,\n roam: false,\n label: { show: true, formatter: '{b}' },\n }],\n };\n}\n\nfunction toTreeNode(item: Record<string, unknown>): Record<string, unknown> {\n const node: Record<string, unknown> = {\n name: String(item.name ?? ''),\n value: Number(item.value ?? 0),\n };\n if (Array.isArray(item.children)) {\n node.children = (item.children as Record<string, unknown>[]).map((child) => toTreeNode(child));\n }\n return node;\n}\n\nfunction buildHistogram(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n options: Record<string, unknown>,\n): Record<string, unknown> {\n // Extract numeric values from flat array or object array\n let values: number[];\n if (!Array.isArray(data) || data.length === 0) return {};\n\n if (typeof data[0] === 'number') {\n values = data as number[];\n } else {\n const field = mapping?.value ?? guessNumberField(data as Record<string, unknown>[]);\n if (!field) return {};\n values = (data as Record<string, unknown>[]).map((row) => Number(row[field] ?? 0));\n }\n\n if (values.length === 0) return {};\n\n // Determine bin count: explicit or Sturges' rule\n const binCount = typeof options.bins === 'number'\n ? options.bins\n : Math.ceil(Math.log2(values.length) + 1);\n\n const min = Math.min(...values);\n const max = Math.max(...values);\n const range = max - min;\n const binWidth = range / binCount || 1;\n\n // Build bins\n const bins: number[] = new Array(binCount).fill(0);\n const labels: string[] = [];\n\n for (let i = 0; i < binCount; i++) {\n const lo = min + i * binWidth;\n const hi = min + (i + 1) * binWidth;\n const fmt = (n: number) => Number.isInteger(n) ? String(n) : n.toFixed(1);\n labels.push(`${fmt(lo)}\\u2013${fmt(hi)}`);\n }\n\n for (const v of values) {\n let idx = Math.floor((v - min) / binWidth);\n if (idx >= binCount) idx = binCount - 1; // clamp max to last bin\n bins[idx]++;\n }\n\n const series: Record<string, unknown> = {\n type: 'bar',\n data: bins,\n barCategoryGap: '0%',\n };\n\n const result: Record<string, unknown> = {\n xAxis: { type: 'category', data: labels, axisTick: { alignWithLabel: true } },\n yAxis: { type: 'value' },\n series: [series],\n tooltip: { trigger: 'axis' },\n };\n\n // Reference lines\n const refLines = options.referenceLines as ReferenceLineOption[] | undefined;\n if (Array.isArray(refLines) && refLines.length > 0) {\n series.markLine = {\n silent: true,\n symbol: 'none',\n data: refLines.map((rl) => {\n const item: Record<string, unknown> = {};\n if (rl.axis === 'x') item.xAxis = rl.value;\n else item.yAxis = rl.value;\n if (rl.label) item.name = rl.label;\n const lineStyle: Record<string, unknown> = {};\n if (rl.color) lineStyle.color = rl.color;\n if (rl.style) lineStyle.type = rl.style;\n if (Object.keys(lineStyle).length > 0) item.lineStyle = lineStyle;\n if (rl.label) item.label = { formatter: rl.label, position: 'end' };\n return item;\n }),\n };\n }\n\n return result;\n}\n\nfunction getNumberFields(data: Record<string, unknown>[]): string[] {\n if (data.length === 0) return [];\n const first = data[0];\n return Object.keys(first).filter((k) => typeof first[k] === 'number');\n}\n\n/**\n * Deep-merge `overrides` into `base` recursively.\n * If both base[key] and overrides[key] are plain objects, merge recursively.\n * Arrays and other values: overrides[key] wins.\n */\nfunction deepMerge(\n base: Record<string, unknown>,\n overrides: Record<string, unknown>,\n): Record<string, unknown> {\n const result = { ...base };\n for (const key of Object.keys(overrides)) {\n const bv = base[key];\n const ov = overrides[key];\n if (isPlainObject(bv) && isPlainObject(ov)) {\n result[key] = deepMerge(bv as Record<string, unknown>, ov as Record<string, unknown>);\n } else {\n result[key] = ov;\n }\n }\n return result;\n}\n\nfunction isPlainObject(v: unknown): v is Record<string, unknown> {\n return v != null && typeof v === 'object' && !Array.isArray(v);\n}\n\n/**\n * Build a formatter string or function for ECharts axis labels\n * based on an AxisFormatOption.\n */\nfunction buildAxisFormatter(fmt: AxisFormatOption, locale?: string): (value: number | string) => string {\n return (value: number | string) => {\n let result: string;\n if (fmt.type) {\n const formatStr = fmt.type === 'currency' && fmt.currency\n ? `currency:${fmt.currency}`\n : fmt.type;\n result = formatValue(value, formatStr, locale);\n // For percent type, formatValue divides by 100 — but axis values are already in\n // display units (e.g. 73 means 73%), so use raw suffix instead\n if (fmt.type === 'percent') {\n result = typeof value === 'number'\n ? new Intl.NumberFormat(locale, { maximumFractionDigits: fmt.decimals ?? 2 }).format(value) + '%'\n : String(value) + '%';\n }\n } else {\n result = String(value);\n }\n if (fmt.decimals !== undefined && fmt.type === 'number') {\n const num = Number(value);\n if (!isNaN(num)) {\n result = new Intl.NumberFormat(locale, {\n minimumFractionDigits: fmt.decimals,\n maximumFractionDigits: fmt.decimals,\n }).format(num);\n }\n }\n if (fmt.prefix) result = fmt.prefix + result;\n if (fmt.suffix) result = result + fmt.suffix;\n return result;\n };\n}\n\n/**\n * Apply xFormat/yFormat to the corresponding axis in the ECharts option.\n * Handles both single axis and axis arrays (dual Y axis).\n */\nfunction applyAxisFormat(\n result: Record<string, unknown>,\n axisKey: 'xAxis' | 'yAxis',\n fmt: AxisFormatOption | undefined,\n locale?: string,\n): void {\n if (!fmt || !result[axisKey]) return;\n\n const formatter = buildAxisFormatter(fmt, locale);\n const axis = result[axisKey];\n\n if (Array.isArray(axis)) {\n // Dual axis — apply to all value-type axes\n result[axisKey] = (axis as Record<string, unknown>[]).map((a) => {\n if (a.type === 'value') {\n return { ...a, axisLabel: { ...(a.axisLabel as Record<string, unknown> ?? {}), formatter } };\n }\n return a;\n });\n } else if (isPlainObject(axis)) {\n const a = axis as Record<string, unknown>;\n result[axisKey] = { ...a, axisLabel: { ...(a.axisLabel as Record<string, unknown> ?? {}), formatter } };\n }\n}\n","import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport type { UWidgetSpec, UWidgetEvent } from '../core/types.js';\nimport { toEChartsOption } from '../renderers/echarts-adapter.js';\nimport { themeStyles } from '../styles/tokens.js';\n\n// Tree-shakeable ECharts imports\nimport * as echarts from 'echarts/core';\nimport { BarChart, LineChart, PieChart, ScatterChart, RadarChart, HeatmapChart, BoxplotChart, FunnelChart, TreemapChart } from 'echarts/charts';\nimport {\n GridComponent,\n TooltipComponent,\n LegendComponent,\n RadarComponent,\n MarkLineComponent,\n VisualMapComponent,\n} from 'echarts/components';\nimport { CanvasRenderer } from 'echarts/renderers';\n\necharts.use([\n BarChart,\n LineChart,\n PieChart,\n ScatterChart,\n RadarChart,\n HeatmapChart,\n BoxplotChart,\n FunnelChart,\n TreemapChart,\n GridComponent,\n TooltipComponent,\n LegendComponent,\n RadarComponent,\n MarkLineComponent,\n VisualMapComponent,\n CanvasRenderer,\n]);\n\n@customElement('uw-chart')\nexport class UwChart extends LitElement {\n static styles = [\n themeStyles,\n css`\n :host {\n display: block;\n container: uw-chart / inline-size;\n }\n\n .chart-container {\n width: 100%;\n height: var(--u-widget-chart-height, 300px);\n }\n\n @container uw-chart (max-width: 20rem) {\n .chart-container {\n height: var(--u-widget-chart-height-narrow, 200px);\n }\n }\n `,\n ];\n\n @property({ type: Object })\n spec: UWidgetSpec | null = null;\n\n private _chart: echarts.ECharts | null = null;\n private _container: HTMLDivElement | null = null;\n private _resizeObserver: ResizeObserver | null = null;\n\n render() {\n if (!this.spec) return nothing;\n const label = this.spec.title ?? `${this.spec.widget} chart`;\n return html`<div class=\"chart-container\" part=\"chart\" role=\"img\" aria-label=${label}></div>`;\n }\n\n protected firstUpdated() {\n this._container = this.shadowRoot?.querySelector('.chart-container') as HTMLDivElement | null;\n this._initChart();\n if (this._container) {\n this._resizeObserver = new ResizeObserver(() => this._chart?.resize());\n this._resizeObserver.observe(this._container);\n }\n }\n\n protected updated(changed: Map<string, unknown>) {\n if (changed.has('spec') && this._container) {\n this._updateChart();\n }\n }\n\n private _initChart() {\n if (!this._container || !this.spec) return;\n\n try {\n this._chart = echarts.init(this._container);\n this._chart.on('click', (params: Record<string, unknown>) => {\n this._onChartClick(params);\n });\n this._updateChart();\n } catch (e) {\n console.warn('[uw-chart] Failed to initialize ECharts:', (e as Error).message);\n }\n }\n\n private _onChartClick(params: Record<string, unknown>) {\n if (!this.spec) return;\n const detail: UWidgetEvent = {\n type: 'select',\n widget: this.spec.widget,\n id: this.spec.id,\n data: {\n name: params.name as string,\n seriesName: params.seriesName as string,\n value: params.value,\n dataIndex: params.dataIndex as number,\n },\n };\n this.dispatchEvent(\n new CustomEvent('u-widget-internal', {\n detail,\n bubbles: true,\n composed: true,\n }),\n );\n }\n\n private _updateChart() {\n if (!this._chart || !this.spec) return;\n\n const option = toEChartsOption(this.spec);\n\n // Inject theme colors from CSS custom properties,\n // but only if the spec didn't provide explicit colors\n const hasSpecColors = Array.isArray(\n (this.spec.options as Record<string, unknown> | undefined)?.colors,\n ) && ((this.spec.options as Record<string, unknown>).colors as unknown[]).length > 0;\n if (!hasSpecColors) {\n const themeColors = this._readThemeColors();\n if (themeColors.length > 0) {\n option.color = themeColors;\n }\n }\n if (this._readCSSVar('--u-widget-bg')) {\n option.backgroundColor = 'transparent';\n }\n\n // Inject text/axis/grid theme from CSS variables\n this._applyThemeStyle(option);\n\n this._chart.setOption(option, true);\n }\n\n private _applyThemeStyle(option: Record<string, unknown>) {\n const textColor = this._readCSSVar('--u-widget-text');\n const secondaryColor = this._readCSSVar('--u-widget-text-secondary');\n const borderColor = this._readCSSVar('--u-widget-border');\n\n if (!textColor) return; // no theme vars available\n\n // Global text style\n option.textStyle = { ...(option.textStyle as Record<string, unknown>), color: textColor };\n\n // Axis styling — merge into existing axis config preserving formatter etc.\n const mergeAxisTheme = (axis: unknown): unknown => {\n if (!axis || typeof axis !== 'object') return axis;\n if (Array.isArray(axis)) return axis.map(mergeAxisTheme);\n const a = axis as Record<string, unknown>;\n return {\n ...a,\n axisLabel: { ...(a.axisLabel as Record<string, unknown> ?? {}), color: secondaryColor || textColor },\n axisLine: { lineStyle: { color: borderColor || secondaryColor } },\n splitLine: { lineStyle: { color: borderColor } },\n };\n };\n if (option.xAxis) option.xAxis = mergeAxisTheme(option.xAxis);\n if (option.yAxis) option.yAxis = mergeAxisTheme(option.yAxis);\n\n // Legend\n if (option.legend && typeof option.legend === 'object') {\n option.legend = { ...option.legend as Record<string, unknown>, textStyle: { color: textColor } };\n }\n }\n\n private _readThemeColors(): string[] {\n const colors: string[] = [];\n // Read --u-widget-chart-color-N (1-based) custom properties\n for (let i = 1; i <= 10; i++) {\n const c = this._readCSSVar(`--u-widget-chart-color-${i}`);\n if (c) colors.push(c);\n else break;\n }\n // Fallback: use --u-widget-primary as first color if no palette defined\n if (colors.length === 0) {\n const primary = this._readCSSVar('--u-widget-primary');\n if (primary) colors.push(primary);\n }\n return colors;\n }\n\n private _readCSSVar(name: string): string {\n return getComputedStyle(this).getPropertyValue(name).trim();\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n this._resizeObserver?.disconnect();\n this._resizeObserver = null;\n this._chart?.dispose();\n this._chart = null;\n }\n\n /** Resize the chart (call when container size changes). */\n resize() {\n this._chart?.resize();\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'uw-chart': UwChart;\n }\n}\n"],"names":["matchConditionalStyle","row","rules","rule","raw","val","aboveOk","belowOk","toEChartsOption","spec","widget","data","mapping","normalizeMapping","options","result","buildCartesian","buildPie","buildScatter","buildRadar","buildHeatmap","buildBoxplot","buildFunnel","buildWaterfall","buildTreemap","buildHistogram","locale","applyAxisFormat","passthrough","deepMerge","type","xField","guessStringField","yFields","guessNumberField","categories","horizontal","seriesOverrides","condStyles","seriesItems","field","i","s","match","item","override","catAxis","valAxis","needsDualYAxis","yAxisConfig","secondAxis","legendNames","refLines","rl","lineStyle","numFields","getNumberFields","yField","colorField","sizeField","opacityField","opacityMin","opacityMax","v","opacityRange","toPoint","pt","style","norm","symbolSizeFn","groups","key","name","points","series","firstSeries","labelField","valueField","pieData","seriesItem","center","children","_options","axisField","indicator","first","keys","stringFields","k","numberFields","xCats","yCats","xSet","ySet","x","y","xIndex","yIndex","heatData","minVal","maxVal","xi","yi","colorRange","params","d","statFields","matched","boxData","f","seriesData","records","baseValues","positiveValues","negativeValues","running","label","value","toTreeNode","node","child","values","binCount","min","binWidth","bins","labels","lo","hi","fmt","n","idx","base","overrides","bv","ov","isPlainObject","buildAxisFormatter","formatStr","formatValue","num","axisKey","formatter","axis","a","echarts","BarChart","LineChart","PieChart","ScatterChart","RadarChart","HeatmapChart","BoxplotChart","FunnelChart","TreemapChart","GridComponent","TooltipComponent","LegendComponent","RadarComponent","MarkLineComponent","VisualMapComponent","CanvasRenderer","UwChart","LitElement","nothing","html","changed","detail","option","themeColors","textColor","secondaryColor","borderColor","mergeAxisTheme","colors","c","primary","themeStyles","css","__decorateClass","property","customElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"u-widgets-charts.js","sources":["../src/renderers/echarts-adapter.ts","../src/elements/uw-chart.ts"],"sourcesContent":["import type { UWidgetSpec, NormalizedMapping, ReferenceLineOption, AxisFormatOption } from '../core/types.js';\nimport { formatValue } from '../core/format.js';\nimport { normalizeMapping } from '../core/normalize.js';\n\ninterface ConditionalStyleRule {\n field: string;\n above?: number;\n below?: number;\n color: string;\n symbol?: string;\n symbolSize?: number;\n}\n\nfunction matchConditionalStyle(\n row: Record<string, unknown>,\n rules: ConditionalStyleRule[],\n): ConditionalStyleRule | undefined {\n for (const rule of rules) {\n const raw = row[rule.field];\n if (raw === undefined || raw === null) continue;\n const val = Number(raw);\n if (Number.isNaN(val)) continue;\n const aboveOk = rule.above === undefined || val > rule.above;\n const belowOk = rule.below === undefined || val < rule.below;\n if (aboveOk && belowOk) return rule;\n }\n return undefined;\n}\n\n/**\n * Translate a u-widget spec into an ECharts option object.\n * This is a pure function with no DOM or ECharts dependency.\n *\n * Supports `options.echarts` passthrough: any key-value pairs in\n * `options.echarts` are deep-merged (one level) into the generated\n * ECharts option, allowing full customization.\n */\nexport function toEChartsOption(spec: UWidgetSpec): Record<string, unknown> {\n const widget = spec.widget;\n const data = spec.data;\n const mapping = spec.mapping ? normalizeMapping(spec.mapping) : undefined;\n const options = spec.options ?? {};\n\n if (!data) return {};\n\n let result: Record<string, unknown>;\n\n switch (widget) {\n case 'chart.bar':\n result = buildCartesian(data, mapping, 'bar', options);\n break;\n case 'chart.line':\n result = buildCartesian(data, mapping, 'line', options);\n break;\n case 'chart.area':\n result = buildCartesian(data, mapping, 'line', { ...options, _area: true });\n break;\n case 'chart.pie':\n result = buildPie(data, mapping, options);\n break;\n case 'chart.scatter':\n result = buildScatter(data, mapping, options);\n break;\n case 'chart.radar':\n result = buildRadar(data, mapping, options);\n break;\n case 'chart.heatmap':\n result = buildHeatmap(data, mapping, options);\n break;\n case 'chart.box':\n result = buildBoxplot(data, mapping, options);\n break;\n case 'chart.funnel':\n result = buildFunnel(data, mapping, options);\n break;\n case 'chart.waterfall':\n result = buildWaterfall(data, mapping, options);\n break;\n case 'chart.treemap':\n result = buildTreemap(data, options);\n break;\n case 'chart.histogram':\n result = buildHistogram(data, mapping, options);\n break;\n default:\n return {};\n }\n\n // Apply chart-level options\n if (options.legend === false && result.legend) {\n result.legend = { ...result.legend as Record<string, unknown>, show: false };\n }\n\n if (options.grid === false) {\n // Hide grid lines on axes (handles both single axis and array)\n const hideGrid = (axis: unknown): unknown => {\n if (!axis || typeof axis !== 'object') return axis;\n if (Array.isArray(axis)) return axis.map(hideGrid);\n return { ...axis as Record<string, unknown>, splitLine: { show: false } };\n };\n if (result.xAxis) result.xAxis = hideGrid(result.xAxis);\n if (result.yAxis) result.yAxis = hideGrid(result.yAxis);\n }\n\n if (options.animate === false) {\n result.animation = false;\n }\n\n if (Array.isArray(options.colors) && options.colors.length > 0) {\n result.color = options.colors;\n }\n\n // Apply axis format options\n const locale = options.locale as string | undefined;\n applyAxisFormat(result, 'xAxis', options.xFormat as AxisFormatOption | undefined, locale);\n applyAxisFormat(result, 'yAxis', options.yFormat as AxisFormatOption | undefined, locale);\n\n // Apply echarts passthrough: deep-merge\n const passthrough = options.echarts as Record<string, unknown> | undefined;\n if (passthrough && typeof passthrough === 'object') {\n result = deepMerge(result, passthrough);\n }\n\n return result;\n}\n\nfunction buildCartesian(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n type: string,\n options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n const xField = mapping?.x ?? guessStringField(data);\n const yFields = mapping?.y ?? [guessNumberField(data)].filter(Boolean) as string[];\n\n if (!xField || yFields.length === 0) return {};\n\n const categories = data.map((row) => String(row[xField] ?? ''));\n const horizontal = !!options.horizontal;\n\n const seriesOverrides = Array.isArray(options.series) ? options.series as Record<string, unknown>[] : [];\n const condStyles = options.conditionalStyles as ConditionalStyleRule[] | undefined;\n\n const seriesItems = yFields.map((field, i) => {\n const s: Record<string, unknown> = {\n name: field,\n type,\n data: data.map((row) => {\n const val = row[field] ?? null;\n if (condStyles?.length) {\n const match = matchConditionalStyle(row, condStyles);\n if (match) {\n const item: Record<string, unknown> = { value: val, itemStyle: { color: match.color } };\n if (match.symbol) item.symbol = match.symbol;\n if (match.symbolSize) item.symbolSize = match.symbolSize;\n return item;\n }\n }\n return val;\n }),\n };\n if (options._area) s.areaStyle = {};\n if (options.smooth) s.smooth = true;\n if (options.step) s.step = options.step === true ? 'end' : options.step;\n\n // Apply per-series overrides from options.series[i]\n const override = seriesOverrides[i];\n if (override) {\n if (override.color) {\n s.itemStyle = { color: override.color };\n s.lineStyle = { ...(s.lineStyle as Record<string, unknown> ?? {}), color: override.color };\n }\n if (override.lineStyle) {\n s.lineStyle = { ...(s.lineStyle as Record<string, unknown> ?? {}), ...(override.lineStyle as Record<string, unknown>) };\n }\n if (override.symbol !== undefined) s.symbol = override.symbol;\n if (override.label) s.name = override.label as string;\n if (override.type) s.type = override.type as string;\n if (override.yAxisIndex !== undefined) s.yAxisIndex = override.yAxisIndex;\n }\n return s;\n });\n\n const catAxis: Record<string, unknown> = { type: 'category', data: categories };\n const valAxis: Record<string, unknown> = { type: 'value' };\n\n // Histogram mode: remove gaps between bars\n if (options.histogram) {\n catAxis.axisTick = { alignWithLabel: true };\n seriesItems.forEach((s) => { s.barCategoryGap = '0%'; });\n }\n\n // Detect if any series requires a secondary Y axis\n const needsDualYAxis = !horizontal && seriesItems.some((s) => (s.yAxisIndex as number) >= 1);\n let yAxisConfig: unknown;\n if (needsDualYAxis) {\n const secondAxis = Array.isArray(options.yAxis) && (options.yAxis as unknown[]).length >= 2\n ? (options.yAxis as Record<string, unknown>[])[1]\n : { type: 'value' };\n yAxisConfig = [valAxis, secondAxis];\n } else {\n yAxisConfig = horizontal ? catAxis : valAxis;\n }\n\n const result: Record<string, unknown> = {\n xAxis: horizontal ? valAxis : catAxis,\n yAxis: yAxisConfig,\n series: seriesItems,\n tooltip: { trigger: 'axis' },\n };\n\n if (yFields.length > 1) {\n const legendNames = seriesItems.map((s) => s.name as string);\n result.legend = { data: legendNames };\n }\n\n if (options.stack) {\n (result.series as Record<string, unknown>[]).forEach((s) => {\n s.stack = 'total';\n });\n }\n\n // Reference lines → ECharts markLine on first series\n const refLines = options.referenceLines as ReferenceLineOption[] | undefined;\n if (Array.isArray(refLines) && refLines.length > 0 && seriesItems.length > 0) {\n seriesItems[0].markLine = {\n silent: true,\n symbol: 'none',\n data: refLines.map((rl) => {\n const item: Record<string, unknown> = {};\n if (rl.axis === 'x') {\n item.xAxis = rl.value;\n } else {\n item.yAxis = rl.value;\n }\n if (rl.label) item.name = rl.label;\n const lineStyle: Record<string, unknown> = {};\n if (rl.color) lineStyle.color = rl.color;\n if (rl.style) lineStyle.type = rl.style;\n if (Object.keys(lineStyle).length > 0) item.lineStyle = lineStyle;\n if (rl.label) item.label = { formatter: rl.label, position: 'end' };\n return item;\n }),\n };\n }\n\n return result;\n}\n\nfunction buildScatter(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n // For scatter, prefer two numeric fields for x/y\n const numFields = getNumberFields(data);\n const xField = mapping?.x ?? numFields[0];\n const yField = (mapping?.y ?? [numFields[1]])[0];\n const colorField = mapping?.color;\n const sizeField = mapping?.size;\n const opacityField = mapping?.opacity;\n\n if (!xField || !yField) return {};\n\n const result: Record<string, unknown> = {\n xAxis: { type: 'value' },\n yAxis: { type: 'value' },\n tooltip: { trigger: 'item' },\n };\n\n // Pre-compute opacity normalization range if needed\n let opacityMin = Infinity;\n let opacityMax = -Infinity;\n if (opacityField) {\n for (const row of data) {\n const v = Number(row[opacityField] ?? 0);\n if (v < opacityMin) opacityMin = v;\n if (v > opacityMax) opacityMax = v;\n }\n }\n const opacityRange = opacityMax - opacityMin || 1;\n\n const condStyles = options.conditionalStyles as ConditionalStyleRule[] | undefined;\n\n // Helper: build a data point — plain array or object with itemStyle for opacity/conditionalStyles\n const toPoint = (row: Record<string, unknown>): unknown => {\n const pt = [Number(row[xField] ?? 0), Number(row[yField] ?? 0)];\n if (sizeField) pt.push(Number(row[sizeField] ?? 0));\n\n if (condStyles?.length) {\n const match = matchConditionalStyle(row, condStyles);\n if (match) {\n const style: Record<string, unknown> = { color: match.color };\n if (opacityField) {\n const raw = Number(row[opacityField] ?? 0);\n style.opacity = Math.round((0.1 + 0.9 * ((raw - opacityMin) / opacityRange)) * 100) / 100;\n }\n const item: Record<string, unknown> = { value: pt, itemStyle: style };\n if (match.symbol) item.symbol = match.symbol;\n if (match.symbolSize) item.symbolSize = match.symbolSize;\n return item;\n }\n }\n\n if (opacityField) {\n const raw = Number(row[opacityField] ?? 0);\n const norm = 0.1 + 0.9 * ((raw - opacityMin) / opacityRange);\n return { value: pt, itemStyle: { opacity: Math.round(norm * 100) / 100 } };\n }\n return pt;\n };\n\n // symbolSize function that maps the third value to pixel radius\n const symbolSizeFn = sizeField\n ? (val: number[] | { value: number[] }) => {\n const arr = Array.isArray(val) ? val : val.value;\n const raw = arr[2] ?? 0;\n // Clamp to [4, 60] range — square root scale for area perception\n return Math.max(4, Math.min(60, Math.sqrt(raw) * 4));\n }\n : undefined;\n\n if (colorField) {\n // Group data by color field → separate series per group\n const groups = new Map<string, unknown[]>();\n for (const row of data) {\n const key = String(row[colorField] ?? 'unknown');\n if (!groups.has(key)) groups.set(key, []);\n groups.get(key)!.push(toPoint(row));\n }\n const seriesItems: Record<string, unknown>[] = [];\n for (const [name, points] of groups) {\n const series: Record<string, unknown> = { name, type: 'scatter', data: points };\n if (symbolSizeFn) series.symbolSize = symbolSizeFn;\n seriesItems.push(series);\n }\n result.series = seriesItems;\n result.legend = { data: Array.from(groups.keys()) };\n } else {\n // Single series — all points same color\n const points = data.map((row) => toPoint(row));\n const series: Record<string, unknown> = { type: 'scatter', data: points };\n if (symbolSizeFn) series.symbolSize = symbolSizeFn;\n result.series = [series];\n }\n\n // Reference lines\n const refLines = options.referenceLines as ReferenceLineOption[] | undefined;\n if (Array.isArray(refLines) && refLines.length > 0) {\n const firstSeries = (result.series as Record<string, unknown>[])[0];\n firstSeries.markLine = {\n silent: true,\n symbol: 'none',\n data: refLines.map((rl) => {\n const item: Record<string, unknown> = {};\n if (rl.axis === 'x') item.xAxis = rl.value;\n else item.yAxis = rl.value;\n if (rl.label) item.name = rl.label;\n const lineStyle: Record<string, unknown> = {};\n if (rl.color) lineStyle.color = rl.color;\n if (rl.style) lineStyle.type = rl.style;\n if (Object.keys(lineStyle).length > 0) item.lineStyle = lineStyle;\n if (rl.label) item.label = { formatter: rl.label, position: 'end' };\n return item;\n }),\n };\n }\n\n return result;\n}\n\nfunction buildPie(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n const labelField = mapping?.label ?? guessStringField(data);\n const valueField = mapping?.value ?? guessNumberField(data);\n\n if (!labelField || !valueField) return {};\n\n const pieData = data.map((row) => ({\n name: String(row[labelField] ?? ''),\n value: Number(row[valueField] ?? 0),\n }));\n\n const radius = options.donut ? ['40%', '70%'] : '50%';\n const seriesItem: Record<string, unknown> = {\n type: 'pie',\n radius,\n data: pieData,\n label: { overflow: 'truncate', width: 80 },\n };\n\n if (options.showLabel === false) {\n seriesItem.label = { show: false };\n }\n\n const result: Record<string, unknown> = {\n tooltip: { trigger: 'item' },\n legend: { orient: 'vertical', left: 'left' },\n series: [seriesItem],\n };\n\n // Donut center label\n const center = options.center as { label?: string; value?: string } | undefined;\n if (options.donut && center && (center.label || center.value)) {\n const children: Record<string, unknown>[] = [];\n if (center.label) {\n children.push({\n type: 'text',\n top: center.value ? -16 : 0,\n style: { text: center.label, fontSize: 13, fill: '#999', textAlign: 'center' },\n });\n }\n if (center.value) {\n children.push({\n type: 'text',\n top: center.label ? 8 : 0,\n style: { text: center.value, fontSize: 20, fontWeight: 'bold', fill: '#333', textAlign: 'center' },\n });\n }\n result.graphic = [{ type: 'group', left: 'center', top: 'middle', children }];\n }\n\n return result;\n}\n\nfunction buildRadar(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n _options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n const axisField = mapping?.axis ?? guessStringField(data);\n const yFields = mapping?.y ?? getNumberFields(data);\n\n if (!axisField || yFields.length === 0) return {};\n\n const indicator = data.map((row) => ({\n name: String(row[axisField] ?? ''),\n }));\n\n const series = yFields.map((field) => ({\n name: field,\n value: data.map((row) => Number(row[field] ?? 0)),\n }));\n\n return {\n tooltip: {},\n legend: { data: yFields },\n radar: { indicator },\n series: [\n {\n type: 'radar',\n data: series,\n },\n ],\n };\n}\n\nfunction buildHeatmap(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n // Determine x, y (category), value (number) fields\n const first = data[0] ?? {};\n const keys = Object.keys(first);\n const stringFields = keys.filter((k) => typeof first[k] === 'string');\n const numberFields = keys.filter((k) => typeof first[k] === 'number');\n\n const xField = mapping?.x ?? stringFields[0];\n // For heatmap, y is a category field (string), not a numeric series\n const yField = mapping?.y?.[0] ?? stringFields.find((k) => k !== xField);\n const valueField = mapping?.value ?? numberFields[0];\n\n if (!xField || !yField || !valueField) return {};\n\n // Extract unique categories preserving order of appearance\n const xCats: string[] = [];\n const yCats: string[] = [];\n const xSet = new Set<string>();\n const ySet = new Set<string>();\n\n for (const row of data) {\n const x = String(row[xField] ?? '');\n const y = String(row[yField] ?? '');\n if (!xSet.has(x)) { xSet.add(x); xCats.push(x); }\n if (!ySet.has(y)) { ySet.add(y); yCats.push(y); }\n }\n\n // Build index maps for O(1) lookup\n const xIndex = new Map<string, number>();\n xCats.forEach((v, i) => xIndex.set(v, i));\n const yIndex = new Map<string, number>();\n yCats.forEach((v, i) => yIndex.set(v, i));\n\n // Build [xIndex, yIndex, value] data\n const heatData: (number | null)[][] = [];\n let minVal = Infinity;\n let maxVal = -Infinity;\n\n for (const row of data) {\n const xi = xIndex.get(String(row[xField] ?? '')) ?? 0;\n const yi = yIndex.get(String(row[yField] ?? '')) ?? 0;\n const v = row[valueField] != null ? Number(row[valueField]) : null;\n heatData.push([xi, yi, v]);\n if (v != null) {\n if (v < minVal) minVal = v;\n if (v > maxVal) maxVal = v;\n }\n }\n\n // Handle edge case of empty/no-value data\n if (!isFinite(minVal)) { minVal = 0; maxVal = 1; }\n\n // Determine color range from options or use defaults\n const colorRange = (options.colorRange as string[]) ?? ['#313695', '#4575b4', '#74add1', '#abd9e9', '#fee090', '#fdae61', '#f46d43', '#d73027'];\n\n return {\n xAxis: { type: 'category', data: xCats, splitArea: { show: true } },\n yAxis: { type: 'category', data: yCats, splitArea: { show: true } },\n visualMap: {\n min: options.min != null ? Number(options.min) : minVal,\n max: options.max != null ? Number(options.max) : maxVal,\n calculable: true,\n orient: 'horizontal',\n left: 'center',\n bottom: 0,\n inRange: { color: colorRange },\n },\n tooltip: {\n trigger: 'item',\n formatter: (params: Record<string, unknown>) => {\n const d = params.data as number[];\n if (!d) return '';\n return `${xCats[d[0]]} × ${yCats[d[1]]}: ${d[2] != null ? d[2] : '-'}`;\n },\n },\n grid: { bottom: 60 },\n series: [{\n type: 'heatmap',\n data: heatData,\n label: { show: options.showLabel !== false },\n }],\n };\n}\n\nfunction buildBoxplot(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n _options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data) || data.length === 0) return {};\n\n const first = data[0] ?? {};\n const keys = Object.keys(first);\n const stringFields = keys.filter((k) => typeof first[k] === 'string');\n const numberFields = keys.filter((k) => typeof first[k] === 'number');\n\n // Category field (x)\n const xField = mapping?.x ?? stringFields[0];\n\n // Stat fields: use mapping.y if provided (5 fields: min, q1, median, q3, max)\n // Otherwise, try well-known names, then fall back to first 5 number fields\n let statFields: string[];\n if (mapping?.y && mapping.y.length >= 5) {\n statFields = mapping.y.slice(0, 5);\n } else {\n const wellKnown = ['min', 'q1', 'median', 'q3', 'max'];\n const matched = wellKnown.filter((name) => numberFields.includes(name));\n statFields = matched.length === 5 ? matched : numberFields.slice(0, 5);\n }\n\n if (statFields.length < 5) return {};\n\n const categories = xField ? data.map((row) => String(row[xField] ?? '')) : undefined;\n\n const boxData = data.map((row) =>\n statFields.map((f) => Number(row[f] ?? 0)),\n );\n\n const result: Record<string, unknown> = {\n tooltip: { trigger: 'item' },\n series: [{\n type: 'boxplot',\n data: boxData,\n }],\n };\n\n if (categories) {\n result.xAxis = { type: 'category', data: categories };\n result.yAxis = { type: 'value' };\n } else {\n result.xAxis = { type: 'category' };\n result.yAxis = { type: 'value' };\n }\n\n return result;\n}\n\n// ── Helpers ──\n\nfunction guessStringField(data: Record<string, unknown>[]): string | undefined {\n if (data.length === 0) return undefined;\n const first = data[0];\n return Object.keys(first).find((k) => typeof first[k] === 'string');\n}\n\nfunction guessNumberField(data: Record<string, unknown>[]): string | undefined {\n if (data.length === 0) return undefined;\n const first = data[0];\n return Object.keys(first).find((k) => typeof first[k] === 'number');\n}\n\nfunction buildFunnel(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n _options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n const labelField = mapping?.label ?? guessStringField(data as Record<string, unknown>[]);\n const valueField = (mapping?.value ?? guessNumberField(data as Record<string, unknown>[]));\n\n if (!labelField || !valueField) return {};\n\n const seriesData = (data as Record<string, unknown>[]).map((row) => ({\n name: String(row[labelField] ?? ''),\n value: Number(row[valueField] ?? 0),\n }));\n\n return {\n tooltip: { trigger: 'item', formatter: '{b}: {c} ({d}%)' },\n legend: { orient: 'vertical', left: 'left' },\n series: [{\n type: 'funnel',\n data: seriesData,\n sort: 'descending',\n gap: 2,\n label: { show: true, position: 'inside' },\n }],\n };\n}\n\nfunction buildWaterfall(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n _options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n const records = data as Record<string, unknown>[];\n const xField = mapping?.x ?? guessStringField(records);\n const yField = (mapping?.y ?? [guessNumberField(records)])[0];\n\n if (!xField || !yField) return {};\n\n const categories: string[] = [];\n const baseValues: number[] = [];\n const positiveValues: (number | null)[] = [];\n const negativeValues: (number | null)[] = [];\n\n let running = 0;\n for (const row of records) {\n const label = String(row[xField] ?? '');\n const value = Number(row[yField] ?? 0);\n categories.push(label);\n\n if (value >= 0) {\n baseValues.push(running);\n positiveValues.push(value);\n negativeValues.push(null);\n } else {\n baseValues.push(running + value);\n positiveValues.push(null);\n negativeValues.push(Math.abs(value));\n }\n running += value;\n }\n\n return {\n tooltip: { trigger: 'axis', axisPointer: { type: 'shadow' } },\n xAxis: { type: 'category', data: categories },\n yAxis: { type: 'value' },\n series: [\n {\n name: 'Base',\n type: 'bar',\n stack: 'waterfall',\n itemStyle: { borderColor: 'transparent', color: 'transparent' },\n emphasis: { itemStyle: { borderColor: 'transparent', color: 'transparent' } },\n data: baseValues,\n },\n {\n name: 'Positive',\n type: 'bar',\n stack: 'waterfall',\n data: positiveValues,\n },\n {\n name: 'Negative',\n type: 'bar',\n stack: 'waterfall',\n data: negativeValues,\n },\n ],\n };\n}\n\nfunction buildTreemap(\n data: unknown,\n _options: Record<string, unknown>,\n): Record<string, unknown> {\n if (!Array.isArray(data)) return {};\n\n // Treemap data uses name/value/children directly — pass through to ECharts\n const seriesData = (data as Record<string, unknown>[]).map((item) => toTreeNode(item));\n\n return {\n tooltip: { trigger: 'item' },\n series: [{\n type: 'treemap',\n data: seriesData,\n leafDepth: 1,\n roam: false,\n label: { show: true, formatter: '{b}' },\n }],\n };\n}\n\nfunction toTreeNode(item: Record<string, unknown>): Record<string, unknown> {\n const node: Record<string, unknown> = {\n name: String(item.name ?? ''),\n value: Number(item.value ?? 0),\n };\n if (Array.isArray(item.children)) {\n node.children = (item.children as Record<string, unknown>[]).map((child) => toTreeNode(child));\n }\n return node;\n}\n\nfunction buildHistogram(\n data: unknown,\n mapping: NormalizedMapping | undefined,\n options: Record<string, unknown>,\n): Record<string, unknown> {\n // Extract numeric values from flat array or object array\n let values: number[];\n if (!Array.isArray(data) || data.length === 0) return {};\n\n if (typeof data[0] === 'number') {\n values = data as number[];\n } else {\n const field = mapping?.value ?? guessNumberField(data as Record<string, unknown>[]);\n if (!field) return {};\n values = (data as Record<string, unknown>[]).map((row) => Number(row[field] ?? 0));\n }\n\n if (values.length === 0) return {};\n\n // Determine bin count: explicit or Sturges' rule\n const binCount = typeof options.bins === 'number'\n ? options.bins\n : Math.ceil(Math.log2(values.length) + 1);\n\n const min = Math.min(...values);\n const max = Math.max(...values);\n const range = max - min;\n const binWidth = range / binCount || 1;\n\n // Build bins\n const bins: number[] = new Array(binCount).fill(0);\n const labels: string[] = [];\n\n for (let i = 0; i < binCount; i++) {\n const lo = min + i * binWidth;\n const hi = min + (i + 1) * binWidth;\n const fmt = (n: number) => Number.isInteger(n) ? String(n) : n.toFixed(1);\n labels.push(`${fmt(lo)}\\u2013${fmt(hi)}`);\n }\n\n for (const v of values) {\n let idx = Math.floor((v - min) / binWidth);\n if (idx >= binCount) idx = binCount - 1; // clamp max to last bin\n bins[idx]++;\n }\n\n const series: Record<string, unknown> = {\n type: 'bar',\n data: bins,\n barCategoryGap: '0%',\n };\n\n const result: Record<string, unknown> = {\n xAxis: { type: 'category', data: labels, axisTick: { alignWithLabel: true } },\n yAxis: { type: 'value' },\n series: [series],\n tooltip: { trigger: 'axis' },\n };\n\n // Reference lines\n const refLines = options.referenceLines as ReferenceLineOption[] | undefined;\n if (Array.isArray(refLines) && refLines.length > 0) {\n series.markLine = {\n silent: true,\n symbol: 'none',\n data: refLines.map((rl) => {\n const item: Record<string, unknown> = {};\n if (rl.axis === 'x') item.xAxis = rl.value;\n else item.yAxis = rl.value;\n if (rl.label) item.name = rl.label;\n const lineStyle: Record<string, unknown> = {};\n if (rl.color) lineStyle.color = rl.color;\n if (rl.style) lineStyle.type = rl.style;\n if (Object.keys(lineStyle).length > 0) item.lineStyle = lineStyle;\n if (rl.label) item.label = { formatter: rl.label, position: 'end' };\n return item;\n }),\n };\n }\n\n return result;\n}\n\nfunction getNumberFields(data: Record<string, unknown>[]): string[] {\n if (data.length === 0) return [];\n const first = data[0];\n return Object.keys(first).filter((k) => typeof first[k] === 'number');\n}\n\n/**\n * Deep-merge `overrides` into `base` recursively.\n * If both base[key] and overrides[key] are plain objects, merge recursively.\n * Arrays and other values: overrides[key] wins.\n */\nfunction deepMerge(\n base: Record<string, unknown>,\n overrides: Record<string, unknown>,\n): Record<string, unknown> {\n const result = { ...base };\n for (const key of Object.keys(overrides)) {\n const bv = base[key];\n const ov = overrides[key];\n if (isPlainObject(bv) && isPlainObject(ov)) {\n result[key] = deepMerge(bv as Record<string, unknown>, ov as Record<string, unknown>);\n } else {\n result[key] = ov;\n }\n }\n return result;\n}\n\nfunction isPlainObject(v: unknown): v is Record<string, unknown> {\n return v != null && typeof v === 'object' && !Array.isArray(v);\n}\n\n/**\n * Build a formatter string or function for ECharts axis labels\n * based on an AxisFormatOption.\n */\nfunction buildAxisFormatter(fmt: AxisFormatOption, locale?: string): (value: number | string) => string {\n return (value: number | string) => {\n let result: string;\n if (fmt.type) {\n const formatStr = fmt.type === 'currency' && fmt.currency\n ? `currency:${fmt.currency}`\n : fmt.type;\n result = formatValue(value, formatStr, locale);\n // For percent type, formatValue divides by 100 — but axis values are already in\n // display units (e.g. 73 means 73%), so use raw suffix instead\n if (fmt.type === 'percent') {\n result = typeof value === 'number'\n ? new Intl.NumberFormat(locale, { maximumFractionDigits: fmt.decimals ?? 2 }).format(value) + '%'\n : String(value) + '%';\n }\n } else {\n result = String(value);\n }\n if (fmt.decimals !== undefined && fmt.type === 'number') {\n const num = Number(value);\n if (!isNaN(num)) {\n result = new Intl.NumberFormat(locale, {\n minimumFractionDigits: fmt.decimals,\n maximumFractionDigits: fmt.decimals,\n }).format(num);\n }\n }\n if (fmt.prefix) result = fmt.prefix + result;\n if (fmt.suffix) result = result + fmt.suffix;\n return result;\n };\n}\n\n/**\n * Apply xFormat/yFormat to the corresponding axis in the ECharts option.\n * Handles both single axis and axis arrays (dual Y axis).\n */\nfunction applyAxisFormat(\n result: Record<string, unknown>,\n axisKey: 'xAxis' | 'yAxis',\n fmt: AxisFormatOption | undefined,\n locale?: string,\n): void {\n if (!fmt || !result[axisKey]) return;\n\n const formatter = buildAxisFormatter(fmt, locale);\n const axis = result[axisKey];\n\n if (Array.isArray(axis)) {\n // Dual axis — apply to all value-type axes\n result[axisKey] = (axis as Record<string, unknown>[]).map((a) => {\n if (a.type === 'value') {\n return { ...a, axisLabel: { ...(a.axisLabel as Record<string, unknown> ?? {}), formatter } };\n }\n return a;\n });\n } else if (isPlainObject(axis)) {\n const a = axis as Record<string, unknown>;\n result[axisKey] = { ...a, axisLabel: { ...(a.axisLabel as Record<string, unknown> ?? {}), formatter } };\n }\n}\n","import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport type { UWidgetSpec, UWidgetEvent } from '../core/types.js';\nimport { toEChartsOption } from '../renderers/echarts-adapter.js';\nimport { themeStyles } from '../styles/tokens.js';\n\n// Tree-shakeable ECharts imports\nimport * as echarts from 'echarts/core';\nimport { BarChart, LineChart, PieChart, ScatterChart, RadarChart, HeatmapChart, BoxplotChart, FunnelChart, TreemapChart } from 'echarts/charts';\nimport {\n GridComponent,\n TooltipComponent,\n LegendComponent,\n RadarComponent,\n MarkLineComponent,\n VisualMapComponent,\n} from 'echarts/components';\nimport { CanvasRenderer } from 'echarts/renderers';\n\necharts.use([\n BarChart,\n LineChart,\n PieChart,\n ScatterChart,\n RadarChart,\n HeatmapChart,\n BoxplotChart,\n FunnelChart,\n TreemapChart,\n GridComponent,\n TooltipComponent,\n LegendComponent,\n RadarComponent,\n MarkLineComponent,\n VisualMapComponent,\n CanvasRenderer,\n]);\n\n@customElement('uw-chart')\nexport class UwChart extends LitElement {\n static styles = [\n themeStyles,\n css`\n :host {\n display: block;\n container: uw-chart / inline-size;\n }\n\n .chart-container {\n width: 100%;\n height: var(--u-widget-chart-height, 300px);\n }\n\n @container uw-chart (max-width: 20rem) {\n .chart-container {\n height: var(--u-widget-chart-height-narrow, 200px);\n }\n }\n `,\n ];\n\n @property({ type: Object })\n spec: UWidgetSpec | null = null;\n\n private _chart: echarts.ECharts | null = null;\n private _container: HTMLDivElement | null = null;\n private _resizeObserver: ResizeObserver | null = null;\n\n render() {\n if (!this.spec) return nothing;\n const label = this.spec.title ?? `${this.spec.widget} chart`;\n return html`<div class=\"chart-container\" part=\"chart\" role=\"img\" aria-label=${label}></div>`;\n }\n\n protected firstUpdated() {\n this._container = this.shadowRoot?.querySelector('.chart-container') as HTMLDivElement | null;\n this._initChart();\n if (this._container) {\n this._resizeObserver = new ResizeObserver(() => this._chart?.resize());\n this._resizeObserver.observe(this._container);\n }\n }\n\n protected updated(changed: Map<string, unknown>) {\n if (changed.has('spec') && this._container) {\n this._updateChart();\n }\n }\n\n private _initChart() {\n if (!this._container || !this.spec) return;\n\n try {\n this._chart = echarts.init(this._container);\n this._chart.on('click', (params: Record<string, unknown>) => {\n this._onChartClick(params);\n });\n this._updateChart();\n } catch (e) {\n console.warn('[uw-chart] Failed to initialize ECharts:', (e as Error).message);\n }\n }\n\n private _onChartClick(params: Record<string, unknown>) {\n if (!this.spec) return;\n const detail: UWidgetEvent = {\n type: 'select',\n widget: this.spec.widget,\n id: this.spec.id,\n data: {\n name: params.name as string,\n seriesName: params.seriesName as string,\n value: params.value,\n dataIndex: params.dataIndex as number,\n },\n };\n this.dispatchEvent(\n new CustomEvent('u-widget-internal', {\n detail,\n bubbles: true,\n composed: true,\n }),\n );\n }\n\n private _updateChart() {\n if (!this._chart || !this.spec) return;\n\n const option = toEChartsOption(this.spec);\n\n // Inject theme colors from CSS custom properties,\n // but only if the spec didn't provide explicit colors\n const hasSpecColors = Array.isArray(\n (this.spec.options as Record<string, unknown> | undefined)?.colors,\n ) && ((this.spec.options as Record<string, unknown>).colors as unknown[]).length > 0;\n if (!hasSpecColors) {\n const themeColors = this._readThemeColors();\n if (themeColors.length > 0) {\n option.color = themeColors;\n }\n }\n const hasExplicitBg = !!(\n (this.spec.options as Record<string, unknown> | undefined)?.echarts as Record<string, unknown> | undefined\n )?.backgroundColor;\n if (!hasExplicitBg && this._readCSSVar('--u-widget-bg')) {\n option.backgroundColor = 'transparent';\n }\n\n // Inject text/axis/grid theme from CSS variables\n this._applyThemeStyle(option);\n\n this._chart.setOption(option, true);\n }\n\n private _applyThemeStyle(option: Record<string, unknown>) {\n const textColor = this._readCSSVar('--u-widget-text');\n const secondaryColor = this._readCSSVar('--u-widget-text-secondary');\n const borderColor = this._readCSSVar('--u-widget-border');\n\n if (!textColor) return; // no theme vars available\n\n // Global text style\n option.textStyle = { ...(option.textStyle as Record<string, unknown>), color: textColor };\n\n // Axis styling — deep-merge into existing axis config preserving all existing properties\n const mergeAxisTheme = (axis: unknown): unknown => {\n if (!axis || typeof axis !== 'object') return axis;\n if (Array.isArray(axis)) return axis.map(mergeAxisTheme);\n const a = axis as Record<string, unknown>;\n const existingLine = a.axisLine as Record<string, unknown> ?? {};\n const existingLineStyle = existingLine.lineStyle as Record<string, unknown> ?? {};\n const existingSplit = a.splitLine as Record<string, unknown> ?? {};\n const existingSplitStyle = existingSplit.lineStyle as Record<string, unknown> ?? {};\n return {\n ...a,\n axisLabel: { ...(a.axisLabel as Record<string, unknown> ?? {}), color: secondaryColor || textColor },\n axisLine: { ...existingLine, lineStyle: { ...existingLineStyle, color: borderColor || secondaryColor } },\n splitLine: { ...existingSplit, lineStyle: { ...existingSplitStyle, color: borderColor } },\n };\n };\n if (option.xAxis) option.xAxis = mergeAxisTheme(option.xAxis);\n if (option.yAxis) option.yAxis = mergeAxisTheme(option.yAxis);\n\n // Legend — merge textStyle preserving existing properties\n if (option.legend && typeof option.legend === 'object') {\n const leg = option.legend as Record<string, unknown>;\n option.legend = { ...leg, textStyle: { ...(leg.textStyle as Record<string, unknown> ?? {}), color: textColor } };\n }\n }\n\n private _readThemeColors(): string[] {\n const colors: string[] = [];\n // Read --u-widget-chart-color-N (1-based) custom properties\n for (let i = 1; i <= 10; i++) {\n const c = this._readCSSVar(`--u-widget-chart-color-${i}`);\n if (c) colors.push(c);\n else break;\n }\n // Fallback: use --u-widget-primary as first color if no palette defined\n if (colors.length === 0) {\n const primary = this._readCSSVar('--u-widget-primary');\n if (primary) colors.push(primary);\n }\n return colors;\n }\n\n private _readCSSVar(name: string): string {\n return getComputedStyle(this).getPropertyValue(name).trim();\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n this._resizeObserver?.disconnect();\n this._resizeObserver = null;\n this._chart?.dispose();\n this._chart = null;\n }\n\n /** Resize the chart (call when container size changes). */\n resize() {\n this._chart?.resize();\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'uw-chart': UwChart;\n }\n}\n"],"names":["matchConditionalStyle","row","rules","rule","raw","val","aboveOk","belowOk","toEChartsOption","spec","widget","data","mapping","normalizeMapping","options","result","buildCartesian","buildPie","buildScatter","buildRadar","buildHeatmap","buildBoxplot","buildFunnel","buildWaterfall","buildTreemap","buildHistogram","hideGrid","axis","locale","applyAxisFormat","passthrough","deepMerge","type","xField","guessStringField","yFields","guessNumberField","categories","horizontal","seriesOverrides","condStyles","seriesItems","field","i","s","match","item","override","catAxis","valAxis","needsDualYAxis","yAxisConfig","secondAxis","legendNames","refLines","rl","lineStyle","numFields","getNumberFields","yField","colorField","sizeField","opacityField","opacityMin","opacityMax","v","opacityRange","toPoint","pt","style","norm","symbolSizeFn","groups","key","name","points","series","firstSeries","labelField","valueField","pieData","seriesItem","center","children","_options","axisField","indicator","first","keys","stringFields","k","numberFields","xCats","yCats","xSet","ySet","x","y","xIndex","yIndex","heatData","minVal","maxVal","xi","yi","colorRange","params","d","statFields","matched","boxData","f","seriesData","records","baseValues","positiveValues","negativeValues","running","label","value","toTreeNode","node","child","values","binCount","min","binWidth","bins","labels","lo","hi","fmt","n","idx","base","overrides","bv","ov","isPlainObject","buildAxisFormatter","formatStr","formatValue","num","axisKey","formatter","a","echarts","BarChart","LineChart","PieChart","ScatterChart","RadarChart","HeatmapChart","BoxplotChart","FunnelChart","TreemapChart","GridComponent","TooltipComponent","LegendComponent","RadarComponent","MarkLineComponent","VisualMapComponent","CanvasRenderer","UwChart","LitElement","nothing","html","changed","detail","option","themeColors","textColor","secondaryColor","borderColor","mergeAxisTheme","existingLine","existingLineStyle","existingSplit","existingSplitStyle","leg","colors","c","primary","themeStyles","css","__decorateClass","property","customElement"],"mappings":"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"}
|