@embeddable.com/remarkable-pro 0.0.24 → 0.0.25
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/BarChartDefaultHorizontalPro.js +2 -2
- package/dist/BarChartDefaultHorizontalPro.js.map +1 -1
- package/dist/BarChartDefaultPro.js +2 -2
- package/dist/BarChartDefaultPro.js.map +1 -1
- package/dist/BarChartGroupedHorizontalPro.js +1 -1
- package/dist/BarChartGroupedPro.js +1 -1
- package/dist/BarChartStackedHorizontalPro.js +1 -1
- package/dist/BarChartStackedPro.js +1 -1
- package/dist/DonutChartPro.js +1 -1
- package/dist/DonutLabelChartPro.js +1 -1
- package/dist/LineChartComparisonDefaultPro.js +1 -1
- package/dist/LineChartDefaultPro.js +1 -1
- package/dist/LineChartGroupedPro.js +1 -1
- package/dist/PieChartPro.js +1 -1
- package/dist/TableChartPaginated.js +1 -1
- package/dist/TableScrollable.js +1 -1
- package/dist/bars.utils-DLqiVSYV.js +154 -0
- package/dist/bars.utils-DLqiVSYV.js.map +1 -0
- package/dist/components/charts/bars/bars.utils.d.ts.map +1 -1
- package/dist/components/charts/lines/LineChartComparisonDefaultPro/LineChartComparisonDefaultPro.utils.d.ts.map +1 -1
- package/dist/components/charts/lines/LineChartDefaultPro/LineChartDefaultPro.utils.d.ts.map +1 -1
- package/dist/components/charts/lines/LineChartGroupedPro/LineChartGroupedPro.utils.d.ts.map +1 -1
- package/dist/components/charts/pies/pies.utils.d.ts.map +1 -1
- package/dist/components/charts/tables/tables.utils.d.ts.map +1 -1
- package/dist/embeddable-components.json +32 -32
- package/dist/{index-BgYPax7r.js → index-BRuc7lF2.js} +2 -2
- package/dist/{index-BgYPax7r.js.map → index-BRuc7lF2.js.map} +1 -1
- package/dist/{index-CiAXHm8i.js → index-ByFoIwAq.js} +2 -2
- package/dist/{index-CiAXHm8i.js.map → index-ByFoIwAq.js.map} +1 -1
- package/dist/{index-CBcVtvlk.js → index-CRWWARnB.js} +2 -2
- package/dist/{index-CBcVtvlk.js.map → index-CRWWARnB.js.map} +1 -1
- package/dist/{index-D2oLkkYS.js → index-CVIirzal.js} +2 -2
- package/dist/{index-D2oLkkYS.js.map → index-CVIirzal.js.map} +1 -1
- package/dist/index-Cj1Zuh74.js +165 -0
- package/dist/index-Cj1Zuh74.js.map +1 -0
- package/dist/{index-DHHYE6GC.js → index-Cn_Rs8nk.js} +2 -2
- package/dist/{index-DHHYE6GC.js.map → index-Cn_Rs8nk.js.map} +1 -1
- package/dist/{index-z7CRXEdV.js → index-D9LxkwlG.js} +2 -2
- package/dist/{index-z7CRXEdV.js.map → index-D9LxkwlG.js.map} +1 -1
- package/dist/index-DDeRZxp1.js +334 -0
- package/dist/index-DDeRZxp1.js.map +1 -0
- package/dist/index-DMtpdR9I.js +170 -0
- package/dist/index-DMtpdR9I.js.map +1 -0
- package/dist/{index-Z5VzRC4L.js → index-DZYPPNrI.js} +2 -2
- package/dist/{index-Z5VzRC4L.js.map → index-DZYPPNrI.js.map} +1 -1
- package/dist/{index-CJkiIKmB.js → index-EOl5XOZN.js} +2 -2
- package/dist/{index-CJkiIKmB.js.map → index-EOl5XOZN.js.map} +1 -1
- package/dist/{index-PyqBKn-b.js → index-L5_Ts7FG.js} +2 -2
- package/dist/{index-PyqBKn-b.js.map → index-L5_Ts7FG.js.map} +1 -1
- package/dist/{index-BXQNwmFh.js → index-Uhz2U4Dp.js} +2 -2
- package/dist/{index-BXQNwmFh.js.map → index-Uhz2U4Dp.js.map} +1 -1
- package/dist/index.js +17 -17
- package/dist/pies.utils-BxCBtjpf.js +77 -0
- package/dist/pies.utils-BxCBtjpf.js.map +1 -0
- package/dist/styles.utils-u6uj51UE.js +59 -0
- package/dist/styles.utils-u6uj51UE.js.map +1 -0
- package/dist/{tables.utils-Cxh-FOdo.js → tables.utils-DMLGNJ4g.js} +2 -1
- package/dist/{tables.utils-Cxh-FOdo.js.map → tables.utils-DMLGNJ4g.js.map} +1 -1
- package/dist/theme/styles/styles.utils.d.ts +12 -0
- package/dist/theme/styles/styles.utils.d.ts.map +1 -1
- package/dist/theme/theme.types.d.ts +10 -0
- package/dist/theme/theme.types.d.ts.map +1 -1
- package/package.json +1 -1
- package/dist/bars.utils-Buw9Xk8l.js +0 -146
- package/dist/bars.utils-Buw9Xk8l.js.map +0 -1
- package/dist/index-0rHy8NOt.js +0 -161
- package/dist/index-0rHy8NOt.js.map +0 -1
- package/dist/index-DEsLQa4J.js +0 -166
- package/dist/index-DEsLQa4J.js.map +0 -1
- package/dist/index-DLfIAAoB.js +0 -332
- package/dist/index-DLfIAAoB.js.map +0 -1
- package/dist/object.utils-D_Zzon-H.js +0 -37
- package/dist/object.utils-D_Zzon-H.js.map +0 -1
- package/dist/pies.utils-CBJLntml.js +0 -73
- package/dist/pies.utils-CBJLntml.js.map +0 -1
|
@@ -1,3 +1,15 @@
|
|
|
1
|
+
import { Dimension, Measure } from '@embeddable.com/core';
|
|
2
|
+
import { Theme } from '../theme.types';
|
|
1
3
|
export declare const injectCssVariables: (styles: Record<string, string>) => () => void;
|
|
2
4
|
export declare const getColor: (key: string, value: string, palette: string[], idx: number) => string;
|
|
5
|
+
type GetDimensionMeasureColorProps = {
|
|
6
|
+
dimensionOrMeasure: Dimension | Measure;
|
|
7
|
+
theme: Theme;
|
|
8
|
+
value: string;
|
|
9
|
+
color: 'background' | 'border';
|
|
10
|
+
index: number;
|
|
11
|
+
chartColors: string[];
|
|
12
|
+
};
|
|
13
|
+
export declare const getDimensionMeasureColor: ({ dimensionOrMeasure, theme, color, value, index, chartColors, }: GetDimensionMeasureColorProps) => any;
|
|
14
|
+
export {};
|
|
3
15
|
//# sourceMappingURL=styles.utils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styles.utils.d.ts","sourceRoot":"","sources":["../../../src/theme/styles/styles.utils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"styles.utils.d.ts","sourceRoot":"","sources":["../../../src/theme/styles/styles.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAavC,eAAO,MAAM,kBAAkB,GAAI,QAAQ,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,eAgBhE,CAAC;AAkCF,eAAO,MAAM,QAAQ,GAAI,KAAK,MAAM,EAAE,OAAO,MAAM,EAAE,SAAS,MAAM,EAAE,EAAE,KAAK,MAAM,KAAG,MA0BrF,CAAC;AAEF,KAAK,6BAA6B,GAAG;IACnC,kBAAkB,EAAE,SAAS,GAAG,OAAO,CAAC;IACxC,KAAK,EAAE,KAAK,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,YAAY,GAAG,QAAQ,CAAC;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,EAAE,CAAC;CACvB,CAAC;AAEF,eAAO,MAAM,wBAAwB,GAAI,kEAOtC,6BAA6B,QA6B/B,CAAC"}
|
|
@@ -11,7 +11,17 @@ export type ThemeI18n = {
|
|
|
11
11
|
translations: Resource;
|
|
12
12
|
};
|
|
13
13
|
export type ThemeChartsLegendPosition = 'top' | 'right' | 'bottom' | 'left';
|
|
14
|
+
export type ThemeChartsColors = {
|
|
15
|
+
borderColor: string;
|
|
16
|
+
backgroundColor: string;
|
|
17
|
+
};
|
|
18
|
+
export type ThemeChartsColorMap = {
|
|
19
|
+
dimensionValue?: Record<string, string>;
|
|
20
|
+
measure?: Record<string, string>;
|
|
21
|
+
};
|
|
14
22
|
export type ThemeCharts = {
|
|
23
|
+
backgroundColorMap?: ThemeChartsColorMap;
|
|
24
|
+
borderColorMap?: ThemeChartsColorMap;
|
|
15
25
|
backgroundColors?: string[];
|
|
16
26
|
borderColors?: string[];
|
|
17
27
|
legendPosition: ThemeChartsLegendPosition;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theme.types.d.ts","sourceRoot":"","sources":["../../src/theme/theme.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,sBAAsB,EAAE,MAAM,iDAAiD,CAAC;AACzF,OAAO,EAAE,eAAe,EAAE,MAAM,0CAA0C,CAAC;AAC3E,OAAO,EAAE,mBAAmB,EAAE,MAAM,6CAA6C,CAAC;AAClF,OAAO,EAAE,oBAAoB,EAAE,MAAM,8CAA8C,CAAC;AAEpF,MAAM,MAAM,SAAS,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAC;IAAC,YAAY,EAAE,QAAQ,CAAA;CAAE,CAAC;AAErE,MAAM,MAAM,yBAAyB,GAAG,KAAK,GAAG,OAAO,GAAG,QAAQ,GAAG,MAAM,CAAC;AAE5E,MAAM,MAAM,WAAW,GAAG;
|
|
1
|
+
{"version":3,"file":"theme.types.d.ts","sourceRoot":"","sources":["../../src/theme/theme.types.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,146 +0,0 @@
|
|
|
1
|
-
import { d as p, C as P } from "./Color.type.emb-DWdIUAm5.js";
|
|
2
|
-
import { r as v, g as x } from "./charts.utils-lvlkFPJk.js";
|
|
3
|
-
import { g as h } from "./formatter.utils-CBCUxVH8.js";
|
|
4
|
-
import { g as D, a as g } from "./object.utils-D_Zzon-H.js";
|
|
5
|
-
const E = (c, d) => {
|
|
6
|
-
var b;
|
|
7
|
-
const m = h(d), { data: o = [], dimension: i, groupDimension: l, measure: t } = c, r = [...new Set(o.map((s) => s[i.name]).filter((s) => s != null))].sort(), a = `${l.name}${l.nativeType === P && ((b = l.inputs) != null && b.granularity) ? `.${l.inputs.granularity}` : ""}`, e = [...new Set(o.map((s) => s[a]))].filter((s) => s != null), n = D(d), u = p(), C = e.map((s, f) => {
|
|
8
|
-
const T = g(
|
|
9
|
-
`${n}.charts.backgroundColors`,
|
|
10
|
-
`${l.name}.${s}`,
|
|
11
|
-
d.charts.backgroundColors ?? u,
|
|
12
|
-
f
|
|
13
|
-
), w = g(
|
|
14
|
-
`${n}.charts.borderColors`,
|
|
15
|
-
`${l.name}.${s}`,
|
|
16
|
-
d.charts.borderColors ?? u,
|
|
17
|
-
f
|
|
18
|
-
);
|
|
19
|
-
return {
|
|
20
|
-
label: m.data(l, s),
|
|
21
|
-
rawLabel: s,
|
|
22
|
-
backgroundColor: T,
|
|
23
|
-
borderColor: w,
|
|
24
|
-
data: r.map((N) => {
|
|
25
|
-
const k = o.find(
|
|
26
|
-
($) => $[a] === s && $[i.name] === N
|
|
27
|
-
);
|
|
28
|
-
return k ? Number(k[t.name]) : 0;
|
|
29
|
-
})
|
|
30
|
-
};
|
|
31
|
-
});
|
|
32
|
-
return {
|
|
33
|
-
labels: r,
|
|
34
|
-
datasets: C
|
|
35
|
-
};
|
|
36
|
-
}, I = (c, d = v) => {
|
|
37
|
-
if (!c.data)
|
|
38
|
-
return {
|
|
39
|
-
labels: [],
|
|
40
|
-
datasets: [{ data: [] }]
|
|
41
|
-
};
|
|
42
|
-
const m = h(d), o = D(d), i = x(c.data, c.dimension, c.measures, c.maxItems), l = p();
|
|
43
|
-
return {
|
|
44
|
-
labels: i.map((t) => t[c.dimension.name]),
|
|
45
|
-
datasets: c.measures.map((t, r) => {
|
|
46
|
-
const a = g(
|
|
47
|
-
`${o}.charts.backgroundColors`,
|
|
48
|
-
t.name,
|
|
49
|
-
d.charts.backgroundColors ?? l,
|
|
50
|
-
r
|
|
51
|
-
), e = g(
|
|
52
|
-
`${o}.charts.borderColors`,
|
|
53
|
-
t.name,
|
|
54
|
-
d.charts.borderColors ?? l,
|
|
55
|
-
r
|
|
56
|
-
);
|
|
57
|
-
return {
|
|
58
|
-
label: m.dimensionOrMeasureTitle(t),
|
|
59
|
-
data: i.map((n) => n[t.name] ?? 0),
|
|
60
|
-
backgroundColor: a,
|
|
61
|
-
borderColor: e
|
|
62
|
-
};
|
|
63
|
-
})
|
|
64
|
-
};
|
|
65
|
-
}, F = (c, d) => {
|
|
66
|
-
const { datasets: m } = c.chart.data, o = c.dataIndex, i = m.reduce((l, t) => {
|
|
67
|
-
const r = t.data[o];
|
|
68
|
-
return l + (r || 0);
|
|
69
|
-
}, 0);
|
|
70
|
-
return d(i);
|
|
71
|
-
}, B = (c, d) => {
|
|
72
|
-
const { onBarClicked: m, measures: o, dimension: i, horizontal: l, data: t } = c, r = h(d);
|
|
73
|
-
return {
|
|
74
|
-
plugins: {
|
|
75
|
-
legend: { position: d.charts.legendPosition ?? "bottom" },
|
|
76
|
-
datalabels: {
|
|
77
|
-
labels: {
|
|
78
|
-
total: {
|
|
79
|
-
formatter: (a, e) => F(
|
|
80
|
-
e,
|
|
81
|
-
(n) => r.data(o[0], n)
|
|
82
|
-
)
|
|
83
|
-
},
|
|
84
|
-
value: {
|
|
85
|
-
formatter: (a, e) => {
|
|
86
|
-
const n = o[e.datasetIndex % o.length];
|
|
87
|
-
return r.data(n, a);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
},
|
|
92
|
-
tooltip: {
|
|
93
|
-
callbacks: {
|
|
94
|
-
title: (a) => {
|
|
95
|
-
var n;
|
|
96
|
-
const e = (n = a[0]) == null ? void 0 : n.label;
|
|
97
|
-
return r.data(i, e);
|
|
98
|
-
},
|
|
99
|
-
label: (a) => {
|
|
100
|
-
const e = o[a.datasetIndex % o.length], n = a.raw;
|
|
101
|
-
return `${r.data(i, a.dataset.label) || ""}: ${r.data(e, n)}`;
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
},
|
|
106
|
-
scales: {
|
|
107
|
-
x: {
|
|
108
|
-
ticks: {
|
|
109
|
-
callback: (a) => {
|
|
110
|
-
if (l)
|
|
111
|
-
return r.data(o[0], a);
|
|
112
|
-
if (!t || !t.labels) return;
|
|
113
|
-
const e = t.labels[Number(a)];
|
|
114
|
-
return r.data(i, e);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
},
|
|
118
|
-
y: {
|
|
119
|
-
ticks: {
|
|
120
|
-
callback: (a) => {
|
|
121
|
-
if (!l)
|
|
122
|
-
return r.data(o[0], a);
|
|
123
|
-
if (!t || !t.labels) return;
|
|
124
|
-
const e = t.labels[Number(a)];
|
|
125
|
-
return r.data(i, e);
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
},
|
|
130
|
-
onClick: (a, e, n) => {
|
|
131
|
-
var s;
|
|
132
|
-
if (!m) return;
|
|
133
|
-
const u = e[0], C = u ? n.data.labels[u.index] : null, b = u ? (s = n.data.datasets[u.datasetIndex]) == null ? void 0 : s.rawLabel : null;
|
|
134
|
-
m({
|
|
135
|
-
axisDimensionValue: C,
|
|
136
|
-
groupingDimensionValue: b
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
};
|
|
140
|
-
};
|
|
141
|
-
export {
|
|
142
|
-
I as a,
|
|
143
|
-
B as b,
|
|
144
|
-
E as g
|
|
145
|
-
};
|
|
146
|
-
//# sourceMappingURL=bars.utils-Buw9Xk8l.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bars.utils-Buw9Xk8l.js","sources":["../src/components/charts/bars/bars.utils.ts"],"sourcesContent":["import { CUBE_DIMENSION_TYPE_TIME, DataResponse, Dimension, Measure } from '@embeddable.com/core';\nimport { Theme } from '../../../theme/theme.types';\nimport { remarkableTheme } from '../../../theme/theme.constants';\nimport { ChartData, ChartOptions } from 'chart.js';\nimport { getThemeFormatter } from '../../../theme/formatter/formatter.utils';\nimport { groupTailAsOther } from '../charts.utils';\nimport { getColor } from '../../../theme/styles/styles.utils';\nimport { getChartColors } from '@embeddable.com/remarkable-ui';\nimport { getObjectStableKey } from '../../../utils.ts/object.utils';\nimport { Context } from 'chartjs-plugin-datalabels';\n\nexport const getBarStackedChartProData = (\n props: {\n data: DataResponse['data'];\n dimension: Dimension;\n groupDimension: Dimension;\n measure: Measure;\n },\n theme: Theme,\n): ChartData<'bar'> => {\n const themeFormatter = getThemeFormatter(theme);\n const { data = [], dimension, groupDimension, measure } = props;\n\n const axis = [...new Set(data.map((d) => d[dimension.name]).filter((d) => d != null))].sort();\n const groupDimensionName = `${groupDimension.name}${groupDimension.nativeType === CUBE_DIMENSION_TYPE_TIME && groupDimension.inputs?.granularity ? `.${groupDimension.inputs.granularity}` : ''}`;\n const groupBy = [...new Set(data.map((d) => d[groupDimensionName]))].filter((d) => d != null);\n\n const themeKey = getObjectStableKey(theme);\n const chartColors = getChartColors();\n const datasets = groupBy.map((groupByItem, index) => {\n const backgroundColor = getColor(\n `${themeKey}.charts.backgroundColors`,\n `${groupDimension.name}.${groupByItem}`,\n theme.charts.backgroundColors ?? chartColors,\n index,\n );\n\n const borderColor = getColor(\n `${themeKey}.charts.borderColors`,\n `${groupDimension.name}.${groupByItem}`,\n theme.charts.borderColors ?? chartColors,\n index,\n );\n\n return {\n label: themeFormatter.data(groupDimension, groupByItem),\n rawLabel: groupByItem,\n backgroundColor,\n borderColor,\n data: axis.map((axisItem) => {\n const record = data.find(\n (d) => d[groupDimensionName] === groupByItem && d[dimension.name] === axisItem,\n );\n return record ? Number(record[measure.name]) : 0;\n }),\n };\n });\n\n return {\n labels: axis,\n datasets,\n };\n};\n\nexport const getBarChartProData = (\n props: {\n data: DataResponse['data'];\n dimension: Dimension;\n measures: Measure[];\n maxItems?: number;\n },\n theme: Theme = remarkableTheme,\n): ChartData<'bar'> => {\n if (!props.data) {\n return {\n labels: [],\n datasets: [{ data: [] }],\n };\n }\n\n const themeFormatter = getThemeFormatter(theme);\n const themeKey = getObjectStableKey(theme);\n const groupedData = groupTailAsOther(props.data, props.dimension, props.measures, props.maxItems);\n const chartColors = getChartColors();\n\n return {\n labels: groupedData.map((item) => {\n return item[props.dimension.name];\n }),\n datasets: props.measures.map((measure, index) => {\n const backgroundColor = getColor(\n `${themeKey}.charts.backgroundColors`,\n measure.name,\n theme.charts.backgroundColors ?? chartColors,\n index,\n );\n\n const borderColor = getColor(\n `${themeKey}.charts.borderColors`,\n measure.name,\n theme.charts.borderColors ?? chartColors,\n index,\n );\n\n return {\n label: themeFormatter.dimensionOrMeasureTitle(measure),\n data: groupedData.map((item) => item[measure.name] ?? 0),\n backgroundColor,\n borderColor,\n };\n }),\n };\n};\n\nconst getBarChartProDatalabelTotalFormatter = (\n context: Context,\n formatter: (value: number) => string,\n) => {\n const { datasets } = context.chart.data;\n const i = context.dataIndex;\n\n const total = datasets.reduce((sum, ds) => {\n const val = ds.data[i] as number;\n return sum + (val || 0);\n }, 0);\n\n return formatter(total);\n};\n\nexport const getBarChartProOptions = (\n options: {\n onBarClicked?: (args: {\n axisDimensionValue: string | null;\n groupingDimensionValue: string | null;\n }) => void;\n measures: Measure[];\n dimension: Dimension;\n horizontal: boolean;\n data: ChartData<'bar'>;\n },\n theme: Theme,\n): Partial<ChartOptions<'bar'>> => {\n const { onBarClicked, measures, dimension, horizontal, data } = options;\n\n const themeFormatter = getThemeFormatter(theme);\n return {\n plugins: {\n legend: { position: theme.charts.legendPosition ?? 'bottom' },\n datalabels: {\n labels: {\n total: {\n formatter: (_value: string | number, context: Context) =>\n getBarChartProDatalabelTotalFormatter(context, (value: number) =>\n themeFormatter.data(measures[0]!, value),\n ),\n },\n value: {\n formatter: (value: string | number, context) => {\n const measure = measures[context.datasetIndex % measures.length]!;\n return themeFormatter.data(measure, value);\n },\n },\n },\n },\n tooltip: {\n callbacks: {\n title: (context) => {\n const label = context[0]?.label;\n return themeFormatter.data(dimension, label);\n },\n label: (context) => {\n const measure = measures[context.datasetIndex % measures.length]!;\n const raw = context.raw as number;\n return `${themeFormatter.data(dimension, context.dataset.label) || ''}: ${themeFormatter.data(measure, raw)}`;\n },\n },\n },\n },\n scales: {\n x: {\n ticks: {\n callback: (value) => {\n if (horizontal) {\n return themeFormatter.data(measures[0]!, value);\n }\n\n if (!data || !data.labels) return undefined;\n\n const label = data.labels[Number(value)] as string;\n\n return themeFormatter.data(dimension, label);\n },\n },\n },\n y: {\n ticks: {\n callback: (value) => {\n if (!horizontal) {\n return themeFormatter.data(measures[0]!, value);\n }\n if (!data || !data.labels) return undefined;\n const label = data.labels[Number(value)] as string;\n return themeFormatter.data(dimension, label);\n },\n },\n },\n },\n onClick: (_event, elements, chart) => {\n if (!onBarClicked) return;\n\n const element = elements[0];\n const axisDimensionValue = (element ? chart.data.labels![element.index] : null) as\n | string\n | null;\n const groupingDimensionValue = (\n element\n ? (chart.data.datasets[element.datasetIndex] as { rawLabel?: string | null })?.rawLabel\n : null\n ) as string | null;\n\n onBarClicked({\n axisDimensionValue,\n groupingDimensionValue,\n });\n },\n };\n};\n"],"names":["getBarStackedChartProData","props","theme","themeFormatter","getThemeFormatter","data","dimension","groupDimension","measure","axis","d","groupDimensionName","CUBE_DIMENSION_TYPE_TIME","_a","groupBy","themeKey","getObjectStableKey","chartColors","getChartColors","datasets","groupByItem","index","backgroundColor","getColor","borderColor","axisItem","record","getBarChartProData","remarkableTheme","groupedData","groupTailAsOther","item","getBarChartProDatalabelTotalFormatter","context","formatter","i","total","sum","ds","val","getBarChartProOptions","options","onBarClicked","measures","horizontal","_value","value","label","raw","_event","elements","chart","element","axisDimensionValue","groupingDimensionValue"],"mappings":"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"}
|
package/dist/index-0rHy8NOt.js
DELETED
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
import { d as j, m as P, j as M, L as S } from "./Color.type.emb-DWdIUAm5.js";
|
|
2
|
-
import { useTheme as y } from "@embeddable.com/react";
|
|
3
|
-
import { a as G, r as O } from "./component.inputs.constants-DO_jX-yc.js";
|
|
4
|
-
import { C as v } from "./ChartCard-BHPN4_tz.js";
|
|
5
|
-
import { g as $ } from "./formatter.utils-CBCUxVH8.js";
|
|
6
|
-
import { g as R, a as w } from "./object.utils-D_Zzon-H.js";
|
|
7
|
-
import { s as F } from "./color.utils-BSg_DFOh.js";
|
|
8
|
-
import { g as T } from "./lines.utils-COGf_F0b.js";
|
|
9
|
-
import { u as _ } from "./charts.fillGaps.hooks-C7KsWcZb.js";
|
|
10
|
-
const D = (i, t) => {
|
|
11
|
-
const u = $(t), { data: r = [], dimension: c, groupDimension: n, measure: o, hasMinMaxYAxisRange: d } = i, l = [...new Set(r.map((e) => e[c.name]).filter((e) => e != null))].sort(), m = [...new Set(r.map((e) => e[n.name]))].filter((e) => e != null), a = R(t), s = j(), p = m.map((e, C) => {
|
|
12
|
-
var b;
|
|
13
|
-
const g = w(
|
|
14
|
-
`${a}.charts.backgroundColors`,
|
|
15
|
-
`${n.name}.${e}`,
|
|
16
|
-
t.charts.backgroundColors ?? s,
|
|
17
|
-
C
|
|
18
|
-
), x = w(
|
|
19
|
-
`${a}.charts.borderColors`,
|
|
20
|
-
`${n.name}.${e}`,
|
|
21
|
-
t.charts.borderColors ?? s,
|
|
22
|
-
C
|
|
23
|
-
);
|
|
24
|
-
return {
|
|
25
|
-
clip: d,
|
|
26
|
-
label: u.data(n, e),
|
|
27
|
-
rawLabel: e,
|
|
28
|
-
backgroundColor: F(g, 0.5),
|
|
29
|
-
pointBackgroundColor: g,
|
|
30
|
-
fill: (b = o.inputs) == null ? void 0 : b.fillUnderLine,
|
|
31
|
-
borderColor: x,
|
|
32
|
-
data: l.map((f) => {
|
|
33
|
-
var k;
|
|
34
|
-
const h = r.find(
|
|
35
|
-
(A) => A[n.name] === e && A[c.name] === f
|
|
36
|
-
);
|
|
37
|
-
return (h == null ? void 0 : h[o.name]) ?? ((k = o.inputs) != null && k.connectGaps ? 0 : null);
|
|
38
|
-
})
|
|
39
|
-
};
|
|
40
|
-
});
|
|
41
|
-
return {
|
|
42
|
-
labels: l,
|
|
43
|
-
datasets: p
|
|
44
|
-
};
|
|
45
|
-
}, K = (i, t) => {
|
|
46
|
-
var l, m;
|
|
47
|
-
const { dimension: u, data: r, measure: c, onLineClicked: n } = i, o = $(t), d = {
|
|
48
|
-
plugins: {
|
|
49
|
-
datalabels: {
|
|
50
|
-
labels: {
|
|
51
|
-
value: {
|
|
52
|
-
formatter: (a) => o.data(c, a)
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
},
|
|
56
|
-
tooltip: {
|
|
57
|
-
callbacks: {
|
|
58
|
-
title: (a) => {
|
|
59
|
-
var p;
|
|
60
|
-
const s = (p = a[0]) == null ? void 0 : p.label;
|
|
61
|
-
return o.data(u, s);
|
|
62
|
-
},
|
|
63
|
-
label: (a) => {
|
|
64
|
-
const s = a.raw;
|
|
65
|
-
return `${a.dataset.label}: ${o.data(c, s)}`;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
},
|
|
70
|
-
scales: {
|
|
71
|
-
x: {
|
|
72
|
-
ticks: {
|
|
73
|
-
callback: (a) => {
|
|
74
|
-
if (!r || !r.labels) return;
|
|
75
|
-
const s = r.labels[Number(a)];
|
|
76
|
-
return o.data(u, s);
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
},
|
|
80
|
-
y: {
|
|
81
|
-
ticks: {
|
|
82
|
-
callback: (a) => o.data(c, a)
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
};
|
|
87
|
-
return P(
|
|
88
|
-
T({ onLineClicked: n }),
|
|
89
|
-
d,
|
|
90
|
-
((m = (l = t.charts) == null ? void 0 : l.lineChartGroupedPro) == null ? void 0 : m.options) || {}
|
|
91
|
-
);
|
|
92
|
-
}, Y = (i) => {
|
|
93
|
-
const t = y();
|
|
94
|
-
G(t);
|
|
95
|
-
const { title: u, description: r, xAxisLabel: c, yAxisLabel: n } = O(i), {
|
|
96
|
-
hideMenu: o,
|
|
97
|
-
measure: d,
|
|
98
|
-
xAxis: l,
|
|
99
|
-
groupBy: m,
|
|
100
|
-
reverseXAxis: a,
|
|
101
|
-
showLegend: s,
|
|
102
|
-
showLogarithmicScale: p,
|
|
103
|
-
showTooltips: e,
|
|
104
|
-
showValueLabels: C,
|
|
105
|
-
yAxisRangeMax: g,
|
|
106
|
-
yAxisRangeMin: x,
|
|
107
|
-
onLineClicked: L
|
|
108
|
-
} = i, b = _({
|
|
109
|
-
results: i.results,
|
|
110
|
-
dimension: i.xAxis
|
|
111
|
-
}), f = D(
|
|
112
|
-
{
|
|
113
|
-
data: b.data,
|
|
114
|
-
dimension: l,
|
|
115
|
-
groupDimension: m,
|
|
116
|
-
measure: d,
|
|
117
|
-
hasMinMaxYAxisRange: x != null || g != null
|
|
118
|
-
},
|
|
119
|
-
t
|
|
120
|
-
), h = K(
|
|
121
|
-
{ data: f, dimension: l, measure: d, onLineClicked: L },
|
|
122
|
-
t
|
|
123
|
-
);
|
|
124
|
-
return /* @__PURE__ */ M.jsx(
|
|
125
|
-
v,
|
|
126
|
-
{
|
|
127
|
-
data: b,
|
|
128
|
-
dimensionsAndMeasures: [d, l, m],
|
|
129
|
-
errorMessage: b.error,
|
|
130
|
-
description: r,
|
|
131
|
-
title: u,
|
|
132
|
-
hideMenu: o,
|
|
133
|
-
children: /* @__PURE__ */ M.jsx(
|
|
134
|
-
S,
|
|
135
|
-
{
|
|
136
|
-
data: f,
|
|
137
|
-
reverseXAxis: a,
|
|
138
|
-
showLegend: s,
|
|
139
|
-
showLogarithmicScale: p,
|
|
140
|
-
showTooltips: e,
|
|
141
|
-
showValueLabels: C,
|
|
142
|
-
xAxisLabel: c,
|
|
143
|
-
yAxisLabel: n,
|
|
144
|
-
yAxisRangeMax: g,
|
|
145
|
-
yAxisRangeMin: x,
|
|
146
|
-
options: h
|
|
147
|
-
}
|
|
148
|
-
)
|
|
149
|
-
}
|
|
150
|
-
);
|
|
151
|
-
}, J = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
152
|
-
__proto__: null,
|
|
153
|
-
default: Y
|
|
154
|
-
}, Symbol.toStringTag, { value: "Module" }));
|
|
155
|
-
export {
|
|
156
|
-
Y as L,
|
|
157
|
-
K as a,
|
|
158
|
-
D as g,
|
|
159
|
-
J as i
|
|
160
|
-
};
|
|
161
|
-
//# sourceMappingURL=index-0rHy8NOt.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-0rHy8NOt.js","sources":["../src/components/charts/lines/LineChartGroupedPro/LineChartGroupedPro.utils.ts","../src/components/charts/lines/LineChartGroupedPro/index.tsx"],"sourcesContent":["import { DataResponse, Dimension, Measure } from '@embeddable.com/core';\nimport { Theme } from '../../../../theme/theme.types';\nimport { ChartData, ChartOptions } from 'chart.js';\nimport { getThemeFormatter } from '../../../../theme/formatter/formatter.utils';\nimport { mergician } from 'mergician';\nimport { getObjectStableKey } from '../../../../utils.ts/object.utils';\nimport { getColor } from '../../../../theme/styles/styles.utils';\nimport { setColorAlpha } from '../../../../utils.ts/color.utils';\nimport { getChartColors } from '@embeddable.com/remarkable-ui';\nimport { getLineChartProOptions, LineChartProOptionsClick } from '../lines.utils';\n\nexport const getLineChartGroupedProData = (\n props: {\n data: DataResponse['data'];\n dimension: Dimension;\n groupDimension: Dimension;\n measure: Measure;\n hasMinMaxYAxisRange: boolean;\n },\n theme: Theme,\n): ChartData<'line'> => {\n const themeFormatter = getThemeFormatter(theme);\n const { data = [], dimension, groupDimension, measure, hasMinMaxYAxisRange } = props;\n\n const axis = [...new Set(data.map((d) => d[dimension.name]).filter((d) => d != null))].sort();\n const groupBy = [...new Set(data.map((d) => d[groupDimension.name]))].filter((d) => d != null);\n\n const themeKey = getObjectStableKey(theme);\n const chartColors = getChartColors();\n const datasets: ChartData<'line'>['datasets'] = groupBy.map((groupByItem, index) => {\n const backgroundColor = getColor(\n `${themeKey}.charts.backgroundColors`,\n `${groupDimension.name}.${groupByItem}`,\n theme.charts.backgroundColors ?? chartColors,\n index,\n );\n\n const borderColor = getColor(\n `${themeKey}.charts.borderColors`,\n `${groupDimension.name}.${groupByItem}`,\n theme.charts.borderColors ?? chartColors,\n index,\n );\n\n const dataset = {\n clip: hasMinMaxYAxisRange,\n label: themeFormatter.data(groupDimension, groupByItem),\n rawLabel: groupByItem,\n backgroundColor: setColorAlpha(backgroundColor, 0.5),\n pointBackgroundColor: backgroundColor,\n fill: measure.inputs?.['fillUnderLine'],\n borderColor,\n data: axis.map((axisItem) => {\n const record = data.find(\n (d) => d[groupDimension.name] === groupByItem && d[dimension.name] === axisItem,\n );\n return record?.[measure.name] ?? (measure.inputs?.['connectGaps'] ? 0 : null);\n }),\n } as ChartData<'line'>['datasets'][number];\n\n return dataset;\n });\n\n return {\n labels: axis,\n datasets,\n };\n};\n\nexport const getLineChartGroupedProOptions = (\n options: {\n dimension: Dimension;\n measure: Measure;\n data: ChartData<'line'>;\n onLineClicked?: LineChartProOptionsClick;\n },\n theme: Theme,\n): ChartOptions<'line'> => {\n const { dimension, data, measure, onLineClicked } = options;\n const themeFormatter = getThemeFormatter(theme);\n\n const lineChartOptions: ChartOptions<'line'> = {\n plugins: {\n datalabels: {\n labels: {\n value: {\n formatter: (value: string | number) => {\n return themeFormatter.data(measure, value);\n },\n },\n },\n },\n tooltip: {\n callbacks: {\n title: (context) => {\n const label = context[0]?.label;\n return themeFormatter.data(dimension, label);\n },\n label: (context) => {\n const raw = context.raw as number;\n return `${context.dataset.label}: ${themeFormatter.data(measure, raw)}`;\n },\n },\n },\n },\n scales: {\n x: {\n ticks: {\n callback: (value) => {\n if (!data || !data.labels) return undefined;\n\n const label = data.labels[Number(value)] as string;\n return themeFormatter.data(dimension, label);\n },\n },\n },\n y: {\n ticks: {\n callback: (value) => {\n return themeFormatter.data(measure, value);\n },\n },\n },\n },\n };\n\n return mergician(\n getLineChartProOptions({ onLineClicked }),\n lineChartOptions,\n theme.charts?.lineChartGroupedPro?.options || {},\n );\n};\n","import { useTheme } from '@embeddable.com/react';\nimport { Theme } from '../../../../theme/theme.types';\nimport { DataResponse, Dimension, Measure } from '@embeddable.com/core';\nimport { i18nSetup } from '../../../../theme/i18n/i18n';\nimport { resolveI18nProps } from '../../../component.utils';\nimport { ChartCard, ChartCardHeaderProps } from '../../shared/ChartCard/ChartCard';\nimport {\n getLineChartGroupedProData,\n getLineChartGroupedProOptions,\n} from './LineChartGroupedPro.utils';\nimport { useFillGaps } from '../../charts.fillGaps.hooks';\nimport { LineChartProOptionsClick } from '../lines.utils';\nimport { LineChart } from '@embeddable.com/remarkable-ui';\n\nexport type LineChartGroupedProPropsOnLineClicked = {\n axisDimensionValue: string | null;\n groupingDimensionValue: string | null;\n};\n\ntype LineChartGroupedProProp = {\n xAxis: Dimension;\n groupBy: Dimension;\n measure: Measure;\n results: DataResponse;\n reverseXAxis?: boolean;\n showLegend?: boolean;\n showLogarithmicScale?: boolean;\n showTooltips?: boolean;\n showValueLabels?: boolean;\n\n xAxisLabel?: string;\n yAxisLabel?: string;\n yAxisRangeMax?: number;\n yAxisRangeMin?: number;\n onLineClicked?: LineChartProOptionsClick;\n} & ChartCardHeaderProps;\n\nconst LineChartGroupedPro = (props: LineChartGroupedProProp) => {\n const theme: Theme = useTheme() as Theme;\n i18nSetup(theme);\n\n const { title, description, xAxisLabel, yAxisLabel } = resolveI18nProps(props);\n const {\n hideMenu,\n measure,\n xAxis,\n groupBy,\n reverseXAxis,\n showLegend,\n showLogarithmicScale,\n showTooltips,\n showValueLabels,\n yAxisRangeMax,\n yAxisRangeMin,\n onLineClicked,\n } = props;\n\n const results = useFillGaps({\n results: props.results,\n dimension: props.xAxis,\n });\n\n const data = getLineChartGroupedProData(\n {\n data: results.data,\n dimension: xAxis,\n groupDimension: groupBy,\n measure,\n hasMinMaxYAxisRange: Boolean(yAxisRangeMin != null || yAxisRangeMax != null),\n },\n\n theme,\n );\n const options = getLineChartGroupedProOptions(\n { data, dimension: xAxis, measure, onLineClicked },\n theme,\n );\n\n return (\n <ChartCard\n data={results}\n dimensionsAndMeasures={[measure, xAxis, groupBy]}\n errorMessage={results.error}\n description={description}\n title={title}\n hideMenu={hideMenu}\n >\n <LineChart\n data={data}\n reverseXAxis={reverseXAxis}\n showLegend={showLegend}\n showLogarithmicScale={showLogarithmicScale}\n showTooltips={showTooltips}\n showValueLabels={showValueLabels}\n xAxisLabel={xAxisLabel}\n yAxisLabel={yAxisLabel}\n yAxisRangeMax={yAxisRangeMax}\n yAxisRangeMin={yAxisRangeMin}\n options={options}\n />\n </ChartCard>\n );\n};\n\nexport default LineChartGroupedPro;\n"],"names":["getLineChartGroupedProData","props","theme","themeFormatter","getThemeFormatter","data","dimension","groupDimension","measure","hasMinMaxYAxisRange","axis","d","groupBy","themeKey","getObjectStableKey","chartColors","getChartColors","datasets","groupByItem","index","backgroundColor","getColor","borderColor","setColorAlpha","_a","axisItem","record","getLineChartGroupedProOptions","options","onLineClicked","lineChartOptions","value","context","label","raw","mergician","getLineChartProOptions","_b","LineChartGroupedPro","useTheme","i18nSetup","title","description","xAxisLabel","yAxisLabel","resolveI18nProps","hideMenu","xAxis","reverseXAxis","showLegend","showLogarithmicScale","showTooltips","showValueLabels","yAxisRangeMax","yAxisRangeMin","results","useFillGaps","jsx","ChartCard","LineChart"],"mappings":"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"}
|
package/dist/index-DEsLQa4J.js
DELETED
|
@@ -1,166 +0,0 @@
|
|
|
1
|
-
import { d as v, e as f, m as j, j as L, L as O } from "./Color.type.emb-DWdIUAm5.js";
|
|
2
|
-
import { useTheme as w } from "@embeddable.com/react";
|
|
3
|
-
import { a as P, r as S } from "./component.inputs.constants-DO_jX-yc.js";
|
|
4
|
-
import { C as F } from "./ChartCard-BHPN4_tz.js";
|
|
5
|
-
import { g as A } from "./formatter.utils-CBCUxVH8.js";
|
|
6
|
-
import { g as R, a as k } from "./object.utils-D_Zzon-H.js";
|
|
7
|
-
import { i as M, s as T } from "./color.utils-BSg_DFOh.js";
|
|
8
|
-
import { u as _ } from "./charts.fillGaps.hooks-C7KsWcZb.js";
|
|
9
|
-
const B = (o, n) => {
|
|
10
|
-
if (!o.data)
|
|
11
|
-
return {
|
|
12
|
-
labels: [],
|
|
13
|
-
datasets: [{ data: [] }]
|
|
14
|
-
};
|
|
15
|
-
const u = A(n), c = R(n), d = o.data;
|
|
16
|
-
return {
|
|
17
|
-
labels: d.map((e) => e[o.dimension.name]),
|
|
18
|
-
datasets: o.measures.map((e, r) => {
|
|
19
|
-
var m, b, C, p;
|
|
20
|
-
const h = !!((m = e.inputs) != null && m.connectGaps), l = d.map((g) => g[e.name] ?? (h ? 0 : null)), i = (b = e.inputs) == null ? void 0 : b.lineColor, a = v(), t = M(i) ? i : k(
|
|
21
|
-
`${c}.charts.backgroundColors`,
|
|
22
|
-
e.name,
|
|
23
|
-
n.charts.backgroundColors ?? a,
|
|
24
|
-
r
|
|
25
|
-
), s = M(i) ? i : k(
|
|
26
|
-
`${c}.charts.borderColors`,
|
|
27
|
-
e.name,
|
|
28
|
-
n.charts.borderColors ?? a,
|
|
29
|
-
r
|
|
30
|
-
);
|
|
31
|
-
return {
|
|
32
|
-
clip: o.hasMinMaxYAxisRange,
|
|
33
|
-
label: u.dimensionOrMeasureTitle(e),
|
|
34
|
-
data: l,
|
|
35
|
-
backgroundColor: T(t, 0.5),
|
|
36
|
-
pointBackgroundColor: t,
|
|
37
|
-
borderDash: (C = e.inputs) != null && C.dashedLine ? [
|
|
38
|
-
f("--em-linechart-line-dash", "0.25rem"),
|
|
39
|
-
f("--em-linechart-line-gap", "0.25rem")
|
|
40
|
-
] : void 0,
|
|
41
|
-
borderColor: s,
|
|
42
|
-
fill: !!((p = e.inputs) != null && p.fillUnderLine)
|
|
43
|
-
};
|
|
44
|
-
})
|
|
45
|
-
};
|
|
46
|
-
}, D = (o, n) => {
|
|
47
|
-
var l, i;
|
|
48
|
-
const { dimension: u, data: c, measures: d, onLineClicked: e } = o, r = A(n);
|
|
49
|
-
return j({
|
|
50
|
-
plugins: {
|
|
51
|
-
datalabels: {
|
|
52
|
-
labels: {
|
|
53
|
-
value: {
|
|
54
|
-
formatter: (a, t) => {
|
|
55
|
-
const s = d[t.datasetIndex];
|
|
56
|
-
return r.data(s, a);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
},
|
|
61
|
-
tooltip: {
|
|
62
|
-
callbacks: {
|
|
63
|
-
title: (a) => {
|
|
64
|
-
var s;
|
|
65
|
-
const t = (s = a[0]) == null ? void 0 : s.label;
|
|
66
|
-
return r.data(u, t);
|
|
67
|
-
},
|
|
68
|
-
label: (a) => {
|
|
69
|
-
const t = d[a.datasetIndex], s = a.raw;
|
|
70
|
-
return `${r.data(u, a.dataset.label) || ""}: ${r.data(t, s)}`;
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
},
|
|
75
|
-
scales: {
|
|
76
|
-
x: {
|
|
77
|
-
ticks: {
|
|
78
|
-
callback: (a) => {
|
|
79
|
-
if (!c || !c.labels) return;
|
|
80
|
-
const t = c.labels[Number(a)];
|
|
81
|
-
return r.data(u, t);
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
},
|
|
85
|
-
y: {
|
|
86
|
-
ticks: {
|
|
87
|
-
callback: (a) => r.data(d[0], a)
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
},
|
|
91
|
-
onClick: (a, t, s) => {
|
|
92
|
-
if (!e) return;
|
|
93
|
-
const m = t[0], b = m ? s.data.labels[m.index] : null;
|
|
94
|
-
e({
|
|
95
|
-
dimensionValue: b
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
}, ((i = (l = n.charts) == null ? void 0 : l.lineChartDefaultPro) == null ? void 0 : i.options) || {});
|
|
99
|
-
}, $ = (o) => {
|
|
100
|
-
const n = w();
|
|
101
|
-
P(n);
|
|
102
|
-
const { title: u, description: c, xAxisLabel: d, yAxisLabel: e } = S(o), {
|
|
103
|
-
hideMenu: r,
|
|
104
|
-
measures: h,
|
|
105
|
-
xAxis: l,
|
|
106
|
-
reverseXAxis: i,
|
|
107
|
-
showLegend: a,
|
|
108
|
-
showLogarithmicScale: t,
|
|
109
|
-
showTooltips: s,
|
|
110
|
-
showValueLabels: m,
|
|
111
|
-
yAxisRangeMax: b,
|
|
112
|
-
yAxisRangeMin: C,
|
|
113
|
-
onLineClicked: p
|
|
114
|
-
} = o, g = _({
|
|
115
|
-
results: o.results,
|
|
116
|
-
dimension: l
|
|
117
|
-
}), x = B(
|
|
118
|
-
{
|
|
119
|
-
data: g.data,
|
|
120
|
-
dimension: l,
|
|
121
|
-
measures: h,
|
|
122
|
-
hasMinMaxYAxisRange: C != null || b != null
|
|
123
|
-
},
|
|
124
|
-
n
|
|
125
|
-
), y = D(
|
|
126
|
-
{ data: x, dimension: l, measures: h, onLineClicked: p },
|
|
127
|
-
n
|
|
128
|
-
);
|
|
129
|
-
return /* @__PURE__ */ L.jsx(
|
|
130
|
-
F,
|
|
131
|
-
{
|
|
132
|
-
data: g,
|
|
133
|
-
dimensionsAndMeasures: [...h, l],
|
|
134
|
-
errorMessage: g.error,
|
|
135
|
-
description: c,
|
|
136
|
-
title: u,
|
|
137
|
-
hideMenu: r,
|
|
138
|
-
children: /* @__PURE__ */ L.jsx(
|
|
139
|
-
O,
|
|
140
|
-
{
|
|
141
|
-
data: x,
|
|
142
|
-
reverseXAxis: i,
|
|
143
|
-
showLegend: a,
|
|
144
|
-
showLogarithmicScale: t,
|
|
145
|
-
showTooltips: s,
|
|
146
|
-
showValueLabels: m,
|
|
147
|
-
xAxisLabel: d,
|
|
148
|
-
yAxisLabel: e,
|
|
149
|
-
yAxisRangeMax: b,
|
|
150
|
-
yAxisRangeMin: C,
|
|
151
|
-
options: y
|
|
152
|
-
}
|
|
153
|
-
)
|
|
154
|
-
}
|
|
155
|
-
);
|
|
156
|
-
}, U = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
157
|
-
__proto__: null,
|
|
158
|
-
default: $
|
|
159
|
-
}, Symbol.toStringTag, { value: "Module" }));
|
|
160
|
-
export {
|
|
161
|
-
$ as L,
|
|
162
|
-
D as a,
|
|
163
|
-
B as g,
|
|
164
|
-
U as i
|
|
165
|
-
};
|
|
166
|
-
//# sourceMappingURL=index-DEsLQa4J.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-DEsLQa4J.js","sources":["../src/components/charts/lines/LineChartDefaultPro/LineChartDefaultPro.utils.ts","../src/components/charts/lines/LineChartDefaultPro/index.tsx"],"sourcesContent":["import { DataResponse, Dimension, Measure } from '@embeddable.com/core';\nimport { Theme } from '../../../../theme/theme.types';\nimport { ChartData, ChartOptions } from 'chart.js';\nimport { getThemeFormatter } from '../../../../theme/formatter/formatter.utils';\nimport { getObjectStableKey } from '../../../../utils.ts/object.utils';\nimport { getChartColors, getStyleNumber } from '@embeddable.com/remarkable-ui';\nimport { getColor } from '../../../../theme/styles/styles.utils';\nimport { mergician } from 'mergician';\nimport { isColorValid, setColorAlpha } from '../../../../utils.ts/color.utils';\nimport { LineChartProOptionsClick } from '../lines.utils';\n\nexport const getLineChartProData = (\n props: {\n data: DataResponse['data'];\n dimension: Dimension;\n measures: Measure[];\n hasMinMaxYAxisRange: boolean;\n },\n theme: Theme,\n): ChartData<'line'> => {\n if (!props.data) {\n return {\n labels: [],\n datasets: [{ data: [] }],\n };\n }\n\n const themeFormatter = getThemeFormatter(theme);\n\n const themeKey = getObjectStableKey(theme);\n const groupedData = props.data;\n\n return {\n labels: groupedData.map((item) => {\n return item[props.dimension.name];\n }),\n datasets: props.measures.map((measure, index) => {\n const zeroFill = Boolean(measure.inputs?.['connectGaps']);\n const values = groupedData.map((item) => item[measure.name] ?? (zeroFill ? 0 : null));\n\n const lineColor = measure.inputs?.['lineColor'];\n const chartColors = getChartColors();\n const backgroundColor = isColorValid(lineColor)\n ? lineColor\n : getColor(\n `${themeKey}.charts.backgroundColors`,\n measure.name,\n theme.charts.backgroundColors ?? chartColors,\n index,\n );\n\n const borderColor = isColorValid(lineColor)\n ? lineColor\n : getColor(\n `${themeKey}.charts.borderColors`,\n measure.name,\n theme.charts.borderColors ?? chartColors,\n index,\n );\n\n return {\n clip: props.hasMinMaxYAxisRange,\n label: themeFormatter.dimensionOrMeasureTitle(measure),\n data: values,\n backgroundColor: setColorAlpha(backgroundColor, 0.5),\n pointBackgroundColor: backgroundColor,\n borderDash: measure.inputs?.['dashedLine']\n ? [\n getStyleNumber('--em-linechart-line-dash', '0.25rem'),\n getStyleNumber('--em-linechart-line-gap', '0.25rem'),\n ]\n : undefined,\n borderColor,\n fill: Boolean(measure.inputs?.['fillUnderLine']),\n } as ChartData<'line'>['datasets'][number];\n }),\n };\n};\n\nexport const getLineChartProOptions = (\n options: {\n dimension: Dimension;\n measures: Measure[];\n data: ChartData<'line'>;\n onLineClicked?: LineChartProOptionsClick;\n },\n theme: Theme,\n): ChartOptions<'line'> => {\n const { dimension, data, measures, onLineClicked } = options;\n const themeFormatter = getThemeFormatter(theme);\n\n const lineChartOptions: ChartOptions<'line'> = {\n plugins: {\n datalabels: {\n labels: {\n value: {\n formatter: (value: string | number, context) => {\n const measure = measures[context.datasetIndex]!;\n return themeFormatter.data(measure, value);\n },\n },\n },\n },\n tooltip: {\n callbacks: {\n title: (context) => {\n const label = context[0]?.label;\n return themeFormatter.data(dimension, label);\n },\n label: (context) => {\n const measure = measures[context.datasetIndex]!;\n const raw = context.raw as number;\n return `${themeFormatter.data(dimension, context.dataset.label) || ''}: ${themeFormatter.data(measure, raw)}`;\n },\n },\n },\n },\n scales: {\n x: {\n ticks: {\n callback: (value) => {\n if (!data || !data.labels) return undefined;\n\n const label = data.labels[Number(value)] as string;\n return themeFormatter.data(dimension, label);\n },\n },\n },\n y: {\n ticks: {\n callback: (value) => {\n return themeFormatter.data(measures[0]!, value);\n },\n },\n },\n },\n onClick: (_event, elements, chart) => {\n if (!onLineClicked) return;\n\n const element = elements[0];\n const dimensionValue = (element ? chart.data.labels![element.index] : null) as string | null;\n\n onLineClicked({\n dimensionValue,\n });\n },\n };\n\n return mergician(lineChartOptions, theme.charts?.lineChartDefaultPro?.options || {});\n};\n","import { useTheme } from '@embeddable.com/react';\nimport { Theme } from '../../../../theme/theme.types';\nimport { DataResponse, Dimension, Measure } from '@embeddable.com/core';\nimport { i18nSetup } from '../../../../theme/i18n/i18n';\nimport { resolveI18nProps } from '../../../component.utils';\nimport { ChartCard, ChartCardHeaderProps } from '../../shared/ChartCard/ChartCard';\nimport { getLineChartProData, getLineChartProOptions } from './LineChartDefaultPro.utils';\nimport { useFillGaps } from '../../charts.fillGaps.hooks';\nimport { LineChartProOptionsClick } from '../lines.utils';\nimport { LineChart } from '@embeddable.com/remarkable-ui';\n\nexport type LineChartProPropsOnLineClicked = { axisDimensionValue: string | null };\n\ntype LineChartProProp = {\n xAxis: Dimension;\n measures: Measure[];\n results: DataResponse;\n reverseXAxis?: boolean;\n showLegend?: boolean;\n showLogarithmicScale?: boolean;\n showTooltips?: boolean;\n showValueLabels?: boolean;\n\n xAxisLabel?: string;\n yAxisLabel?: string;\n yAxisRangeMax?: number;\n yAxisRangeMin?: number;\n onLineClicked?: LineChartProOptionsClick;\n} & ChartCardHeaderProps;\n\nconst LineChartPro = (props: LineChartProProp) => {\n const theme: Theme = useTheme() as Theme;\n i18nSetup(theme);\n\n const { title, description, xAxisLabel, yAxisLabel } = resolveI18nProps(props);\n const {\n hideMenu,\n measures,\n xAxis,\n reverseXAxis,\n showLegend,\n showLogarithmicScale,\n showTooltips,\n showValueLabels,\n yAxisRangeMax,\n yAxisRangeMin,\n onLineClicked,\n } = props;\n\n const results = useFillGaps({\n results: props.results,\n dimension: xAxis,\n });\n\n const data = getLineChartProData(\n {\n data: results.data,\n dimension: xAxis,\n measures,\n hasMinMaxYAxisRange: Boolean(yAxisRangeMin != null || yAxisRangeMax != null),\n },\n theme,\n );\n const options = getLineChartProOptions(\n { data, dimension: xAxis, measures, onLineClicked },\n theme,\n );\n\n return (\n <ChartCard\n data={results}\n dimensionsAndMeasures={[...measures, xAxis]}\n errorMessage={results.error}\n description={description}\n title={title}\n hideMenu={hideMenu}\n >\n <LineChart\n data={data}\n reverseXAxis={reverseXAxis}\n showLegend={showLegend}\n showLogarithmicScale={showLogarithmicScale}\n showTooltips={showTooltips}\n showValueLabels={showValueLabels}\n xAxisLabel={xAxisLabel}\n yAxisLabel={yAxisLabel}\n yAxisRangeMax={yAxisRangeMax}\n yAxisRangeMin={yAxisRangeMin}\n options={options}\n />\n </ChartCard>\n );\n};\n\nexport default LineChartPro;\n"],"names":["getLineChartProData","props","theme","themeFormatter","getThemeFormatter","themeKey","getObjectStableKey","groupedData","item","measure","index","zeroFill","_a","values","lineColor","_b","chartColors","getChartColors","backgroundColor","isColorValid","getColor","borderColor","setColorAlpha","_c","getStyleNumber","_d","getLineChartProOptions","options","dimension","data","measures","onLineClicked","mergician","value","context","label","raw","_event","elements","chart","element","dimensionValue","LineChartPro","useTheme","i18nSetup","title","description","xAxisLabel","yAxisLabel","resolveI18nProps","hideMenu","xAxis","reverseXAxis","showLegend","showLogarithmicScale","showTooltips","showValueLabels","yAxisRangeMax","yAxisRangeMin","results","useFillGaps","jsx","ChartCard","LineChart"],"mappings":"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"}
|