drizzle-cube 0.2.7 → 0.2.8
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/client/charts.js +11 -11
- package/dist/client/chunks/{chart-activitygridchart-config-48WqIofo.js → chart-activitygridchart-config-BngZDVh_.js} +96 -90
- package/dist/client/chunks/chart-activitygridchart-config-BngZDVh_.js.map +1 -0
- package/dist/client/chunks/{chart-areachart-config-D8taXdn1.js → chart-areachart-config-DWN1E5ej.js} +2 -2
- package/dist/client/chunks/{chart-areachart-config-D8taXdn1.js.map → chart-areachart-config-DWN1E5ej.js.map} +1 -1
- package/dist/client/chunks/chart-barchart-Bdjz8DJp.js +171 -0
- package/dist/client/chunks/chart-barchart-Bdjz8DJp.js.map +1 -0
- package/dist/client/chunks/{chart-barchart-config-DjRZBtLb.js → chart-barchart-config-DZA0xTns.js} +2 -2
- package/dist/client/chunks/{chart-barchart-config-DjRZBtLb.js.map → chart-barchart-config-DZA0xTns.js.map} +1 -1
- package/dist/client/chunks/{chart-bubblechart-config-C6ck2qmg.js → chart-bubblechart-config-C79lfDSO.js} +2 -2
- package/dist/client/chunks/{chart-bubblechart-config-C6ck2qmg.js.map → chart-bubblechart-config-C79lfDSO.js.map} +1 -1
- package/dist/client/chunks/chart-datatable-Mo4gYCwa.js +249 -0
- package/dist/client/chunks/chart-datatable-Mo4gYCwa.js.map +1 -0
- package/dist/client/chunks/{chart-datatable-config-B5z0SlOJ.js → chart-datatable-config-DqGw99R3.js} +2 -2
- package/dist/client/chunks/{chart-datatable-config-B5z0SlOJ.js.map → chart-datatable-config-DqGw99R3.js.map} +1 -1
- package/dist/client/chunks/{chart-kpidelta-Cf1JmtGF.js → chart-kpidelta-CTcuIO9G.js} +2 -2
- package/dist/client/chunks/{chart-kpidelta-Cf1JmtGF.js.map → chart-kpidelta-CTcuIO9G.js.map} +1 -1
- package/dist/client/chunks/{chart-kpidelta-config-CnZfi_P2.js → chart-kpidelta-config-B-Y-LHmd.js} +2 -2
- package/dist/client/chunks/{chart-kpidelta-config-CnZfi_P2.js.map → chart-kpidelta-config-B-Y-LHmd.js.map} +1 -1
- package/dist/client/chunks/{chart-kpinumber-config-CVikHojM.js → chart-kpinumber-config-BaNaJMI6.js} +2 -2
- package/dist/client/chunks/{chart-kpinumber-config-CVikHojM.js.map → chart-kpinumber-config-BaNaJMI6.js.map} +1 -1
- package/dist/client/chunks/{chart-kpinumber-eEMpzorv.js → chart-kpinumber-slEXt8C-.js} +3 -3
- package/dist/client/chunks/{chart-kpinumber-eEMpzorv.js.map → chart-kpinumber-slEXt8C-.js.map} +1 -1
- package/dist/client/chunks/{chart-kpitext-config-B2MovXSw.js → chart-kpitext-config-BNywYqEW.js} +2 -2
- package/dist/client/chunks/{chart-kpitext-config-B2MovXSw.js.map → chart-kpitext-config-BNywYqEW.js.map} +1 -1
- package/dist/client/chunks/{chart-kpitext-CppmccTK.js → chart-kpitext-giq03TOK.js} +2 -2
- package/dist/client/chunks/{chart-kpitext-CppmccTK.js.map → chart-kpitext-giq03TOK.js.map} +1 -1
- package/dist/client/chunks/{chart-linechart-config-CVBVB7nS.js → chart-linechart-config-BL_1mjHF.js} +2 -2
- package/dist/client/chunks/{chart-linechart-config-CVBVB7nS.js.map → chart-linechart-config-BL_1mjHF.js.map} +1 -1
- package/dist/client/chunks/{chart-markdownchart-config-Cq5Sxrgq.js → chart-markdownchart-config-DtZOfYu4.js} +2 -2
- package/dist/client/chunks/{chart-markdownchart-config-Cq5Sxrgq.js.map → chart-markdownchart-config-DtZOfYu4.js.map} +1 -1
- package/dist/client/chunks/{chart-piechart-config-Bdd31Gdi.js → chart-piechart-config-Bg4jeIFo.js} +2 -2
- package/dist/client/chunks/{chart-piechart-config-Bdd31Gdi.js.map → chart-piechart-config-Bg4jeIFo.js.map} +1 -1
- package/dist/client/chunks/{chart-radarchart-config-BWyfn0ij.js → chart-radarchart-config-d6dLkI7B.js} +2 -2
- package/dist/client/chunks/{chart-radarchart-config-BWyfn0ij.js.map → chart-radarchart-config-d6dLkI7B.js.map} +1 -1
- package/dist/client/chunks/{chart-radialbarchart-config-lU2_NQCD.js → chart-radialbarchart-config-BGf97-BV.js} +2 -2
- package/dist/client/chunks/{chart-radialbarchart-config-lU2_NQCD.js.map → chart-radialbarchart-config-BGf97-BV.js.map} +1 -1
- package/dist/client/chunks/{chart-scatterchart-config-DtLnut1M.js → chart-scatterchart-config-DEIB74ot.js} +2 -2
- package/dist/client/chunks/{chart-scatterchart-config-DtLnut1M.js.map → chart-scatterchart-config-DEIB74ot.js.map} +1 -1
- package/dist/client/chunks/{chart-treemapchart-config-BEiIWQnR.js → chart-treemapchart-config-ppKPTB96.js} +2 -2
- package/dist/client/chunks/{chart-treemapchart-config-BEiIWQnR.js.map → chart-treemapchart-config-ppKPTB96.js.map} +1 -1
- package/dist/client/chunks/{charts-BsPkAFTR.js → charts-MJLpxe3r.js} +25 -25
- package/dist/client/chunks/{charts-BsPkAFTR.js.map → charts-MJLpxe3r.js.map} +1 -1
- package/dist/client/chunks/components-CXA6-jJq.js +9845 -0
- package/dist/client/chunks/components-CXA6-jJq.js.map +1 -0
- package/dist/client/chunks/{icons-D6z-_9sa.js → icons-B2XSxpVK.js} +213 -181
- package/dist/client/chunks/icons-B2XSxpVK.js.map +1 -0
- package/dist/client/components/AnalysisBuilder/AnalysisAxisDropZone.d.ts +27 -0
- package/dist/client/components/AnalysisBuilder/AnalysisChartConfigPanel.d.ts +21 -0
- package/dist/client/components/AnalysisBuilder/AnalysisFilterGroup.d.ts +20 -0
- package/dist/client/components/AnalysisBuilder/AnalysisFilterItem.d.ts +16 -0
- package/dist/client/components/AnalysisBuilder/AnalysisFilterSection.d.ts +12 -0
- package/dist/client/components/AnalysisBuilder/AnalysisQueryPanel.d.ts +10 -0
- package/dist/client/components/AnalysisBuilder/AnalysisResultsPanel.d.ts +12 -0
- package/dist/client/components/AnalysisBuilder/BreakdownItemCard.d.ts +10 -0
- package/dist/client/components/AnalysisBuilder/BreakdownSection.d.ts +8 -0
- package/dist/client/components/AnalysisBuilder/FieldDetailPanel.d.ts +4 -0
- package/dist/client/components/AnalysisBuilder/FieldSearchItem.d.ts +6 -0
- package/dist/client/components/AnalysisBuilder/FieldSearchModal.d.ts +2 -0
- package/dist/client/components/AnalysisBuilder/MetricItemCard.d.ts +9 -0
- package/dist/client/components/AnalysisBuilder/MetricsSection.d.ts +8 -0
- package/dist/client/components/AnalysisBuilder/index.d.ts +3 -0
- package/dist/client/components/AnalysisBuilder/types.d.ts +366 -0
- package/dist/client/components/AnalysisBuilder/utils.d.ts +103 -0
- package/dist/client/components/ChartTypeSelector.d.ts +6 -1
- package/dist/client/components/QueryBuilder/CubeMetaExplorer.d.ts +2 -2
- package/dist/client/components/QueryBuilder/QueryPanel.d.ts +2 -2
- package/dist/client/components/QueryBuilder/types.d.ts +7 -138
- package/dist/client/components/charts/DataTable.d.ts +1 -1
- package/dist/client/components.js +16 -9725
- package/dist/client/components.js.map +1 -1
- package/dist/client/icons/types.d.ts +6 -0
- package/dist/client/icons.js +1 -1
- package/dist/client/index.d.ts +1 -0
- package/dist/client/index.js +3202 -49
- package/dist/client/index.js.map +1 -1
- package/dist/client/shared/chartDefaults.d.ts +64 -0
- package/dist/client/shared/components/QueryAnalysisPanel.d.ts +7 -0
- package/dist/client/shared/index.d.ts +10 -0
- package/dist/client/shared/types.d.ts +134 -0
- package/dist/client/shared/utils.d.ts +101 -0
- package/dist/client/styles.css +1 -1
- package/dist/client/types.d.ts +1 -0
- package/dist/client/utils/index.d.ts +1 -0
- package/dist/client/utils/pivotUtils.d.ts +78 -0
- package/dist/client-bundle-stats.html +1 -1
- package/package.json +1 -1
- package/dist/client/chunks/chart-activitygridchart-config-48WqIofo.js.map +0 -1
- package/dist/client/chunks/chart-barchart-7bCO3dnb.js +0 -177
- package/dist/client/chunks/chart-barchart-7bCO3dnb.js.map +0 -1
- package/dist/client/chunks/chart-datatable-BTqU80Qo.js +0 -57
- package/dist/client/chunks/chart-datatable-BTqU80Qo.js.map +0 -1
- package/dist/client/chunks/icons-D6z-_9sa.js.map +0 -1
package/dist/client/charts.js
CHANGED
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { L as t, r as e, f as s,
|
|
2
|
-
import { a as
|
|
3
|
-
import { default as L } from "./chunks/chart-barchart-
|
|
1
|
+
import { L as t, r as e, f as s, b as o, k as C, l as h, m as f, i as l, q as p, p as d, n as i, o as R, a as c, u as m } from "./chunks/charts-MJLpxe3r.js";
|
|
2
|
+
import { a as g, C as x, N as u, P as A } from "./chunks/chart-activitygridchart-Cz4bEf3V.js";
|
|
3
|
+
import { default as L } from "./chunks/chart-barchart-Bdjz8DJp.js";
|
|
4
4
|
import { default as y } from "./chunks/chart-linechart-BfnU6L-D.js";
|
|
5
5
|
import { A as I } from "./chunks/chart-areachart-DLdolSnU.js";
|
|
6
|
-
import { default as
|
|
7
|
-
import { default as
|
|
8
|
-
import { default as
|
|
6
|
+
import { default as b } from "./chunks/chart-piechart-CZRDQxeB.js";
|
|
7
|
+
import { default as N } from "./chunks/chart-scatterchart-C83KgqYY.js";
|
|
8
|
+
import { default as V } from "./chunks/chart-radarchart-D5yRnY9j.js";
|
|
9
9
|
import { default as D } from "./chunks/chart-radialbarchart-Djtcn7aH.js";
|
|
10
10
|
import { default as H } from "./chunks/chart-treemapchart-BDKnKGTz.js";
|
|
11
|
-
import { default as k } from "./chunks/chart-datatable-
|
|
11
|
+
import { default as k } from "./chunks/chart-datatable-Mo4gYCwa.js";
|
|
12
12
|
export {
|
|
13
|
-
|
|
13
|
+
g as CHART_COLORS,
|
|
14
14
|
x as CHART_MARGINS,
|
|
15
15
|
k as DataTable,
|
|
16
16
|
t as LazyChart,
|
|
@@ -19,10 +19,10 @@ export {
|
|
|
19
19
|
I as RechartsAreaChart,
|
|
20
20
|
L as RechartsBarChart,
|
|
21
21
|
y as RechartsLineChart,
|
|
22
|
-
|
|
23
|
-
|
|
22
|
+
b as RechartsPieChart,
|
|
23
|
+
V as RechartsRadarChart,
|
|
24
24
|
D as RechartsRadialBarChart,
|
|
25
|
-
|
|
25
|
+
N as RechartsScatterChart,
|
|
26
26
|
H as RechartsTreeMapChart,
|
|
27
27
|
e as clearChartConfigCache,
|
|
28
28
|
s as formatChartData,
|
|
@@ -1,125 +1,131 @@
|
|
|
1
1
|
import { jsx as s } from "react/jsx-runtime";
|
|
2
|
-
import { d as
|
|
2
|
+
import { d as r, a as h, b as d, c as y, e as p, f as $, g as f, h as g, i as u, j as v, k as b, l as T, m as D, n as k, o as w, p as A, q as x, r as C, s as M, t as I, u as B, v as N, w as O, x as R, y as S, z as F, A as G, B as K, C as _, D as j, E as q, F as L, G as z, H as P, I as U, J as V, K as H, L as W, M as E, N as Z, O as J, P as Q, Q as X, R as Y, S as aa, T as ta, U as ea, V as oa, W as ia, X as ca, Y as ra, Z as na, _ as sa, $ as da, a0 as ya, a1 as ga, a2 as ua, a3 as ma, a4 as la, a5 as ha, a6 as pa, a7 as $a, a8 as fa, a9 as va, aa as ba, ab as Ta, ac as m } from "./icons-B2XSxpVK.js";
|
|
3
3
|
const l = {
|
|
4
4
|
// Action icons
|
|
5
|
-
close: { icon:
|
|
6
|
-
add: { icon:
|
|
7
|
-
edit: { icon:
|
|
8
|
-
delete: { icon:
|
|
9
|
-
refresh: { icon:
|
|
10
|
-
copy: { icon:
|
|
11
|
-
duplicate: { icon:
|
|
12
|
-
settings: { icon:
|
|
13
|
-
filter: { icon:
|
|
14
|
-
share: { icon:
|
|
15
|
-
expand: { icon:
|
|
16
|
-
collapse: { icon:
|
|
17
|
-
search: { icon:
|
|
18
|
-
menu: { icon:
|
|
19
|
-
run: { icon:
|
|
20
|
-
check: { icon:
|
|
21
|
-
link: { icon:
|
|
22
|
-
eye: { icon:
|
|
23
|
-
eyeOff: { icon:
|
|
24
|
-
adjustments: { icon:
|
|
25
|
-
desktop: { icon:
|
|
26
|
-
table: { icon:
|
|
5
|
+
close: { icon: Ta, category: "action" },
|
|
6
|
+
add: { icon: ba, category: "action" },
|
|
7
|
+
edit: { icon: va, category: "action" },
|
|
8
|
+
delete: { icon: fa, category: "action" },
|
|
9
|
+
refresh: { icon: r, category: "action" },
|
|
10
|
+
copy: { icon: $a, category: "action" },
|
|
11
|
+
duplicate: { icon: pa, category: "action" },
|
|
12
|
+
settings: { icon: ha, category: "action" },
|
|
13
|
+
filter: { icon: la, category: "action" },
|
|
14
|
+
share: { icon: ma, category: "action" },
|
|
15
|
+
expand: { icon: g, category: "action" },
|
|
16
|
+
collapse: { icon: u, category: "action" },
|
|
17
|
+
search: { icon: ua, category: "action" },
|
|
18
|
+
menu: { icon: ga, category: "action" },
|
|
19
|
+
run: { icon: ya, category: "action" },
|
|
20
|
+
check: { icon: da, category: "action" },
|
|
21
|
+
link: { icon: sa, category: "action" },
|
|
22
|
+
eye: { icon: na, category: "action" },
|
|
23
|
+
eyeOff: { icon: ra, category: "action" },
|
|
24
|
+
adjustments: { icon: ca, category: "action" },
|
|
25
|
+
desktop: { icon: ia, category: "action" },
|
|
26
|
+
table: { icon: oa, category: "action" },
|
|
27
|
+
sun: { icon: ea, category: "action" },
|
|
28
|
+
moon: { icon: ta, category: "action" },
|
|
29
|
+
ellipsisHorizontal: { icon: aa, category: "action" },
|
|
30
|
+
documentText: { icon: Y, category: "action" },
|
|
31
|
+
bookOpen: { icon: X, category: "action" },
|
|
32
|
+
codeBracket: { icon: Q, category: "action" },
|
|
27
33
|
// Field type icons (solid for visual distinction)
|
|
28
|
-
measure: { icon:
|
|
29
|
-
dimension: { icon:
|
|
34
|
+
measure: { icon: J, category: "field" },
|
|
35
|
+
dimension: { icon: Z, category: "field" },
|
|
30
36
|
timeDimension: { icon: E, category: "field" },
|
|
31
37
|
segment: { icon: W, category: "field" },
|
|
32
38
|
// Chart type icons (Tabler - keeping existing visuals)
|
|
33
39
|
chartBar: { icon: H, category: "chart" },
|
|
34
|
-
chartLine: { icon:
|
|
35
|
-
chartArea: { icon:
|
|
36
|
-
chartPie: { icon:
|
|
37
|
-
chartScatter: { icon:
|
|
40
|
+
chartLine: { icon: V, category: "chart" },
|
|
41
|
+
chartArea: { icon: U, category: "chart" },
|
|
42
|
+
chartPie: { icon: P, category: "chart" },
|
|
43
|
+
chartScatter: { icon: z, category: "chart" },
|
|
38
44
|
chartBubble: { icon: L, category: "chart" },
|
|
39
45
|
chartRadar: { icon: q, category: "chart" },
|
|
40
|
-
chartRadialBar: { icon:
|
|
41
|
-
chartTreemap: { icon:
|
|
46
|
+
chartRadialBar: { icon: j, category: "chart" },
|
|
47
|
+
chartTreemap: { icon: _, category: "chart" },
|
|
42
48
|
chartTable: { icon: K, category: "chart" },
|
|
43
49
|
chartActivityGrid: { icon: G, category: "chart" },
|
|
44
50
|
chartKpiNumber: { icon: F, category: "chart" },
|
|
45
51
|
chartKpiDelta: { icon: S, category: "chart" },
|
|
46
|
-
chartKpiText: { icon:
|
|
47
|
-
chartMarkdown: { icon:
|
|
52
|
+
chartKpiText: { icon: R, category: "chart" },
|
|
53
|
+
chartMarkdown: { icon: O, category: "chart" },
|
|
48
54
|
// Measure type icons (solid)
|
|
49
55
|
measureCount: { icon: N, category: "measure" },
|
|
50
56
|
measureCountDistinct: { icon: B, category: "measure" },
|
|
51
57
|
measureCountDistinctApprox: { icon: I, category: "measure" },
|
|
52
58
|
measureSum: { icon: M, category: "measure" },
|
|
53
|
-
measureAvg: { icon:
|
|
59
|
+
measureAvg: { icon: C, category: "measure" },
|
|
54
60
|
measureMin: { icon: d, category: "measure" },
|
|
55
61
|
measureMax: { icon: y, category: "measure" },
|
|
56
|
-
measureRunningTotal: { icon:
|
|
62
|
+
measureRunningTotal: { icon: x, category: "measure" },
|
|
57
63
|
measureCalculated: { icon: A, category: "measure" },
|
|
58
64
|
measureNumber: { icon: w, category: "measure" },
|
|
59
65
|
// State icons
|
|
60
66
|
success: { icon: k, category: "state" },
|
|
61
|
-
warning: { icon:
|
|
62
|
-
error: { icon:
|
|
67
|
+
warning: { icon: D, category: "state" },
|
|
68
|
+
error: { icon: T, category: "state" },
|
|
63
69
|
info: { icon: b, category: "state" },
|
|
64
|
-
loading: { icon:
|
|
70
|
+
loading: { icon: r, category: "state" },
|
|
65
71
|
sparkles: { icon: v, category: "state" },
|
|
66
72
|
// Navigation icons
|
|
67
|
-
chevronUp: { icon:
|
|
68
|
-
chevronDown: { icon:
|
|
69
|
-
chevronLeft: { icon:
|
|
70
|
-
chevronRight: { icon:
|
|
73
|
+
chevronUp: { icon: u, category: "navigation" },
|
|
74
|
+
chevronDown: { icon: g, category: "navigation" },
|
|
75
|
+
chevronLeft: { icon: f, category: "navigation" },
|
|
76
|
+
chevronRight: { icon: $, category: "navigation" },
|
|
71
77
|
chevronUpDown: { icon: p, category: "navigation" },
|
|
72
78
|
arrowUp: { icon: y, category: "navigation" },
|
|
73
79
|
arrowDown: { icon: d, category: "navigation" },
|
|
74
80
|
arrowRight: { icon: h, category: "navigation" },
|
|
75
|
-
arrowPath: { icon:
|
|
81
|
+
arrowPath: { icon: r, category: "navigation" }
|
|
76
82
|
};
|
|
77
|
-
let
|
|
78
|
-
function
|
|
79
|
-
return
|
|
83
|
+
let o = { ...l };
|
|
84
|
+
function xa() {
|
|
85
|
+
return o;
|
|
80
86
|
}
|
|
81
|
-
function
|
|
82
|
-
const e =
|
|
83
|
-
return e ? ({ className: a, ...
|
|
87
|
+
function c(t) {
|
|
88
|
+
const e = o[t];
|
|
89
|
+
return e ? ({ className: a, ...i }) => /* @__PURE__ */ s(m, { icon: e.icon, className: a, ...i }) : (console.warn(`Icon "${t}" not found in registry, using fallback`), ({ className: a, ...i }) => /* @__PURE__ */ s(m, { icon: o.info.icon, className: a, ...i }));
|
|
84
90
|
}
|
|
85
|
-
function
|
|
86
|
-
return
|
|
91
|
+
function Ca(t) {
|
|
92
|
+
return o[t]?.icon ?? o.info.icon;
|
|
87
93
|
}
|
|
88
|
-
function
|
|
89
|
-
|
|
90
|
-
...
|
|
94
|
+
function Ma(t, e) {
|
|
95
|
+
o[t] && (o[t] = {
|
|
96
|
+
...o[t],
|
|
91
97
|
icon: e
|
|
92
98
|
});
|
|
93
99
|
}
|
|
94
|
-
function
|
|
100
|
+
function Ia(t) {
|
|
95
101
|
for (const [e, a] of Object.entries(t))
|
|
96
|
-
if (a && e in
|
|
97
|
-
const
|
|
102
|
+
if (a && e in o) {
|
|
103
|
+
const i = e;
|
|
98
104
|
if ("body" in a)
|
|
99
|
-
i
|
|
100
|
-
...i
|
|
105
|
+
o[i] = {
|
|
106
|
+
...o[i],
|
|
101
107
|
icon: a
|
|
102
108
|
};
|
|
103
109
|
else {
|
|
104
110
|
const n = a;
|
|
105
|
-
i
|
|
106
|
-
...i
|
|
111
|
+
o[i] = {
|
|
112
|
+
...o[i],
|
|
107
113
|
...n,
|
|
108
|
-
icon: n.icon ?? i
|
|
114
|
+
icon: n.icon ?? o[i].icon
|
|
109
115
|
};
|
|
110
116
|
}
|
|
111
117
|
}
|
|
112
118
|
}
|
|
113
|
-
function
|
|
114
|
-
|
|
119
|
+
function Ba() {
|
|
120
|
+
o = { ...l };
|
|
115
121
|
}
|
|
116
|
-
function
|
|
122
|
+
function Na(t) {
|
|
117
123
|
const e = {};
|
|
118
|
-
for (const [a,
|
|
119
|
-
|
|
124
|
+
for (const [a, i] of Object.entries(o))
|
|
125
|
+
i.category === t && (e[a] = c(a));
|
|
120
126
|
return e;
|
|
121
127
|
}
|
|
122
|
-
function
|
|
128
|
+
function Oa(t) {
|
|
123
129
|
const a = {
|
|
124
130
|
count: "measureCount",
|
|
125
131
|
countDistinct: "measureCountDistinct",
|
|
@@ -132,9 +138,9 @@ function Ca(t) {
|
|
|
132
138
|
calculated: "measureCalculated",
|
|
133
139
|
number: "measureNumber"
|
|
134
140
|
}[t || ""] || "measureCount";
|
|
135
|
-
return
|
|
141
|
+
return c(a);
|
|
136
142
|
}
|
|
137
|
-
function
|
|
143
|
+
function Da(t) {
|
|
138
144
|
const a = {
|
|
139
145
|
bar: "chartBar",
|
|
140
146
|
line: "chartLine",
|
|
@@ -152,9 +158,9 @@ function pa(t) {
|
|
|
152
158
|
kpiText: "chartKpiText",
|
|
153
159
|
markdown: "chartMarkdown"
|
|
154
160
|
}[t] || "chartBar";
|
|
155
|
-
return
|
|
161
|
+
return c(a);
|
|
156
162
|
}
|
|
157
|
-
function
|
|
163
|
+
function Ra(t) {
|
|
158
164
|
const a = {
|
|
159
165
|
measure: "measure",
|
|
160
166
|
dimension: "dimension",
|
|
@@ -162,10 +168,10 @@ function xa(t) {
|
|
|
162
168
|
time: "timeDimension",
|
|
163
169
|
segment: "segment"
|
|
164
170
|
}[t] || "dimension";
|
|
165
|
-
return
|
|
171
|
+
return c(a);
|
|
166
172
|
}
|
|
167
|
-
const
|
|
168
|
-
icon:
|
|
173
|
+
const ka = {
|
|
174
|
+
icon: Da("activityGrid"),
|
|
169
175
|
description: "GitHub-style activity grid showing temporal patterns across different time scales",
|
|
170
176
|
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",
|
|
171
177
|
dropZones: [
|
|
@@ -208,23 +214,23 @@ const fa = {
|
|
|
208
214
|
message: "Activity measure is required for intensity mapping"
|
|
209
215
|
} : { isValid: !0 };
|
|
210
216
|
}
|
|
211
|
-
},
|
|
217
|
+
}, Sa = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
212
218
|
__proto__: null,
|
|
213
|
-
activityGridChartConfig:
|
|
219
|
+
activityGridChartConfig: ka
|
|
214
220
|
}, Symbol.toStringTag, { value: "Module" }));
|
|
215
221
|
export {
|
|
216
|
-
|
|
222
|
+
Sa as A,
|
|
217
223
|
l as D,
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
224
|
+
Oa as a,
|
|
225
|
+
c as b,
|
|
226
|
+
Ra as c,
|
|
227
|
+
Ca as d,
|
|
228
|
+
Ba as e,
|
|
229
|
+
xa as f,
|
|
230
|
+
Da as g,
|
|
231
|
+
Na as h,
|
|
232
|
+
ka as i,
|
|
233
|
+
Ia as r,
|
|
234
|
+
Ma as s
|
|
229
235
|
};
|
|
230
|
-
//# sourceMappingURL=chart-activitygridchart-config-
|
|
236
|
+
//# sourceMappingURL=chart-activitygridchart-config-BngZDVh_.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chart-activitygridchart-config-BngZDVh_.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/**\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\n */\nexport function getIcon(name: IconName): ComponentType<IconProps> {\n const iconDef = _registry[name]\n if (!iconDef) {\n console.warn(`Icon \"${name}\" not found in registry, using fallback`)\n return ({ className, ...props }: IconProps) => (\n <Icon icon={_registry.info.icon} className={className} {...props} />\n )\n }\n\n return ({ className, ...props }: IconProps) => (\n <Icon icon={iconDef.icon} className={className} {...props} />\n )\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 }\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 }\n }\n}\n\n/**\n * Reset the registry to default icons\n */\nexport function resetIcons(): void {\n _registry = { ...DEFAULT_ICONS }\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","getIconRegistry","getIcon","name","iconDef","className","props","jsx","Icon","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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"}
|
package/dist/client/chunks/{chart-areachart-config-D8taXdn1.js → chart-areachart-config-DWN1E5ej.js}
RENAMED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { g as e } from "./chart-activitygridchart-config-
|
|
1
|
+
import { g as e } from "./chart-activitygridchart-config-BngZDVh_.js";
|
|
2
2
|
const s = {
|
|
3
3
|
icon: e("area"),
|
|
4
4
|
description: "Emphasize magnitude of change over time",
|
|
@@ -62,4 +62,4 @@ const s = {
|
|
|
62
62
|
export {
|
|
63
63
|
s as areaChartConfig
|
|
64
64
|
};
|
|
65
|
-
//# sourceMappingURL=chart-areachart-config-
|
|
65
|
+
//# sourceMappingURL=chart-areachart-config-DWN1E5ej.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chart-areachart-config-
|
|
1
|
+
{"version":3,"file":"chart-areachart-config-DWN1E5ej.js","sources":["../../../src/client/components/charts/AreaChart.config.tsx"],"sourcesContent":["import type { ChartTypeConfig } from '../../charts/chartConfigs'\nimport { getChartTypeIcon } from '../../icons'\n\n/**\n * Configuration for the area chart type\n */\nexport const areaChartConfig: ChartTypeConfig = {\n icon: getChartTypeIcon('area'),\n description: 'Emphasize magnitude of change over time',\n useCase: 'Best for showing cumulative totals, volume changes, or stacked comparisons over time',\n dropZones: [\n {\n key: 'xAxis',\n label: 'X-Axis (Time/Categories)',\n description: 'Time dimensions or dimensions for X-axis',\n mandatory: true,\n acceptTypes: ['dimension', 'timeDimension'],\n emptyText: 'Drop time dimensions or dimensions here'\n },\n {\n key: 'yAxis',\n label: 'Y-Axis (Values)',\n description: 'Measures for area values',\n mandatory: true,\n acceptTypes: ['measure'],\n emptyText: 'Drop measures here'\n },\n {\n key: 'series',\n label: 'Series (Stack Areas)',\n description: 'Dimensions to create stacked areas',\n mandatory: false,\n acceptTypes: ['dimension'],\n emptyText: 'Drop dimensions here for stacked areas'\n }\n ],\n displayOptions: ['showLegend', 'showGrid', 'showTooltip', 'hideHeader'],\n displayOptionsConfig: [\n {\n key: 'stackType',\n label: 'Stacking',\n type: 'select',\n defaultValue: 'none',\n options: [\n { value: 'none', label: 'None' },\n { value: 'normal', label: 'Stacked' },\n { value: 'percent', label: 'Stacked 100%' }\n ],\n description: 'How to stack multiple area series'\n },\n {\n key: 'connectNulls',\n label: 'Connect Nulls',\n type: 'boolean',\n defaultValue: false,\n description: 'Draw continuous line through missing data points'\n },\n {\n key: 'target',\n label: 'Target Values',\n type: 'string',\n placeholder: 'e.g., 100 or 50,75 for spread',\n description: 'Single value or comma-separated values to spread across X-axis'\n }\n ]\n}"],"names":["areaChartConfig","getChartTypeIcon"],"mappings":";AAMO,MAAMA,IAAmC;AAAA,EAC9C,MAAMC,EAAiB,MAAM;AAAA,EAC7B,aAAa;AAAA,EACb,SAAS;AAAA,EACT,WAAW;AAAA,IACT;AAAA,MACE,KAAK;AAAA,MACL,OAAO;AAAA,MACP,aAAa;AAAA,MACb,WAAW;AAAA,MACX,aAAa,CAAC,aAAa,eAAe;AAAA,MAC1C,WAAW;AAAA,IAAA;AAAA,IAEb;AAAA,MACE,KAAK;AAAA,MACL,OAAO;AAAA,MACP,aAAa;AAAA,MACb,WAAW;AAAA,MACX,aAAa,CAAC,SAAS;AAAA,MACvB,WAAW;AAAA,IAAA;AAAA,IAEb;AAAA,MACE,KAAK;AAAA,MACL,OAAO;AAAA,MACP,aAAa;AAAA,MACb,WAAW;AAAA,MACX,aAAa,CAAC,WAAW;AAAA,MACzB,WAAW;AAAA,IAAA;AAAA,EACb;AAAA,EAEF,gBAAgB,CAAC,cAAc,YAAY,eAAe,YAAY;AAAA,EACtE,sBAAsB;AAAA,IACpB;AAAA,MACE,KAAK;AAAA,MACL,OAAO;AAAA,MACP,MAAM;AAAA,MACN,cAAc;AAAA,MACd,SAAS;AAAA,QACP,EAAE,OAAO,QAAQ,OAAO,OAAA;AAAA,QACxB,EAAE,OAAO,UAAU,OAAO,UAAA;AAAA,QAC1B,EAAE,OAAO,WAAW,OAAO,eAAA;AAAA,MAAe;AAAA,MAE5C,aAAa;AAAA,IAAA;AAAA,IAEf;AAAA,MACE,KAAK;AAAA,MACL,OAAO;AAAA,MACP,MAAM;AAAA,MACN,cAAc;AAAA,MACd,aAAa;AAAA,IAAA;AAAA,IAEf;AAAA,MACE,KAAK;AAAA,MACL,OAAO;AAAA,MACP,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aAAa;AAAA,IAAA;AAAA,EACf;AAEJ;"}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import { jsx as e, jsxs as a, Fragment as H } from "react/jsx-runtime";
|
|
2
|
+
import { useState as K, useMemo as _ } from "react";
|
|
3
|
+
import { ComposedChart as W, CartesianGrid as $, XAxis as P, YAxis as X, Legend as Y, Bar as U, Cell as q, Line as O } from "recharts";
|
|
4
|
+
import { C as J } from "./chart-chartcontainer-CdwzIKP1.js";
|
|
5
|
+
import { C as Q } from "./chart-charttooltip-k8soCd2n.js";
|
|
6
|
+
import { u as Z, t as ee, i as te, C as re, f as V, N as se, P as E, a as G } from "./chart-activitygridchart-Cz4bEf3V.js";
|
|
7
|
+
import { p as ae, s as ie } from "./chart-areachart-DLdolSnU.js";
|
|
8
|
+
function ue({
|
|
9
|
+
data: d,
|
|
10
|
+
chartConfig: r,
|
|
11
|
+
displayConfig: c = {},
|
|
12
|
+
queryObject: T,
|
|
13
|
+
height: u = "100%",
|
|
14
|
+
colorPalette: g
|
|
15
|
+
}) {
|
|
16
|
+
const [h, L] = K(null), { labelMap: S, getFieldLabel: M } = Z(), C = c?.stackType ?? (c?.stacked ? "normal" : "none"), z = C !== "none", f = C === "percent", N = {
|
|
17
|
+
showLegend: c?.showLegend ?? !0,
|
|
18
|
+
showGrid: c?.showGrid ?? !0,
|
|
19
|
+
showTooltip: c?.showTooltip ?? !0
|
|
20
|
+
};
|
|
21
|
+
let m, i = [], A = [], n = null;
|
|
22
|
+
r?.xAxis && r?.yAxis ? (m = Array.isArray(r.xAxis) ? r.xAxis[0] : r.xAxis, i = Array.isArray(r.yAxis) ? r.yAxis : [r.yAxis], A = r.series || []) : r?.x && r?.y ? (m = r.x, i = Array.isArray(r.y) ? r.y : [r.y]) : n = "Invalid or missing chart axis configuration", !n && (!m || !i || i.length === 0) && (n = "Missing required X-axis or Y-axis fields");
|
|
23
|
+
const { data: p, seriesKeys: x } = _(() => n || !d || d.length === 0 || !m ? { data: [], seriesKeys: [] } : ee(
|
|
24
|
+
d,
|
|
25
|
+
m,
|
|
26
|
+
i,
|
|
27
|
+
T,
|
|
28
|
+
A,
|
|
29
|
+
S
|
|
30
|
+
), [d, m, i, T, A, S, n]), { chartData: l, skippedCount: y } = _(() => {
|
|
31
|
+
if (p.length === 0 || x.length === 0)
|
|
32
|
+
return { chartData: [], skippedCount: 0 };
|
|
33
|
+
const o = p.filter((k) => x.some((b) => te(k[b]))), v = p.length - o.length;
|
|
34
|
+
return { chartData: o, skippedCount: v };
|
|
35
|
+
}, [p, x]);
|
|
36
|
+
try {
|
|
37
|
+
if (!d || d.length === 0)
|
|
38
|
+
return /* @__PURE__ */ e("div", { className: "flex items-center justify-center w-full text-dc-text-muted", style: { height: u }, children: /* @__PURE__ */ a("div", { className: "text-center", children: [
|
|
39
|
+
/* @__PURE__ */ e("div", { className: "text-sm font-semibold mb-1", children: "No data available" }),
|
|
40
|
+
/* @__PURE__ */ e("div", { className: "text-xs text-dc-text-secondary", children: "No data points to display in bar chart" })
|
|
41
|
+
] }) });
|
|
42
|
+
if (n)
|
|
43
|
+
return /* @__PURE__ */ e("div", { className: "flex items-center justify-center w-full text-yellow-600", style: { height: u }, children: /* @__PURE__ */ a("div", { className: "text-center", children: [
|
|
44
|
+
/* @__PURE__ */ e("div", { className: "text-sm font-semibold mb-1", children: "Configuration Error" }),
|
|
45
|
+
/* @__PURE__ */ e("div", { className: "text-xs", children: n })
|
|
46
|
+
] }) });
|
|
47
|
+
const o = f ? "expand" : void 0, v = x.length === 1 && l.some((t) => {
|
|
48
|
+
const s = t[x[0]];
|
|
49
|
+
return typeof s == "number" && s < 0;
|
|
50
|
+
}), k = N.showLegend, b = {
|
|
51
|
+
...re,
|
|
52
|
+
left: 40
|
|
53
|
+
// Increased from 20 to 40 for Y-axis label space
|
|
54
|
+
}, I = ae(c?.target || ""), w = ie(I, l.length);
|
|
55
|
+
let D = l;
|
|
56
|
+
return w.length > 0 && (D = l.map((t, s) => ({
|
|
57
|
+
...t,
|
|
58
|
+
__target: w[s] || null
|
|
59
|
+
}))), !l || l.length === 0 ? /* @__PURE__ */ e("div", { className: "flex items-center justify-center w-full text-dc-text-muted", style: { height: u }, children: /* @__PURE__ */ a("div", { className: "text-center", children: [
|
|
60
|
+
/* @__PURE__ */ e("div", { className: "text-sm font-semibold mb-1", children: "No valid data" }),
|
|
61
|
+
/* @__PURE__ */ e("div", { className: "text-xs text-dc-text-secondary", children: "No valid data points for bar chart after transformation" })
|
|
62
|
+
] }) }) : /* @__PURE__ */ a("div", { className: "relative w-full", style: { height: u }, children: [
|
|
63
|
+
/* @__PURE__ */ e(J, { height: y > 0 ? "calc(100% - 20px)" : "100%", children: /* @__PURE__ */ a(W, { data: D, margin: b, stackOffset: o, children: [
|
|
64
|
+
N.showGrid && /* @__PURE__ */ e($, { strokeDasharray: "3 3" }),
|
|
65
|
+
/* @__PURE__ */ e(
|
|
66
|
+
P,
|
|
67
|
+
{
|
|
68
|
+
dataKey: "name",
|
|
69
|
+
tick: { fontSize: 12 },
|
|
70
|
+
angle: -45,
|
|
71
|
+
textAnchor: "end",
|
|
72
|
+
height: 60
|
|
73
|
+
}
|
|
74
|
+
),
|
|
75
|
+
/* @__PURE__ */ e(
|
|
76
|
+
X,
|
|
77
|
+
{
|
|
78
|
+
tick: { fontSize: 12 },
|
|
79
|
+
tickFormatter: f ? (t) => `${(t * 100).toFixed(0)}%` : void 0,
|
|
80
|
+
domain: f ? [0, 1] : void 0,
|
|
81
|
+
label: f ? void 0 : { value: M(i[0]), angle: -90, position: "left", style: { textAnchor: "middle", fontSize: "12px" } }
|
|
82
|
+
}
|
|
83
|
+
),
|
|
84
|
+
N.showTooltip && /* @__PURE__ */ e(
|
|
85
|
+
Q,
|
|
86
|
+
{
|
|
87
|
+
formatter: (t, s) => t == null ? ["No data", s] : s === "Target" ? [V(t), "Target Value"] : f && typeof t == "number" ? [`${(t * 100).toFixed(1)}%`, s] : [V(t), s]
|
|
88
|
+
}
|
|
89
|
+
),
|
|
90
|
+
k && /* @__PURE__ */ e(
|
|
91
|
+
Y,
|
|
92
|
+
{
|
|
93
|
+
wrapperStyle: { fontSize: "12px", paddingTop: "25px" },
|
|
94
|
+
iconType: "rect",
|
|
95
|
+
iconSize: 8,
|
|
96
|
+
layout: "horizontal",
|
|
97
|
+
align: "center",
|
|
98
|
+
verticalAlign: "bottom",
|
|
99
|
+
onMouseEnter: (t) => L(String(t.dataKey || "")),
|
|
100
|
+
onMouseLeave: () => L(null)
|
|
101
|
+
}
|
|
102
|
+
),
|
|
103
|
+
x.map((t, s) => /* @__PURE__ */ e(
|
|
104
|
+
U,
|
|
105
|
+
{
|
|
106
|
+
dataKey: t,
|
|
107
|
+
stackId: z ? "stack" : void 0,
|
|
108
|
+
fill: v ? E : g?.colors && g.colors[s % g.colors.length] || G[s % G.length],
|
|
109
|
+
fillOpacity: h ? h === t ? 1 : 0.3 : 1,
|
|
110
|
+
children: v && l.map((R, j) => {
|
|
111
|
+
const F = R[t], B = typeof F == "number" && F < 0 ? se : E;
|
|
112
|
+
return /* @__PURE__ */ e(
|
|
113
|
+
q,
|
|
114
|
+
{
|
|
115
|
+
fill: B,
|
|
116
|
+
fillOpacity: h ? h === t ? 1 : 0.3 : 1
|
|
117
|
+
},
|
|
118
|
+
`cell-${j}`
|
|
119
|
+
);
|
|
120
|
+
})
|
|
121
|
+
},
|
|
122
|
+
t
|
|
123
|
+
)),
|
|
124
|
+
w.length > 0 && /* @__PURE__ */ a(H, { children: [
|
|
125
|
+
/* @__PURE__ */ e(
|
|
126
|
+
O,
|
|
127
|
+
{
|
|
128
|
+
type: "monotone",
|
|
129
|
+
dataKey: "__target",
|
|
130
|
+
stroke: "#ffffff",
|
|
131
|
+
strokeWidth: 2,
|
|
132
|
+
dot: !1,
|
|
133
|
+
activeDot: !1,
|
|
134
|
+
connectNulls: !1
|
|
135
|
+
}
|
|
136
|
+
),
|
|
137
|
+
/* @__PURE__ */ e(
|
|
138
|
+
O,
|
|
139
|
+
{
|
|
140
|
+
type: "monotone",
|
|
141
|
+
dataKey: "__target",
|
|
142
|
+
name: "Target",
|
|
143
|
+
stroke: "#8B5CF6",
|
|
144
|
+
strokeWidth: 2,
|
|
145
|
+
strokeDasharray: "2 3",
|
|
146
|
+
dot: !1,
|
|
147
|
+
activeDot: !1,
|
|
148
|
+
connectNulls: !1
|
|
149
|
+
}
|
|
150
|
+
)
|
|
151
|
+
] })
|
|
152
|
+
] }) }),
|
|
153
|
+
y > 0 && /* @__PURE__ */ a("div", { className: "text-xs text-dc-text-muted text-center mt-1", children: [
|
|
154
|
+
y,
|
|
155
|
+
" data point",
|
|
156
|
+
y !== 1 ? "s" : "",
|
|
157
|
+
" with no values hidden"
|
|
158
|
+
] })
|
|
159
|
+
] });
|
|
160
|
+
} catch (o) {
|
|
161
|
+
return /* @__PURE__ */ e("div", { className: "flex flex-col items-center justify-center w-full text-red-500 p-4", style: { height: u }, children: /* @__PURE__ */ a("div", { className: "text-center", children: [
|
|
162
|
+
/* @__PURE__ */ e("div", { className: "text-sm font-semibold mb-1", children: "Bar Chart Error" }),
|
|
163
|
+
/* @__PURE__ */ e("div", { className: "text-xs mb-2", children: o instanceof Error ? o.message : "Unknown rendering error" }),
|
|
164
|
+
/* @__PURE__ */ e("div", { className: "text-xs text-dc-text-muted", children: "Check the data and configuration" })
|
|
165
|
+
] }) });
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
export {
|
|
169
|
+
ue as default
|
|
170
|
+
};
|
|
171
|
+
//# sourceMappingURL=chart-barchart-Bdjz8DJp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chart-barchart-Bdjz8DJp.js","sources":["../../../src/client/components/charts/BarChart.tsx"],"sourcesContent":["import { useState, useMemo } from 'react'\nimport { ComposedChart, Bar, Line, XAxis, YAxis, CartesianGrid, Cell, Legend } from 'recharts'\nimport ChartContainer from './ChartContainer'\nimport ChartTooltip from './ChartTooltip'\nimport { CHART_COLORS, POSITIVE_COLOR, NEGATIVE_COLOR, CHART_MARGINS } from '../../utils/chartConstants'\nimport { transformChartDataWithSeries, isValidNumericValue, formatNumericValue } from '../../utils/chartUtils'\nimport { parseTargetValues, spreadTargetValues } from '../../utils/targetUtils'\nimport { useCubeContext } from '../../providers/CubeProvider'\nimport type { ChartProps } from '../../types'\n\nexport default function BarChart({\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: contextGetFieldLabel } = useCubeContext()\n\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 }\n\n // Validate chartConfig - support both legacy and new formats\n // Do validation but don't early return yet (hooks must come first)\n let xAxisField: string | undefined\n let yAxisFields: string[] = []\n let seriesFields: string[] = []\n let configError: string | null = null\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 configError = 'Invalid or missing chart axis configuration'\n }\n\n if (!configError && (!xAxisField || !yAxisFields || yAxisFields.length === 0)) {\n configError = 'Missing required X-axis or Y-axis fields'\n }\n\n // Transform data (will be empty arrays if config is invalid)\n const { data: transformedData, seriesKeys } = useMemo(() => {\n if (configError || !data || data.length === 0 || !xAxisField) {\n return { data: [], seriesKeys: [] }\n }\n return transformChartDataWithSeries(\n data,\n xAxisField,\n yAxisFields,\n queryObject,\n seriesFields,\n labelMap\n )\n }, [data, xAxisField, yAxisFields, queryObject, seriesFields, labelMap, configError])\n\n // Null handling: Filter out data points where ALL measure values are null\n // This prevents rendering empty bars and makes the chart clearer\n const { chartData, skippedCount } = useMemo(() => {\n if (transformedData.length === 0 || seriesKeys.length === 0) {\n return { chartData: [], skippedCount: 0 }\n }\n const filtered = transformedData.filter(row => {\n // Keep the row if at least one series has a valid numeric value\n return seriesKeys.some(key => isValidNumericValue(row[key]))\n })\n const skipped = transformedData.length - filtered.length\n return { chartData: filtered, skippedCount: skipped }\n }, [transformedData, seriesKeys])\n\n // Now handle early returns AFTER all hooks\n try {\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 bar chart</div>\n </div>\n </div>\n )\n }\n\n if (configError) {\n return (\n <div className=\"flex items-center justify-center w-full text-yellow-600\" style={{ height }}>\n <div className=\"text-center\">\n <div className=\"text-sm font-semibold mb-1\">Configuration Error</div>\n <div className=\"text-xs\">{configError}</div>\n </div>\n </div>\n )\n }\n\n // Determine stack offset for percentage stacking\n const stackOffset = isPercentStack ? 'expand' as const : undefined\n \n // Check if we should use positive/negative coloring\n // This is enabled when we have single series data with mixed positive/negative values\n const usePositiveNegativeColoring = seriesKeys.length === 1 && chartData.some(row => {\n const value = row[seriesKeys[0]]\n return typeof value === 'number' && value < 0\n })\n \n // Determine if legend will be shown\n const showLegend = safeDisplayConfig.showLegend\n \n // Use custom chart margins with extra left space for Y-axis label\n const chartMargins = {\n ...CHART_MARGINS,\n left: 40 // Increased from 20 to 40 for Y-axis label space\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 bar chart after transformation</div>\n </div>\n </div>\n )\n }\n\n return (\n <div className=\"relative w-full\" style={{ height }}>\n <ChartContainer height={skippedCount > 0 ? `calc(100% - 20px)` : \"100%\"}>\n <ComposedChart data={enhancedChartData} margin={chartMargins} stackOffset={stackOffset}>\n {safeDisplayConfig.showGrid && (\n <CartesianGrid strokeDasharray=\"3 3\" />\n )}\n <XAxis\n dataKey=\"name\"\n tick={{ fontSize: 12 }}\n angle={-45}\n textAnchor=\"end\"\n height={60}\n />\n <YAxis\n tick={{ fontSize: 12 }}\n tickFormatter={isPercentStack ? (v) => `${(v * 100).toFixed(0)}%` : undefined}\n domain={isPercentStack ? [0, 1] : undefined}\n label={isPercentStack ? undefined : { value: contextGetFieldLabel(yAxisFields[0]), angle: -90, position: 'left', style: { textAnchor: 'middle', fontSize: '12px' } }}\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 return [formatNumericValue(value), 'Target Value']\n }\n // Format as percentage when using percent stacking\n if (isPercentStack && typeof value === 'number') {\n return [`${(value * 100).toFixed(1)}%`, name]\n }\n return [formatNumericValue(value), name]\n }}\n />\n )}\n {showLegend && (\n <Legend \n wrapperStyle={{ fontSize: '12px', paddingTop: '25px' }}\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 <Bar\n key={seriesKey}\n dataKey={seriesKey}\n stackId={shouldStack ? \"stack\" : undefined}\n fill={usePositiveNegativeColoring ? POSITIVE_COLOR : ((colorPalette?.colors && colorPalette.colors[index % colorPalette.colors.length]) || CHART_COLORS[index % CHART_COLORS.length])}\n fillOpacity={hoveredLegend ? (hoveredLegend === seriesKey ? 1 : 0.3) : 1}\n >\n {usePositiveNegativeColoring && chartData.map((entry, entryIndex) => {\n const value = entry[seriesKey]\n const fillColor = typeof value === 'number' && value < 0 ? NEGATIVE_COLOR : POSITIVE_COLOR\n return (\n <Cell \n key={`cell-${entryIndex}`} \n fill={fillColor}\n fillOpacity={hoveredLegend ? (hoveredLegend === seriesKey ? 1 : 0.3) : 1}\n />\n )\n })}\n </Bar>\n ))}\n {spreadTargets.length > 0 && (\n <>\n {/* White background line */}\n <Line\n type=\"monotone\"\n dataKey=\"__target\"\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 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 {skippedCount > 0 && (\n <div className=\"text-xs text-dc-text-muted text-center mt-1\">\n {skippedCount} data point{skippedCount !== 1 ? 's' : ''} with no values hidden\n </div>\n )}\n </div>\n )\n } catch (error) {\n // 'BarChart rendering error\n return (\n <div className=\"flex flex-col items-center justify-center w-full text-red-500 p-4\" style={{ height }}>\n <div className=\"text-center\">\n <div className=\"text-sm font-semibold mb-1\">Bar 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":["BarChart","data","chartConfig","displayConfig","queryObject","height","colorPalette","hoveredLegend","setHoveredLegend","useState","labelMap","contextGetFieldLabel","useCubeContext","stackType","shouldStack","isPercentStack","safeDisplayConfig","xAxisField","yAxisFields","seriesFields","configError","transformedData","seriesKeys","useMemo","transformChartDataWithSeries","chartData","skippedCount","filtered","row","key","isValidNumericValue","skipped","jsx","jsxs","stackOffset","usePositiveNegativeColoring","value","showLegend","chartMargins","CHART_MARGINS","targetValues","parseTargetValues","spreadTargets","spreadTargetValues","enhancedChartData","dataPoint","index","ChartContainer","ComposedChart","CartesianGrid","XAxis","YAxis","v","ChartTooltip","name","formatNumericValue","Legend","o","seriesKey","Bar","POSITIVE_COLOR","CHART_COLORS","entry","entryIndex","fillColor","NEGATIVE_COLOR","Cell","Fragment","Line","error"],"mappings":"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"}
|