@embeddable.com/remarkable-pro 0.0.3 → 0.0.5

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 (116) hide show
  1. package/README.md +68 -17
  2. package/dist/BarChartDefaultHorizontalPro.js +25 -85
  3. package/dist/BarChartDefaultHorizontalPro.js.map +1 -1
  4. package/dist/BarChartDefaultPro.js +25 -84
  5. package/dist/BarChartDefaultPro.js.map +1 -1
  6. package/dist/BarChartGroupedHorizontalPro.js +33 -102
  7. package/dist/BarChartGroupedHorizontalPro.js.map +1 -1
  8. package/dist/BarChartGroupedPro.js +27 -95
  9. package/dist/BarChartGroupedPro.js.map +1 -1
  10. package/dist/BarChartStackedHorizontalPro.js +28 -98
  11. package/dist/BarChartStackedHorizontalPro.js.map +1 -1
  12. package/dist/BarChartStackedPro.js +28 -97
  13. package/dist/BarChartStackedPro.js.map +1 -1
  14. package/dist/{ChartCard-CsKQOusx.js → ChartCard-DPqhmLst.js} +19 -19
  15. package/dist/{ChartCard-CsKQOusx.js.map → ChartCard-DPqhmLst.js.map} +1 -1
  16. package/dist/{Color.type.emb-9H0O-uuD.js → Color.type.emb-WlORCMYm.js} +2 -2
  17. package/dist/{Color.type.emb-9H0O-uuD.js.map → Color.type.emb-WlORCMYm.js.map} +1 -1
  18. package/dist/ColorEditor.js +2 -2
  19. package/dist/{ComparisonPeriod.type.emb-C3XjaFoD.js → ComparisonPeriod.type.emb-2GetmOu1.js} +2 -2
  20. package/dist/{ComparisonPeriod.type.emb-C3XjaFoD.js.map → ComparisonPeriod.type.emb-2GetmOu1.js.map} +1 -1
  21. package/dist/ComparisonPeriodSelectFieldPro.js +17 -58
  22. package/dist/ComparisonPeriodSelectFieldPro.js.map +1 -1
  23. package/dist/DateRangeSelectFieldPro.js +3 -3
  24. package/dist/DonutChartPro.js +3 -3
  25. package/dist/DonutLabelChartPro.js +3 -3
  26. package/dist/EditorCard-BaL9GbQ9.js +32 -0
  27. package/dist/{EditorCard-BMEwnQuU.js.map → EditorCard-BaL9GbQ9.js.map} +1 -1
  28. package/dist/HeatMapPro.js +26 -93
  29. package/dist/HeatMapPro.js.map +1 -1
  30. package/dist/KpiChartNumberComparisonPro.js +25 -94
  31. package/dist/KpiChartNumberComparisonPro.js.map +1 -1
  32. package/dist/KpiChartNumberPro.js +14 -31
  33. package/dist/KpiChartNumberPro.js.map +1 -1
  34. package/dist/LineChartComparisonDefaultPro.js +59 -370
  35. package/dist/LineChartComparisonDefaultPro.js.map +1 -1
  36. package/dist/LineChartDefaultPro.js +31 -179
  37. package/dist/LineChartDefaultPro.js.map +1 -1
  38. package/dist/LineChartGroupedPro.js +30 -174
  39. package/dist/LineChartGroupedPro.js.map +1 -1
  40. package/dist/MultiSelectFieldPro.js +3 -3
  41. package/dist/PieChartPro.js +3 -3
  42. package/dist/PivotTablePro.js +23 -86
  43. package/dist/PivotTablePro.js.map +1 -1
  44. package/dist/SingleSelectFieldPro.js +3 -3
  45. package/dist/TableChartPaginated.js +37 -172
  46. package/dist/TableChartPaginated.js.map +1 -1
  47. package/dist/{bars.utils-BU_k5fia.js → bars.utils-aO0eZx5e.js} +7 -7
  48. package/dist/{bars.utils-BU_k5fia.js.map → bars.utils-aO0eZx5e.js.map} +1 -1
  49. package/dist/{charts.utils-rO92wRxO.js → charts.utils-CZnXoUqF.js} +4 -4
  50. package/dist/{charts.utils-rO92wRxO.js.map → charts.utils-CZnXoUqF.js.map} +1 -1
  51. package/dist/{component.constants-uP1WYyUb.js → component.constants-C7cqSNbp.js} +2 -2
  52. package/dist/{component.constants-uP1WYyUb.js.map → component.constants-C7cqSNbp.js.map} +1 -1
  53. package/dist/components/charts/tables/HeatMapPro/index.d.ts.map +1 -1
  54. package/dist/components/charts/tables/PivotTablePro/index.d.ts.map +1 -1
  55. package/dist/components/charts/tables/tables.hooks.d.ts +17 -0
  56. package/dist/components/charts/tables/tables.hooks.d.ts.map +1 -0
  57. package/dist/embeddable-components.json +13 -13
  58. package/dist/{formatter.utils-CeEdL8uQ.js → formatter.utils-CfrcSyDX.js} +2 -2
  59. package/dist/{formatter.utils-CeEdL8uQ.js.map → formatter.utils-CfrcSyDX.js.map} +1 -1
  60. package/dist/{index-Dwl9clc9.js → index-2EH0Voxh.js} +5 -5
  61. package/dist/{index-Dwl9clc9.js.map → index-2EH0Voxh.js.map} +1 -1
  62. package/dist/index-85Nzu6wl.js +95 -0
  63. package/dist/index-85Nzu6wl.js.map +1 -0
  64. package/dist/index-9GEogpMN.js +82 -0
  65. package/dist/index-9GEogpMN.js.map +1 -0
  66. package/dist/{index-BWpUwKTH.js → index-BAomPP89.js} +5 -5
  67. package/dist/{index-BWpUwKTH.js.map → index-BAomPP89.js.map} +1 -1
  68. package/dist/{index-DLFOG9Ar.js → index-BQf2W8Zn.js} +6 -6
  69. package/dist/{index-DLFOG9Ar.js.map → index-BQf2W8Zn.js.map} +1 -1
  70. package/dist/index-BSc_Axva.js +326 -0
  71. package/dist/index-BSc_Axva.js.map +1 -0
  72. package/dist/index-BjdJeBiT.js +73 -0
  73. package/dist/index-BjdJeBiT.js.map +1 -0
  74. package/dist/index-C1EIos9z.js +159 -0
  75. package/dist/index-C1EIos9z.js.map +1 -0
  76. package/dist/index-C_F-ZHJz.js +163 -0
  77. package/dist/index-C_F-ZHJz.js.map +1 -0
  78. package/dist/index-Cc-mtCkt.js +83 -0
  79. package/dist/index-Cc-mtCkt.js.map +1 -0
  80. package/dist/index-CvmifdRS.js +72 -0
  81. package/dist/index-CvmifdRS.js.map +1 -0
  82. package/dist/index-D1L8EF47.js +82 -0
  83. package/dist/index-D1L8EF47.js.map +1 -0
  84. package/dist/{index-DedIqjbn.js → index-D8D1R5YG.js} +17 -18
  85. package/dist/{index-DedIqjbn.js.map → index-D8D1R5YG.js.map} +1 -1
  86. package/dist/index-DGz1wzRd.js +81 -0
  87. package/dist/index-DGz1wzRd.js.map +1 -0
  88. package/dist/index-DORMEL0e.js +82 -0
  89. package/dist/index-DORMEL0e.js.map +1 -0
  90. package/dist/index-DTuHmdil.js +89 -0
  91. package/dist/index-DTuHmdil.js.map +1 -0
  92. package/dist/index-DZU1PTjb.js +148 -0
  93. package/dist/index-DZU1PTjb.js.map +1 -0
  94. package/dist/index-DaeSYZkv.js +30 -0
  95. package/dist/index-DaeSYZkv.js.map +1 -0
  96. package/dist/{index-Brb617sy.js → index-Dhwlo6sD.js} +5 -5
  97. package/dist/{index-Brb617sy.js.map → index-Dhwlo6sD.js.map} +1 -1
  98. package/dist/{index-B8bT85NR.js → index-L9ViZuWi.js} +5 -5
  99. package/dist/{index-B8bT85NR.js.map → index-L9ViZuWi.js.map} +1 -1
  100. package/dist/{index-DrosyYQD.js → index-WCMGd0_l.js} +15 -14
  101. package/dist/{index-DrosyYQD.js.map → index-WCMGd0_l.js.map} +1 -1
  102. package/dist/index-wy7P41uG.js +56 -0
  103. package/dist/index-wy7P41uG.js.map +1 -0
  104. package/dist/index.d.ts +27 -6
  105. package/dist/index.d.ts.map +1 -1
  106. package/dist/index.js +117 -74
  107. package/dist/index.js.map +1 -1
  108. package/dist/{pies.utils-Dap7Duqb.js → pies.utils-DlK4ABKU.js} +5 -5
  109. package/dist/{pies.utils-Dap7Duqb.js.map → pies.utils-DlK4ABKU.js.map} +1 -1
  110. package/dist/remarkable-pro.css +1 -1
  111. package/dist/tables.hooks-BQdyUxau.js +45 -0
  112. package/dist/tables.hooks-BQdyUxau.js.map +1 -0
  113. package/dist/{timeRange.utils-J3a4XL64.js → timeRange.utils-CWl9EGOR.js} +2 -2
  114. package/dist/{timeRange.utils-J3a4XL64.js.map → timeRange.utils-CWl9EGOR.js.map} +1 -1
  115. package/package.json +2 -2
  116. package/dist/EditorCard-BMEwnQuU.js +0 -32
@@ -1,190 +1,42 @@
1
- import { useTheme as V, defineComponent as v } from "@embeddable.com/react";
2
- import { a as w, r as R, v as F, E as L, g as x, z as P, F as S, G as T, I as B, J as O, K as j, M as G, N as I, O as $, P as K, S as N, T as X, H as z } from "./component.constants-uP1WYyUb.js";
3
- import { a as E, h as f, m as U, j as A, L as Y, V as _, l as H } from "./index-DedIqjbn.js";
4
- import { C as J } from "./ChartCard-CsKQOusx.js";
5
- import { g as D } from "./formatter.utils-CeEdL8uQ.js";
6
- import { g as W, a as k } from "./object.utils-D_Zzon-H.js";
7
- import { i as y, s as q } from "./color.utils-BSg_DFOh.js";
8
- import { u as Q } from "./charts.fillGaps.hooks-YayOXVmt.js";
9
- import { C as Z } from "./Color.type.emb-9H0O-uuD.js";
10
- const ee = (e, l) => {
11
- if (!e.data)
12
- return {
13
- labels: [],
14
- datasets: [{ data: [] }]
15
- };
16
- const m = D(l), i = W(l), c = e.data;
17
- return {
18
- labels: c.map((s) => s[e.dimension.name]),
19
- datasets: e.measures.map((s, n) => {
20
- var d, b, g, C;
21
- const u = !!((d = s.inputs) != null && d.connectGaps), h = c.map((p) => p[s.name] ?? (u ? 0 : null)), r = (b = s.inputs) == null ? void 0 : b.lineColor, a = E(), t = y(r) ? r : k(
22
- `${i}.charts.backgroundColors`,
23
- s.name,
24
- l.charts.backgroundColors ?? a,
25
- n
26
- ), o = y(r) ? r : k(
27
- `${i}.charts.borderColors`,
28
- s.name,
29
- l.charts.borderColors ?? a,
30
- n
31
- );
32
- return {
33
- clip: e.hasMinMaxYAxisRange,
34
- label: m.dimensionOrMeasureTitle(s),
35
- data: h,
36
- backgroundColor: q(t, 0.5),
37
- pointBackgroundColor: t,
38
- borderDash: (g = s.inputs) != null && g.dashedLine ? [
39
- f("--em-linechart-line-dash", "0.25rem"),
40
- f("--em-linechart-line-gap", "0.25rem")
41
- ] : void 0,
42
- borderColor: o,
43
- fill: !!((C = s.inputs) != null && C.fillUnderLine)
44
- };
45
- })
46
- };
47
- }, ae = (e, l) => {
48
- var h, r;
49
- const { dimension: m, data: i, measures: c, onLineClicked: s } = e, n = D(l);
50
- return U({
51
- plugins: {
52
- datalabels: {
53
- labels: {
54
- value: {
55
- formatter: (a, t) => {
56
- const o = c[t.datasetIndex];
57
- return n.data(o, a);
58
- }
59
- }
60
- }
61
- },
62
- tooltip: {
63
- callbacks: {
64
- title: (a) => {
65
- var o;
66
- const t = (o = a[0]) == null ? void 0 : o.label;
67
- return n.data(m, t);
68
- },
69
- label: (a) => {
70
- const t = c[a.datasetIndex], o = a.raw;
71
- return `${n.data(m, a.dataset.label) || ""}: ${n.data(t, o)}`;
72
- }
73
- }
74
- }
75
- },
76
- scales: {
77
- x: {
78
- ticks: {
79
- callback: (a) => {
80
- if (!i || !i.labels) return;
81
- const t = i.labels[Number(a)];
82
- return n.data(m, t);
83
- }
84
- }
85
- },
86
- y: {
87
- ticks: {
88
- callback: (a) => n.data(c[0], a)
89
- }
90
- }
91
- },
92
- onClick: (a, t, o) => {
93
- const d = t[0], b = d ? o.data.labels[d.index] : null;
94
- s({
95
- dimensionValue: b
96
- });
97
- }
98
- }, ((r = (h = l.charts) == null ? void 0 : h.lineChartDefaultPro) == null ? void 0 : r.options) || {});
99
- }, se = (e) => {
100
- const l = V();
101
- w(l);
102
- const { title: m, description: i, xAxisLabel: c, yAxisLabel: s } = R(e), {
103
- measures: n,
104
- xAxis: u,
105
- reverseXAxis: h,
106
- showLegend: r,
107
- showLogarithmicScale: a,
108
- showTooltips: t,
109
- showValueLabels: o,
110
- yAxisRangeMax: d,
111
- yAxisRangeMin: b,
112
- onLineClicked: g
113
- } = e, C = Q({
114
- results: e.results,
115
- dimension: u
116
- }), p = ee(
117
- {
118
- data: C.data,
119
- dimension: u,
120
- measures: n,
121
- hasMinMaxYAxisRange: b != null || d != null
122
- },
123
- l
124
- ), M = ae(
125
- { data: p, dimension: u, measures: n, onLineClicked: g },
126
- l
127
- );
128
- return /* @__PURE__ */ A.jsx(
129
- J,
130
- {
131
- data: C,
132
- dimensionsAndMeasures: [...n, u],
133
- errorMessage: C.error,
134
- subtitle: i,
135
- title: m,
136
- children: /* @__PURE__ */ A.jsx(
137
- Y,
138
- {
139
- data: p,
140
- reverseXAxis: h,
141
- showLegend: r,
142
- showLogarithmicScale: a,
143
- showTooltips: t,
144
- showValueLabels: o,
145
- xAxisLabel: c,
146
- yAxisLabel: s,
147
- yAxisRangeMax: d,
148
- yAxisRangeMin: b,
149
- options: M
150
- }
151
- )
152
- }
153
- );
154
- }, te = {
1
+ import { defineComponent as i } from "@embeddable.com/react";
2
+ import { v as l, E as s, g as a, z as n, F as t, G as o, I as r, J as m, K as u, M as d, N as c, O as p, P as x, S as L, T as f, H as C } from "./component.constants-C7cqSNbp.js";
3
+ import { L as h } from "./index-C_F-ZHJz.js";
4
+ import { V as b, l as g } from "./index-D8D1R5YG.js";
5
+ import { C as A } from "./Color.type.emb-WlORCMYm.js";
6
+ const D = {
155
7
  name: "LineChartDefaultPro",
156
8
  label: "Line Chart - Default",
157
9
  category: "Line Charts",
158
10
  inputs: [
159
- F,
11
+ l,
160
12
  {
161
- ...L,
13
+ ...s,
162
14
  inputs: [
163
- ...L.inputs,
164
- { ...x, name: "fillUnderLine", label: "Fill under line" },
15
+ ...s.inputs,
16
+ { ...a, name: "fillUnderLine", label: "Fill under line" },
165
17
  {
166
- type: Z,
18
+ type: A,
167
19
  category: "Component Settings",
168
20
  name: "lineColor",
169
21
  label: "Line color"
170
22
  },
171
- { ...x, name: "connectGaps", label: "Connect gaps", defaultValue: !0 },
172
- { ...x, name: "dashedLine", label: "Dashed line", defaultValue: !1 }
23
+ { ...a, name: "connectGaps", label: "Connect gaps", defaultValue: !0 },
24
+ { ...a, name: "dashedLine", label: "Dashed line", defaultValue: !1 }
173
25
  ]
174
26
  },
175
- { ...P, label: "X-axis", name: "xAxis" },
176
- S,
177
- T,
178
- B,
179
- O,
180
- j,
181
- G,
182
- I,
183
- $,
184
- K,
185
- N,
186
- X,
187
- z
27
+ { ...n, label: "X-axis", name: "xAxis" },
28
+ t,
29
+ o,
30
+ r,
31
+ m,
32
+ u,
33
+ d,
34
+ c,
35
+ p,
36
+ x,
37
+ L,
38
+ f,
39
+ C
188
40
  ],
189
41
  events: [
190
42
  {
@@ -199,10 +51,10 @@ const ee = (e, l) => {
199
51
  ]
200
52
  }
201
53
  ]
202
- }, be = v(se, te, {
54
+ }, P = i(h, D, {
203
55
  props: (e) => ({
204
56
  ...e,
205
- results: H({
57
+ results: g({
206
58
  limit: e.maxResults,
207
59
  from: e.dataset,
208
60
  select: [...e.measures, e.xAxis]
@@ -210,12 +62,12 @@ const ee = (e, l) => {
210
62
  }),
211
63
  events: {
212
64
  onLineClicked: (e) => ({
213
- axisDimensionValue: e.dimensionValue || _.noFilter()
65
+ axisDimensionValue: e.dimensionValue || b.noFilter()
214
66
  })
215
67
  }
216
68
  });
217
69
  export {
218
- be as default,
219
- te as meta
70
+ P as default,
71
+ D as meta
220
72
  };
221
73
  //# sourceMappingURL=LineChartDefaultPro.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"LineChartDefaultPro.js","sources":["../src/components/charts/lines/LineChartDefaultPro/LineChartDefaultPro.utils.ts","../src/components/charts/lines/LineChartDefaultPro/index.tsx","../src/components/charts/lines/LineChartDefaultPro/LineChartDefaultPro.emb.ts"],"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 { getChartContrastColors, 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 chartContrastColors = getChartContrastColors();\n const backgroundColor = isColorValid(lineColor)\n ? lineColor\n : getColor(\n `${themeKey}.charts.backgroundColors`,\n measure.name,\n theme.charts.backgroundColors ?? chartContrastColors,\n index,\n );\n\n const borderColor = isColorValid(lineColor)\n ? lineColor\n : getColor(\n `${themeKey}.charts.borderColors`,\n measure.name,\n theme.charts.borderColors ?? chartContrastColors,\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 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 } 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 description: string;\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 title: string;\n xAxisLabel: string;\n yAxisLabel: string;\n yAxisRangeMax?: number;\n yAxisRangeMin?: number;\n onLineClicked: LineChartProOptionsClick;\n};\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 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 subtitle={description}\n title={title}\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","import { defineComponent, EmbeddedComponentMeta, Inputs } from '@embeddable.com/react';\nimport {\n dataset,\n description,\n dimensionWithDateBounds,\n genericBoolean,\n maxResults,\n measures,\n reverseXAxis,\n showLegend,\n showLogarithmicScale,\n showTooltips,\n showValueLabels,\n title,\n xAxisLabel,\n yAxisLabel,\n yAxisRangeMax,\n yAxisRangeMin,\n} from '../../../component.constants';\nimport LineChartDefaultPro from './index';\nimport { loadData, Value } from '@embeddable.com/core';\nimport { LineChartProOptionsClickArg } from '../lines.utils';\nimport ColorType from '../../../../editors/ColorEditor/Color.type.emb';\n\nexport const meta = {\n name: 'LineChartDefaultPro',\n label: 'Line Chart - Default',\n category: 'Line Charts',\n inputs: [\n dataset,\n {\n ...measures,\n inputs: [\n ...measures.inputs,\n { ...genericBoolean, name: 'fillUnderLine', label: 'Fill under line' },\n {\n type: ColorType,\n category: 'Component Settings',\n name: 'lineColor',\n label: 'Line color',\n },\n { ...genericBoolean, name: 'connectGaps', label: 'Connect gaps', defaultValue: true },\n { ...genericBoolean, name: 'dashedLine', label: 'Dashed line', defaultValue: false },\n ],\n },\n { ...dimensionWithDateBounds, label: 'X-axis', name: 'xAxis' },\n title,\n description,\n showLegend,\n showTooltips,\n showValueLabels,\n showLogarithmicScale,\n xAxisLabel,\n yAxisLabel,\n reverseXAxis,\n yAxisRangeMin,\n yAxisRangeMax,\n maxResults,\n ],\n events: [\n {\n name: 'onLineClicked',\n label: 'A line is clicked',\n properties: [\n {\n name: 'axisDimensionValue',\n label: 'Clicked Axis Dimension Value',\n type: 'string',\n },\n ],\n },\n ],\n} as const satisfies EmbeddedComponentMeta;\n\nexport default defineComponent(LineChartDefaultPro, meta, {\n props: (inputs: Inputs<typeof meta>) => {\n return {\n ...inputs,\n results: loadData({\n limit: inputs.maxResults,\n from: inputs.dataset,\n select: [...inputs.measures, inputs.xAxis],\n }),\n };\n },\n events: {\n onLineClicked: (value: LineChartProOptionsClickArg) => {\n return {\n axisDimensionValue: value.dimensionValue || Value.noFilter(),\n };\n },\n },\n});\n"],"names":["getLineChartProData","props","theme","themeFormatter","getThemeFormatter","themeKey","getObjectStableKey","groupedData","item","measure","index","zeroFill","_a","values","lineColor","_b","chartContrastColors","getChartContrastColors","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","xAxis","reverseXAxis","showLegend","showLogarithmicScale","showTooltips","showValueLabels","yAxisRangeMax","yAxisRangeMin","results","useFillGaps","jsx","ChartCard","LineChart","meta","dataset","genericBoolean","ColorType","dimensionWithDateBounds","maxResults","LineChartDefaultPro_emb","defineComponent","LineChartDefaultPro","inputs","loadData","Value"],"mappings":"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"}
1
+ {"version":3,"file":"LineChartDefaultPro.js","sources":["../src/components/charts/lines/LineChartDefaultPro/LineChartDefaultPro.emb.ts"],"sourcesContent":["import { defineComponent, EmbeddedComponentMeta, Inputs } from '@embeddable.com/react';\nimport {\n dataset,\n description,\n dimensionWithDateBounds,\n genericBoolean,\n maxResults,\n measures,\n reverseXAxis,\n showLegend,\n showLogarithmicScale,\n showTooltips,\n showValueLabels,\n title,\n xAxisLabel,\n yAxisLabel,\n yAxisRangeMax,\n yAxisRangeMin,\n} from '../../../component.constants';\nimport LineChartDefaultPro from './index';\nimport { loadData, Value } from '@embeddable.com/core';\nimport { LineChartProOptionsClickArg } from '../lines.utils';\nimport ColorType from '../../../../editors/ColorEditor/Color.type.emb';\n\nexport const meta = {\n name: 'LineChartDefaultPro',\n label: 'Line Chart - Default',\n category: 'Line Charts',\n inputs: [\n dataset,\n {\n ...measures,\n inputs: [\n ...measures.inputs,\n { ...genericBoolean, name: 'fillUnderLine', label: 'Fill under line' },\n {\n type: ColorType,\n category: 'Component Settings',\n name: 'lineColor',\n label: 'Line color',\n },\n { ...genericBoolean, name: 'connectGaps', label: 'Connect gaps', defaultValue: true },\n { ...genericBoolean, name: 'dashedLine', label: 'Dashed line', defaultValue: false },\n ],\n },\n { ...dimensionWithDateBounds, label: 'X-axis', name: 'xAxis' },\n title,\n description,\n showLegend,\n showTooltips,\n showValueLabels,\n showLogarithmicScale,\n xAxisLabel,\n yAxisLabel,\n reverseXAxis,\n yAxisRangeMin,\n yAxisRangeMax,\n maxResults,\n ],\n events: [\n {\n name: 'onLineClicked',\n label: 'A line is clicked',\n properties: [\n {\n name: 'axisDimensionValue',\n label: 'Clicked Axis Dimension Value',\n type: 'string',\n },\n ],\n },\n ],\n} as const satisfies EmbeddedComponentMeta;\n\nexport default defineComponent(LineChartDefaultPro, meta, {\n props: (inputs: Inputs<typeof meta>) => {\n return {\n ...inputs,\n results: loadData({\n limit: inputs.maxResults,\n from: inputs.dataset,\n select: [...inputs.measures, inputs.xAxis],\n }),\n };\n },\n events: {\n onLineClicked: (value: LineChartProOptionsClickArg) => {\n return {\n axisDimensionValue: value.dimensionValue || Value.noFilter(),\n };\n },\n },\n});\n"],"names":["meta","dataset","measures","genericBoolean","ColorType","dimensionWithDateBounds","title","description","showLegend","showTooltips","showValueLabels","showLogarithmicScale","xAxisLabel","yAxisLabel","reverseXAxis","yAxisRangeMin","yAxisRangeMax","maxResults","LineChartDefaultPro_emb","defineComponent","LineChartDefaultPro","inputs","loadData","value","Value"],"mappings":";;;;;AAwBO,MAAMA,IAAO;AAAA,EAClB,MAAM;AAAA,EACN,OAAO;AAAA,EACP,UAAU;AAAA,EACV,QAAQ;AAAA,IACNC;AAAA,IACA;AAAA,MACE,GAAGC;AAAA,MACH,QAAQ;AAAA,QACN,GAAGA,EAAS;AAAA,QACZ,EAAE,GAAGC,GAAgB,MAAM,iBAAiB,OAAO,kBAAA;AAAA,QACnD;AAAA,UACE,MAAMC;AAAA,UACN,UAAU;AAAA,UACV,MAAM;AAAA,UACN,OAAO;AAAA,QAAA;AAAA,QAET,EAAE,GAAGD,GAAgB,MAAM,eAAe,OAAO,gBAAgB,cAAc,GAAA;AAAA,QAC/E,EAAE,GAAGA,GAAgB,MAAM,cAAc,OAAO,eAAe,cAAc,GAAA;AAAA,MAAM;AAAA,IACrF;AAAA,IAEF,EAAE,GAAGE,GAAyB,OAAO,UAAU,MAAM,QAAA;AAAA,IACrDC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,EAAA;AAAA,EAEF,QAAQ;AAAA,IACN;AAAA,MACE,MAAM;AAAA,MACN,OAAO;AAAA,MACP,YAAY;AAAA,QACV;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,UACP,MAAM;AAAA,QAAA;AAAA,MACR;AAAA,IACF;AAAA,EACF;AAEJ,GAEAC,IAAeC,EAAgBC,GAAqBpB,GAAM;AAAA,EACxD,OAAO,CAACqB,OACC;AAAA,IACL,GAAGA;AAAA,IACH,SAASC,EAAS;AAAA,MAChB,OAAOD,EAAO;AAAA,MACd,MAAMA,EAAO;AAAA,MACb,QAAQ,CAAC,GAAGA,EAAO,UAAUA,EAAO,KAAK;AAAA,IAAA,CAC1C;AAAA,EAAA;AAAA,EAGL,QAAQ;AAAA,IACN,eAAe,CAACE,OACP;AAAA,MACL,oBAAoBA,EAAM,kBAAkBC,EAAM,SAAA;AAAA,IAAS;AAAA,EAE/D;AAEJ,CAAC;"}
@@ -1,179 +1,35 @@
1
- import { useTheme as P, defineComponent as R } from "@embeddable.com/react";
2
- import { a as F, r as $, v, D as w, g as y, z as S, w as j, F as O, G as T, H as B, I as K, J as X, K as N, M as U, N as Y, O as z, P as E, S as H, T as J } from "./component.constants-uP1WYyUb.js";
3
- import { a as W, m as _, j as D, L as q, V as G, l as Q } from "./index-DedIqjbn.js";
4
- import { C as Z } from "./ChartCard-CsKQOusx.js";
5
- import { g as M } from "./formatter.utils-CeEdL8uQ.js";
6
- import { g as I, a as V } from "./object.utils-D_Zzon-H.js";
7
- import { s as ee } from "./color.utils-BSg_DFOh.js";
8
- import { g as ae } from "./lines.utils-CFEUUo4k.js";
9
- import { u as se } from "./charts.fillGaps.hooks-YayOXVmt.js";
10
- const ne = (e, t) => {
11
- const c = M(t), { data: r = [], dimension: l, groupDimension: i, measure: n, hasMinMaxYAxisRange: u } = e, m = [...new Set(r.map((s) => s[l.name]).filter((s) => s != null))].sort(), d = [...new Set(r.map((s) => s[i.name]))].filter((s) => s != null), a = I(t), o = W(), p = d.map((s, g) => {
12
- var x;
13
- const b = V(
14
- `${a}.charts.backgroundColors`,
15
- `${i.name}.${s}`,
16
- t.charts.backgroundColors ?? o,
17
- g
18
- ), h = V(
19
- `${a}.charts.borderColors`,
20
- `${i.name}.${s}`,
21
- t.charts.borderColors ?? o,
22
- g
23
- );
24
- return {
25
- clip: u,
26
- label: c.data(i, s),
27
- rawLabel: s,
28
- backgroundColor: ee(b, 0.5),
29
- pointBackgroundColor: b,
30
- fill: (x = n.inputs) == null ? void 0 : x.fillUnderLine,
31
- borderColor: h,
32
- data: m.map((L) => {
33
- var A;
34
- const f = r.find(
35
- (k) => k[i.name] === s && k[l.name] === L
36
- );
37
- return (f == null ? void 0 : f[n.name]) ?? ((A = n.inputs) != null && A.connectGaps ? 0 : null);
38
- })
39
- };
40
- });
41
- return {
42
- labels: m,
43
- datasets: p
44
- };
45
- }, te = (e, t) => {
46
- var m, d;
47
- const { dimension: c, data: r, measure: l, onLineClicked: i } = e, n = M(t), u = {
48
- plugins: {
49
- datalabels: {
50
- labels: {
51
- value: {
52
- formatter: (a) => n.data(l, a)
53
- }
54
- }
55
- },
56
- tooltip: {
57
- callbacks: {
58
- title: (a) => {
59
- var p;
60
- const o = (p = a[0]) == null ? void 0 : p.label;
61
- return n.data(c, o);
62
- },
63
- label: (a) => {
64
- const o = a.raw;
65
- return `${a.dataset.label}: ${n.data(l, o)}`;
66
- }
67
- }
68
- }
69
- },
70
- scales: {
71
- x: {
72
- ticks: {
73
- callback: (a) => {
74
- if (!r || !r.labels) return;
75
- const o = r.labels[Number(a)];
76
- return n.data(c, o);
77
- }
78
- }
79
- },
80
- y: {
81
- ticks: {
82
- callback: (a) => n.data(l, a)
83
- }
84
- }
85
- }
86
- };
87
- return _(
88
- ae({ onLineClicked: i }),
89
- u,
90
- ((d = (m = t.charts) == null ? void 0 : m.lineChartGroupedPro) == null ? void 0 : d.options) || {}
91
- );
92
- }, oe = (e) => {
93
- const t = P();
94
- F(t);
95
- const { title: c, description: r, xAxisLabel: l, yAxisLabel: i } = $(e), {
96
- measure: n,
97
- xAxis: u,
98
- groupBy: m,
99
- reverseXAxis: d,
100
- showLegend: a,
101
- showLogarithmicScale: o,
102
- showTooltips: p,
103
- showValueLabels: s,
104
- yAxisRangeMax: g,
105
- yAxisRangeMin: b,
106
- onLineClicked: h
107
- } = e, C = se({
108
- results: e.results,
109
- dimension: e.xAxis
110
- }), x = ne(
111
- {
112
- data: C.data,
113
- dimension: u,
114
- groupDimension: m,
115
- measure: n,
116
- hasMinMaxYAxisRange: b != null || g != null
117
- },
118
- t
119
- ), L = te(
120
- { data: x, dimension: u, measure: n, onLineClicked: h },
121
- t
122
- );
123
- return /* @__PURE__ */ D.jsx(
124
- Z,
125
- {
126
- data: C,
127
- dimensionsAndMeasures: [n, u, m],
128
- errorMessage: C.error,
129
- subtitle: r,
130
- title: c,
131
- children: /* @__PURE__ */ D.jsx(
132
- q,
133
- {
134
- data: x,
135
- reverseXAxis: d,
136
- showLegend: a,
137
- showLogarithmicScale: o,
138
- showTooltips: p,
139
- showValueLabels: s,
140
- xAxisLabel: l,
141
- yAxisLabel: i,
142
- yAxisRangeMax: g,
143
- yAxisRangeMin: b,
144
- options: L
145
- }
146
- )
147
- }
148
- );
149
- }, re = {
1
+ import { defineComponent as n } from "@embeddable.com/react";
2
+ import { v as o, D as a, g as i, z as l, w as r, F as t, G as m, H as u, I as p, J as d, K as g, M as x, N as c, O as L, P as b, S as V, T as h } from "./component.constants-C7cqSNbp.js";
3
+ import { L as C } from "./index-C1EIos9z.js";
4
+ import { V as s, l as D } from "./index-D8D1R5YG.js";
5
+ const f = {
150
6
  name: "LineChartGroupedPro",
151
7
  label: "Line Chart - Grouped",
152
8
  category: "Line Charts",
153
9
  inputs: [
154
- v,
10
+ o,
155
11
  {
156
- ...w,
12
+ ...a,
157
13
  inputs: [
158
- ...w.inputs,
159
- { ...y, name: "fillUnderLine", label: "Fill under line" },
160
- { ...y, name: "connectGaps", label: "Connect gaps", defaultValue: !0 }
14
+ ...a.inputs,
15
+ { ...i, name: "fillUnderLine", label: "Fill under line" },
16
+ { ...i, name: "connectGaps", label: "Connect gaps", defaultValue: !0 }
161
17
  ]
162
18
  },
163
- { ...S, name: "xAxis", label: "X-axis" },
164
- { ...j, name: "groupBy", label: "Group by" },
165
- O,
166
- T,
167
- B,
168
- K,
169
- X,
170
- N,
171
- U,
172
- Y,
173
- z,
174
- E,
175
- H,
176
- J
19
+ { ...l, name: "xAxis", label: "X-axis" },
20
+ { ...r, name: "groupBy", label: "Group by" },
21
+ t,
22
+ m,
23
+ u,
24
+ p,
25
+ d,
26
+ g,
27
+ x,
28
+ c,
29
+ L,
30
+ b,
31
+ V,
32
+ h
177
33
  ],
178
34
  events: [
179
35
  {
@@ -193,10 +49,10 @@ const ne = (e, t) => {
193
49
  ]
194
50
  }
195
51
  ]
196
- }, xe = R(oe, re, {
52
+ }, w = n(C, f, {
197
53
  props: (e) => ({
198
54
  ...e,
199
- results: Q({
55
+ results: D({
200
56
  limit: e.maxResults,
201
57
  from: e.dataset,
202
58
  select: [e.xAxis, e.groupBy, e.measure]
@@ -204,13 +60,13 @@ const ne = (e, t) => {
204
60
  }),
205
61
  events: {
206
62
  onLineClicked: (e) => ({
207
- axisDimensionValue: e.dimensionValue || G.noFilter(),
208
- groupingDimensionValue: e.groupingDimensionValue || G.noFilter()
63
+ axisDimensionValue: e.dimensionValue || s.noFilter(),
64
+ groupingDimensionValue: e.groupingDimensionValue || s.noFilter()
209
65
  })
210
66
  }
211
67
  });
212
68
  export {
213
- xe as default,
214
- re as meta
69
+ w as default,
70
+ f as meta
215
71
  };
216
72
  //# sourceMappingURL=LineChartGroupedPro.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"LineChartGroupedPro.js","sources":["../src/components/charts/lines/LineChartGroupedPro/LineChartGroupedPro.utils.ts","../src/components/charts/lines/LineChartGroupedPro/index.tsx","../src/components/charts/lines/LineChartGroupedPro/LineChartGroupedPro.emb.ts"],"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 { getChartContrastColors } 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 chartContrastColors = getChartContrastColors();\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 ?? chartContrastColors,\n index,\n );\n\n const borderColor = getColor(\n `${themeKey}.charts.borderColors`,\n `${groupDimension.name}.${groupByItem}`,\n theme.charts.borderColors ?? chartContrastColors,\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 } 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 description: string;\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 title: string;\n xAxisLabel: string;\n yAxisLabel: string;\n yAxisRangeMax?: number;\n yAxisRangeMin?: number;\n onLineClicked: LineChartProOptionsClick;\n};\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 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 subtitle={description}\n title={title}\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","import { defineComponent, EmbeddedComponentMeta, Inputs } from '@embeddable.com/react';\nimport {\n dataset,\n description,\n dimension,\n dimensionWithDateBounds,\n genericBoolean,\n maxResults,\n measure,\n reverseXAxis,\n showLegend,\n showLogarithmicScale,\n showTooltips,\n showValueLabels,\n title,\n xAxisLabel,\n yAxisLabel,\n yAxisRangeMax,\n yAxisRangeMin,\n} from '../../../component.constants';\nimport LineChartGroupedPro from './index';\nimport { loadData, Value } from '@embeddable.com/core';\nimport { LineChartProOptionsClickArg } from '../lines.utils';\n\nexport const meta = {\n name: 'LineChartGroupedPro',\n label: 'Line Chart - Grouped',\n category: 'Line Charts',\n inputs: [\n dataset,\n {\n ...measure,\n inputs: [\n ...measure.inputs,\n { ...genericBoolean, name: 'fillUnderLine', label: 'Fill under line' },\n { ...genericBoolean, name: 'connectGaps', label: 'Connect gaps', defaultValue: true },\n ],\n },\n { ...dimensionWithDateBounds, name: 'xAxis', label: 'X-axis' },\n { ...dimension, name: 'groupBy', label: 'Group by' },\n title,\n description,\n maxResults,\n showLegend,\n showTooltips,\n showValueLabels,\n showLogarithmicScale,\n xAxisLabel,\n yAxisLabel,\n reverseXAxis,\n yAxisRangeMin,\n yAxisRangeMax,\n ],\n events: [\n {\n name: 'onLineClicked',\n label: 'A line is clicked',\n properties: [\n {\n name: 'axisDimensionValue',\n label: 'Clicked Axis Dimension Value',\n type: 'string',\n },\n {\n name: 'groupingDimensionValue',\n label: 'Clicked Grouping Dimension Value',\n type: 'string',\n },\n ],\n },\n ],\n} as const satisfies EmbeddedComponentMeta;\n\nexport default defineComponent(LineChartGroupedPro, meta, {\n props: (inputs: Inputs<typeof meta>) => {\n return {\n ...inputs,\n results: loadData({\n limit: inputs.maxResults,\n from: inputs.dataset,\n select: [inputs.xAxis, inputs.groupBy, inputs.measure],\n }),\n };\n },\n events: {\n onLineClicked: (value: LineChartProOptionsClickArg) => {\n return {\n axisDimensionValue: value.dimensionValue || Value.noFilter(),\n groupingDimensionValue: value.groupingDimensionValue || Value.noFilter(),\n };\n },\n },\n});\n"],"names":["getLineChartGroupedProData","props","theme","themeFormatter","getThemeFormatter","data","dimension","groupDimension","measure","hasMinMaxYAxisRange","axis","d","groupBy","themeKey","getObjectStableKey","chartContrastColors","getChartContrastColors","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","xAxis","reverseXAxis","showLegend","showLogarithmicScale","showTooltips","showValueLabels","yAxisRangeMax","yAxisRangeMin","results","useFillGaps","jsx","ChartCard","LineChart","meta","dataset","genericBoolean","dimensionWithDateBounds","maxResults","LineChartGroupedPro_emb","defineComponent","inputs","loadData","Value"],"mappings":"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"}
1
+ {"version":3,"file":"LineChartGroupedPro.js","sources":["../src/components/charts/lines/LineChartGroupedPro/LineChartGroupedPro.emb.ts"],"sourcesContent":["import { defineComponent, EmbeddedComponentMeta, Inputs } from '@embeddable.com/react';\nimport {\n dataset,\n description,\n dimension,\n dimensionWithDateBounds,\n genericBoolean,\n maxResults,\n measure,\n reverseXAxis,\n showLegend,\n showLogarithmicScale,\n showTooltips,\n showValueLabels,\n title,\n xAxisLabel,\n yAxisLabel,\n yAxisRangeMax,\n yAxisRangeMin,\n} from '../../../component.constants';\nimport LineChartGroupedPro from './index';\nimport { loadData, Value } from '@embeddable.com/core';\nimport { LineChartProOptionsClickArg } from '../lines.utils';\n\nexport const meta = {\n name: 'LineChartGroupedPro',\n label: 'Line Chart - Grouped',\n category: 'Line Charts',\n inputs: [\n dataset,\n {\n ...measure,\n inputs: [\n ...measure.inputs,\n { ...genericBoolean, name: 'fillUnderLine', label: 'Fill under line' },\n { ...genericBoolean, name: 'connectGaps', label: 'Connect gaps', defaultValue: true },\n ],\n },\n { ...dimensionWithDateBounds, name: 'xAxis', label: 'X-axis' },\n { ...dimension, name: 'groupBy', label: 'Group by' },\n title,\n description,\n maxResults,\n showLegend,\n showTooltips,\n showValueLabels,\n showLogarithmicScale,\n xAxisLabel,\n yAxisLabel,\n reverseXAxis,\n yAxisRangeMin,\n yAxisRangeMax,\n ],\n events: [\n {\n name: 'onLineClicked',\n label: 'A line is clicked',\n properties: [\n {\n name: 'axisDimensionValue',\n label: 'Clicked Axis Dimension Value',\n type: 'string',\n },\n {\n name: 'groupingDimensionValue',\n label: 'Clicked Grouping Dimension Value',\n type: 'string',\n },\n ],\n },\n ],\n} as const satisfies EmbeddedComponentMeta;\n\nexport default defineComponent(LineChartGroupedPro, meta, {\n props: (inputs: Inputs<typeof meta>) => {\n return {\n ...inputs,\n results: loadData({\n limit: inputs.maxResults,\n from: inputs.dataset,\n select: [inputs.xAxis, inputs.groupBy, inputs.measure],\n }),\n };\n },\n events: {\n onLineClicked: (value: LineChartProOptionsClickArg) => {\n return {\n axisDimensionValue: value.dimensionValue || Value.noFilter(),\n groupingDimensionValue: value.groupingDimensionValue || Value.noFilter(),\n };\n },\n },\n});\n"],"names":["meta","dataset","measure","genericBoolean","dimensionWithDateBounds","dimension","title","description","maxResults","showLegend","showTooltips","showValueLabels","showLogarithmicScale","xAxisLabel","yAxisLabel","reverseXAxis","yAxisRangeMin","yAxisRangeMax","LineChartGroupedPro_emb","defineComponent","LineChartGroupedPro","inputs","loadData","value","Value"],"mappings":";;;;AAwBO,MAAMA,IAAO;AAAA,EAClB,MAAM;AAAA,EACN,OAAO;AAAA,EACP,UAAU;AAAA,EACV,QAAQ;AAAA,IACNC;AAAA,IACA;AAAA,MACE,GAAGC;AAAA,MACH,QAAQ;AAAA,QACN,GAAGA,EAAQ;AAAA,QACX,EAAE,GAAGC,GAAgB,MAAM,iBAAiB,OAAO,kBAAA;AAAA,QACnD,EAAE,GAAGA,GAAgB,MAAM,eAAe,OAAO,gBAAgB,cAAc,GAAA;AAAA,MAAK;AAAA,IACtF;AAAA,IAEF,EAAE,GAAGC,GAAyB,MAAM,SAAS,OAAO,SAAA;AAAA,IACpD,EAAE,GAAGC,GAAW,MAAM,WAAW,OAAO,WAAA;AAAA,IACxCC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,EAAA;AAAA,EAEF,QAAQ;AAAA,IACN;AAAA,MACE,MAAM;AAAA,MACN,OAAO;AAAA,MACP,YAAY;AAAA,QACV;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,UACP,MAAM;AAAA,QAAA;AAAA,QAER;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,UACP,MAAM;AAAA,QAAA;AAAA,MACR;AAAA,IACF;AAAA,EACF;AAEJ,GAEAC,IAAeC,EAAgBC,GAAqBpB,GAAM;AAAA,EACxD,OAAO,CAACqB,OACC;AAAA,IACL,GAAGA;AAAA,IACH,SAASC,EAAS;AAAA,MAChB,OAAOD,EAAO;AAAA,MACd,MAAMA,EAAO;AAAA,MACb,QAAQ,CAACA,EAAO,OAAOA,EAAO,SAASA,EAAO,OAAO;AAAA,IAAA,CACtD;AAAA,EAAA;AAAA,EAGL,QAAQ;AAAA,IACN,eAAe,CAACE,OACP;AAAA,MACL,oBAAoBA,EAAM,kBAAkBC,EAAM,SAAA;AAAA,MAClD,wBAAwBD,EAAM,0BAA0BC,EAAM,SAAA;AAAA,IAAS;AAAA,EAE3E;AAEJ,CAAC;"}
@@ -1,7 +1,7 @@
1
1
  import { defineComponent as i } from "@embeddable.com/react";
2
- import { V as t, l as r } from "./index-DedIqjbn.js";
3
- import { v as s, w as d, F as u, G as m, _ as c } from "./component.constants-uP1WYyUb.js";
4
- import { M as p, a as f } from "./index-BWpUwKTH.js";
2
+ import { V as t, l as r } from "./index-D8D1R5YG.js";
3
+ import { v as s, w as d, F as u, G as m, _ as c } from "./component.constants-C7cqSNbp.js";
4
+ import { M as p, a as f } from "./index-BAomPP89.js";
5
5
  const g = {
6
6
  name: "MultiSelectFieldPro",
7
7
  label: "Multi Select Field",
@@ -1,7 +1,7 @@
1
- import { V as a, l as s } from "./index-DedIqjbn.js";
1
+ import { V as a, l as s } from "./index-D8D1R5YG.js";
2
2
  import { defineComponent as t } from "@embeddable.com/react";
3
- import { P as o } from "./index-B8bT85NR.js";
4
- import { v as i, D as n, w as r, F as m, G as l, I as d, Z as p, J as c, K as u } from "./component.constants-uP1WYyUb.js";
3
+ import { P as o } from "./index-L9ViZuWi.js";
4
+ import { v as i, D as n, w as r, F as m, G as l, I as d, Z as p, J as c, K as u } from "./component.constants-C7cqSNbp.js";
5
5
  const C = {
6
6
  name: "PieChartPro",
7
7
  label: "Pie Chart",