drizzle-cube 0.2.13 → 0.2.15
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/adapters/compiler-A-Mz5Rzh.cjs +22 -0
- package/dist/adapters/{compiler-DrkCCzf0.js → compiler-CQq2_dSQ.js} +1677 -1540
- package/dist/adapters/express/index.cjs +1 -1
- package/dist/adapters/express/index.js +1 -1
- package/dist/adapters/fastify/index.cjs +1 -1
- package/dist/adapters/fastify/index.js +1 -1
- package/dist/adapters/hono/index.cjs +1 -1
- package/dist/adapters/hono/index.js +1 -1
- package/dist/adapters/nextjs/index.cjs +1 -1
- package/dist/adapters/nextjs/index.js +1 -1
- package/dist/client/charts.js +27 -36
- package/dist/client/charts.js.map +1 -1
- package/dist/client/chunks/charts-B8YMw1mi.js +7227 -0
- package/dist/client/chunks/charts-B8YMw1mi.js.map +1 -0
- package/dist/client/chunks/charts-amt7VOyw.js +277 -0
- package/dist/client/chunks/{charts-CHzWeaY1.js.map → charts-amt7VOyw.js.map} +1 -1
- package/dist/client/chunks/components-K3xrnHN-.js +13698 -0
- package/dist/client/chunks/components-K3xrnHN-.js.map +1 -0
- package/dist/client/chunks/core-Dkym7d1O.js +6 -0
- package/dist/client/chunks/core-Dkym7d1O.js.map +1 -0
- package/dist/client/chunks/{index-DlsvcKXf.js → index-B7NSVb33.js} +2 -2
- package/dist/client/chunks/{index-DlsvcKXf.js.map → index-B7NSVb33.js.map} +1 -1
- package/dist/client/chunks/javascript-DII1YQGr.js +659 -0
- package/dist/client/chunks/javascript-DII1YQGr.js.map +1 -0
- package/dist/client/components/AnalysisBuilder/AnalysisFilterItem.d.ts +1 -3
- package/dist/client/components/AnalysisBuilder/FilterConfigModal.d.ts +16 -0
- package/dist/client/components/AnalyticsPortlet.d.ts +2 -1
- package/dist/client/components/DashboardFilters/FilterEditModal.d.ts +1 -1
- package/dist/client/components/DashboardFilters/ReadOnlyFilterList.d.ts +1 -1
- package/dist/client/components/DashboardPortletCard.d.ts +3 -3
- package/dist/client/components/QueryBuilderShim.d.ts +3 -0
- package/dist/client/components/charts/ActivityGridChart.d.ts +3 -1
- package/dist/client/components/charts/AreaChart.d.ts +3 -1
- package/dist/client/components/charts/BarChart.d.ts +3 -1
- package/dist/client/components/charts/BubbleChart.d.ts +3 -1
- package/dist/client/components/charts/DataTable.d.ts +3 -1
- package/dist/client/components/charts/KpiDelta.d.ts +3 -1
- package/dist/client/components/charts/KpiNumber.d.ts +3 -1
- package/dist/client/components/charts/KpiText.d.ts +3 -1
- package/dist/client/components/charts/LineChart.d.ts +3 -1
- package/dist/client/components/charts/MarkdownChart.d.ts +3 -1
- package/dist/client/components/charts/PieChart.d.ts +3 -1
- package/dist/client/components/charts/RadarChart.d.ts +3 -1
- package/dist/client/components/charts/RadialBarChart.d.ts +3 -1
- package/dist/client/components/charts/ScatterChart.d.ts +3 -1
- package/dist/client/components/charts/TreeMapChart.d.ts +3 -1
- package/dist/client/components/{QueryBuilder → shared}/CubeMetaExplorer.d.ts +1 -1
- package/dist/client/components/{QueryBuilder → shared}/DateRangeFilter.d.ts +1 -1
- package/dist/client/components/{QueryBuilder → shared}/FilterBuilder.d.ts +1 -1
- package/dist/client/components/{QueryBuilder → shared}/FilterGroup.d.ts +1 -1
- package/dist/client/components/{QueryBuilder → shared}/FilterItem.d.ts +1 -1
- package/dist/client/components/{QueryBuilder → shared}/FilterValueSelector.d.ts +1 -1
- package/dist/client/components/{QueryBuilder → shared}/utils.d.ts +1 -1
- package/dist/client/components.d.ts +1 -1
- package/dist/client/components.js +2 -2
- package/dist/client/hooks/useCubeFieldLabel.d.ts +16 -0
- package/dist/client/hooks/useScrollDetection.d.ts +27 -0
- package/dist/client/hooks/useTheme.d.ts +11 -0
- package/dist/client/hooks.js +8 -8
- package/dist/client/icons.js +5 -5
- package/dist/client/index.d.ts +8 -3
- package/dist/client/index.js +50 -45
- package/dist/client/index.js.map +1 -1
- package/dist/client/providers/CubeApiProvider.d.ts +22 -0
- package/dist/client/providers/CubeFeaturesProvider.d.ts +15 -0
- package/dist/client/providers/CubeMetaProvider.d.ts +17 -0
- package/dist/client/providers/CubeProvider.d.ts +28 -8
- package/dist/client/providers.js +3 -3
- package/dist/client/shared/components/CodeBlock.d.ts +10 -0
- package/dist/client/shared/index.d.ts +1 -0
- package/dist/client/styles.css +1 -1
- package/dist/client/utils/chartUtils.d.ts +2 -2
- package/dist/client/utils/filterUtils.d.ts +15 -0
- package/dist/client/utils/index.d.ts +1 -0
- package/dist/client/{components/QueryBuilder → utils}/shareUtils.d.ts +1 -1
- package/dist/client/utils/syntaxHighlighting.d.ts +31 -0
- package/dist/client-bundle-stats.html +1 -1
- package/dist/server/index.cjs +16 -16
- package/dist/server/index.d.ts +50 -0
- package/dist/server/index.js +857 -729
- package/package.json +5 -1
- package/dist/adapters/compiler-CMwSRhTS.cjs +0 -22
- package/dist/client/chunks/chart-activitygridchart-CUGN9Xq9.js +0 -2622
- package/dist/client/chunks/chart-activitygridchart-CUGN9Xq9.js.map +0 -1
- package/dist/client/chunks/chart-activitygridchart-config-AVBoHdRn.js +0 -244
- package/dist/client/chunks/chart-activitygridchart-config-AVBoHdRn.js.map +0 -1
- package/dist/client/chunks/chart-areachart-B4tknnsY.js +0 -239
- package/dist/client/chunks/chart-areachart-B4tknnsY.js.map +0 -1
- package/dist/client/chunks/chart-areachart-config-D9pPUKHZ.js +0 -78
- package/dist/client/chunks/chart-areachart-config-D9pPUKHZ.js.map +0 -1
- package/dist/client/chunks/chart-axisformatcontrols-Ch_IYF94.js +0 -196
- package/dist/client/chunks/chart-axisformatcontrols-Ch_IYF94.js.map +0 -1
- package/dist/client/chunks/chart-barchart-D_op06r-.js +0 -216
- package/dist/client/chunks/chart-barchart-D_op06r-.js.map +0 -1
- package/dist/client/chunks/chart-barchart-config-iniz62ni.js +0 -71
- package/dist/client/chunks/chart-barchart-config-iniz62ni.js.map +0 -1
- package/dist/client/chunks/chart-bubblechart-BsaIXUbS.js +0 -214
- package/dist/client/chunks/chart-bubblechart-BsaIXUbS.js.map +0 -1
- package/dist/client/chunks/chart-bubblechart-config-yLq2oyR3.js +0 -72
- package/dist/client/chunks/chart-bubblechart-config-yLq2oyR3.js.map +0 -1
- package/dist/client/chunks/chart-chartcontainer-CdwzIKP1.js +0 -103
- package/dist/client/chunks/chart-chartcontainer-CdwzIKP1.js.map +0 -1
- package/dist/client/chunks/chart-charttooltip-Bx3I8jQv.js +0 -26
- package/dist/client/chunks/chart-charttooltip-Bx3I8jQv.js.map +0 -1
- package/dist/client/chunks/chart-datatable-C7MS9q4Y.js +0 -283
- package/dist/client/chunks/chart-datatable-C7MS9q4Y.js.map +0 -1
- package/dist/client/chunks/chart-datatable-config-DmEA3A-7.js +0 -29
- package/dist/client/chunks/chart-datatable-config-DmEA3A-7.js.map +0 -1
- package/dist/client/chunks/chart-kpidelta-7-KOmb3w.js +0 -436
- package/dist/client/chunks/chart-kpidelta-7-KOmb3w.js.map +0 -1
- package/dist/client/chunks/chart-kpidelta-config-DtSDG4Kl.js +0 -98
- package/dist/client/chunks/chart-kpidelta-config-DtSDG4Kl.js.map +0 -1
- package/dist/client/chunks/chart-kpinumber-HOPfcK2N.js +0 -398
- package/dist/client/chunks/chart-kpinumber-HOPfcK2N.js.map +0 -1
- package/dist/client/chunks/chart-kpinumber-config-Da2LFeKM.js +0 -76
- package/dist/client/chunks/chart-kpinumber-config-Da2LFeKM.js.map +0 -1
- package/dist/client/chunks/chart-kpitext-BZkC9u3A.js +0 -165
- package/dist/client/chunks/chart-kpitext-BZkC9u3A.js.map +0 -1
- package/dist/client/chunks/chart-kpitext-config-DjvigyfE.js +0 -48
- package/dist/client/chunks/chart-kpitext-config-DjvigyfE.js.map +0 -1
- package/dist/client/chunks/chart-linechart-DqFmLbRe.js +0 -198
- package/dist/client/chunks/chart-linechart-DqFmLbRe.js.map +0 -1
- package/dist/client/chunks/chart-linechart-config-DLVS2Zxc.js +0 -66
- package/dist/client/chunks/chart-linechart-config-DLVS2Zxc.js.map +0 -1
- package/dist/client/chunks/chart-markdownchart-9n_TemoB.js +0 -256
- package/dist/client/chunks/chart-markdownchart-9n_TemoB.js.map +0 -1
- package/dist/client/chunks/chart-markdownchart-config-CgOA3YSw.js +0 -61
- package/dist/client/chunks/chart-markdownchart-config-CgOA3YSw.js.map +0 -1
- package/dist/client/chunks/chart-piechart-CrXFd9pE.js +0 -127
- package/dist/client/chunks/chart-piechart-CrXFd9pE.js.map +0 -1
- package/dist/client/chunks/chart-piechart-config-DgwOeKHr.js +0 -39
- package/dist/client/chunks/chart-piechart-config-DgwOeKHr.js.map +0 -1
- package/dist/client/chunks/chart-radarchart-config-BAV8D5PR.js +0 -45
- package/dist/client/chunks/chart-radarchart-config-BAV8D5PR.js.map +0 -1
- package/dist/client/chunks/chart-radarchart-tar2GBkO.js +0 -131
- package/dist/client/chunks/chart-radarchart-tar2GBkO.js.map +0 -1
- package/dist/client/chunks/chart-radialbarchart-ab8Swtal.js +0 -120
- package/dist/client/chunks/chart-radialbarchart-ab8Swtal.js.map +0 -1
- package/dist/client/chunks/chart-radialbarchart-config-CKozBBEC.js +0 -38
- package/dist/client/chunks/chart-radialbarchart-config-CKozBBEC.js.map +0 -1
- package/dist/client/chunks/chart-scatterchart-BP06BeU5.js +0 -203
- package/dist/client/chunks/chart-scatterchart-BP06BeU5.js.map +0 -1
- package/dist/client/chunks/chart-scatterchart-config-UdHmbZ3s.js +0 -54
- package/dist/client/chunks/chart-scatterchart-config-UdHmbZ3s.js.map +0 -1
- package/dist/client/chunks/chart-treemapchart-DAiixITm.js +0 -265
- package/dist/client/chunks/chart-treemapchart-DAiixITm.js.map +0 -1
- package/dist/client/chunks/chart-treemapchart-config-D17VOwTM.js +0 -47
- package/dist/client/chunks/chart-treemapchart-config-D17VOwTM.js.map +0 -1
- package/dist/client/chunks/charts-CHzWeaY1.js +0 -286
- package/dist/client/chunks/components-DnM9CCUS.js +0 -13931
- package/dist/client/chunks/components-DnM9CCUS.js.map +0 -1
- package/dist/client/components/QueryBuilder/QueryAnalysisPanel.d.ts +0 -7
- package/dist/client/components/QueryBuilder/QueryPanel.d.ts +0 -4
- package/dist/client/components/QueryBuilder/ResultsPanel.d.ts +0 -4
- package/dist/client/components/QueryBuilder/SetupPanel.d.ts +0 -11
- package/dist/client/components/QueryBuilder/ShareWarningModal.d.ts +0 -9
- package/dist/client/components/QueryBuilder/index.d.ts +0 -3
- /package/dist/client/components/{QueryBuilder → shared}/DateRangeSelector.d.ts +0 -0
|
@@ -1,244 +0,0 @@
|
|
|
1
|
-
import { jsx as y } from "react/jsx-runtime";
|
|
2
|
-
import { d, a as f, b as g, c as u, e as b, f as v, g as k, h as l, i as m, j as T, k as D, l as w, m as C, n as A, o as I, p as x, q as M, r as B, s as F, t as N, u as O, v as R, w as S, x as _, y as G, z as K, A as j, B as q, C as L, D as z, E as P, F as U, G as V, H, I as W, J as E, K as Z, L as J, M as Q, N as X, O as Y, P as aa, Q as ta, R as ea, S as oa, T as ia, U as ca, V as ra, W as na, X as sa, Y as da, Z as ya, _ as ga, $ as ua, a0 as la, a1 as ma, a2 as ha, a3 as pa, a4 as $a, a5 as fa, a6 as ba, a7 as va, a8 as ka, a9 as Ta, aa as Da, ab as wa, ac as h } from "./icons-B2XSxpVK.js";
|
|
3
|
-
const p = {
|
|
4
|
-
// Action icons
|
|
5
|
-
close: { icon: wa, category: "action" },
|
|
6
|
-
add: { icon: Da, category: "action" },
|
|
7
|
-
edit: { icon: Ta, category: "action" },
|
|
8
|
-
delete: { icon: ka, category: "action" },
|
|
9
|
-
refresh: { icon: d, category: "action" },
|
|
10
|
-
copy: { icon: va, category: "action" },
|
|
11
|
-
duplicate: { icon: ba, category: "action" },
|
|
12
|
-
settings: { icon: fa, category: "action" },
|
|
13
|
-
filter: { icon: $a, category: "action" },
|
|
14
|
-
share: { icon: pa, category: "action" },
|
|
15
|
-
expand: { icon: l, category: "action" },
|
|
16
|
-
collapse: { icon: m, category: "action" },
|
|
17
|
-
search: { icon: ha, category: "action" },
|
|
18
|
-
menu: { icon: ma, category: "action" },
|
|
19
|
-
run: { icon: la, category: "action" },
|
|
20
|
-
check: { icon: ua, category: "action" },
|
|
21
|
-
link: { icon: ga, category: "action" },
|
|
22
|
-
eye: { icon: ya, category: "action" },
|
|
23
|
-
eyeOff: { icon: da, category: "action" },
|
|
24
|
-
adjustments: { icon: sa, category: "action" },
|
|
25
|
-
desktop: { icon: na, category: "action" },
|
|
26
|
-
table: { icon: ra, category: "action" },
|
|
27
|
-
sun: { icon: ca, category: "action" },
|
|
28
|
-
moon: { icon: ia, category: "action" },
|
|
29
|
-
ellipsisHorizontal: { icon: oa, category: "action" },
|
|
30
|
-
documentText: { icon: ea, category: "action" },
|
|
31
|
-
bookOpen: { icon: ta, category: "action" },
|
|
32
|
-
codeBracket: { icon: aa, category: "action" },
|
|
33
|
-
// Field type icons (solid for visual distinction)
|
|
34
|
-
measure: { icon: Y, category: "field" },
|
|
35
|
-
dimension: { icon: X, category: "field" },
|
|
36
|
-
timeDimension: { icon: Q, category: "field" },
|
|
37
|
-
segment: { icon: J, category: "field" },
|
|
38
|
-
// Chart type icons (Tabler - keeping existing visuals)
|
|
39
|
-
chartBar: { icon: Z, category: "chart" },
|
|
40
|
-
chartLine: { icon: E, category: "chart" },
|
|
41
|
-
chartArea: { icon: W, category: "chart" },
|
|
42
|
-
chartPie: { icon: H, category: "chart" },
|
|
43
|
-
chartScatter: { icon: V, category: "chart" },
|
|
44
|
-
chartBubble: { icon: U, category: "chart" },
|
|
45
|
-
chartRadar: { icon: P, category: "chart" },
|
|
46
|
-
chartRadialBar: { icon: z, category: "chart" },
|
|
47
|
-
chartTreemap: { icon: L, category: "chart" },
|
|
48
|
-
chartTable: { icon: q, category: "chart" },
|
|
49
|
-
chartActivityGrid: { icon: j, category: "chart" },
|
|
50
|
-
chartKpiNumber: { icon: K, category: "chart" },
|
|
51
|
-
chartKpiDelta: { icon: G, category: "chart" },
|
|
52
|
-
chartKpiText: { icon: _, category: "chart" },
|
|
53
|
-
chartMarkdown: { icon: S, category: "chart" },
|
|
54
|
-
// Measure type icons (solid)
|
|
55
|
-
measureCount: { icon: R, category: "measure" },
|
|
56
|
-
measureCountDistinct: { icon: O, category: "measure" },
|
|
57
|
-
measureCountDistinctApprox: { icon: N, category: "measure" },
|
|
58
|
-
measureSum: { icon: F, category: "measure" },
|
|
59
|
-
measureAvg: { icon: B, category: "measure" },
|
|
60
|
-
measureMin: { icon: g, category: "measure" },
|
|
61
|
-
measureMax: { icon: u, category: "measure" },
|
|
62
|
-
measureRunningTotal: { icon: M, category: "measure" },
|
|
63
|
-
measureCalculated: { icon: x, category: "measure" },
|
|
64
|
-
measureNumber: { icon: I, category: "measure" },
|
|
65
|
-
// State icons
|
|
66
|
-
success: { icon: A, category: "state" },
|
|
67
|
-
warning: { icon: C, category: "state" },
|
|
68
|
-
error: { icon: w, category: "state" },
|
|
69
|
-
info: { icon: D, category: "state" },
|
|
70
|
-
loading: { icon: d, category: "state" },
|
|
71
|
-
sparkles: { icon: T, category: "state" },
|
|
72
|
-
// Navigation icons
|
|
73
|
-
chevronUp: { icon: m, category: "navigation" },
|
|
74
|
-
chevronDown: { icon: l, category: "navigation" },
|
|
75
|
-
chevronLeft: { icon: k, category: "navigation" },
|
|
76
|
-
chevronRight: { icon: v, category: "navigation" },
|
|
77
|
-
chevronUpDown: { icon: b, category: "navigation" },
|
|
78
|
-
arrowUp: { icon: u, category: "navigation" },
|
|
79
|
-
arrowDown: { icon: g, category: "navigation" },
|
|
80
|
-
arrowRight: { icon: f, category: "navigation" },
|
|
81
|
-
arrowPath: { icon: d, category: "navigation" }
|
|
82
|
-
};
|
|
83
|
-
let o = { ...p };
|
|
84
|
-
const r = /* @__PURE__ */ new Map();
|
|
85
|
-
function Ma() {
|
|
86
|
-
return o;
|
|
87
|
-
}
|
|
88
|
-
function n(a) {
|
|
89
|
-
const e = r.get(a);
|
|
90
|
-
if (e)
|
|
91
|
-
return e;
|
|
92
|
-
const t = o[a];
|
|
93
|
-
if (!t)
|
|
94
|
-
return console.warn(`Icon "${a}" not found in registry, using fallback`), ({ className: s, ...$ }) => /* @__PURE__ */ y(h, { icon: o.info.icon, className: s, ...$ });
|
|
95
|
-
const i = ({ className: c, ...s }) => /* @__PURE__ */ y(h, { icon: t.icon, className: c, ...s });
|
|
96
|
-
return r.set(a, i), i;
|
|
97
|
-
}
|
|
98
|
-
function Ba(a) {
|
|
99
|
-
return o[a]?.icon ?? o.info.icon;
|
|
100
|
-
}
|
|
101
|
-
function Fa(a, e) {
|
|
102
|
-
o[a] && (o[a] = {
|
|
103
|
-
...o[a],
|
|
104
|
-
icon: e
|
|
105
|
-
}, r.delete(a));
|
|
106
|
-
}
|
|
107
|
-
function Na(a) {
|
|
108
|
-
for (const [e, t] of Object.entries(a))
|
|
109
|
-
if (t && e in o) {
|
|
110
|
-
const i = e;
|
|
111
|
-
if ("body" in t)
|
|
112
|
-
o[i] = {
|
|
113
|
-
...o[i],
|
|
114
|
-
icon: t
|
|
115
|
-
};
|
|
116
|
-
else {
|
|
117
|
-
const c = t;
|
|
118
|
-
o[i] = {
|
|
119
|
-
...o[i],
|
|
120
|
-
...c,
|
|
121
|
-
icon: c.icon ?? o[i].icon
|
|
122
|
-
};
|
|
123
|
-
}
|
|
124
|
-
r.delete(i);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
function Oa() {
|
|
128
|
-
o = { ...p }, r.clear();
|
|
129
|
-
}
|
|
130
|
-
function Ra(a) {
|
|
131
|
-
const e = {};
|
|
132
|
-
for (const [t, i] of Object.entries(o))
|
|
133
|
-
i.category === a && (e[t] = n(t));
|
|
134
|
-
return e;
|
|
135
|
-
}
|
|
136
|
-
function Sa(a) {
|
|
137
|
-
const t = {
|
|
138
|
-
count: "measureCount",
|
|
139
|
-
countDistinct: "measureCountDistinct",
|
|
140
|
-
countDistinctApprox: "measureCountDistinctApprox",
|
|
141
|
-
sum: "measureSum",
|
|
142
|
-
avg: "measureAvg",
|
|
143
|
-
min: "measureMin",
|
|
144
|
-
max: "measureMax",
|
|
145
|
-
runningTotal: "measureRunningTotal",
|
|
146
|
-
calculated: "measureCalculated",
|
|
147
|
-
number: "measureNumber"
|
|
148
|
-
}[a || ""] || "measureCount";
|
|
149
|
-
return n(t);
|
|
150
|
-
}
|
|
151
|
-
function Ca(a) {
|
|
152
|
-
const t = {
|
|
153
|
-
bar: "chartBar",
|
|
154
|
-
line: "chartLine",
|
|
155
|
-
area: "chartArea",
|
|
156
|
-
pie: "chartPie",
|
|
157
|
-
scatter: "chartScatter",
|
|
158
|
-
bubble: "chartBubble",
|
|
159
|
-
radar: "chartRadar",
|
|
160
|
-
radialBar: "chartRadialBar",
|
|
161
|
-
treemap: "chartTreemap",
|
|
162
|
-
table: "chartTable",
|
|
163
|
-
activityGrid: "chartActivityGrid",
|
|
164
|
-
kpiNumber: "chartKpiNumber",
|
|
165
|
-
kpiDelta: "chartKpiDelta",
|
|
166
|
-
kpiText: "chartKpiText",
|
|
167
|
-
markdown: "chartMarkdown"
|
|
168
|
-
}[a] || "chartBar";
|
|
169
|
-
return n(t);
|
|
170
|
-
}
|
|
171
|
-
function _a(a) {
|
|
172
|
-
const t = {
|
|
173
|
-
measure: "measure",
|
|
174
|
-
dimension: "dimension",
|
|
175
|
-
timeDimension: "timeDimension",
|
|
176
|
-
time: "timeDimension",
|
|
177
|
-
segment: "segment"
|
|
178
|
-
}[a] || "dimension";
|
|
179
|
-
return n(t);
|
|
180
|
-
}
|
|
181
|
-
const Aa = {
|
|
182
|
-
icon: Ca("activityGrid"),
|
|
183
|
-
description: "GitHub-style activity grid showing temporal patterns across different time scales",
|
|
184
|
-
useCase: "Best for visualizing activity patterns over time. Supports hour (3hr blocks × days), day (days × weeks), week (weeks × months), month (months × quarters), and quarter (quarters × years) granularities",
|
|
185
|
-
dropZones: [
|
|
186
|
-
{
|
|
187
|
-
key: "dateField",
|
|
188
|
-
label: "Time Dimension",
|
|
189
|
-
description: "Time field that determines grid structure (granularity affects layout)",
|
|
190
|
-
mandatory: !0,
|
|
191
|
-
maxItems: 1,
|
|
192
|
-
acceptTypes: ["timeDimension"],
|
|
193
|
-
emptyText: "Drop a time dimension (granularity affects grid structure)"
|
|
194
|
-
},
|
|
195
|
-
{
|
|
196
|
-
key: "valueField",
|
|
197
|
-
label: "Activity Measure",
|
|
198
|
-
description: "Measure used for activity intensity (color coding)",
|
|
199
|
-
mandatory: !0,
|
|
200
|
-
maxItems: 1,
|
|
201
|
-
acceptTypes: ["measure"],
|
|
202
|
-
emptyText: "Drop a measure for activity intensity"
|
|
203
|
-
}
|
|
204
|
-
],
|
|
205
|
-
displayOptions: ["showLabels", "showTooltip", "hideHeader"],
|
|
206
|
-
displayOptionsConfig: [
|
|
207
|
-
{
|
|
208
|
-
key: "fitToWidth",
|
|
209
|
-
label: "Fit to Width",
|
|
210
|
-
type: "boolean",
|
|
211
|
-
defaultValue: !1,
|
|
212
|
-
description: "Automatically size blocks to fill portlet width and height while maintaining aspect ratio"
|
|
213
|
-
}
|
|
214
|
-
],
|
|
215
|
-
validate: (a) => {
|
|
216
|
-
const { dateField: e, valueField: t } = a;
|
|
217
|
-
return !e || Array.isArray(e) && e.length === 0 ? {
|
|
218
|
-
isValid: !1,
|
|
219
|
-
message: "Time dimension is required for activity grid"
|
|
220
|
-
} : !t || Array.isArray(t) && t.length === 0 ? {
|
|
221
|
-
isValid: !1,
|
|
222
|
-
message: "Activity measure is required for intensity mapping"
|
|
223
|
-
} : { isValid: !0 };
|
|
224
|
-
}
|
|
225
|
-
}, Ga = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
226
|
-
__proto__: null,
|
|
227
|
-
activityGridChartConfig: Aa
|
|
228
|
-
}, Symbol.toStringTag, { value: "Module" }));
|
|
229
|
-
export {
|
|
230
|
-
Ga as A,
|
|
231
|
-
p as D,
|
|
232
|
-
Sa as a,
|
|
233
|
-
n as b,
|
|
234
|
-
Ba as c,
|
|
235
|
-
Oa as d,
|
|
236
|
-
Ma as e,
|
|
237
|
-
Ra as f,
|
|
238
|
-
Ca as g,
|
|
239
|
-
_a as h,
|
|
240
|
-
Aa as i,
|
|
241
|
-
Na as r,
|
|
242
|
-
Fa as s
|
|
243
|
-
};
|
|
244
|
-
//# sourceMappingURL=chart-activitygridchart-config-AVBoHdRn.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chart-activitygridchart-config-AVBoHdRn.js","sources":["../../../src/client/icons/defaultIcons.ts","../../../src/client/icons/registry.tsx","../../../src/client/components/charts/ActivityGridChart.config.tsx"],"sourcesContent":["/**\n * Default icon definitions using Iconify icon sets\n * Uses HeroIcons (outline/solid) and Tabler icons via Iconify\n */\n\n// HeroIcons Outline\nimport xMark from '@iconify-icons/heroicons-outline/x-mark'\nimport plus from '@iconify-icons/heroicons-outline/plus'\nimport pencil from '@iconify-icons/heroicons-outline/pencil'\nimport trash from '@iconify-icons/heroicons-outline/trash'\nimport arrowPath from '@iconify-icons/heroicons-outline/arrow-path'\nimport clipboardDocument from '@iconify-icons/heroicons-outline/clipboard-document'\nimport documentDuplicate from '@iconify-icons/heroicons-outline/document-duplicate'\nimport cog from '@iconify-icons/heroicons-outline/cog'\nimport funnel from '@iconify-icons/heroicons-outline/funnel'\nimport share from '@iconify-icons/heroicons-outline/share'\nimport chevronUp from '@iconify-icons/heroicons-outline/chevron-up'\nimport chevronDown from '@iconify-icons/heroicons-outline/chevron-down'\nimport chevronLeft from '@iconify-icons/heroicons-outline/chevron-left'\nimport chevronRight from '@iconify-icons/heroicons-outline/chevron-right'\nimport magnifyingGlass from '@iconify-icons/heroicons-outline/magnifying-glass'\nimport bars3 from '@iconify-icons/heroicons-outline/bars-3'\nimport checkCircle from '@iconify-icons/heroicons-outline/check-circle'\nimport exclamationTriangle from '@iconify-icons/heroicons-outline/exclaimation-triangle'\nimport exclamationCircle from '@iconify-icons/heroicons-outline/exclamation-circle'\nimport sparkles from '@iconify-icons/heroicons-outline/sparkles'\nimport eye from '@iconify-icons/heroicons-outline/eye'\nimport eyeSlash from '@iconify-icons/heroicons-outline/eye-slash'\nimport adjustmentsHorizontal from '@iconify-icons/heroicons-outline/adjustments-horizontal'\nimport computerDesktop from '@iconify-icons/heroicons-outline/computer-desktop'\nimport tableCells from '@iconify-icons/heroicons-outline/table-cells'\nimport link from '@iconify-icons/heroicons-outline/link'\nimport arrowRight from '@iconify-icons/heroicons-outline/arrow-right'\nimport sun from '@iconify-icons/heroicons-outline/sun'\nimport moon from '@iconify-icons/heroicons-outline/moon'\nimport ellipsisHorizontal from '@iconify-icons/heroicons-outline/ellipsis-horizontal'\nimport documentText from '@iconify-icons/heroicons-outline/document-text'\nimport bookOpen from '@iconify-icons/heroicons-outline/book-open'\nimport codeBracket from '@iconify-icons/heroicons-outline/code-bracket'\n\n// HeroIcons Solid (for field type indicators and measures)\nimport chartBarSolid from '@iconify-icons/heroicons-solid/chart-bar'\nimport tagSolid from '@iconify-icons/heroicons-solid/tag'\nimport calendarSolid from '@iconify-icons/heroicons-solid/calendar'\nimport rectangleGroupSolid from '@iconify-icons/heroicons-solid/rectangle-group'\nimport playSolid from '@iconify-icons/heroicons-solid/play'\nimport checkSolid from '@iconify-icons/heroicons-solid/check'\nimport scaleSolid from '@iconify-icons/heroicons-solid/scale'\nimport arrowDownCircleSolid from '@iconify-icons/heroicons-solid/arrow-down-circle'\nimport arrowUpCircleSolid from '@iconify-icons/heroicons-solid/arrow-up-circle'\nimport arrowTrendingUpSolid from '@iconify-icons/heroicons-solid/arrow-trending-up'\nimport beakerSolid from '@iconify-icons/heroicons-solid/beaker'\nimport bars3BottomLeftSolid from '@iconify-icons/heroicons-solid/bars-3-bottom-left'\nimport fingerPrintSolid from '@iconify-icons/heroicons-solid/finger-print'\nimport chartBarSquareSolid from '@iconify-icons/heroicons-solid/chart-bar-square'\nimport plusCircleSolid from '@iconify-icons/heroicons-solid/plus-circle'\nimport hashtagSolid from '@iconify-icons/heroicons-solid/hashtag'\n\n// Tabler icons for chart types (already using these)\nimport chartBarTabler from '@iconify-icons/tabler/chart-bar'\nimport chartLine from '@iconify-icons/tabler/chart-line'\nimport chartAreaLine from '@iconify-icons/tabler/chart-area-line'\nimport chartPie from '@iconify-icons/tabler/chart-pie'\nimport chartDots2 from '@iconify-icons/tabler/chart-dots-2'\nimport chartBubble from '@iconify-icons/tabler/chart-bubble'\nimport chartRadar from '@iconify-icons/tabler/chart-radar'\nimport radar2 from '@iconify-icons/tabler/radar-2'\nimport chartTreemap from '@iconify-icons/tabler/chart-treemap'\nimport table from '@iconify-icons/tabler/table'\nimport calendarStats from '@iconify-icons/tabler/calendar-stats'\nimport number from '@iconify-icons/tabler/number'\nimport trendingUp from '@iconify-icons/tabler/trending-up'\nimport typography from '@iconify-icons/tabler/typography'\nimport fileText from '@iconify-icons/tabler/file-text'\nimport infoCircle from '@iconify-icons/tabler/info-circle'\nimport selector from '@iconify-icons/tabler/selector'\n\nimport type { IconRegistry } from './types'\n\n/**\n * Default icon registry with all icons used in drizzle-cube\n */\nexport const DEFAULT_ICONS: IconRegistry = {\n // Action icons\n close: { icon: xMark, category: 'action' },\n add: { icon: plus, category: 'action' },\n edit: { icon: pencil, category: 'action' },\n delete: { icon: trash, category: 'action' },\n refresh: { icon: arrowPath, category: 'action' },\n copy: { icon: clipboardDocument, category: 'action' },\n duplicate: { icon: documentDuplicate, category: 'action' },\n settings: { icon: cog, category: 'action' },\n filter: { icon: funnel, category: 'action' },\n share: { icon: share, category: 'action' },\n expand: { icon: chevronDown, category: 'action' },\n collapse: { icon: chevronUp, category: 'action' },\n search: { icon: magnifyingGlass, category: 'action' },\n menu: { icon: bars3, category: 'action' },\n run: { icon: playSolid, category: 'action' },\n check: { icon: checkSolid, category: 'action' },\n link: { icon: link, category: 'action' },\n eye: { icon: eye, category: 'action' },\n eyeOff: { icon: eyeSlash, category: 'action' },\n adjustments: { icon: adjustmentsHorizontal, category: 'action' },\n desktop: { icon: computerDesktop, category: 'action' },\n table: { icon: tableCells, category: 'action' },\n sun: { icon: sun, category: 'action' },\n moon: { icon: moon, category: 'action' },\n ellipsisHorizontal: { icon: ellipsisHorizontal, category: 'action' },\n documentText: { icon: documentText, category: 'action' },\n bookOpen: { icon: bookOpen, category: 'action' },\n codeBracket: { icon: codeBracket, category: 'action' },\n\n // Field type icons (solid for visual distinction)\n measure: { icon: chartBarSolid, category: 'field' },\n dimension: { icon: tagSolid, category: 'field' },\n timeDimension: { icon: calendarSolid, category: 'field' },\n segment: { icon: rectangleGroupSolid, category: 'field' },\n\n // Chart type icons (Tabler - keeping existing visuals)\n chartBar: { icon: chartBarTabler, category: 'chart' },\n chartLine: { icon: chartLine, category: 'chart' },\n chartArea: { icon: chartAreaLine, category: 'chart' },\n chartPie: { icon: chartPie, category: 'chart' },\n chartScatter: { icon: chartDots2, category: 'chart' },\n chartBubble: { icon: chartBubble, category: 'chart' },\n chartRadar: { icon: chartRadar, category: 'chart' },\n chartRadialBar: { icon: radar2, category: 'chart' },\n chartTreemap: { icon: chartTreemap, category: 'chart' },\n chartTable: { icon: table, category: 'chart' },\n chartActivityGrid: { icon: calendarStats, category: 'chart' },\n chartKpiNumber: { icon: number, category: 'chart' },\n chartKpiDelta: { icon: trendingUp, category: 'chart' },\n chartKpiText: { icon: typography, category: 'chart' },\n chartMarkdown: { icon: fileText, category: 'chart' },\n\n // Measure type icons (solid)\n measureCount: { icon: bars3BottomLeftSolid, category: 'measure' },\n measureCountDistinct: { icon: fingerPrintSolid, category: 'measure' },\n measureCountDistinctApprox: { icon: chartBarSquareSolid, category: 'measure' },\n measureSum: { icon: plusCircleSolid, category: 'measure' },\n measureAvg: { icon: scaleSolid, category: 'measure' },\n measureMin: { icon: arrowDownCircleSolid, category: 'measure' },\n measureMax: { icon: arrowUpCircleSolid, category: 'measure' },\n measureRunningTotal: { icon: arrowTrendingUpSolid, category: 'measure' },\n measureCalculated: { icon: beakerSolid, category: 'measure' },\n measureNumber: { icon: hashtagSolid, category: 'measure' },\n\n // State icons\n success: { icon: checkCircle, category: 'state' },\n warning: { icon: exclamationTriangle, category: 'state' },\n error: { icon: exclamationCircle, category: 'state' },\n info: { icon: infoCircle, category: 'state' },\n loading: { icon: arrowPath, category: 'state' },\n sparkles: { icon: sparkles, category: 'state' },\n\n // Navigation icons\n chevronUp: { icon: chevronUp, category: 'navigation' },\n chevronDown: { icon: chevronDown, category: 'navigation' },\n chevronLeft: { icon: chevronLeft, category: 'navigation' },\n chevronRight: { icon: chevronRight, category: 'navigation' },\n chevronUpDown: { icon: selector, category: 'navigation' },\n arrowUp: { icon: arrowUpCircleSolid, category: 'navigation' },\n arrowDown: { icon: arrowDownCircleSolid, category: 'navigation' },\n arrowRight: { icon: arrowRight, category: 'navigation' },\n arrowPath: { icon: arrowPath, category: 'navigation' },\n}\n","/**\n * Icon Registry - Centralized icon management following the theme pattern\n * Allows users to override any icon with their own implementations\n */\n\nimport { Icon } from '@iconify/react'\nimport type { IconifyIcon } from '@iconify/types'\nimport type { ComponentType } from 'react'\nimport { DEFAULT_ICONS } from './defaultIcons'\nimport type { IconRegistry, IconName, IconDefinition, IconCategory, IconProps, PartialIconRegistry } from './types'\n\n// Internal mutable registry - starts with defaults\nlet _registry: IconRegistry = { ...DEFAULT_ICONS }\n\n// Cache for icon components to avoid recreating on every getIcon() call\n// This prevents React from unmounting/remounting icons on each render\nconst _iconComponentCache = new Map<IconName, ComponentType<IconProps>>()\n\n/**\n * Get the full icon registry\n */\nexport function getIconRegistry(): IconRegistry {\n return _registry\n}\n\n/**\n * Get a specific icon as a React component\n * @param name The icon name from the registry\n * @returns A React component that renders the icon (cached for stable references)\n */\nexport function getIcon(name: IconName): ComponentType<IconProps> {\n // Check cache first for stable component references\n const cached = _iconComponentCache.get(name)\n if (cached) {\n return cached\n }\n\n const iconDef = _registry[name]\n if (!iconDef) {\n console.warn(`Icon \"${name}\" not found in registry, using fallback`)\n // Create and cache fallback component\n const FallbackIcon = ({ className, ...props }: IconProps) => (\n <Icon icon={_registry.info.icon} className={className} {...props} />\n )\n return FallbackIcon\n }\n\n // Create and cache the icon component\n const IconComponent = ({ className, ...props }: IconProps) => (\n <Icon icon={iconDef.icon} className={className} {...props} />\n )\n _iconComponentCache.set(name, IconComponent)\n return IconComponent\n}\n\n/**\n * Get icon data directly (for use with Iconify's Icon component)\n * @param name The icon name from the registry\n * @returns The IconifyIcon data\n */\nexport function getIconData(name: IconName): IconifyIcon {\n return _registry[name]?.icon ?? _registry.info.icon\n}\n\n/**\n * Override a single icon in the registry\n * @param name The icon name to override\n * @param icon The new IconifyIcon data\n */\nexport function setIcon(name: IconName, icon: IconifyIcon): void {\n if (_registry[name]) {\n _registry[name] = {\n ..._registry[name],\n icon\n }\n // Clear cache for this icon so it gets recreated with new definition\n _iconComponentCache.delete(name)\n }\n}\n\n/**\n * Register multiple icon overrides at once\n * @param overrides Partial registry with icons to override\n */\nexport function registerIcons(overrides: PartialIconRegistry): void {\n for (const [key, value] of Object.entries(overrides)) {\n if (value && key in _registry) {\n const iconKey = key as IconName\n\n // Check if it's a raw IconifyIcon or a full IconDefinition\n if ('body' in value) {\n // It's an IconifyIcon\n _registry[iconKey] = {\n ..._registry[iconKey],\n icon: value as IconifyIcon\n }\n } else {\n // It's a partial IconDefinition\n const partial = value as Partial<IconDefinition>\n _registry[iconKey] = {\n ..._registry[iconKey],\n ...partial,\n icon: partial.icon ?? _registry[iconKey].icon\n }\n }\n // Clear cache for this icon so it gets recreated with new definition\n _iconComponentCache.delete(iconKey)\n }\n }\n}\n\n/**\n * Reset the registry to default icons\n */\nexport function resetIcons(): void {\n _registry = { ...DEFAULT_ICONS }\n // Clear all cached icon components\n _iconComponentCache.clear()\n}\n\n/**\n * Get all icons in a specific category\n * @param category The icon category to filter by\n * @returns Record of icon names to their components\n */\nexport function getIconsByCategory(category: IconCategory): Record<string, ComponentType<IconProps>> {\n const result: Record<string, ComponentType<IconProps>> = {}\n\n for (const [key, value] of Object.entries(_registry)) {\n if (value.category === category) {\n result[key] = getIcon(key as IconName)\n }\n }\n\n return result\n}\n\n/**\n * Helper to get measure type icon component\n * @param measureType The measure type (count, avg, sum, etc.)\n * @returns React component for the icon\n */\nexport function getMeasureTypeIcon(measureType: string | undefined): ComponentType<IconProps> {\n const typeMap: Record<string, IconName> = {\n count: 'measureCount',\n countDistinct: 'measureCountDistinct',\n countDistinctApprox: 'measureCountDistinctApprox',\n sum: 'measureSum',\n avg: 'measureAvg',\n min: 'measureMin',\n max: 'measureMax',\n runningTotal: 'measureRunningTotal',\n calculated: 'measureCalculated',\n number: 'measureNumber'\n }\n\n const iconName = typeMap[measureType || ''] || 'measureCount'\n return getIcon(iconName)\n}\n\n/**\n * Helper to get chart type icon component\n * @param chartType The chart type (bar, line, pie, etc.)\n * @returns React component for the icon\n */\nexport function getChartTypeIcon(chartType: string): ComponentType<IconProps> {\n const typeMap: Record<string, IconName> = {\n bar: 'chartBar',\n line: 'chartLine',\n area: 'chartArea',\n pie: 'chartPie',\n scatter: 'chartScatter',\n bubble: 'chartBubble',\n radar: 'chartRadar',\n radialBar: 'chartRadialBar',\n treemap: 'chartTreemap',\n table: 'chartTable',\n activityGrid: 'chartActivityGrid',\n kpiNumber: 'chartKpiNumber',\n kpiDelta: 'chartKpiDelta',\n kpiText: 'chartKpiText',\n markdown: 'chartMarkdown'\n }\n\n const iconName = typeMap[chartType] || 'chartBar'\n return getIcon(iconName)\n}\n\n/**\n * Helper to get field type icon component\n * @param fieldType The field type (measure, dimension, timeDimension)\n * @returns React component for the icon\n */\nexport function getFieldTypeIcon(fieldType: string): ComponentType<IconProps> {\n const typeMap: Record<string, IconName> = {\n measure: 'measure',\n dimension: 'dimension',\n timeDimension: 'timeDimension',\n time: 'timeDimension',\n segment: 'segment'\n }\n\n const iconName = typeMap[fieldType] || 'dimension'\n return getIcon(iconName)\n}\n","import type { ChartTypeConfig } from '../../charts/chartConfigs'\nimport { getChartTypeIcon } from '../../icons'\n\n/**\n * Configuration for the activity grid chart type\n */\nexport const activityGridChartConfig: ChartTypeConfig = {\n icon: getChartTypeIcon('activityGrid'),\n description: 'GitHub-style activity grid showing temporal patterns across different time scales',\n useCase: 'Best for visualizing activity patterns over time. Supports hour (3hr blocks × days), day (days × weeks), week (weeks × months), month (months × quarters), and quarter (quarters × years) granularities',\n dropZones: [\n {\n key: 'dateField',\n label: 'Time Dimension',\n description: 'Time field that determines grid structure (granularity affects layout)',\n mandatory: true,\n maxItems: 1,\n acceptTypes: ['timeDimension'],\n emptyText: 'Drop a time dimension (granularity affects grid structure)'\n },\n {\n key: 'valueField',\n label: 'Activity Measure',\n description: 'Measure used for activity intensity (color coding)',\n mandatory: true,\n maxItems: 1,\n acceptTypes: ['measure'],\n emptyText: 'Drop a measure for activity intensity'\n }\n ],\n displayOptions: ['showLabels', 'showTooltip', 'hideHeader'],\n displayOptionsConfig: [\n {\n key: 'fitToWidth',\n label: 'Fit to Width',\n type: 'boolean',\n defaultValue: false,\n description: 'Automatically size blocks to fill portlet width and height while maintaining aspect ratio'\n }\n ],\n validate: (config) => {\n const { dateField, valueField } = config\n \n if (!dateField || (Array.isArray(dateField) && dateField.length === 0)) {\n return {\n isValid: false,\n message: 'Time dimension is required for activity grid'\n }\n }\n \n if (!valueField || (Array.isArray(valueField) && valueField.length === 0)) {\n return {\n isValid: false,\n message: 'Activity measure is required for intensity mapping'\n }\n }\n \n return { isValid: true }\n }\n}"],"names":["DEFAULT_ICONS","xMark","plus","pencil","trash","arrowPath","clipboardDocument","documentDuplicate","cog","funnel","share","chevronDown","chevronUp","magnifyingGlass","bars3","playSolid","checkSolid","link","eye","eyeSlash","adjustmentsHorizontal","computerDesktop","tableCells","sun","moon","ellipsisHorizontal","documentText","bookOpen","codeBracket","chartBarSolid","tagSolid","calendarSolid","rectangleGroupSolid","chartBarTabler","chartLine","chartAreaLine","chartPie","chartDots2","chartBubble","chartRadar","radar2","chartTreemap","table","calendarStats","number","trendingUp","typography","fileText","bars3BottomLeftSolid","fingerPrintSolid","chartBarSquareSolid","plusCircleSolid","scaleSolid","arrowDownCircleSolid","arrowUpCircleSolid","arrowTrendingUpSolid","beakerSolid","hashtagSolid","checkCircle","exclamationTriangle","exclamationCircle","infoCircle","sparkles","chevronLeft","chevronRight","selector","arrowRight","_registry","_iconComponentCache","getIconRegistry","getIcon","name","cached","iconDef","className","props","jsx","Icon","IconComponent","getIconData","setIcon","icon","registerIcons","overrides","key","value","iconKey","partial","resetIcons","getIconsByCategory","category","result","getMeasureTypeIcon","measureType","iconName","getChartTypeIcon","chartType","getFieldTypeIcon","fieldType","activityGridChartConfig","config","dateField","valueField"],"mappings":"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"}
|
|
@@ -1,239 +0,0 @@
|
|
|
1
|
-
import { jsx as r, jsxs as f, Fragment as K } from "react/jsx-runtime";
|
|
2
|
-
import { useState as C } from "react";
|
|
3
|
-
import { ComposedChart as X, CartesianGrid as q, XAxis as B, YAxis as M, Legend as U, Area as J, Line as O } from "recharts";
|
|
4
|
-
import { C as Q } from "./chart-chartcontainer-CdwzIKP1.js";
|
|
5
|
-
import { C as Z } from "./chart-charttooltip-Bx3I8jQv.js";
|
|
6
|
-
import { u as P, t as ee, C as te, f as w, a as F } from "./chart-activitygridchart-CUGN9Xq9.js";
|
|
7
|
-
function re(s) {
|
|
8
|
-
if (!s || typeof s != "string")
|
|
9
|
-
return [];
|
|
10
|
-
const t = s.trim();
|
|
11
|
-
if (!t)
|
|
12
|
-
return [];
|
|
13
|
-
try {
|
|
14
|
-
const i = t.split(",").map((a) => a.trim()).filter((a) => a !== "").map((a) => {
|
|
15
|
-
const o = parseFloat(a);
|
|
16
|
-
if (isNaN(o))
|
|
17
|
-
throw new Error(`Invalid numeric value: ${a}`);
|
|
18
|
-
return o;
|
|
19
|
-
});
|
|
20
|
-
return i.length > 0 ? i : [];
|
|
21
|
-
} catch (i) {
|
|
22
|
-
return console.warn("Failed to parse target values:", i), [];
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
function se(s, t) {
|
|
26
|
-
if (s.length === 0 || t <= 0)
|
|
27
|
-
return [];
|
|
28
|
-
if (s.length === 1)
|
|
29
|
-
return new Array(t).fill(s[0]);
|
|
30
|
-
const i = [], a = Math.floor(t / s.length), o = t % s.length;
|
|
31
|
-
let d = 0;
|
|
32
|
-
for (let l = 0; l < s.length; l++) {
|
|
33
|
-
const p = a + (l < o ? 1 : 0);
|
|
34
|
-
for (let g = 0; g < p; g++)
|
|
35
|
-
i[d++] = s[l];
|
|
36
|
-
}
|
|
37
|
-
return i;
|
|
38
|
-
}
|
|
39
|
-
function me(s, t) {
|
|
40
|
-
return t === 0 ? s === 0 ? 0 : s > 0 ? 100 : -100 : (s - t) / t * 100;
|
|
41
|
-
}
|
|
42
|
-
function xe(s, t = 1) {
|
|
43
|
-
return `${s >= 0 ? "+" : ""}${s.toFixed(t)}%`;
|
|
44
|
-
}
|
|
45
|
-
function ie({
|
|
46
|
-
data: s,
|
|
47
|
-
chartConfig: t,
|
|
48
|
-
displayConfig: i = {},
|
|
49
|
-
queryObject: a,
|
|
50
|
-
height: o = "100%",
|
|
51
|
-
colorPalette: d
|
|
52
|
-
}) {
|
|
53
|
-
const [l, p] = C(null), { labelMap: g, getFieldLabel: S } = P();
|
|
54
|
-
try {
|
|
55
|
-
const m = i?.stackType ?? (i?.stacked ? "normal" : "none"), E = m !== "none", V = m === "percent", v = {
|
|
56
|
-
showLegend: i?.showLegend ?? !0,
|
|
57
|
-
showGrid: i?.showGrid ?? !0,
|
|
58
|
-
showTooltip: i?.showTooltip ?? !0,
|
|
59
|
-
connectNulls: i?.connectNulls ?? !1
|
|
60
|
-
}, x = i?.leftYAxisFormat, N = i?.rightYAxisFormat;
|
|
61
|
-
if (!s || s.length === 0)
|
|
62
|
-
return /* @__PURE__ */ r("div", { className: "flex items-center justify-center w-full text-dc-text-muted", style: { height: o }, children: /* @__PURE__ */ f("div", { className: "text-center", children: [
|
|
63
|
-
/* @__PURE__ */ r("div", { className: "text-sm font-semibold mb-1", children: "No data available" }),
|
|
64
|
-
/* @__PURE__ */ r("div", { className: "text-xs text-dc-text-secondary", children: "No data points to display in area chart" })
|
|
65
|
-
] }) });
|
|
66
|
-
let k, c, _ = [];
|
|
67
|
-
if (t?.xAxis && t?.yAxis)
|
|
68
|
-
k = Array.isArray(t.xAxis) ? t.xAxis[0] : t.xAxis, c = Array.isArray(t.yAxis) ? t.yAxis : [t.yAxis], _ = t.series || [];
|
|
69
|
-
else if (t?.x && t?.y)
|
|
70
|
-
k = t.x, c = Array.isArray(t.y) ? t.y : [t.y];
|
|
71
|
-
else
|
|
72
|
-
return /* @__PURE__ */ r("div", { className: "flex items-center justify-center w-full text-dc-warning", style: { height: o }, children: /* @__PURE__ */ f("div", { className: "text-center", children: [
|
|
73
|
-
/* @__PURE__ */ r("div", { className: "text-sm font-semibold mb-1", children: "Configuration Error" }),
|
|
74
|
-
/* @__PURE__ */ r("div", { className: "text-xs", children: "Invalid or missing chart axis configuration" })
|
|
75
|
-
] }) });
|
|
76
|
-
if (!k || !c || c.length === 0)
|
|
77
|
-
return /* @__PURE__ */ r("div", { className: "flex items-center justify-center w-full text-dc-warning", style: { height: o }, children: /* @__PURE__ */ f("div", { className: "text-center", children: [
|
|
78
|
-
/* @__PURE__ */ r("div", { className: "text-sm font-semibold mb-1", children: "Configuration Error" }),
|
|
79
|
-
/* @__PURE__ */ r("div", { className: "text-xs", children: "Missing required X-axis or Y-axis fields" })
|
|
80
|
-
] }) });
|
|
81
|
-
const { data: u, seriesKeys: G } = ee(
|
|
82
|
-
s,
|
|
83
|
-
k,
|
|
84
|
-
c,
|
|
85
|
-
a,
|
|
86
|
-
_,
|
|
87
|
-
g
|
|
88
|
-
), h = t?.yAxisAssignment || {}, T = {};
|
|
89
|
-
c.forEach((e) => {
|
|
90
|
-
const n = S(e);
|
|
91
|
-
T[n] = e;
|
|
92
|
-
});
|
|
93
|
-
const b = c.some((e) => h[e] === "right"), z = c.filter((e) => (h[e] || "left") === "left"), j = c.filter((e) => h[e] === "right"), Y = E && !b, y = V && !b, $ = v.showLegend, R = {
|
|
94
|
-
...te,
|
|
95
|
-
left: 40,
|
|
96
|
-
// Space for left Y-axis label
|
|
97
|
-
right: b ? 40 : 20
|
|
98
|
-
// Extra space for right Y-axis label if needed
|
|
99
|
-
}, W = re(i?.target || ""), I = se(W, u.length);
|
|
100
|
-
let D = u;
|
|
101
|
-
return I.length > 0 && (D = u.map((e, n) => ({
|
|
102
|
-
...e,
|
|
103
|
-
__target: I[n] || null
|
|
104
|
-
}))), !u || u.length === 0 ? /* @__PURE__ */ r("div", { className: "flex items-center justify-center w-full text-dc-text-muted", style: { height: o }, children: /* @__PURE__ */ f("div", { className: "text-center", children: [
|
|
105
|
-
/* @__PURE__ */ r("div", { className: "text-sm font-semibold mb-1", children: "No valid data" }),
|
|
106
|
-
/* @__PURE__ */ r("div", { className: "text-xs text-dc-text-secondary", children: "No valid data points for area chart after transformation" })
|
|
107
|
-
] }) }) : /* @__PURE__ */ r(Q, { height: o, children: /* @__PURE__ */ f(X, { data: D, margin: R, stackOffset: y ? "expand" : void 0, children: [
|
|
108
|
-
v.showGrid && /* @__PURE__ */ r(q, { strokeDasharray: "3 3" }),
|
|
109
|
-
/* @__PURE__ */ r(B, { dataKey: "name", tick: { fontSize: 12 }, angle: -45, textAnchor: "end", height: 60 }),
|
|
110
|
-
/* @__PURE__ */ r(
|
|
111
|
-
M,
|
|
112
|
-
{
|
|
113
|
-
yAxisId: "left",
|
|
114
|
-
orientation: "left",
|
|
115
|
-
tick: { fontSize: 12 },
|
|
116
|
-
tickFormatter: y ? (e) => `${(e * 100).toFixed(0)}%` : x ? (e) => w(e, x) : void 0,
|
|
117
|
-
domain: y ? [0, 1] : void 0,
|
|
118
|
-
label: y ? void 0 : z.length > 0 ? {
|
|
119
|
-
value: x?.label || S(z[0]),
|
|
120
|
-
angle: -90,
|
|
121
|
-
position: "left",
|
|
122
|
-
style: { textAnchor: "middle", fontSize: "12px" }
|
|
123
|
-
} : void 0
|
|
124
|
-
}
|
|
125
|
-
),
|
|
126
|
-
b && /* @__PURE__ */ r(
|
|
127
|
-
M,
|
|
128
|
-
{
|
|
129
|
-
yAxisId: "right",
|
|
130
|
-
orientation: "right",
|
|
131
|
-
tick: { fontSize: 12 },
|
|
132
|
-
tickFormatter: N ? (e) => w(e, N) : void 0,
|
|
133
|
-
label: j.length > 0 ? {
|
|
134
|
-
value: N?.label || S(j[0]),
|
|
135
|
-
angle: 90,
|
|
136
|
-
position: "right",
|
|
137
|
-
style: { textAnchor: "middle", fontSize: "12px" }
|
|
138
|
-
} : void 0
|
|
139
|
-
}
|
|
140
|
-
),
|
|
141
|
-
v.showTooltip && /* @__PURE__ */ r(
|
|
142
|
-
Z,
|
|
143
|
-
{
|
|
144
|
-
formatter: (e, n) => {
|
|
145
|
-
if (e == null)
|
|
146
|
-
return ["No data", n];
|
|
147
|
-
if (n === "Target")
|
|
148
|
-
return [w(e, x), "Target Value"];
|
|
149
|
-
if (y && typeof e == "number")
|
|
150
|
-
return [`${(e * 100).toFixed(1)}%`, n];
|
|
151
|
-
const A = T[n], H = (A && h[A] === "right" ? "right" : "left") === "right" ? N : x;
|
|
152
|
-
return [w(e, H), n];
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
),
|
|
156
|
-
$ && /* @__PURE__ */ r(
|
|
157
|
-
U,
|
|
158
|
-
{
|
|
159
|
-
wrapperStyle: { fontSize: "12px", paddingTop: "10px" },
|
|
160
|
-
iconType: "rect",
|
|
161
|
-
iconSize: 8,
|
|
162
|
-
layout: "horizontal",
|
|
163
|
-
align: "center",
|
|
164
|
-
verticalAlign: "bottom",
|
|
165
|
-
onMouseEnter: (e) => p(String(e.dataKey || "")),
|
|
166
|
-
onMouseLeave: () => p(null)
|
|
167
|
-
}
|
|
168
|
-
),
|
|
169
|
-
G.map((e, n) => {
|
|
170
|
-
const A = T[e], L = A && h[A] === "right" ? "right" : "left";
|
|
171
|
-
return /* @__PURE__ */ r(
|
|
172
|
-
J,
|
|
173
|
-
{
|
|
174
|
-
type: "monotone",
|
|
175
|
-
dataKey: e,
|
|
176
|
-
yAxisId: L,
|
|
177
|
-
stackId: Y ? "stack" : void 0,
|
|
178
|
-
stroke: d?.colors && d.colors[n % d.colors.length] || F[n % F.length],
|
|
179
|
-
fill: d?.colors && d.colors[n % d.colors.length] || F[n % F.length],
|
|
180
|
-
fillOpacity: l ? l === e ? 0.6 : 0.1 : 0.3,
|
|
181
|
-
strokeWidth: 2,
|
|
182
|
-
strokeOpacity: l ? l === e ? 1 : 0.3 : 1,
|
|
183
|
-
connectNulls: v.connectNulls
|
|
184
|
-
},
|
|
185
|
-
e
|
|
186
|
-
);
|
|
187
|
-
}),
|
|
188
|
-
I.length > 0 && /* @__PURE__ */ f(K, { children: [
|
|
189
|
-
/* @__PURE__ */ r(
|
|
190
|
-
O,
|
|
191
|
-
{
|
|
192
|
-
type: "monotone",
|
|
193
|
-
dataKey: "__target",
|
|
194
|
-
yAxisId: "left",
|
|
195
|
-
stroke: "#ffffff",
|
|
196
|
-
strokeWidth: 2,
|
|
197
|
-
dot: !1,
|
|
198
|
-
activeDot: !1,
|
|
199
|
-
connectNulls: !1
|
|
200
|
-
}
|
|
201
|
-
),
|
|
202
|
-
/* @__PURE__ */ r(
|
|
203
|
-
O,
|
|
204
|
-
{
|
|
205
|
-
type: "monotone",
|
|
206
|
-
dataKey: "__target",
|
|
207
|
-
yAxisId: "left",
|
|
208
|
-
name: "Target",
|
|
209
|
-
stroke: "#8B5CF6",
|
|
210
|
-
strokeWidth: 2,
|
|
211
|
-
strokeDasharray: "2 3",
|
|
212
|
-
dot: !1,
|
|
213
|
-
activeDot: !1,
|
|
214
|
-
connectNulls: !1
|
|
215
|
-
}
|
|
216
|
-
)
|
|
217
|
-
] })
|
|
218
|
-
] }) });
|
|
219
|
-
} catch (m) {
|
|
220
|
-
return /* @__PURE__ */ r("div", { className: "flex flex-col items-center justify-center w-full text-dc-error p-4", style: { height: o }, children: /* @__PURE__ */ f("div", { className: "text-center", children: [
|
|
221
|
-
/* @__PURE__ */ r("div", { className: "text-sm font-semibold mb-1", children: "Area Chart Error" }),
|
|
222
|
-
/* @__PURE__ */ r("div", { className: "text-xs mb-2", children: m instanceof Error ? m.message : "Unknown rendering error" }),
|
|
223
|
-
/* @__PURE__ */ r("div", { className: "text-xs text-dc-text-muted", children: "Check the data and configuration" })
|
|
224
|
-
] }) });
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
const ue = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
228
|
-
__proto__: null,
|
|
229
|
-
default: ie
|
|
230
|
-
}, Symbol.toStringTag, { value: "Module" }));
|
|
231
|
-
export {
|
|
232
|
-
ie as A,
|
|
233
|
-
ue as a,
|
|
234
|
-
me as c,
|
|
235
|
-
xe as f,
|
|
236
|
-
re as p,
|
|
237
|
-
se as s
|
|
238
|
-
};
|
|
239
|
-
//# sourceMappingURL=chart-areachart-B4tknnsY.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chart-areachart-B4tknnsY.js","sources":["../../../src/client/utils/targetUtils.ts","../../../src/client/components/charts/AreaChart.tsx"],"sourcesContent":["/**\n * Utility functions for handling target values in charts\n */\n\n/**\n * Parse target values from string format\n * @param targetString - String containing target values (e.g., \"100\" or \"50,75,100\")\n * @returns Array of numeric target values\n */\nexport function parseTargetValues(targetString: string): number[] {\n if (!targetString || typeof targetString !== 'string') {\n return []\n }\n\n const trimmed = targetString.trim()\n if (!trimmed) {\n return []\n }\n\n try {\n // Split by comma and parse each value\n const values = trimmed\n .split(',')\n .map(val => val.trim())\n .filter(val => val !== '')\n .map(val => {\n const num = parseFloat(val)\n if (isNaN(num)) {\n throw new Error(`Invalid numeric value: ${val}`)\n }\n return num\n })\n\n return values.length > 0 ? values : []\n } catch (error) {\n console.warn('Failed to parse target values:', error)\n return []\n }\n}\n\n/**\n * Spread target values across data points\n * @param targets - Array of target values\n * @param dataLength - Number of data points to spread across\n * @returns Array of target values for each data point\n */\nexport function spreadTargetValues(targets: number[], dataLength: number): number[] {\n if (targets.length === 0 || dataLength <= 0) {\n return []\n }\n\n // If only one target value, repeat for all data points\n if (targets.length === 1) {\n return new Array(dataLength).fill(targets[0])\n }\n\n // If we have multiple targets, spread them evenly across data points\n const result: number[] = []\n const baseGroupSize = Math.floor(dataLength / targets.length)\n const remainder = dataLength % targets.length\n\n let currentIndex = 0\n \n for (let i = 0; i < targets.length; i++) {\n // Calculate group size for this target\n // First 'remainder' groups get an extra item\n const groupSize = baseGroupSize + (i < remainder ? 1 : 0)\n \n // Fill this group with the current target value\n for (let j = 0; j < groupSize; j++) {\n result[currentIndex++] = targets[i]\n }\n }\n\n return result\n}\n\n/**\n * Calculate variance between actual and target values\n * @param actual - Actual value\n * @param target - Target value\n * @returns Variance as percentage\n */\nexport function calculateVariance(actual: number, target: number): number {\n if (target === 0) {\n return actual === 0 ? 0 : (actual > 0 ? 100 : -100)\n }\n return ((actual - target) / target) * 100\n}\n\n/**\n * Format variance as percentage string with appropriate sign and color indication\n * @param variance - Variance percentage\n * @param decimals - Number of decimal places (default: 1)\n * @returns Formatted variance string (e.g., \"+12.5%\" or \"-8.3%\")\n */\nexport function formatVariance(variance: number, decimals: number = 1): string {\n const sign = variance >= 0 ? '+' : ''\n return `${sign}${variance.toFixed(decimals)}%`\n}\n\n/**\n * Get unique target values for reference lines\n * @param targets - Array of target values (may contain duplicates)\n * @returns Array of unique target values\n */\nexport function getUniqueTargets(targets: number[]): number[] {\n return [...new Set(targets)].sort((a, b) => a - b)\n}","import { useState } from 'react'\nimport { ComposedChart, Area, Line, XAxis, YAxis, CartesianGrid, Legend } from 'recharts'\nimport ChartContainer from './ChartContainer'\nimport ChartTooltip from './ChartTooltip'\nimport { CHART_COLORS, CHART_MARGINS } from '../../utils/chartConstants'\nimport { transformChartDataWithSeries, formatAxisValue } from '../../utils/chartUtils'\nimport { parseTargetValues, spreadTargetValues } from '../../utils/targetUtils'\nimport { useCubeContext } from '../../providers/CubeProvider'\nimport type { ChartProps } from '../../types'\n\nexport default function AreaChart({ \n data, \n chartConfig, \n displayConfig = {},\n queryObject,\n height = \"100%\",\n colorPalette\n}: ChartProps) {\n const [hoveredLegend, setHoveredLegend] = useState<string | null>(null)\n const { labelMap, getFieldLabel } = useCubeContext()\n \n try {\n // Determine stacking from stackType (new) or stacked (legacy)\n const stackType = displayConfig?.stackType ?? (displayConfig?.stacked ? 'normal' : 'none')\n const shouldStack = stackType !== 'none'\n const isPercentStack = stackType === 'percent'\n\n const safeDisplayConfig = {\n showLegend: displayConfig?.showLegend ?? true,\n showGrid: displayConfig?.showGrid ?? true,\n showTooltip: displayConfig?.showTooltip ?? true,\n connectNulls: displayConfig?.connectNulls ?? false\n }\n\n // Extract axis format configs\n const leftYAxisFormat = displayConfig?.leftYAxisFormat\n const rightYAxisFormat = displayConfig?.rightYAxisFormat\n\n if (!data || data.length === 0) {\n return (\n <div className=\"flex items-center justify-center w-full text-dc-text-muted\" style={{ height }}>\n <div className=\"text-center\">\n <div className=\"text-sm font-semibold mb-1\">No data available</div>\n <div className=\"text-xs text-dc-text-secondary\">No data points to display in area chart</div>\n </div>\n </div>\n )\n }\n\n // Validate chartConfig - support both legacy and new formats\n let xAxisField: string\n let yAxisFields: string[]\n let seriesFields: string[] = []\n \n if (chartConfig?.xAxis && chartConfig?.yAxis) {\n // New format\n xAxisField = Array.isArray(chartConfig.xAxis) ? chartConfig.xAxis[0] : chartConfig.xAxis\n yAxisFields = Array.isArray(chartConfig.yAxis) ? chartConfig.yAxis : [chartConfig.yAxis]\n seriesFields = chartConfig.series || []\n } else if (chartConfig?.x && chartConfig?.y) {\n // Legacy format\n xAxisField = chartConfig.x\n yAxisFields = Array.isArray(chartConfig.y) ? chartConfig.y : [chartConfig.y]\n } else {\n return (\n <div className=\"flex items-center justify-center w-full text-dc-warning\" style={{ height }}>\n <div className=\"text-center\">\n <div className=\"text-sm font-semibold mb-1\">Configuration Error</div>\n <div className=\"text-xs\">Invalid or missing chart axis configuration</div>\n </div>\n </div>\n )\n }\n\n if (!xAxisField || !yAxisFields || yAxisFields.length === 0) {\n return (\n <div className=\"flex items-center justify-center w-full text-dc-warning\" style={{ height }}>\n <div className=\"text-center\">\n <div className=\"text-sm font-semibold mb-1\">Configuration Error</div>\n <div className=\"text-xs\">Missing required X-axis or Y-axis fields</div>\n </div>\n </div>\n )\n }\n\n // Use shared function to transform data and handle series\n const { data: chartData, seriesKeys } = transformChartDataWithSeries(\n data,\n xAxisField,\n yAxisFields,\n queryObject,\n seriesFields,\n labelMap\n )\n\n // Dual Y-axis support: extract yAxisAssignment from chartConfig\n const yAxisAssignment = chartConfig?.yAxisAssignment || {}\n\n // Build mapping from series key (label) to original field name\n const seriesKeyToField: Record<string, string> = {}\n yAxisFields.forEach((field) => {\n const label = getFieldLabel(field)\n seriesKeyToField[label] = field\n })\n\n // Determine if we need a right Y-axis\n const hasRightAxis = yAxisFields.some((field) => yAxisAssignment[field] === 'right')\n\n // Get fields for left and right axes for labels\n const leftAxisFields = yAxisFields.filter((f) => (yAxisAssignment[f] || 'left') === 'left')\n const rightAxisFields = yAxisFields.filter((f) => yAxisAssignment[f] === 'right')\n\n // Disable stacking when dual Y-axis is used (areas on different axes can't be stacked)\n const effectiveShouldStack = shouldStack && !hasRightAxis\n const effectiveIsPercentStack = isPercentStack && !hasRightAxis\n\n // Determine if legend will be shown\n const showLegend = safeDisplayConfig.showLegend\n\n // Use custom chart margins with extra space for Y-axis labels\n const chartMargins = {\n ...CHART_MARGINS,\n left: 40, // Space for left Y-axis label\n right: hasRightAxis ? 40 : 20 // Extra space for right Y-axis label if needed\n }\n \n // Process target values and add to chart data\n const targetValues = parseTargetValues(displayConfig?.target || '')\n const spreadTargets = spreadTargetValues(targetValues, chartData.length)\n \n // Add target data to chart data if targets exist\n let enhancedChartData = chartData\n if (spreadTargets.length > 0) {\n enhancedChartData = chartData.map((dataPoint, index) => ({\n ...dataPoint,\n __target: spreadTargets[index] || null\n }))\n }\n \n // Validate transformed data\n if (!chartData || chartData.length === 0) {\n return (\n <div className=\"flex items-center justify-center w-full text-dc-text-muted\" style={{ height }}>\n <div className=\"text-center\">\n <div className=\"text-sm font-semibold mb-1\">No valid data</div>\n <div className=\"text-xs text-dc-text-secondary\">No valid data points for area chart after transformation</div>\n </div>\n </div>\n )\n }\n\n // Determine stack offset for percentage stacking\n const stackOffset = effectiveIsPercentStack ? ('expand' as const) : undefined\n\n return (\n <ChartContainer height={height}>\n <ComposedChart data={enhancedChartData} margin={chartMargins} stackOffset={stackOffset}>\n {safeDisplayConfig.showGrid && <CartesianGrid strokeDasharray=\"3 3\" />}\n <XAxis dataKey=\"name\" tick={{ fontSize: 12 }} angle={-45} textAnchor=\"end\" height={60} />\n <YAxis\n yAxisId=\"left\"\n orientation=\"left\"\n tick={{ fontSize: 12 }}\n tickFormatter={\n effectiveIsPercentStack\n ? (v) => `${(v * 100).toFixed(0)}%`\n : leftYAxisFormat\n ? (value) => formatAxisValue(value, leftYAxisFormat)\n : undefined\n }\n domain={effectiveIsPercentStack ? [0, 1] : undefined}\n label={\n effectiveIsPercentStack\n ? undefined\n : leftAxisFields.length > 0\n ? {\n value: leftYAxisFormat?.label || getFieldLabel(leftAxisFields[0]),\n angle: -90,\n position: 'left',\n style: { textAnchor: 'middle', fontSize: '12px' }\n }\n : undefined\n }\n />\n {hasRightAxis && (\n <YAxis\n yAxisId=\"right\"\n orientation=\"right\"\n tick={{ fontSize: 12 }}\n tickFormatter={rightYAxisFormat ? (value) => formatAxisValue(value, rightYAxisFormat) : undefined}\n label={\n rightAxisFields.length > 0\n ? {\n value: rightYAxisFormat?.label || getFieldLabel(rightAxisFields[0]),\n angle: 90,\n position: 'right',\n style: { textAnchor: 'middle', fontSize: '12px' }\n }\n : undefined\n }\n />\n )}\n {safeDisplayConfig.showTooltip && (\n <ChartTooltip\n formatter={(value: any, name: any) => {\n // Handle null values in tooltip\n if (value === null || value === undefined) {\n return ['No data', name]\n }\n if (name === 'Target') {\n // Use left Y-axis format for target values\n return [formatAxisValue(value, leftYAxisFormat), 'Target Value']\n }\n // Format as percentage when using percent stacking\n if (effectiveIsPercentStack && typeof value === 'number') {\n return [`${(value * 100).toFixed(1)}%`, name]\n }\n // Determine which axis format to use based on series name\n const originalField = seriesKeyToField[name]\n const axisId = originalField && yAxisAssignment[originalField] === 'right' ? 'right' : 'left'\n const formatConfig = axisId === 'right' ? rightYAxisFormat : leftYAxisFormat\n return [formatAxisValue(value, formatConfig), name]\n }}\n />\n )}\n {showLegend && (\n <Legend \n wrapperStyle={{ fontSize: '12px', paddingTop: '10px' }}\n iconType=\"rect\"\n iconSize={8}\n layout=\"horizontal\"\n align=\"center\"\n verticalAlign=\"bottom\"\n onMouseEnter={(o) => setHoveredLegend(String(o.dataKey || ''))}\n onMouseLeave={() => setHoveredLegend(null)}\n />\n )}\n {seriesKeys.map((seriesKey, index) => {\n // Look up the original field name to get its axis assignment\n const originalField = seriesKeyToField[seriesKey]\n const axisId = originalField && yAxisAssignment[originalField] === 'right' ? 'right' : 'left'\n return (\n <Area\n key={seriesKey}\n type=\"monotone\"\n dataKey={seriesKey}\n yAxisId={axisId}\n stackId={effectiveShouldStack ? 'stack' : undefined}\n stroke={\n (colorPalette?.colors && colorPalette.colors[index % colorPalette.colors.length]) ||\n CHART_COLORS[index % CHART_COLORS.length]\n }\n fill={\n (colorPalette?.colors && colorPalette.colors[index % colorPalette.colors.length]) ||\n CHART_COLORS[index % CHART_COLORS.length]\n }\n fillOpacity={hoveredLegend ? (hoveredLegend === seriesKey ? 0.6 : 0.1) : 0.3}\n strokeWidth={2}\n strokeOpacity={hoveredLegend ? (hoveredLegend === seriesKey ? 1 : 0.3) : 1}\n connectNulls={safeDisplayConfig.connectNulls}\n />\n )\n })}\n {spreadTargets.length > 0 && (\n <>\n {/* White background line */}\n <Line\n type=\"monotone\"\n dataKey=\"__target\"\n yAxisId=\"left\"\n stroke=\"#ffffff\"\n strokeWidth={2}\n dot={false}\n activeDot={false}\n connectNulls={false}\n />\n {/* Grey dashed line on top */}\n <Line\n type=\"monotone\"\n dataKey=\"__target\"\n yAxisId=\"left\"\n name=\"Target\"\n stroke=\"#8B5CF6\"\n strokeWidth={2}\n strokeDasharray=\"2 3\"\n dot={false}\n activeDot={false}\n connectNulls={false}\n />\n </>\n )}\n </ComposedChart>\n </ChartContainer>\n )\n } catch (error) {\n // 'AreaChart rendering error\n return (\n <div className=\"flex flex-col items-center justify-center w-full text-dc-error p-4\" style={{ height }}>\n <div className=\"text-center\">\n <div className=\"text-sm font-semibold mb-1\">Area Chart Error</div>\n <div className=\"text-xs mb-2\">{error instanceof Error ? error.message : 'Unknown rendering error'}</div>\n <div className=\"text-xs text-dc-text-muted\">Check the data and configuration</div>\n </div>\n </div>\n )\n }\n}"],"names":["parseTargetValues","targetString","trimmed","values","val","num","error","spreadTargetValues","targets","dataLength","result","baseGroupSize","remainder","currentIndex","i","groupSize","j","calculateVariance","actual","target","formatVariance","variance","decimals","AreaChart","data","chartConfig","displayConfig","queryObject","height","colorPalette","hoveredLegend","setHoveredLegend","useState","labelMap","getFieldLabel","useCubeContext","stackType","shouldStack","isPercentStack","safeDisplayConfig","leftYAxisFormat","rightYAxisFormat","jsx","jsxs","xAxisField","yAxisFields","seriesFields","chartData","seriesKeys","transformChartDataWithSeries","yAxisAssignment","seriesKeyToField","field","label","hasRightAxis","leftAxisFields","f","rightAxisFields","effectiveShouldStack","effectiveIsPercentStack","showLegend","chartMargins","CHART_MARGINS","targetValues","spreadTargets","enhancedChartData","dataPoint","index","ChartContainer","ComposedChart","CartesianGrid","XAxis","YAxis","v","value","formatAxisValue","ChartTooltip","name","originalField","formatConfig","Legend","o","seriesKey","axisId","Area","CHART_COLORS","Fragment","Line"],"mappings":"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"}
|