drizzle-cube 0.2.7 → 0.2.9

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.
Files changed (95) hide show
  1. package/dist/client/charts.js +11 -11
  2. package/dist/client/chunks/chart-activitygridchart-config-DVH-sdYZ.js +244 -0
  3. package/dist/client/chunks/chart-activitygridchart-config-DVH-sdYZ.js.map +1 -0
  4. package/dist/client/chunks/{chart-areachart-config-D8taXdn1.js → chart-areachart-config-C2iwLEgm.js} +2 -2
  5. package/dist/client/chunks/{chart-areachart-config-D8taXdn1.js.map → chart-areachart-config-C2iwLEgm.js.map} +1 -1
  6. package/dist/client/chunks/chart-barchart-Bdjz8DJp.js +171 -0
  7. package/dist/client/chunks/chart-barchart-Bdjz8DJp.js.map +1 -0
  8. package/dist/client/chunks/{chart-barchart-config-DjRZBtLb.js → chart-barchart-config-CAsUZfHw.js} +2 -2
  9. package/dist/client/chunks/{chart-barchart-config-DjRZBtLb.js.map → chart-barchart-config-CAsUZfHw.js.map} +1 -1
  10. package/dist/client/chunks/{chart-bubblechart-config-C6ck2qmg.js → chart-bubblechart-config-DRuY0m7S.js} +2 -2
  11. package/dist/client/chunks/{chart-bubblechart-config-C6ck2qmg.js.map → chart-bubblechart-config-DRuY0m7S.js.map} +1 -1
  12. package/dist/client/chunks/{chart-datatable-config-B5z0SlOJ.js → chart-datatable-config-C0MoGDgo.js} +2 -2
  13. package/dist/client/chunks/{chart-datatable-config-B5z0SlOJ.js.map → chart-datatable-config-C0MoGDgo.js.map} +1 -1
  14. package/dist/client/chunks/chart-datatable-zyVFtRJ_.js +249 -0
  15. package/dist/client/chunks/chart-datatable-zyVFtRJ_.js.map +1 -0
  16. package/dist/client/chunks/{chart-kpidelta-Cf1JmtGF.js → chart-kpidelta-CTcuIO9G.js} +2 -2
  17. package/dist/client/chunks/{chart-kpidelta-Cf1JmtGF.js.map → chart-kpidelta-CTcuIO9G.js.map} +1 -1
  18. package/dist/client/chunks/{chart-kpidelta-config-CnZfi_P2.js → chart-kpidelta-config-Bq2Ph_Sp.js} +2 -2
  19. package/dist/client/chunks/{chart-kpidelta-config-CnZfi_P2.js.map → chart-kpidelta-config-Bq2Ph_Sp.js.map} +1 -1
  20. package/dist/client/chunks/{chart-kpinumber-config-CVikHojM.js → chart-kpinumber-config-OMNhJXdH.js} +2 -2
  21. package/dist/client/chunks/{chart-kpinumber-config-CVikHojM.js.map → chart-kpinumber-config-OMNhJXdH.js.map} +1 -1
  22. package/dist/client/chunks/{chart-kpinumber-eEMpzorv.js → chart-kpinumber-slEXt8C-.js} +3 -3
  23. package/dist/client/chunks/{chart-kpinumber-eEMpzorv.js.map → chart-kpinumber-slEXt8C-.js.map} +1 -1
  24. package/dist/client/chunks/{chart-kpitext-config-B2MovXSw.js → chart-kpitext-config-BLiwQIVN.js} +2 -2
  25. package/dist/client/chunks/{chart-kpitext-config-B2MovXSw.js.map → chart-kpitext-config-BLiwQIVN.js.map} +1 -1
  26. package/dist/client/chunks/{chart-kpitext-CppmccTK.js → chart-kpitext-giq03TOK.js} +2 -2
  27. package/dist/client/chunks/{chart-kpitext-CppmccTK.js.map → chart-kpitext-giq03TOK.js.map} +1 -1
  28. package/dist/client/chunks/{chart-linechart-config-CVBVB7nS.js → chart-linechart-config-CVbDAvCB.js} +2 -2
  29. package/dist/client/chunks/{chart-linechart-config-CVBVB7nS.js.map → chart-linechart-config-CVbDAvCB.js.map} +1 -1
  30. package/dist/client/chunks/{chart-markdownchart-config-Cq5Sxrgq.js → chart-markdownchart-config-uttA9Th4.js} +2 -2
  31. package/dist/client/chunks/{chart-markdownchart-config-Cq5Sxrgq.js.map → chart-markdownchart-config-uttA9Th4.js.map} +1 -1
  32. package/dist/client/chunks/{chart-piechart-config-Bdd31Gdi.js → chart-piechart-config-J748ISAR.js} +2 -2
  33. package/dist/client/chunks/{chart-piechart-config-Bdd31Gdi.js.map → chart-piechart-config-J748ISAR.js.map} +1 -1
  34. package/dist/client/chunks/{chart-radarchart-config-BWyfn0ij.js → chart-radarchart-config-CU_MwXOg.js} +2 -2
  35. package/dist/client/chunks/{chart-radarchart-config-BWyfn0ij.js.map → chart-radarchart-config-CU_MwXOg.js.map} +1 -1
  36. package/dist/client/chunks/{chart-radialbarchart-config-lU2_NQCD.js → chart-radialbarchart-config-D0eEa2hb.js} +2 -2
  37. package/dist/client/chunks/{chart-radialbarchart-config-lU2_NQCD.js.map → chart-radialbarchart-config-D0eEa2hb.js.map} +1 -1
  38. package/dist/client/chunks/{chart-scatterchart-config-DtLnut1M.js → chart-scatterchart-config-Bh0qBq9F.js} +2 -2
  39. package/dist/client/chunks/{chart-scatterchart-config-DtLnut1M.js.map → chart-scatterchart-config-Bh0qBq9F.js.map} +1 -1
  40. package/dist/client/chunks/{chart-treemapchart-config-BEiIWQnR.js → chart-treemapchart-config-Bl0wYGhB.js} +2 -2
  41. package/dist/client/chunks/{chart-treemapchart-config-BEiIWQnR.js.map → chart-treemapchart-config-Bl0wYGhB.js.map} +1 -1
  42. package/dist/client/chunks/{charts-BsPkAFTR.js → charts-BUq4jszb.js} +25 -25
  43. package/dist/client/chunks/{charts-BsPkAFTR.js.map → charts-BUq4jszb.js.map} +1 -1
  44. package/dist/client/chunks/components-DnhfrXo3.js +9846 -0
  45. package/dist/client/chunks/components-DnhfrXo3.js.map +1 -0
  46. package/dist/client/chunks/{icons-D6z-_9sa.js → icons-B2XSxpVK.js} +213 -181
  47. package/dist/client/chunks/icons-B2XSxpVK.js.map +1 -0
  48. package/dist/client/components/AnalysisBuilder/AnalysisAxisDropZone.d.ts +27 -0
  49. package/dist/client/components/AnalysisBuilder/AnalysisChartConfigPanel.d.ts +21 -0
  50. package/dist/client/components/AnalysisBuilder/AnalysisFilterGroup.d.ts +20 -0
  51. package/dist/client/components/AnalysisBuilder/AnalysisFilterItem.d.ts +16 -0
  52. package/dist/client/components/AnalysisBuilder/AnalysisFilterSection.d.ts +14 -0
  53. package/dist/client/components/AnalysisBuilder/AnalysisQueryPanel.d.ts +11 -0
  54. package/dist/client/components/AnalysisBuilder/AnalysisResultsPanel.d.ts +13 -0
  55. package/dist/client/components/AnalysisBuilder/BreakdownItemCard.d.ts +12 -0
  56. package/dist/client/components/AnalysisBuilder/BreakdownSection.d.ts +9 -0
  57. package/dist/client/components/AnalysisBuilder/FieldDetailPanel.d.ts +4 -0
  58. package/dist/client/components/AnalysisBuilder/FieldSearchItem.d.ts +6 -0
  59. package/dist/client/components/AnalysisBuilder/FieldSearchModal.d.ts +2 -0
  60. package/dist/client/components/AnalysisBuilder/MetricItemCard.d.ts +11 -0
  61. package/dist/client/components/AnalysisBuilder/MetricsSection.d.ts +9 -0
  62. package/dist/client/components/AnalysisBuilder/index.d.ts +3 -0
  63. package/dist/client/components/AnalysisBuilder/types.d.ts +408 -0
  64. package/dist/client/components/AnalysisBuilder/utils.d.ts +103 -0
  65. package/dist/client/components/ChartTypeSelector.d.ts +6 -1
  66. package/dist/client/components/QueryBuilder/CubeMetaExplorer.d.ts +2 -2
  67. package/dist/client/components/QueryBuilder/QueryPanel.d.ts +2 -2
  68. package/dist/client/components/QueryBuilder/types.d.ts +7 -138
  69. package/dist/client/components/charts/DataTable.d.ts +1 -1
  70. package/dist/client/components.js +16 -9725
  71. package/dist/client/components.js.map +1 -1
  72. package/dist/client/icons/registry.d.ts +1 -1
  73. package/dist/client/icons/types.d.ts +6 -0
  74. package/dist/client/icons.js +1 -1
  75. package/dist/client/index.d.ts +1 -0
  76. package/dist/client/index.js +3466 -49
  77. package/dist/client/index.js.map +1 -1
  78. package/dist/client/shared/chartDefaults.d.ts +64 -0
  79. package/dist/client/shared/components/QueryAnalysisPanel.d.ts +7 -0
  80. package/dist/client/shared/index.d.ts +10 -0
  81. package/dist/client/shared/types.d.ts +134 -0
  82. package/dist/client/shared/utils.d.ts +101 -0
  83. package/dist/client/styles.css +1 -1
  84. package/dist/client/types.d.ts +1 -0
  85. package/dist/client/utils/index.d.ts +1 -0
  86. package/dist/client/utils/pivotUtils.d.ts +78 -0
  87. package/dist/client-bundle-stats.html +1 -1
  88. package/package.json +1 -1
  89. package/dist/client/chunks/chart-activitygridchart-config-48WqIofo.js +0 -230
  90. package/dist/client/chunks/chart-activitygridchart-config-48WqIofo.js.map +0 -1
  91. package/dist/client/chunks/chart-barchart-7bCO3dnb.js +0 -177
  92. package/dist/client/chunks/chart-barchart-7bCO3dnb.js.map +0 -1
  93. package/dist/client/chunks/chart-datatable-BTqU80Qo.js +0 -57
  94. package/dist/client/chunks/chart-datatable-BTqU80Qo.js.map +0 -1
  95. package/dist/client/chunks/icons-D6z-_9sa.js.map +0 -1
@@ -1,16 +1,16 @@
1
- import { L as t, r as e, f as s, g 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-BsPkAFTR.js";
2
- import { a as n, C as x, N as u, P as A } from "./chunks/chart-activitygridchart-Cz4bEf3V.js";
3
- import { default as L } from "./chunks/chart-barchart-7bCO3dnb.js";
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-BUq4jszb.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 E } from "./chunks/chart-piechart-CZRDQxeB.js";
7
- import { default as P } from "./chunks/chart-scatterchart-C83KgqYY.js";
8
- import { default as b } from "./chunks/chart-radarchart-D5yRnY9j.js";
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-BTqU80Qo.js";
11
+ import { default as k } from "./chunks/chart-datatable-zyVFtRJ_.js";
12
12
  export {
13
- n as CHART_COLORS,
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
- E as RechartsPieChart,
23
- b as RechartsRadarChart,
22
+ b as RechartsPieChart,
23
+ V as RechartsRadarChart,
24
24
  D as RechartsRadialBarChart,
25
- P as RechartsScatterChart,
25
+ N as RechartsScatterChart,
26
26
  H as RechartsTreeMapChart,
27
27
  e as clearChartConfigCache,
28
28
  s as formatChartData,
@@ -0,0 +1,244 @@
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
+ _a as c,
235
+ Ba as d,
236
+ Oa as e,
237
+ Ma as f,
238
+ Ca as g,
239
+ Ra as h,
240
+ Aa as i,
241
+ Na as r,
242
+ Fa as s
243
+ };
244
+ //# sourceMappingURL=chart-activitygridchart-config-DVH-sdYZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chart-activitygridchart-config-DVH-sdYZ.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,4 +1,4 @@
1
- import { g as e } from "./chart-activitygridchart-config-48WqIofo.js";
1
+ import { g as e } from "./chart-activitygridchart-config-DVH-sdYZ.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-D8taXdn1.js.map
65
+ //# sourceMappingURL=chart-areachart-config-C2iwLEgm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"chart-areachart-config-D8taXdn1.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;"}
1
+ {"version":3,"file":"chart-areachart-config-C2iwLEgm.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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"}
@@ -1,4 +1,4 @@
1
- import { g as e } from "./chart-activitygridchart-config-48WqIofo.js";
1
+ import { g as e } from "./chart-activitygridchart-config-DVH-sdYZ.js";
2
2
  const i = {
3
3
  icon: e("bar"),
4
4
  description: "Compare values across categories",
@@ -55,4 +55,4 @@ const i = {
55
55
  export {
56
56
  i as barChartConfig
57
57
  };
58
- //# sourceMappingURL=chart-barchart-config-DjRZBtLb.js.map
58
+ //# sourceMappingURL=chart-barchart-config-CAsUZfHw.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"chart-barchart-config-DjRZBtLb.js","sources":["../../../src/client/components/charts/BarChart.config.tsx"],"sourcesContent":["import type { ChartTypeConfig } from '../../charts/chartConfigs'\nimport { getChartTypeIcon } from '../../icons'\n\n/**\n * Configuration for the bar chart type\n */\nexport const barChartConfig: ChartTypeConfig = {\n icon: getChartTypeIcon('bar'),\n description: 'Compare values across categories',\n useCase: 'Best for comparing discrete categories, showing rankings, or displaying changes over time',\n dropZones: [\n {\n key: 'xAxis',\n label: 'X-Axis (Categories)',\n description: 'Dimensions and time dimensions for grouping',\n mandatory: false,\n acceptTypes: ['dimension', 'timeDimension'],\n emptyText: 'Drop dimensions & time dimensions here'\n },\n {\n key: 'yAxis',\n label: 'Y-Axis (Values)',\n description: 'Measures for bar heights',\n mandatory: true,\n acceptTypes: ['measure'],\n emptyText: 'Drop measures here'\n },\n {\n key: 'series',\n label: 'Series (Split into Multiple Series)',\n description: 'Dimensions to create separate data series',\n mandatory: false,\n acceptTypes: ['dimension'],\n emptyText: 'Drop dimensions here to split data into series'\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 bar series'\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":["barChartConfig","getChartTypeIcon"],"mappings":";AAMO,MAAMA,IAAkC;AAAA,EAC7C,MAAMC,EAAiB,KAAK;AAAA,EAC5B,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,aAAa;AAAA,MACb,aAAa;AAAA,IAAA;AAAA,EACf;AAEJ;"}
1
+ {"version":3,"file":"chart-barchart-config-CAsUZfHw.js","sources":["../../../src/client/components/charts/BarChart.config.tsx"],"sourcesContent":["import type { ChartTypeConfig } from '../../charts/chartConfigs'\nimport { getChartTypeIcon } from '../../icons'\n\n/**\n * Configuration for the bar chart type\n */\nexport const barChartConfig: ChartTypeConfig = {\n icon: getChartTypeIcon('bar'),\n description: 'Compare values across categories',\n useCase: 'Best for comparing discrete categories, showing rankings, or displaying changes over time',\n dropZones: [\n {\n key: 'xAxis',\n label: 'X-Axis (Categories)',\n description: 'Dimensions and time dimensions for grouping',\n mandatory: false,\n acceptTypes: ['dimension', 'timeDimension'],\n emptyText: 'Drop dimensions & time dimensions here'\n },\n {\n key: 'yAxis',\n label: 'Y-Axis (Values)',\n description: 'Measures for bar heights',\n mandatory: true,\n acceptTypes: ['measure'],\n emptyText: 'Drop measures here'\n },\n {\n key: 'series',\n label: 'Series (Split into Multiple Series)',\n description: 'Dimensions to create separate data series',\n mandatory: false,\n acceptTypes: ['dimension'],\n emptyText: 'Drop dimensions here to split data into series'\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 bar series'\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":["barChartConfig","getChartTypeIcon"],"mappings":";AAMO,MAAMA,IAAkC;AAAA,EAC7C,MAAMC,EAAiB,KAAK;AAAA,EAC5B,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,aAAa;AAAA,MACb,aAAa;AAAA,IAAA;AAAA,EACf;AAEJ;"}
@@ -1,4 +1,4 @@
1
- import { g as e } from "./chart-activitygridchart-config-48WqIofo.js";
1
+ import { g as e } from "./chart-activitygridchart-config-DVH-sdYZ.js";
2
2
  const s = {
3
3
  icon: e("bubble"),
4
4
  description: "Compare three dimensions of data",
@@ -55,4 +55,4 @@ const s = {
55
55
  export {
56
56
  s as bubbleChartConfig
57
57
  };
58
- //# sourceMappingURL=chart-bubblechart-config-C6ck2qmg.js.map
58
+ //# sourceMappingURL=chart-bubblechart-config-DRuY0m7S.js.map