@embeddable.com/remarkable-pro 0.1.2 → 0.1.4

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 (205) hide show
  1. package/dist/BarChartDefaultHorizontalPro.js +9 -8
  2. package/dist/BarChartDefaultHorizontalPro.js.map +1 -1
  3. package/dist/BarChartDefaultPro.js +5 -4
  4. package/dist/BarChartDefaultPro.js.map +1 -1
  5. package/dist/BarChartGroupedHorizontalPro.js +5 -4
  6. package/dist/BarChartGroupedHorizontalPro.js.map +1 -1
  7. package/dist/BarChartGroupedPro.js +7 -6
  8. package/dist/BarChartGroupedPro.js.map +1 -1
  9. package/dist/BarChartStackedHorizontalPro.js +10 -9
  10. package/dist/BarChartStackedHorizontalPro.js.map +1 -1
  11. package/dist/BarChartStackedPro.js +13 -12
  12. package/dist/BarChartStackedPro.js.map +1 -1
  13. package/dist/ChartCard-Be7mHyBp.js +117 -0
  14. package/dist/ChartCard-Be7mHyBp.js.map +1 -0
  15. package/dist/{ChartGranularitySelectField-C_6Mugcw.js → ChartGranularitySelectField-D-H0yKZH.js} +3 -3
  16. package/dist/{ChartGranularitySelectField-C_6Mugcw.js.map → ChartGranularitySelectField-D-H0yKZH.js.map} +1 -1
  17. package/dist/{Color.type.emb-De2K8PVb.js → Color.type.emb-CGyFSpIN.js} +11697 -11296
  18. package/dist/Color.type.emb-CGyFSpIN.js.map +1 -0
  19. package/dist/ColorEditor.js +1 -1
  20. package/dist/ComparisonPeriodSelectFieldPro.js +9 -8
  21. package/dist/ComparisonPeriodSelectFieldPro.js.map +1 -1
  22. package/dist/DateRangePickerCustomPro.js +42 -41
  23. package/dist/DateRangePickerCustomPro.js.map +1 -1
  24. package/dist/DateRangeSelectFieldPro.js +6 -5
  25. package/dist/DateRangeSelectFieldPro.js.map +1 -1
  26. package/dist/{DimensionAndMeasureSingleSelectField-CJ1yAcRd.js → DimensionAndMeasureSingleSelectField-BOWAqIok.js} +3 -3
  27. package/dist/{DimensionAndMeasureSingleSelectField-CJ1yAcRd.js.map → DimensionAndMeasureSingleSelectField-BOWAqIok.js.map} +1 -1
  28. package/dist/DimensionSingleSelectFieldPro.js +32 -31
  29. package/dist/DimensionSingleSelectFieldPro.js.map +1 -1
  30. package/dist/DonutChartPro.js +16 -15
  31. package/dist/DonutChartPro.js.map +1 -1
  32. package/dist/DonutLabelChartPro.js +10 -9
  33. package/dist/DonutLabelChartPro.js.map +1 -1
  34. package/dist/EditorCard-C8PKNLWT.js +33 -0
  35. package/dist/EditorCard-C8PKNLWT.js.map +1 -0
  36. package/dist/{GranularitySelectField-DuRk6qY8.js → GranularitySelectField-DUbr0dRq.js} +3 -3
  37. package/dist/{GranularitySelectField-DuRk6qY8.js.map → GranularitySelectField-DUbr0dRq.js.map} +1 -1
  38. package/dist/GranularitySelectFieldPro.js +18 -17
  39. package/dist/GranularitySelectFieldPro.js.map +1 -1
  40. package/dist/HeatMapPro.js +5 -4
  41. package/dist/HeatMapPro.js.map +1 -1
  42. package/dist/{IconCalendarFilled-CYiLMPm9.js → IconCalendarFilled-BOHNn82C.js} +2 -2
  43. package/dist/{IconCalendarFilled-CYiLMPm9.js.map → IconCalendarFilled-BOHNn82C.js.map} +1 -1
  44. package/dist/KpiChartNumberComparisonPro.js +5 -4
  45. package/dist/KpiChartNumberComparisonPro.js.map +1 -1
  46. package/dist/KpiChartNumberPro.js +12 -5
  47. package/dist/KpiChartNumberPro.js.map +1 -1
  48. package/dist/LineChartComparisonDefaultPro.js +8 -7
  49. package/dist/LineChartComparisonDefaultPro.js.map +1 -1
  50. package/dist/LineChartDefaultPro.js +5 -4
  51. package/dist/LineChartDefaultPro.js.map +1 -1
  52. package/dist/LineChartGroupedPro.js +5 -4
  53. package/dist/LineChartGroupedPro.js.map +1 -1
  54. package/dist/MeasureSingleSelectFieldPro.js +32 -31
  55. package/dist/MeasureSingleSelectFieldPro.js.map +1 -1
  56. package/dist/MultiSelectFieldPro.js +9 -8
  57. package/dist/MultiSelectFieldPro.js.map +1 -1
  58. package/dist/PieChartPro.js +9 -8
  59. package/dist/PieChartPro.js.map +1 -1
  60. package/dist/PivotTablePro.js +5 -4
  61. package/dist/PivotTablePro.js.map +1 -1
  62. package/dist/SingleSelectFieldPro.js +23 -22
  63. package/dist/SingleSelectFieldPro.js.map +1 -1
  64. package/dist/TableChartPaginated.js +10 -9
  65. package/dist/TableChartPaginated.js.map +1 -1
  66. package/dist/TableScrollable.js +244 -242
  67. package/dist/TableScrollable.js.map +1 -1
  68. package/dist/{bars.utils-7WiIKMS8.js → bars.utils-Ccwx-tAf.js} +7 -7
  69. package/dist/{bars.utils-7WiIKMS8.js.map → bars.utils-Ccwx-tAf.js.map} +1 -1
  70. package/dist/{charts.utils-CeUb1OP-.js → charts.utils-ypZsf-22.js} +725 -688
  71. package/dist/charts.utils-ypZsf-22.js.map +1 -0
  72. package/dist/{component.inputs.constants-DzpzJ9Na.js → component.inputs.constants-MAjey7Me.js} +92 -86
  73. package/dist/component.inputs.constants-MAjey7Me.js.map +1 -0
  74. package/dist/components/charts/bars/BarChartDefaultHorizontalPro/index.d.ts.map +1 -1
  75. package/dist/components/charts/bars/BarChartDefaultPro/index.d.ts.map +1 -1
  76. package/dist/components/charts/bars/BarChartGroupedHorizontalPro/index.d.ts.map +1 -1
  77. package/dist/components/charts/bars/BarChartGroupedPro/index.d.ts.map +1 -1
  78. package/dist/components/charts/bars/BarChartStackedHorizontalPro/index.d.ts.map +1 -1
  79. package/dist/components/charts/bars/BarChartStackedPro/index.d.ts.map +1 -1
  80. package/dist/components/charts/kpis/KpiChartNumberComparisonPro/index.d.ts.map +1 -1
  81. package/dist/components/charts/kpis/KpiChartNumberPro/index.d.ts.map +1 -1
  82. package/dist/components/charts/lines/LineChartComparisonDefaultPro/index.d.ts.map +1 -1
  83. package/dist/components/charts/lines/LineChartDefaultPro/index.d.ts.map +1 -1
  84. package/dist/components/charts/lines/LineChartGroupedPro/index.d.ts.map +1 -1
  85. package/dist/components/charts/shared/ChartCard/ChartCard.d.ts +1 -0
  86. package/dist/components/charts/shared/ChartCard/ChartCard.d.ts.map +1 -1
  87. package/dist/components/charts/tables/HeatMapPro/index.d.ts.map +1 -1
  88. package/dist/components/charts/tables/PivotTablePro/index.d.ts.map +1 -1
  89. package/dist/components/charts/tables/TableChartPaginated/index.d.ts.map +1 -1
  90. package/dist/components/charts/tables/TableScrollable/index.d.ts.map +1 -1
  91. package/dist/components/component.inputs.constants.d.ts +6 -0
  92. package/dist/components/component.inputs.constants.d.ts.map +1 -1
  93. package/dist/components/editors/ComparisonPeriodSelectFieldPro/index.d.ts +2 -2
  94. package/dist/components/editors/ComparisonPeriodSelectFieldPro/index.d.ts.map +1 -1
  95. package/dist/components/editors/GranularitySelectFieldPro/index.d.ts +2 -2
  96. package/dist/components/editors/GranularitySelectFieldPro/index.d.ts.map +1 -1
  97. package/dist/components/editors/MultiSelectFieldPro/index.d.ts +2 -2
  98. package/dist/components/editors/MultiSelectFieldPro/index.d.ts.map +1 -1
  99. package/dist/components/editors/SingleSelectFieldPro/index.d.ts +2 -2
  100. package/dist/components/editors/SingleSelectFieldPro/index.d.ts.map +1 -1
  101. package/dist/components/editors/dates/DateRangePickerCustomPro/index.d.ts +2 -2
  102. package/dist/components/editors/dates/DateRangePickerCustomPro/index.d.ts.map +1 -1
  103. package/dist/components/editors/dates/DateRangePickerPresetsPro/index.d.ts +2 -2
  104. package/dist/components/editors/dates/DateRangePickerPresetsPro/index.d.ts.map +1 -1
  105. package/dist/components/editors/shared/EditorCard/EditorCard.d.ts +6 -3
  106. package/dist/components/editors/shared/EditorCard/EditorCard.d.ts.map +1 -1
  107. package/dist/embeddable-components.json +28 -28
  108. package/dist/embeddable-theme-0137e.js +1090 -1053
  109. package/dist/{formatter.utils-CiN6axbW.js → formatter.utils-BeLScsYW.js} +2 -2
  110. package/dist/{formatter.utils-CiN6axbW.js.map → formatter.utils-BeLScsYW.js.map} +1 -1
  111. package/dist/index-B4AV2TSq.js +346 -0
  112. package/dist/{index-BEckqi71.js.map → index-B4AV2TSq.js.map} +1 -1
  113. package/dist/{index-Cd59K5g3.js → index-BWJHhuBQ.js} +6 -6
  114. package/dist/{index-Cd59K5g3.js.map → index-BWJHhuBQ.js.map} +1 -1
  115. package/dist/index-BZ2MzjOb.js +83 -0
  116. package/dist/index-BZ2MzjOb.js.map +1 -0
  117. package/dist/index-Bg7ZniJ2.js +37 -0
  118. package/dist/index-Bg7ZniJ2.js.map +1 -0
  119. package/dist/index-BlaQtlpt.js +114 -0
  120. package/dist/index-BlaQtlpt.js.map +1 -0
  121. package/dist/index-CRxhm_xI.js +99 -0
  122. package/dist/index-CRxhm_xI.js.map +1 -0
  123. package/dist/index-CzJiHUjz.js +93 -0
  124. package/dist/index-CzJiHUjz.js.map +1 -0
  125. package/dist/index-D4RtNAm0.js +60 -0
  126. package/dist/index-D4RtNAm0.js.map +1 -0
  127. package/dist/index-DH1xtNOE.js +37 -0
  128. package/dist/index-DH1xtNOE.js.map +1 -0
  129. package/dist/index-DHVSgVH0.js +32 -0
  130. package/dist/index-DHVSgVH0.js.map +1 -0
  131. package/dist/{index-BCVHDZZk.js → index-DHWLaRmn.js} +51 -51
  132. package/dist/index-DHWLaRmn.js.map +1 -0
  133. package/dist/{index-APJ7mYHR.js → index-DPF51yD5.js} +5 -5
  134. package/dist/{index-APJ7mYHR.js.map → index-DPF51yD5.js.map} +1 -1
  135. package/dist/index-DiU1B7O9.js +91 -0
  136. package/dist/index-DiU1B7O9.js.map +1 -0
  137. package/dist/index-DjdyOpZx.js +98 -0
  138. package/dist/index-DjdyOpZx.js.map +1 -0
  139. package/dist/index-KyBmwDIm.js +88 -0
  140. package/dist/index-KyBmwDIm.js.map +1 -0
  141. package/dist/index-SaoYT_gT.js +178 -0
  142. package/dist/index-SaoYT_gT.js.map +1 -0
  143. package/dist/index-bJoBwWW3.js +94 -0
  144. package/dist/index-bJoBwWW3.js.map +1 -0
  145. package/dist/index-eVkC4ywY.js +92 -0
  146. package/dist/index-eVkC4ywY.js.map +1 -0
  147. package/dist/index-g8MvTSdJ.js +84 -0
  148. package/dist/index-g8MvTSdJ.js.map +1 -0
  149. package/dist/index-rMR9Yklq.js +183 -0
  150. package/dist/index-rMR9Yklq.js.map +1 -0
  151. package/dist/{index-CTds3eHF.js → index-y6eDhxWa.js} +5 -5
  152. package/dist/{index-CTds3eHF.js.map → index-y6eDhxWa.js.map} +1 -1
  153. package/dist/index.js +29 -29
  154. package/dist/{pies.utils-MOzFigDD.js → pies.utils-5-O3kg-9.js} +5 -5
  155. package/dist/{pies.utils-MOzFigDD.js.map → pies.utils-5-O3kg-9.js.map} +1 -1
  156. package/dist/{preview.data.constants-BBIMPXYy.js → preview.data.constants-Cdk-GUa5.js} +2 -2
  157. package/dist/{preview.data.constants-BBIMPXYy.js.map → preview.data.constants-Cdk-GUa5.js.map} +1 -1
  158. package/dist/remarkable-pro.css +1 -1
  159. package/dist/{tables.utils-C7MWIQsp.js → tables.utils-CG1MXpGj.js} +4 -4
  160. package/dist/tables.utils-CG1MXpGj.js.map +1 -0
  161. package/dist/{timeRange.utils-LHM3sXwE.js → timeRange.utils-Rkw2u-vc.js} +2 -2
  162. package/dist/{timeRange.utils-LHM3sXwE.js.map → timeRange.utils-Rkw2u-vc.js.map} +1 -1
  163. package/package.json +4 -3
  164. package/dist/ChartCard-CfVMn37p.js +0 -116
  165. package/dist/ChartCard-CfVMn37p.js.map +0 -1
  166. package/dist/Color.type.emb-De2K8PVb.js.map +0 -1
  167. package/dist/EditorCard-B9UFM_uA.js +0 -32
  168. package/dist/EditorCard-B9UFM_uA.js.map +0 -1
  169. package/dist/charts.utils-CeUb1OP-.js.map +0 -1
  170. package/dist/component.inputs.constants-DzpzJ9Na.js.map +0 -1
  171. package/dist/index-387srVl0.js +0 -93
  172. package/dist/index-387srVl0.js.map +0 -1
  173. package/dist/index-3xjxWqDJ.js +0 -90
  174. package/dist/index-3xjxWqDJ.js.map +0 -1
  175. package/dist/index-7JWw7tI5.js +0 -47
  176. package/dist/index-7JWw7tI5.js.map +0 -1
  177. package/dist/index-BCVHDZZk.js.map +0 -1
  178. package/dist/index-BEckqi71.js +0 -346
  179. package/dist/index-BYB6yWhD.js +0 -92
  180. package/dist/index-BYB6yWhD.js.map +0 -1
  181. package/dist/index-BnOZcps-.js +0 -98
  182. package/dist/index-BnOZcps-.js.map +0 -1
  183. package/dist/index-Bv9-6Ht7.js +0 -113
  184. package/dist/index-Bv9-6Ht7.js.map +0 -1
  185. package/dist/index-C26JokZs.js +0 -91
  186. package/dist/index-C26JokZs.js.map +0 -1
  187. package/dist/index-CEDNCQK8.js +0 -31
  188. package/dist/index-CEDNCQK8.js.map +0 -1
  189. package/dist/index-ClEmYHgx.js +0 -60
  190. package/dist/index-ClEmYHgx.js.map +0 -1
  191. package/dist/index-Cp90DbOu.js +0 -83
  192. package/dist/index-Cp90DbOu.js.map +0 -1
  193. package/dist/index-Crpz4FA4.js +0 -87
  194. package/dist/index-Crpz4FA4.js.map +0 -1
  195. package/dist/index-D37a5H7U.js +0 -182
  196. package/dist/index-D37a5H7U.js.map +0 -1
  197. package/dist/index-DADSJYlJ.js +0 -177
  198. package/dist/index-DADSJYlJ.js.map +0 -1
  199. package/dist/index-DeWASjPW.js +0 -97
  200. package/dist/index-DeWASjPW.js.map +0 -1
  201. package/dist/index-DffpQwrs.js +0 -82
  202. package/dist/index-DffpQwrs.js.map +0 -1
  203. package/dist/index-mtJHlsB1.js +0 -47
  204. package/dist/index-mtJHlsB1.js.map +0 -1
  205. package/dist/tables.utils-C7MWIQsp.js.map +0 -1
@@ -1,66 +1,66 @@
1
- import { x as M, y as z, j as t, z as N, E as q, F as d, G as B, J as G, N as J, O as Q, Q as A, R as H } from "./Color.type.emb-De2K8PVb.js";
2
- import { useTheme as K } from "@embeddable.com/react";
3
- import { g as P, u as U, a as W, c as v, b as X } from "./dates.utils-BF32dTLi.js";
4
- import { e as Y, a as Z, r as $, i as m } from "./component.inputs.constants-DzpzJ9Na.js";
5
- import { E as V } from "./EditorCard-B9UFM_uA.js";
6
- import { useState as R, useEffect as ee } from "react";
7
- import { I as ae } from "./IconCalendarFilled-CYiLMPm9.js";
8
- const te = (o) => o.map((n) => ({
1
+ import { x as z, y as N, j as t, z as q, E as B, F as d, G, J, N as Q, O as A, Q as H, R as K } from "./Color.type.emb-CGyFSpIN.js";
2
+ import { useTheme as U } from "@embeddable.com/react";
3
+ import { g as P, u as W, a as X, c as v, b as Y } from "./dates.utils-BF32dTLi.js";
4
+ import { e as Z, a as $, r as V, i as m } from "./component.inputs.constants-MAjey7Me.js";
5
+ import { E as ee } from "./EditorCard-C8PKNLWT.js";
6
+ import { useState as R, useEffect as ae } from "react";
7
+ import { I as te } from "./IconCalendarFilled-BOHNn82C.js";
8
+ const ne = (o) => o.map((n) => ({
9
9
  rightLabel: P(n.getRange(), n.dateFormat),
10
10
  value: n.value,
11
- label: Y(n.label)
12
- })), ne = "_dateRangePickerContent_pig22_1", se = "_dateRangePickerContainer_pig22_5", b = {
13
- dateRangePickerContent: ne,
14
- dateRangePickerContainer: se
15
- }, oe = (o) => {
16
- const n = K();
17
- Z(n);
18
- const { dayjsLocaleReady: i } = U(), { onChange: s, clearable: k, selectedValue: e, showCustomRangeOptions: j, showTwoMonths: D } = o, u = !j, [x, f] = R(u), [S, C] = R(!1), [l, c] = R(
19
- W(e)
11
+ label: Z(n.label)
12
+ })), se = "_dateRangePickerContent_pig22_1", oe = "_dateRangePickerContainer_pig22_5", b = {
13
+ dateRangePickerContent: se,
14
+ dateRangePickerContainer: oe
15
+ }, re = (o) => {
16
+ const n = U();
17
+ $(n);
18
+ const { dayjsLocaleReady: i } = W(), { onChange: s, clearable: k, selectedValue: e, showCustomRangeOptions: j, showTwoMonths: D } = o, u = !j, [x, f] = R(u), [S, p] = R(!1), [l, c] = R(
19
+ X(e)
20
20
  ), r = n.defaults.dateRangesOptions;
21
- if (ee(() => {
21
+ if (ae(() => {
22
22
  if (!i)
23
23
  return;
24
24
  const a = v(e, r);
25
- M(a, e) || s(a);
25
+ z(a, e) || s(a);
26
26
  }, [e, i, s, r]), !i)
27
27
  return null;
28
- const { description: T, placeholder: p, title: O } = $(o), h = te(r), L = (a) => {
28
+ const { description: T, placeholder: C, title: O, tooltip: L } = V(o), h = ne(r), F = (a) => {
29
29
  const g = v(
30
30
  { relativeTimeString: a },
31
31
  r
32
32
  );
33
33
  s(g), c(void 0);
34
- }, F = (a) => {
35
- s(X(a)), C(!1);
36
- }, I = () => {
34
+ }, I = (a) => {
35
+ s(Y(a)), p(!1);
36
+ }, _ = () => {
37
37
  c(void 0), s(void 0);
38
- }, _ = (() => {
38
+ }, w = (() => {
39
39
  if (e != null && e.relativeTimeString) {
40
40
  const a = h.find((g) => g.value === e.relativeTimeString);
41
41
  if (a)
42
42
  return a.label;
43
43
  }
44
44
  return e != null && e.from && (e != null && e.to) ? P(e, "MMM DD") : "";
45
- })(), w = n.i18n.language ?? n.formatter.locale, y = z(l, e), E = D ? 2 : 1;
46
- return /* @__PURE__ */ t.jsx(V, { title: O, subtitle: T, children: /* @__PURE__ */ t.jsx(
47
- N,
45
+ })(), y = n.i18n.language ?? n.formatter.locale, E = N(l, e), M = D ? 2 : 1;
46
+ return /* @__PURE__ */ t.jsx(ee, { title: O, description: T, tooltip: L, children: /* @__PURE__ */ t.jsx(
47
+ q,
48
48
  {
49
49
  open: S,
50
- onOpenChange: C,
50
+ onOpenChange: p,
51
51
  avoidCollisions: !1,
52
52
  triggerComponent: /* @__PURE__ */ t.jsx(
53
- H,
53
+ K,
54
54
  {
55
- startIcon: ae,
56
- "aria-label": p,
57
- placeholder: p,
58
- valueLabel: _,
59
- onClear: I,
55
+ startIcon: te,
56
+ "aria-label": C,
57
+ placeholder: C,
58
+ valueLabel: w,
59
+ onClear: _,
60
60
  isClearable: k
61
61
  }
62
62
  ),
63
- children: /* @__PURE__ */ t.jsx(q, { fitContent: !0, className: b.dateRangePickerContent, children: x ? /* @__PURE__ */ t.jsxs("div", { className: b.dateRangePickerContainer, children: [
63
+ children: /* @__PURE__ */ t.jsx(B, { fitContent: !0, className: b.dateRangePickerContent, children: x ? /* @__PURE__ */ t.jsxs("div", { className: b.dateRangePickerContainer, children: [
64
64
  !u && /* @__PURE__ */ t.jsx(
65
65
  d,
66
66
  {
@@ -68,28 +68,28 @@ const te = (o) => o.map((n) => ({
68
68
  onClick: (a) => {
69
69
  a.preventDefault(), f(!1);
70
70
  },
71
- startIcon: /* @__PURE__ */ t.jsx(B, {})
71
+ startIcon: /* @__PURE__ */ t.jsx(G, {})
72
72
  }
73
73
  ),
74
74
  /* @__PURE__ */ t.jsx(
75
- G,
75
+ J,
76
76
  {
77
- locale: w,
78
- numberOfMonths: E,
77
+ locale: y,
78
+ numberOfMonths: M,
79
79
  value: l,
80
80
  onChange: c
81
81
  }
82
82
  ),
83
83
  /* @__PURE__ */ t.jsx(
84
- J,
84
+ Q,
85
85
  {
86
86
  size: "small",
87
- disabled: y,
88
- onClick: () => F(l),
87
+ disabled: E,
88
+ onClick: () => I(l),
89
89
  children: m.t("editors.dateRangePicker.apply")
90
90
  }
91
91
  )
92
- ] }) : /* @__PURE__ */ t.jsxs(Q, { children: [
92
+ ] }) : /* @__PURE__ */ t.jsxs(A, { children: [
93
93
  /* @__PURE__ */ t.jsx(
94
94
  d,
95
95
  {
@@ -97,7 +97,7 @@ const te = (o) => o.map((n) => ({
97
97
  onClick: (a) => {
98
98
  a.preventDefault(), f(!0);
99
99
  },
100
- endIcon: /* @__PURE__ */ t.jsx(A, {})
100
+ endIcon: /* @__PURE__ */ t.jsx(H, {})
101
101
  }
102
102
  ),
103
103
  h.map((a) => /* @__PURE__ */ t.jsx(
@@ -105,20 +105,20 @@ const te = (o) => o.map((n) => ({
105
105
  {
106
106
  ...a,
107
107
  isSelected: (e == null ? void 0 : e.relativeTimeString) === a.value,
108
- onClick: () => L(a.value)
108
+ onClick: () => F(a.value)
109
109
  },
110
110
  a.value
111
111
  ))
112
112
  ] }) })
113
113
  }
114
114
  ) });
115
- }, ue = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
115
+ }, fe = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
116
116
  __proto__: null,
117
- default: oe
117
+ default: re
118
118
  }, Symbol.toStringTag, { value: "Module" }));
119
119
  export {
120
- oe as D,
121
- te as g,
122
- ue as i
120
+ re as D,
121
+ ne as g,
122
+ fe as i
123
123
  };
124
- //# sourceMappingURL=index-BCVHDZZk.js.map
124
+ //# sourceMappingURL=index-DHWLaRmn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-DHWLaRmn.js","sources":["../src/components/editors/dates/DateRangePickerPresetsPro/DateRangePickerPresetsPro.utils.ts","../src/components/editors/dates/DateRangePickerPresetsPro/index.tsx"],"sourcesContent":["import { DateRangeSelectFieldProOption } from './DateRangePickerPresetsPro.types';\nimport { SelectListOptionProps } from '@embeddable.com/remarkable-ui';\nimport { resolveI18nString } from '../../../component.utils';\nimport { getTimeRangeLabel } from '../dates.utils';\n\nexport const getDateRangeSelectFieldProOptions = (\n dateRangeSelectFieldProOptions: DateRangeSelectFieldProOption[],\n): SelectListOptionProps[] => {\n return dateRangeSelectFieldProOptions.map((option) => {\n return {\n rightLabel: getTimeRangeLabel(option.getRange(), option.dateFormat),\n value: option.value,\n label: resolveI18nString(option.label),\n };\n });\n};\n","import { useTheme } from '@embeddable.com/react';\nimport {\n Button,\n DateRangePicker,\n Dropdown,\n SelectFieldContent,\n SelectFieldContentList,\n SelectListOption,\n DateRange,\n SelectFieldTrigger,\n isSameDateRange,\n shallowEqual,\n} from '@embeddable.com/remarkable-ui';\nimport { Theme } from '../../../../theme/theme.types';\nimport { useLoadDayjsLocale } from '../../../../utils.ts/date.utils';\nimport { getDateRangeSelectFieldProOptions } from './DateRangePickerPresetsPro.utils';\nimport { TimeRange } from '@embeddable.com/core';\nimport { resolveI18nProps } from '../../../component.utils';\nimport { EditorCard, EditorCardHeaderProps } from '../../shared/EditorCard/EditorCard';\nimport { IconCalendarFilled, IconChevronLeft, IconChevronRight } from '@tabler/icons-react';\nimport { i18n, i18nSetup } from '../../../../theme/i18n/i18n';\nimport { useEffect, useState } from 'react';\nimport styles from './DateRangePickerPresetsPro.module.css';\nimport {\n getDateRangeFromTimeRange,\n getTimeRangeFromDateRange,\n getTimeRangeFromPresets,\n getTimeRangeLabel,\n} from '../dates.utils';\n\ntype DateRangePickerPresetsProps = {\n onChange: (newDateRange: TimeRange) => void;\n placeholder?: string;\n selectedValue?: TimeRange;\n\n clearable?: boolean;\n showCustomRangeOptions?: boolean;\n showTwoMonths?: boolean;\n} & EditorCardHeaderProps;\n\nconst DateRangePickerPresets = (props: DateRangePickerPresetsProps) => {\n const theme: Theme = useTheme() as Theme;\n i18nSetup(theme);\n const { dayjsLocaleReady } = useLoadDayjsLocale();\n const { onChange, clearable, selectedValue, showCustomRangeOptions, showTwoMonths } = props;\n const onlyDateRangePicker = !showCustomRangeOptions;\n const [showDateRangePicker, setShowDateRangePicker] = useState(onlyDateRangePicker);\n\n const [isOpen, setIsOpen] = useState(false);\n const [dateRange, setDateRange] = useState<DateRange | undefined>(\n getDateRangeFromTimeRange(selectedValue),\n );\n\n const dateRangeOptions = theme.defaults.dateRangesOptions;\n\n useEffect(() => {\n if (!dayjsLocaleReady) {\n return;\n }\n // Step 1: Convert relativeTimeString to actual time range (from/to)\n const newTimeRange = getTimeRangeFromPresets(selectedValue, dateRangeOptions);\n\n if (!shallowEqual(newTimeRange, selectedValue)) {\n onChange(newTimeRange);\n }\n }, [selectedValue, dayjsLocaleReady, onChange, dateRangeOptions]);\n\n if (!dayjsLocaleReady) {\n return null;\n }\n\n const { description, placeholder, title, tooltip } = resolveI18nProps(props);\n\n const options = getDateRangeSelectFieldProOptions(dateRangeOptions);\n\n const handleOptionChange = (newValue: string | undefined) => {\n const newTimeRange = getTimeRangeFromPresets(\n { relativeTimeString: newValue } as TimeRange,\n dateRangeOptions,\n );\n\n onChange(newTimeRange);\n setDateRange(undefined);\n };\n\n const handleDateRangeChange = (newDateRange: DateRange | undefined) => {\n onChange(getTimeRangeFromDateRange(newDateRange));\n setIsOpen(false);\n };\n\n const handleClear = () => {\n setDateRange(undefined);\n onChange(undefined);\n };\n\n const getValueLabel = () => {\n if (selectedValue?.relativeTimeString) {\n const option = options.find((option) => option.value === selectedValue.relativeTimeString);\n if (option) {\n return option.label;\n }\n }\n\n if (selectedValue?.from && selectedValue?.to) {\n return getTimeRangeLabel(selectedValue, 'MMM DD');\n }\n\n return '';\n };\n\n const valueLabel = getValueLabel();\n\n const locale = theme.i18n.language ?? theme.formatter.locale;\n const isSubmitDisabled = isSameDateRange(dateRange, selectedValue);\n const numberOfMonths = showTwoMonths ? 2 : 1;\n\n return (\n <EditorCard title={title} description={description} tooltip={tooltip}>\n <Dropdown\n open={isOpen}\n onOpenChange={setIsOpen}\n avoidCollisions={false}\n triggerComponent={\n <SelectFieldTrigger\n startIcon={IconCalendarFilled}\n aria-label={placeholder}\n placeholder={placeholder}\n valueLabel={valueLabel}\n onClear={handleClear}\n isClearable={clearable}\n />\n }\n >\n <SelectFieldContent fitContent className={styles.dateRangePickerContent}>\n {showDateRangePicker ? (\n <div className={styles.dateRangePickerContainer}>\n {!onlyDateRangePicker && (\n <SelectListOption\n label={i18n.t('editors.dateRangePicker.backToPresets')}\n onClick={(e) => {\n e.preventDefault();\n setShowDateRangePicker(false);\n }}\n startIcon={<IconChevronLeft />}\n />\n )}\n <DateRangePicker\n locale={locale}\n numberOfMonths={numberOfMonths}\n value={dateRange}\n onChange={setDateRange}\n />\n <Button\n size=\"small\"\n disabled={isSubmitDisabled}\n onClick={() => handleDateRangeChange(dateRange)}\n >\n {i18n.t('editors.dateRangePicker.apply')}\n </Button>\n </div>\n ) : (\n <SelectFieldContentList>\n <SelectListOption\n label={i18n.t('editors.dateRangePicker.custom')}\n onClick={(e) => {\n e.preventDefault();\n setShowDateRangePicker(true);\n }}\n endIcon={<IconChevronRight />}\n />\n {options.map((option) => (\n <SelectListOption\n key={option.value}\n {...option}\n isSelected={selectedValue?.relativeTimeString === option.value}\n onClick={() => handleOptionChange(option.value)}\n />\n ))}\n </SelectFieldContentList>\n )}\n </SelectFieldContent>\n </Dropdown>\n </EditorCard>\n );\n};\n\nexport default DateRangePickerPresets;\n"],"names":["getDateRangeSelectFieldProOptions","dateRangeSelectFieldProOptions","option","getTimeRangeLabel","resolveI18nString","DateRangePickerPresets","props","theme","useTheme","i18nSetup","dayjsLocaleReady","useLoadDayjsLocale","onChange","clearable","selectedValue","showCustomRangeOptions","showTwoMonths","onlyDateRangePicker","showDateRangePicker","setShowDateRangePicker","useState","isOpen","setIsOpen","dateRange","setDateRange","getDateRangeFromTimeRange","dateRangeOptions","useEffect","newTimeRange","getTimeRangeFromPresets","shallowEqual","description","placeholder","title","tooltip","resolveI18nProps","options","handleOptionChange","newValue","handleDateRangeChange","newDateRange","getTimeRangeFromDateRange","handleClear","valueLabel","locale","isSubmitDisabled","isSameDateRange","numberOfMonths","jsx","EditorCard","Dropdown","SelectFieldTrigger","IconCalendarFilled","SelectFieldContent","styles","jsxs","SelectListOption","i18n","e","IconChevronLeft","DateRangePicker","Button","SelectFieldContentList","IconChevronRight"],"mappings":";;;;;;;AAKO,MAAMA,KAAoC,CAC/CC,MAEOA,EAA+B,IAAI,CAACC,OAClC;AAAA,EACL,YAAYC,EAAkBD,EAAO,SAAA,GAAYA,EAAO,UAAU;AAAA,EAClE,OAAOA,EAAO;AAAA,EACd,OAAOE,EAAkBF,EAAO,KAAK;AAAA,EAExC;;;GC0BGG,KAAyB,CAACC,MAAuC;AACrE,QAAMC,IAAeC,EAAA;AACrB,EAAAC,EAAUF,CAAK;AACf,QAAM,EAAE,kBAAAG,EAAA,IAAqBC,EAAA,GACvB,EAAE,UAAAC,GAAU,WAAAC,GAAW,eAAAC,GAAe,wBAAAC,GAAwB,eAAAC,MAAkBV,GAChFW,IAAsB,CAACF,GACvB,CAACG,GAAqBC,CAAsB,IAAIC,EAASH,CAAmB,GAE5E,CAACI,GAAQC,CAAS,IAAIF,EAAS,EAAK,GACpC,CAACG,GAAWC,CAAY,IAAIJ;AAAA,IAChCK,EAA0BX,CAAa;AAAA,EAAA,GAGnCY,IAAmBnB,EAAM,SAAS;AAcxC,MAZAoB,GAAU,MAAM;AACd,QAAI,CAACjB;AACH;AAGF,UAAMkB,IAAeC,EAAwBf,GAAeY,CAAgB;AAE5E,IAAKI,EAAaF,GAAcd,CAAa,KAC3CF,EAASgB,CAAY;AAAA,EAEzB,GAAG,CAACd,GAAeJ,GAAkBE,GAAUc,CAAgB,CAAC,GAE5D,CAAChB;AACH,WAAO;AAGT,QAAM,EAAE,aAAAqB,GAAa,aAAAC,GAAa,OAAAC,GAAO,SAAAC,EAAA,IAAYC,EAAiB7B,CAAK,GAErE8B,IAAUpC,GAAkC0B,CAAgB,GAE5DW,IAAqB,CAACC,MAAiC;AAC3D,UAAMV,IAAeC;AAAA,MACnB,EAAE,oBAAoBS,EAAA;AAAA,MACtBZ;AAAA,IAAA;AAGF,IAAAd,EAASgB,CAAY,GACrBJ,EAAa,MAAS;AAAA,EACxB,GAEMe,IAAwB,CAACC,MAAwC;AACrE,IAAA5B,EAAS6B,EAA0BD,CAAY,CAAC,GAChDlB,EAAU,EAAK;AAAA,EACjB,GAEMoB,IAAc,MAAM;AACxB,IAAAlB,EAAa,MAAS,GACtBZ,EAAS,MAAS;AAAA,EACpB,GAiBM+B,KAfgB,MAAM;AAC1B,QAAI7B,KAAA,QAAAA,EAAe,oBAAoB;AACrC,YAAMZ,IAASkC,EAAQ,KAAK,CAAClC,MAAWA,EAAO,UAAUY,EAAc,kBAAkB;AACzF,UAAIZ;AACF,eAAOA,EAAO;AAAA,IAElB;AAEA,WAAIY,KAAA,QAAAA,EAAe,SAAQA,KAAA,QAAAA,EAAe,MACjCX,EAAkBW,GAAe,QAAQ,IAG3C;AAAA,EACT,GAEmB,GAEb8B,IAASrC,EAAM,KAAK,YAAYA,EAAM,UAAU,QAChDsC,IAAmBC,EAAgBvB,GAAWT,CAAa,GAC3DiC,IAAiB/B,IAAgB,IAAI;AAE3C,SACEgC,gBAAAA,EAAAA,IAACC,IAAA,EAAW,OAAAhB,GAAc,aAAAF,GAA0B,SAAAG,GAClD,UAAAc,gBAAAA,EAAAA;AAAAA,IAACE;AAAA,IAAA;AAAA,MACC,MAAM7B;AAAA,MACN,cAAcC;AAAA,MACd,iBAAiB;AAAA,MACjB,kBACE0B,gBAAAA,EAAAA;AAAAA,QAACG;AAAA,QAAA;AAAA,UACC,WAAWC;AAAA,UACX,cAAYpB;AAAA,UACZ,aAAAA;AAAA,UACA,YAAAW;AAAA,UACA,SAASD;AAAA,UACT,aAAa7B;AAAA,QAAA;AAAA,MAAA;AAAA,MAIjB,UAAAmC,gBAAAA,EAAAA,IAACK,GAAA,EAAmB,YAAU,IAAC,WAAWC,EAAO,wBAC9C,UAAApC,IACCqC,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAWD,EAAO,0BACpB,UAAA;AAAA,QAAA,CAACrC,KACA+B,gBAAAA,EAAAA;AAAAA,UAACQ;AAAA,UAAA;AAAA,YACC,OAAOC,EAAK,EAAE,uCAAuC;AAAA,YACrD,SAAS,CAACC,MAAM;AACd,cAAAA,EAAE,eAAA,GACFvC,EAAuB,EAAK;AAAA,YAC9B;AAAA,YACA,iCAAYwC,GAAA,CAAA,CAAgB;AAAA,UAAA;AAAA,QAAA;AAAA,QAGhCX,gBAAAA,EAAAA;AAAAA,UAACY;AAAA,UAAA;AAAA,YACC,QAAAhB;AAAA,YACA,gBAAAG;AAAA,YACA,OAAOxB;AAAA,YACP,UAAUC;AAAA,UAAA;AAAA,QAAA;AAAA,QAEZwB,gBAAAA,EAAAA;AAAAA,UAACa;AAAA,UAAA;AAAA,YACC,MAAK;AAAA,YACL,UAAUhB;AAAA,YACV,SAAS,MAAMN,EAAsBhB,CAAS;AAAA,YAE7C,UAAAkC,EAAK,EAAE,+BAA+B;AAAA,UAAA;AAAA,QAAA;AAAA,MACzC,EAAA,CACF,2BAECK,GAAA,EACC,UAAA;AAAA,QAAAd,gBAAAA,EAAAA;AAAAA,UAACQ;AAAA,UAAA;AAAA,YACC,OAAOC,EAAK,EAAE,gCAAgC;AAAA,YAC9C,SAAS,CAACC,MAAM;AACd,cAAAA,EAAE,eAAA,GACFvC,EAAuB,EAAI;AAAA,YAC7B;AAAA,YACA,+BAAU4C,GAAA,CAAA,CAAiB;AAAA,UAAA;AAAA,QAAA;AAAA,QAE5B3B,EAAQ,IAAI,CAAClC,MACZ8C,gBAAAA,EAAAA;AAAAA,UAACQ;AAAA,UAAA;AAAA,YAEE,GAAGtD;AAAA,YACJ,aAAYY,KAAA,gBAAAA,EAAe,wBAAuBZ,EAAO;AAAA,YACzD,SAAS,MAAMmC,EAAmBnC,EAAO,KAAK;AAAA,UAAA;AAAA,UAHzCA,EAAO;AAAA,QAAA,CAKf;AAAA,MAAA,EAAA,CACH,EAAA,CAEJ;AAAA,IAAA;AAAA,EAAA,GAEJ;AAEJ;;;;"}
@@ -1,8 +1,8 @@
1
- import { m as S, j as l, D } from "./Color.type.emb-De2K8PVb.js";
1
+ import { m as S, j as l, D } from "./Color.type.emb-CGyFSpIN.js";
2
2
  import { useTheme as b } from "@embeddable.com/react";
3
- import { g as v, a as M } from "./pies.utils-MOzFigDD.js";
4
- import { a as _, r as k } from "./component.inputs.constants-DzpzJ9Na.js";
5
- import { C as w } from "./ChartCard-CfVMn37p.js";
3
+ import { g as v, a as M } from "./pies.utils-5-O3kg-9.js";
4
+ import { a as _, r as k } from "./component.inputs.constants-MAjey7Me.js";
5
+ import { C as w } from "./ChartCard-Be7mHyBp.js";
6
6
  const L = (s) => {
7
7
  var n;
8
8
  const e = b();
@@ -60,4 +60,4 @@ export {
60
60
  L as D,
61
61
  z as i
62
62
  };
63
- //# sourceMappingURL=index-APJ7mYHR.js.map
63
+ //# sourceMappingURL=index-DPF51yD5.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index-APJ7mYHR.js","sources":["../src/components/charts/pies/DonutChartPro/index.tsx"],"sourcesContent":["import { useTheme } from '@embeddable.com/react';\nimport { Theme } from '../../../../theme/theme.types';\nimport { getPieChartProOptions, getPieChartProData } from '../pies.utils';\nimport { DefaultPieChartProps } from '../pies.types';\nimport { i18nSetup } from '../../../../theme/i18n/i18n';\nimport { ChartCard } from '../../shared/ChartCard/ChartCard';\nimport { DonutChart } from '@embeddable.com/remarkable-ui';\nimport { mergician } from 'mergician';\nimport { resolveI18nProps } from '../../../component.utils';\n\ntype DonutChartProProps = DefaultPieChartProps;\n\nconst DonutChartPro = (props: DonutChartProProps) => {\n const theme = useTheme() as Theme;\n i18nSetup(theme);\n\n const {\n description,\n dimension,\n maxLegendItems,\n measure,\n results,\n showLegend,\n showTooltips,\n showValueLabels,\n title,\n onSegmentClick,\n } = resolveI18nProps(props);\n\n const { hideMenu } = props;\n\n const data = getPieChartProData(\n { data: results.data, dimension, measure, maxLegendItems },\n theme,\n );\n\n const options = mergician(\n getPieChartProOptions(measure, theme),\n theme.charts.donutChartPro?.options ?? {},\n );\n\n const handleSegmentClick = (index: number | undefined) => {\n if (!onSegmentClick) return;\n onSegmentClick({\n dimensionValue: index === undefined ? undefined : results.data?.[index]?.[dimension.name],\n });\n };\n\n return (\n <ChartCard\n data={results}\n dimensionsAndMeasures={[dimension, measure]}\n errorMessage={results.error}\n description={description}\n title={title}\n hideMenu={hideMenu}\n >\n <DonutChart\n data={data}\n options={options}\n showLegend={showLegend}\n showTooltips={showTooltips}\n showValueLabels={showValueLabels}\n onSegmentClick={handleSegmentClick}\n />\n </ChartCard>\n );\n};\n\nexport default DonutChartPro;\n"],"names":["DonutChartPro","props","theme","useTheme","i18nSetup","description","dimension","maxLegendItems","measure","results","showLegend","showTooltips","showValueLabels","title","onSegmentClick","resolveI18nProps","hideMenu","data","getPieChartProData","options","mergician","getPieChartProOptions","_a","handleSegmentClick","index","_b","jsx","ChartCard","DonutChart"],"mappings":";;;;;AAYA,MAAMA,IAAgB,CAACC,MAA8B;;AACnD,QAAMC,IAAQC,EAAA;AACd,EAAAC,EAAUF,CAAK;AAEf,QAAM;AAAA,IACJ,aAAAG;AAAA,IACA,WAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,SAAAC;AAAA,IACA,SAAAC;AAAA,IACA,YAAAC;AAAA,IACA,cAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,OAAAC;AAAA,IACA,gBAAAC;AAAA,EAAA,IACEC,EAAiBd,CAAK,GAEpB,EAAE,UAAAe,MAAaf,GAEfgB,IAAOC;AAAA,IACX,EAAE,MAAMT,EAAQ,MAAM,WAAAH,GAAW,SAAAE,GAAS,gBAAAD,EAAA;AAAA,IAC1CL;AAAA,EAAA,GAGIiB,IAAUC;AAAA,IACdC,EAAsBb,GAASN,CAAK;AAAA,MACpCoB,IAAApB,EAAM,OAAO,kBAAb,gBAAAoB,EAA4B,YAAW,CAAA;AAAA,EAAC,GAGpCC,IAAqB,CAACC,MAA8B;;AACxD,IAAKV,KACLA,EAAe;AAAA,MACb,gBAAgBU,MAAU,WAAwBC,KAAAH,IAAAb,EAAQ,SAAR,gBAAAa,EAAeE,OAAf,OAAZ,SAAYC,EAAwBnB,EAAU;AAAA,IAAI,CACzF;AAAA,EACH;AAEA,SACEoB,gBAAAA,EAAAA;AAAAA,IAACC;AAAA,IAAA;AAAA,MACC,MAAMlB;AAAA,MACN,uBAAuB,CAACH,GAAWE,CAAO;AAAA,MAC1C,cAAcC,EAAQ;AAAA,MACtB,aAAAJ;AAAA,MACA,OAAAQ;AAAA,MACA,UAAAG;AAAA,MAEA,UAAAU,gBAAAA,EAAAA;AAAAA,QAACE;AAAA,QAAA;AAAA,UACC,MAAAX;AAAA,UACA,SAAAE;AAAA,UACA,YAAAT;AAAA,UACA,cAAAC;AAAA,UACA,iBAAAC;AAAA,UACA,gBAAgBW;AAAA,QAAA;AAAA,MAAA;AAAA,IAClB;AAAA,EAAA;AAGN;;;;"}
1
+ {"version":3,"file":"index-DPF51yD5.js","sources":["../src/components/charts/pies/DonutChartPro/index.tsx"],"sourcesContent":["import { useTheme } from '@embeddable.com/react';\nimport { Theme } from '../../../../theme/theme.types';\nimport { getPieChartProOptions, getPieChartProData } from '../pies.utils';\nimport { DefaultPieChartProps } from '../pies.types';\nimport { i18nSetup } from '../../../../theme/i18n/i18n';\nimport { ChartCard } from '../../shared/ChartCard/ChartCard';\nimport { DonutChart } from '@embeddable.com/remarkable-ui';\nimport { mergician } from 'mergician';\nimport { resolveI18nProps } from '../../../component.utils';\n\ntype DonutChartProProps = DefaultPieChartProps;\n\nconst DonutChartPro = (props: DonutChartProProps) => {\n const theme = useTheme() as Theme;\n i18nSetup(theme);\n\n const {\n description,\n dimension,\n maxLegendItems,\n measure,\n results,\n showLegend,\n showTooltips,\n showValueLabels,\n title,\n onSegmentClick,\n } = resolveI18nProps(props);\n\n const { hideMenu } = props;\n\n const data = getPieChartProData(\n { data: results.data, dimension, measure, maxLegendItems },\n theme,\n );\n\n const options = mergician(\n getPieChartProOptions(measure, theme),\n theme.charts.donutChartPro?.options ?? {},\n );\n\n const handleSegmentClick = (index: number | undefined) => {\n if (!onSegmentClick) return;\n onSegmentClick({\n dimensionValue: index === undefined ? undefined : results.data?.[index]?.[dimension.name],\n });\n };\n\n return (\n <ChartCard\n data={results}\n dimensionsAndMeasures={[dimension, measure]}\n errorMessage={results.error}\n description={description}\n title={title}\n hideMenu={hideMenu}\n >\n <DonutChart\n data={data}\n options={options}\n showLegend={showLegend}\n showTooltips={showTooltips}\n showValueLabels={showValueLabels}\n onSegmentClick={handleSegmentClick}\n />\n </ChartCard>\n );\n};\n\nexport default DonutChartPro;\n"],"names":["DonutChartPro","props","theme","useTheme","i18nSetup","description","dimension","maxLegendItems","measure","results","showLegend","showTooltips","showValueLabels","title","onSegmentClick","resolveI18nProps","hideMenu","data","getPieChartProData","options","mergician","getPieChartProOptions","_a","handleSegmentClick","index","_b","jsx","ChartCard","DonutChart"],"mappings":";;;;;AAYA,MAAMA,IAAgB,CAACC,MAA8B;;AACnD,QAAMC,IAAQC,EAAA;AACd,EAAAC,EAAUF,CAAK;AAEf,QAAM;AAAA,IACJ,aAAAG;AAAA,IACA,WAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,SAAAC;AAAA,IACA,SAAAC;AAAA,IACA,YAAAC;AAAA,IACA,cAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,OAAAC;AAAA,IACA,gBAAAC;AAAA,EAAA,IACEC,EAAiBd,CAAK,GAEpB,EAAE,UAAAe,MAAaf,GAEfgB,IAAOC;AAAA,IACX,EAAE,MAAMT,EAAQ,MAAM,WAAAH,GAAW,SAAAE,GAAS,gBAAAD,EAAA;AAAA,IAC1CL;AAAA,EAAA,GAGIiB,IAAUC;AAAA,IACdC,EAAsBb,GAASN,CAAK;AAAA,MACpCoB,IAAApB,EAAM,OAAO,kBAAb,gBAAAoB,EAA4B,YAAW,CAAA;AAAA,EAAC,GAGpCC,IAAqB,CAACC,MAA8B;;AACxD,IAAKV,KACLA,EAAe;AAAA,MACb,gBAAgBU,MAAU,WAAwBC,KAAAH,IAAAb,EAAQ,SAAR,gBAAAa,EAAeE,OAAf,OAAZ,SAAYC,EAAwBnB,EAAU;AAAA,IAAI,CACzF;AAAA,EACH;AAEA,SACEoB,gBAAAA,EAAAA;AAAAA,IAACC;AAAA,IAAA;AAAA,MACC,MAAMlB;AAAA,MACN,uBAAuB,CAACH,GAAWE,CAAO;AAAA,MAC1C,cAAcC,EAAQ;AAAA,MACtB,aAAAJ;AAAA,MACA,OAAAQ;AAAA,MACA,UAAAG;AAAA,MAEA,UAAAU,gBAAAA,EAAAA;AAAAA,QAACE;AAAA,QAAA;AAAA,UACC,MAAAX;AAAA,UACA,SAAAE;AAAA,UACA,YAAAT;AAAA,UACA,cAAAC;AAAA,UACA,iBAAAC;AAAA,UACA,gBAAgBW;AAAA,QAAA;AAAA,MAAA;AAAA,IAClB;AAAA,EAAA;AAGN;;;;"}
@@ -0,0 +1,91 @@
1
+ import { m as T, j as t, B as w } from "./Color.type.emb-CGyFSpIN.js";
2
+ import { useTheme as G } from "@embeddable.com/react";
3
+ import { a as _, r as v } from "./component.inputs.constants-MAjey7Me.js";
4
+ import { C as O } from "./ChartCard-Be7mHyBp.js";
5
+ import { b as R, a as k } from "./bars.utils-Ccwx-tAf.js";
6
+ import { u as z } from "./charts.fillGaps.hooks-C7KsWcZb.js";
7
+ import { C as D } from "./ChartGranularitySelectField-D-H0yKZH.js";
8
+ const F = (e) => {
9
+ var d, c;
10
+ const s = G();
11
+ _(s);
12
+ const {
13
+ groupBy: i,
14
+ measure: r,
15
+ reverseXAxis: h,
16
+ showLegend: p,
17
+ showLogarithmicScale: x,
18
+ showTooltips: g,
19
+ showTotalLabels: C,
20
+ showValueLabels: f,
21
+ xAxis: a,
22
+ yAxisRangeMax: b,
23
+ yAxisRangeMin: y,
24
+ setGranularity: A,
25
+ onBarClicked: B
26
+ } = e, { tooltip: n, description: l, title: m, xAxisLabel: M, yAxisLabel: j } = v(e), { hideMenu: S } = e, o = z({
27
+ results: e.results,
28
+ dimension: e.xAxis
29
+ }), u = R(
30
+ {
31
+ data: o.data,
32
+ dimension: a,
33
+ groupDimension: i,
34
+ measure: r
35
+ },
36
+ s
37
+ ), L = T(
38
+ k(
39
+ { measures: [r], horizontal: !1, onBarClicked: B, data: u, dimension: a },
40
+ s
41
+ ),
42
+ ((c = (d = s.charts) == null ? void 0 : d.barChartGroupedPro) == null ? void 0 : c.options) || {}
43
+ ), P = !m && !l && !n;
44
+ return /* @__PURE__ */ t.jsxs(
45
+ O,
46
+ {
47
+ data: o,
48
+ dimensionsAndMeasures: [r, a, i],
49
+ errorMessage: o.error,
50
+ description: l,
51
+ title: m,
52
+ tooltip: n,
53
+ hideMenu: S,
54
+ children: [
55
+ /* @__PURE__ */ t.jsx(
56
+ D,
57
+ {
58
+ hasMarginTop: P,
59
+ dimension: a,
60
+ onChange: A
61
+ }
62
+ ),
63
+ /* @__PURE__ */ t.jsx(
64
+ w,
65
+ {
66
+ data: u,
67
+ showLegend: p,
68
+ showTooltips: g,
69
+ showValueLabels: f,
70
+ showLogarithmicScale: x,
71
+ xAxisLabel: M,
72
+ yAxisLabel: j,
73
+ reverseXAxis: h,
74
+ yAxisRangeMin: y,
75
+ yAxisRangeMax: b,
76
+ showTotalLabels: C,
77
+ options: L
78
+ }
79
+ )
80
+ ]
81
+ }
82
+ );
83
+ }, K = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
84
+ __proto__: null,
85
+ default: F
86
+ }, Symbol.toStringTag, { value: "Module" }));
87
+ export {
88
+ F as B,
89
+ K as i
90
+ };
91
+ //# sourceMappingURL=index-DiU1B7O9.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-DiU1B7O9.js","sources":["../src/components/charts/bars/BarChartGroupedPro/index.tsx"],"sourcesContent":["import { useTheme } from '@embeddable.com/react';\nimport { Theme } from '../../../../theme/theme.types';\nimport { i18nSetup } from '../../../../theme/i18n/i18n';\nimport { ChartCard, ChartCardHeaderProps } from '../../shared/ChartCard/ChartCard';\nimport { resolveI18nProps } from '../../../component.utils';\nimport { BarChart } from '@embeddable.com/remarkable-ui';\nimport { getBarChartProOptions, getBarStackedChartProData } from '../bars.utils';\nimport { mergician } from 'mergician';\nimport { DataResponse, Dimension, Granularity, Measure } from '@embeddable.com/core';\nimport { useFillGaps } from '../../charts.fillGaps.hooks';\nimport { ChartGranularitySelectField } from '../../shared/ChartGranularitySelectField/ChartGranularitySelectField';\n\ntype BarChartGroupedProProps = {\n groupBy: Dimension;\n measure: Measure;\n results: DataResponse;\n reverseXAxis?: boolean;\n showLegend?: boolean;\n showLogarithmicScale?: boolean;\n showTooltips?: boolean;\n showTotalLabels?: boolean;\n showValueLabels?: boolean;\n xAxis: Dimension;\n xAxisLabel?: string;\n yAxisLabel?: string;\n yAxisRangeMax?: number;\n yAxisRangeMin?: number;\n setGranularity: (granularity: Granularity) => void;\n onBarClicked?: (args: {\n axisDimensionValue: string | null;\n groupingDimensionValue: string | null;\n }) => void;\n} & ChartCardHeaderProps;\n\nconst BarChartGroupedPro = (props: BarChartGroupedProProps) => {\n const theme = useTheme() as Theme;\n i18nSetup(theme);\n\n const {\n groupBy,\n measure,\n reverseXAxis,\n showLegend,\n showLogarithmicScale,\n showTooltips,\n showTotalLabels,\n showValueLabels,\n xAxis,\n yAxisRangeMax,\n yAxisRangeMin,\n setGranularity,\n onBarClicked,\n } = props;\n\n const { tooltip, description, title, xAxisLabel, yAxisLabel } = resolveI18nProps(props);\n\n const { hideMenu } = props;\n\n const results = useFillGaps({\n results: props.results,\n dimension: props.xAxis,\n });\n\n const data = getBarStackedChartProData(\n {\n data: results.data,\n dimension: xAxis,\n groupDimension: groupBy,\n measure,\n },\n theme,\n );\n\n const options = mergician(\n getBarChartProOptions(\n { measures: [measure], horizontal: false, onBarClicked, data, dimension: xAxis },\n theme,\n ),\n theme.charts?.barChartGroupedPro?.options || {},\n );\n\n const granularitySelectorHasMarginTop = !title && !description && !tooltip;\n\n return (\n <ChartCard\n data={results}\n dimensionsAndMeasures={[measure, xAxis, groupBy]}\n errorMessage={results.error}\n description={description}\n title={title}\n tooltip={tooltip}\n hideMenu={hideMenu}\n >\n <ChartGranularitySelectField\n hasMarginTop={granularitySelectorHasMarginTop}\n dimension={xAxis}\n onChange={setGranularity}\n />\n <BarChart\n data={data}\n showLegend={showLegend}\n showTooltips={showTooltips}\n showValueLabels={showValueLabels}\n showLogarithmicScale={showLogarithmicScale}\n xAxisLabel={xAxisLabel}\n yAxisLabel={yAxisLabel}\n reverseXAxis={reverseXAxis}\n yAxisRangeMin={yAxisRangeMin}\n yAxisRangeMax={yAxisRangeMax}\n showTotalLabels={showTotalLabels}\n options={options}\n />\n </ChartCard>\n );\n};\n\nexport default BarChartGroupedPro;\n"],"names":["BarChartGroupedPro","props","theme","useTheme","i18nSetup","groupBy","measure","reverseXAxis","showLegend","showLogarithmicScale","showTooltips","showTotalLabels","showValueLabels","xAxis","yAxisRangeMax","yAxisRangeMin","setGranularity","onBarClicked","tooltip","description","title","xAxisLabel","yAxisLabel","resolveI18nProps","hideMenu","results","useFillGaps","data","getBarStackedChartProData","options","mergician","getBarChartProOptions","_b","_a","granularitySelectorHasMarginTop","jsxs","ChartCard","jsx","ChartGranularitySelectField","BarChart"],"mappings":";;;;;;;AAkCA,MAAMA,IAAqB,CAACC,MAAmC;;AAC7D,QAAMC,IAAQC,EAAA;AACd,EAAAC,EAAUF,CAAK;AAEf,QAAM;AAAA,IACJ,SAAAG;AAAA,IACA,SAAAC;AAAA,IACA,cAAAC;AAAA,IACA,YAAAC;AAAA,IACA,sBAAAC;AAAA,IACA,cAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,OAAAC;AAAA,IACA,eAAAC;AAAA,IACA,eAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,cAAAC;AAAA,EAAA,IACEhB,GAEE,EAAE,SAAAiB,GAAS,aAAAC,GAAa,OAAAC,GAAO,YAAAC,GAAY,YAAAC,EAAA,IAAeC,EAAiBtB,CAAK,GAEhF,EAAE,UAAAuB,MAAavB,GAEfwB,IAAUC,EAAY;AAAA,IAC1B,SAASzB,EAAM;AAAA,IACf,WAAWA,EAAM;AAAA,EAAA,CAClB,GAEK0B,IAAOC;AAAA,IACX;AAAA,MACE,MAAMH,EAAQ;AAAA,MACd,WAAWZ;AAAA,MACX,gBAAgBR;AAAA,MAChB,SAAAC;AAAA,IAAA;AAAA,IAEFJ;AAAA,EAAA,GAGI2B,IAAUC;AAAA,IACdC;AAAA,MACE,EAAE,UAAU,CAACzB,CAAO,GAAG,YAAY,IAAO,cAAAW,GAAc,MAAAU,GAAM,WAAWd,EAAA;AAAA,MACzEX;AAAA,IAAA;AAAA,MAEF8B,KAAAC,IAAA/B,EAAM,WAAN,gBAAA+B,EAAc,uBAAd,gBAAAD,EAAkC,YAAW,CAAA;AAAA,EAAC,GAG1CE,IAAkC,CAACd,KAAS,CAACD,KAAe,CAACD;AAEnE,SACEiB,gBAAAA,EAAAA;AAAAA,IAACC;AAAA,IAAA;AAAA,MACC,MAAMX;AAAA,MACN,uBAAuB,CAACnB,GAASO,GAAOR,CAAO;AAAA,MAC/C,cAAcoB,EAAQ;AAAA,MACtB,aAAAN;AAAA,MACA,OAAAC;AAAA,MACA,SAAAF;AAAA,MACA,UAAAM;AAAA,MAEA,UAAA;AAAA,QAAAa,gBAAAA,EAAAA;AAAAA,UAACC;AAAA,UAAA;AAAA,YACC,cAAcJ;AAAA,YACd,WAAWrB;AAAA,YACX,UAAUG;AAAA,UAAA;AAAA,QAAA;AAAA,QAEZqB,gBAAAA,EAAAA;AAAAA,UAACE;AAAA,UAAA;AAAA,YACC,MAAAZ;AAAA,YACA,YAAAnB;AAAA,YACA,cAAAE;AAAA,YACA,iBAAAE;AAAA,YACA,sBAAAH;AAAA,YACA,YAAAY;AAAA,YACA,YAAAC;AAAA,YACA,cAAAf;AAAA,YACA,eAAAQ;AAAA,YACA,eAAAD;AAAA,YACA,iBAAAH;AAAA,YACA,SAAAkB;AAAA,UAAA;AAAA,QAAA;AAAA,MACF;AAAA,IAAA;AAAA,EAAA;AAGN;;;;"}
@@ -0,0 +1,98 @@
1
+ import { j as u, H as R } from "./Color.type.emb-CGyFSpIN.js";
2
+ import { useTheme as _ } from "@embeddable.com/react";
3
+ import { a as P, r as k } from "./component.inputs.constants-MAjey7Me.js";
4
+ import { C as B } from "./ChartCard-Be7mHyBp.js";
5
+ import { g as c } from "./formatter.utils-BeLScsYW.js";
6
+ import { u as d } from "./charts.fillGaps.hooks-C7KsWcZb.js";
7
+ import { u as W } from "./tables.hooks-BQdyUxau.js";
8
+ const f = (e, s) => {
9
+ const t = c(s);
10
+ return {
11
+ key: e.measure.name,
12
+ label: t.dimensionOrMeasureTitle(e.measure),
13
+ format: (o) => t.data(e.measure, o)
14
+ };
15
+ }, a = (e, s) => {
16
+ const t = c(s);
17
+ return {
18
+ key: e.dimension.name,
19
+ label: t.dimensionOrMeasureTitle(e.dimension),
20
+ format: (o) => t.data(e.dimension, o)
21
+ };
22
+ }, z = (e) => {
23
+ var l;
24
+ const s = _();
25
+ P(s);
26
+ const { title: t, description: o, tooltip: h } = k(e), {
27
+ hideMenu: C,
28
+ measure: i,
29
+ rowDimension: n,
30
+ columnDimension: r,
31
+ maxColor: M,
32
+ midColor: D,
33
+ minColor: w,
34
+ displayNullAs: x,
35
+ columnWidth: T,
36
+ firstColumnWidth: g,
37
+ showValues: y,
38
+ minThreshold: b,
39
+ maxThreshold: j
40
+ } = e, p = Array.from(
41
+ new Set((e.results.data ?? []).filter(Boolean).map((m) => m[r.name]))
42
+ ), F = Array.from(
43
+ new Set((e.results.data ?? []).filter(Boolean).map((m) => m[n.name]))
44
+ ), H = d({
45
+ results: e.results,
46
+ dimension: r
47
+ }), O = d({
48
+ results: H,
49
+ dimension: n
50
+ }), S = W({
51
+ results: O,
52
+ columnOrder: p,
53
+ rowOrder: F,
54
+ columnDimension: r,
55
+ rowDimension: n,
56
+ measures: [i]
57
+ }), v = f({ measure: i }, s), A = a({ dimension: n }, s), G = a({ dimension: r }, s);
58
+ return /* @__PURE__ */ u.jsx(
59
+ B,
60
+ {
61
+ title: t,
62
+ description: o,
63
+ tooltip: h,
64
+ data: e.results,
65
+ dimensionsAndMeasures: [n, r, i],
66
+ errorMessage: (l = e.results) == null ? void 0 : l.error,
67
+ hideMenu: C,
68
+ children: /* @__PURE__ */ u.jsx(
69
+ R,
70
+ {
71
+ data: S,
72
+ measure: v,
73
+ rowDimension: A,
74
+ columnDimension: G,
75
+ maxColor: M,
76
+ midColor: D,
77
+ minColor: w,
78
+ showValues: y,
79
+ minThreshold: b,
80
+ maxThreshold: j,
81
+ columnWidth: T,
82
+ firstColumnWidth: g,
83
+ displayNullAs: x
84
+ }
85
+ )
86
+ }
87
+ );
88
+ }, L = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
89
+ __proto__: null,
90
+ default: z,
91
+ getHeatDimension: a,
92
+ getHeatMeasure: f
93
+ }, Symbol.toStringTag, { value: "Module" }));
94
+ export {
95
+ z as H,
96
+ L as i
97
+ };
98
+ //# sourceMappingURL=index-DjdyOpZx.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-DjdyOpZx.js","sources":["../src/components/charts/tables/HeatMapPro/index.tsx"],"sourcesContent":["import { useTheme } from '@embeddable.com/react';\nimport { Theme } from '../../../../theme/theme.types';\nimport { i18nSetup } from '../../../../theme/i18n/i18n';\nimport { ChartCard, ChartCardHeaderProps } from '../../shared/ChartCard/ChartCard';\nimport { resolveI18nProps } from '../../../component.utils';\nimport { DataResponse, Dimension, Measure } from '@embeddable.com/core';\nimport { HeatMap, HeatMapPropsDimension, HeatMapPropsMeasure } from '@embeddable.com/remarkable-ui';\nimport { getThemeFormatter } from '../../../../theme/formatter/formatter.utils';\nimport { useFillGaps } from '../../charts.fillGaps.hooks';\nimport { useGetTableSortedResults } from '../tables.hooks';\n\ntype HeatMapProProps = {\n columnDimension: Dimension;\n columnWidth?: number;\n\n displayNullAs?: string;\n firstColumnWidth?: number;\n maxColor?: string;\n maxThreshold?: string;\n measure: Measure;\n midColor?: string;\n minColor?: string;\n minThreshold?: string;\n results: DataResponse;\n rowDimension: Dimension;\n showValues?: boolean;\n} & ChartCardHeaderProps;\n\nexport const getHeatMeasure = (\n props: { measure: Measure },\n theme: Theme,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): HeatMapPropsMeasure<any> => {\n const themeFormatter = getThemeFormatter(theme);\n\n return {\n key: props.measure.name,\n label: themeFormatter.dimensionOrMeasureTitle(props.measure),\n format: (value) => {\n return themeFormatter.data(props.measure, value);\n },\n };\n};\n\nexport const getHeatDimension = (\n props: { dimension: Dimension },\n theme: Theme,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): HeatMapPropsDimension<any> => {\n const themeFormatter = getThemeFormatter(theme);\n\n return {\n key: props.dimension.name,\n label: themeFormatter.dimensionOrMeasureTitle(props.dimension),\n format: (value: string) => themeFormatter.data(props.dimension, value),\n };\n};\n\nconst HeatMapPro = (props: HeatMapProProps) => {\n const theme = useTheme() as Theme;\n i18nSetup(theme);\n\n const { title, description, tooltip } = resolveI18nProps(props);\n const {\n hideMenu,\n measure,\n rowDimension,\n columnDimension,\n maxColor,\n midColor,\n minColor,\n displayNullAs,\n columnWidth,\n firstColumnWidth,\n showValues,\n minThreshold,\n maxThreshold,\n } = props;\n\n const columnOrder = Array.from(\n new Set((props.results.data ?? []).filter(Boolean).map((d) => d[columnDimension.name])),\n );\n\n const rowOrder = Array.from(\n new Set((props.results.data ?? []).filter(Boolean).map((d) => d[rowDimension.name])),\n );\n\n // Fill gaps for the column dimension\n const resultsColumnDimensionFillGaps = useFillGaps({\n results: props.results,\n dimension: columnDimension,\n });\n\n // Fill gaps for the row dimension\n const resultsRowColumnDimensionFillGaps = useFillGaps({\n results: resultsColumnDimensionFillGaps,\n dimension: rowDimension,\n });\n\n const results = useGetTableSortedResults({\n results: resultsRowColumnDimensionFillGaps,\n columnOrder,\n rowOrder,\n columnDimension,\n rowDimension,\n measures: [measure],\n });\n\n const pivotMeasures = getHeatMeasure({ measure }, theme);\n const pivotRowDimension = getHeatDimension({ dimension: rowDimension }, theme);\n const pivotColumnDimension = getHeatDimension({ dimension: columnDimension }, theme);\n\n return (\n <ChartCard\n title={title}\n description={description}\n tooltip={tooltip}\n data={props.results}\n dimensionsAndMeasures={[rowDimension, columnDimension, measure]}\n errorMessage={props.results?.error}\n hideMenu={hideMenu}\n >\n <HeatMap\n data={results}\n measure={pivotMeasures}\n rowDimension={pivotRowDimension}\n columnDimension={pivotColumnDimension}\n maxColor={maxColor}\n midColor={midColor}\n minColor={minColor}\n showValues={showValues}\n minThreshold={minThreshold}\n maxThreshold={maxThreshold}\n columnWidth={columnWidth}\n firstColumnWidth={firstColumnWidth}\n displayNullAs={displayNullAs}\n />\n </ChartCard>\n );\n};\n\nexport default HeatMapPro;\n"],"names":["getHeatMeasure","props","theme","themeFormatter","getThemeFormatter","value","getHeatDimension","HeatMapPro","useTheme","i18nSetup","title","description","tooltip","resolveI18nProps","hideMenu","measure","rowDimension","columnDimension","maxColor","midColor","minColor","displayNullAs","columnWidth","firstColumnWidth","showValues","minThreshold","maxThreshold","columnOrder","d","rowOrder","resultsColumnDimensionFillGaps","useFillGaps","resultsRowColumnDimensionFillGaps","results","useGetTableSortedResults","pivotMeasures","pivotRowDimension","pivotColumnDimension","jsx","ChartCard","_a","HeatMap"],"mappings":"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"}
@@ -0,0 +1,88 @@
1
+ import { j as f, K as T } from "./Color.type.emb-CGyFSpIN.js";
2
+ import { useTheme as w } from "@embeddable.com/react";
3
+ import { a as A, r as N, i as o } from "./component.inputs.constants-MAjey7Me.js";
4
+ import { C as O } from "./ChartCard-Be7mHyBp.js";
5
+ import { g as k } from "./formatter.utils-BeLScsYW.js";
6
+ import { useEffect as q } from "react";
7
+ import { g as E, a as V } from "./timeRange.utils-Rkw2u-vc.js";
8
+ const B = (s) => {
9
+ var l, g, p, h, u, v;
10
+ const t = w();
11
+ A(t);
12
+ const { title: C, description: P, tooltip: b } = N(s), {
13
+ hideMenu: L,
14
+ changeFontSize: y,
15
+ comparisonPeriod: i,
16
+ comparisonDateRange: D,
17
+ displayChangeAsPercentage: S,
18
+ fontSize: _,
19
+ measure: r,
20
+ primaryDateRange: m,
21
+ results: a,
22
+ resultsComparison: e,
23
+ reversePositiveNegativeColors: j,
24
+ percentageDecimalPlaces: x,
25
+ setComparisonDateRange: d
26
+ } = s;
27
+ q(() => {
28
+ if (!d) return;
29
+ const n = E(
30
+ m,
31
+ i,
32
+ t
33
+ );
34
+ d(n);
35
+ }, [i, JSON.stringify(m), t]);
36
+ const F = (g = (l = a.data) == null ? void 0 : l[0]) == null ? void 0 : g[r.name], R = D ? (h = (p = e == null ? void 0 : e.data) == null ? void 0 : p[0]) == null ? void 0 : h[r.name] : void 0, z = k(t), K = (n) => z.data(r, n), M = `vs ${V(i, t).toLowerCase()}`, c = {
37
+ isLoading: !!(a.isLoading || e != null && e.isLoading),
38
+ data: !(a != null && a.data) && !(e != null && e.data) ? void 0 : [
39
+ ...(u = a.data) != null && u.length ? [{ label: o.t("charts.primaryPeriod"), ...a.data[0] }] : [],
40
+ ...(v = e == null ? void 0 : e.data) != null && v.length ? [{ label: o.t("charts.comparisonPeriod"), ...e.data[0] }] : []
41
+ ]
42
+ };
43
+ return /* @__PURE__ */ f.jsx(
44
+ O,
45
+ {
46
+ data: c,
47
+ dimensionsAndMeasures: [
48
+ // Add a label dimension to distinguish primary and comparison periods in exports
49
+ {
50
+ name: "label",
51
+ title: o.t("charts.label"),
52
+ nativeType: "string",
53
+ __type__: "dimension"
54
+ },
55
+ r
56
+ ],
57
+ errorMessage: a.error,
58
+ description: P,
59
+ title: C,
60
+ tooltip: b,
61
+ hideMenu: L,
62
+ children: /* @__PURE__ */ f.jsx(
63
+ T,
64
+ {
65
+ value: F,
66
+ comparisonValue: c.isLoading ? void 0 : R,
67
+ valueFormatter: K,
68
+ valueFontSize: _,
69
+ trendFontSize: y,
70
+ invertChangeColors: j,
71
+ showChangeAsPercentage: S,
72
+ comparisonLabel: M,
73
+ percentageDecimalPlaces: x,
74
+ noPreviousDataLabel: o.t("charts.kpiChart.noPreviousData"),
75
+ equalComparisonLabel: o.t("charts.kpiChart.equalComparison")
76
+ }
77
+ )
78
+ }
79
+ );
80
+ }, W = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
81
+ __proto__: null,
82
+ default: B
83
+ }, Symbol.toStringTag, { value: "Module" }));
84
+ export {
85
+ B as K,
86
+ W as i
87
+ };
88
+ //# sourceMappingURL=index-KyBmwDIm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-KyBmwDIm.js","sources":["../src/components/charts/kpis/KpiChartNumberComparisonPro/index.tsx"],"sourcesContent":["import { useTheme } from '@embeddable.com/react';\nimport { Theme } from '../../../../theme/theme.types';\nimport { DataResponse, Measure, TimeRange } from '@embeddable.com/core';\nimport { i18n, i18nSetup } from '../../../../theme/i18n/i18n';\nimport { resolveI18nProps } from '../../../component.utils';\nimport { ChartCard, ChartCardHeaderProps } from '../../shared/ChartCard/ChartCard';\nimport { KpiChart } from '@embeddable.com/remarkable-ui';\nimport { getThemeFormatter } from '../../../../theme/formatter/formatter.utils';\nimport { useEffect } from 'react';\nimport {\n getComparisonPeriodDateRange,\n getComparisonPeriodLabel,\n} from '../../../utils/timeRange.utils';\n\ntype KpiChartNumberComparisonProProp = {\n changeFontSize?: number;\n comparisonPeriod?: string;\n\n displayChangeAsPercentage?: boolean;\n fontSize?: number;\n measure: Measure;\n primaryDateRange: TimeRange;\n results: DataResponse;\n resultsComparison: DataResponse | undefined;\n reversePositiveNegativeColors?: boolean;\n\n percentageDecimalPlaces?: number;\n comparisonDateRange: TimeRange;\n setComparisonDateRange?: (dateRange: TimeRange) => void;\n} & ChartCardHeaderProps;\n\nconst KpiChartNumberComparisonPro = (props: KpiChartNumberComparisonProProp) => {\n const theme: Theme = useTheme() as Theme;\n i18nSetup(theme);\n\n const { title, description, tooltip } = resolveI18nProps(props);\n const {\n hideMenu,\n changeFontSize,\n comparisonPeriod,\n comparisonDateRange,\n displayChangeAsPercentage,\n fontSize,\n measure,\n primaryDateRange,\n results,\n resultsComparison,\n reversePositiveNegativeColors,\n percentageDecimalPlaces,\n setComparisonDateRange,\n } = props;\n\n useEffect(() => {\n if (!setComparisonDateRange) return;\n\n const newComparisonDateRange = getComparisonPeriodDateRange(\n primaryDateRange,\n comparisonPeriod,\n theme,\n );\n setComparisonDateRange(newComparisonDateRange);\n }, [comparisonPeriod, JSON.stringify(primaryDateRange), theme]);\n\n const value: number = results.data?.[0]?.[measure.name];\n const comparisonValue = comparisonDateRange\n ? resultsComparison?.data?.[0]?.[measure.name]\n : undefined;\n\n const themeFormatter = getThemeFormatter(theme);\n const valueFormatter = (valueToFormat: number) => themeFormatter.data(measure, valueToFormat);\n const comparisonLabel = `vs ${getComparisonPeriodLabel(comparisonPeriod, theme).toLowerCase()}`;\n\n const resultsCombined: DataResponse = {\n isLoading: Boolean(results.isLoading || resultsComparison?.isLoading),\n data:\n !results?.data && !resultsComparison?.data\n ? undefined\n : [\n ...(results.data?.length\n ? [{ label: i18n.t('charts.primaryPeriod'), ...results.data[0] }]\n : []),\n ...(resultsComparison?.data?.length\n ? [{ label: i18n.t('charts.comparisonPeriod'), ...resultsComparison.data[0] }]\n : []),\n ],\n };\n\n return (\n <ChartCard\n data={resultsCombined}\n dimensionsAndMeasures={[\n // Add a label dimension to distinguish primary and comparison periods in exports\n {\n name: 'label',\n title: i18n.t('charts.label'),\n nativeType: 'string',\n __type__: 'dimension',\n },\n measure,\n ]}\n errorMessage={results.error}\n description={description}\n title={title}\n tooltip={tooltip}\n hideMenu={hideMenu}\n >\n <KpiChart\n value={value}\n comparisonValue={resultsCombined.isLoading ? undefined : comparisonValue}\n valueFormatter={valueFormatter}\n valueFontSize={fontSize}\n trendFontSize={changeFontSize}\n invertChangeColors={reversePositiveNegativeColors}\n showChangeAsPercentage={displayChangeAsPercentage}\n comparisonLabel={comparisonLabel}\n percentageDecimalPlaces={percentageDecimalPlaces}\n noPreviousDataLabel={i18n.t('charts.kpiChart.noPreviousData')}\n equalComparisonLabel={i18n.t('charts.kpiChart.equalComparison')}\n />\n </ChartCard>\n );\n};\n\nexport default KpiChartNumberComparisonPro;\n"],"names":["KpiChartNumberComparisonPro","props","theme","useTheme","i18nSetup","title","description","tooltip","resolveI18nProps","hideMenu","changeFontSize","comparisonPeriod","comparisonDateRange","displayChangeAsPercentage","fontSize","measure","primaryDateRange","results","resultsComparison","reversePositiveNegativeColors","percentageDecimalPlaces","setComparisonDateRange","useEffect","newComparisonDateRange","getComparisonPeriodDateRange","value","_b","_a","comparisonValue","_d","_c","themeFormatter","getThemeFormatter","valueFormatter","valueToFormat","comparisonLabel","getComparisonPeriodLabel","resultsCombined","_e","i18n","_f","jsx","ChartCard","KpiChart"],"mappings":";;;;;;;AA+BA,MAAMA,IAA8B,CAACC,MAA2C;;AAC9E,QAAMC,IAAeC,EAAA;AACrB,EAAAC,EAAUF,CAAK;AAEf,QAAM,EAAE,OAAAG,GAAO,aAAAC,GAAa,SAAAC,EAAA,IAAYC,EAAiBP,CAAK,GACxD;AAAA,IACJ,UAAAQ;AAAA,IACA,gBAAAC;AAAA,IACA,kBAAAC;AAAA,IACA,qBAAAC;AAAA,IACA,2BAAAC;AAAA,IACA,UAAAC;AAAA,IACA,SAAAC;AAAA,IACA,kBAAAC;AAAA,IACA,SAAAC;AAAA,IACA,mBAAAC;AAAA,IACA,+BAAAC;AAAA,IACA,yBAAAC;AAAA,IACA,wBAAAC;AAAA,EAAA,IACEpB;AAEJ,EAAAqB,EAAU,MAAM;AACd,QAAI,CAACD,EAAwB;AAE7B,UAAME,IAAyBC;AAAA,MAC7BR;AAAA,MACAL;AAAA,MACAT;AAAA,IAAA;AAEF,IAAAmB,EAAuBE,CAAsB;AAAA,EAC/C,GAAG,CAACZ,GAAkB,KAAK,UAAUK,CAAgB,GAAGd,CAAK,CAAC;AAE9D,QAAMuB,KAAgBC,KAAAC,IAAAV,EAAQ,SAAR,gBAAAU,EAAe,OAAf,gBAAAD,EAAoBX,EAAQ,OAC5Ca,IAAkBhB,KACpBiB,KAAAC,IAAAZ,KAAA,gBAAAA,EAAmB,SAAnB,gBAAAY,EAA0B,OAA1B,gBAAAD,EAA+Bd,EAAQ,QACvC,QAEEgB,IAAiBC,EAAkB9B,CAAK,GACxC+B,IAAiB,CAACC,MAA0BH,EAAe,KAAKhB,GAASmB,CAAa,GACtFC,IAAkB,MAAMC,EAAyBzB,GAAkBT,CAAK,EAAE,aAAa,IAEvFmC,IAAgC;AAAA,IACpC,WAAW,GAAQpB,EAAQ,aAAaC,KAAA,QAAAA,EAAmB;AAAA,IAC3D,MACE,EAACD,KAAA,QAAAA,EAAS,SAAQ,EAACC,KAAA,QAAAA,EAAmB,QAClC,SACA;AAAA,MACE,IAAIoB,IAAArB,EAAQ,SAAR,QAAAqB,EAAc,SACd,CAAC,EAAE,OAAOC,EAAK,EAAE,sBAAsB,GAAG,GAAGtB,EAAQ,KAAK,CAAC,EAAA,CAAG,IAC9D,CAAA;AAAA,MACJ,IAAIuB,IAAAtB,KAAA,gBAAAA,EAAmB,SAAnB,QAAAsB,EAAyB,SACzB,CAAC,EAAE,OAAOD,EAAK,EAAE,yBAAyB,GAAG,GAAGrB,EAAkB,KAAK,CAAC,EAAA,CAAG,IAC3E,CAAA;AAAA,IAAC;AAAA,EACP;AAGR,SACEuB,gBAAAA,EAAAA;AAAAA,IAACC;AAAA,IAAA;AAAA,MACC,MAAML;AAAA,MACN,uBAAuB;AAAA;AAAA,QAErB;AAAA,UACE,MAAM;AAAA,UACN,OAAOE,EAAK,EAAE,cAAc;AAAA,UAC5B,YAAY;AAAA,UACZ,UAAU;AAAA,QAAA;AAAA,QAEZxB;AAAA,MAAA;AAAA,MAEF,cAAcE,EAAQ;AAAA,MACtB,aAAAX;AAAA,MACA,OAAAD;AAAA,MACA,SAAAE;AAAA,MACA,UAAAE;AAAA,MAEA,UAAAgC,gBAAAA,EAAAA;AAAAA,QAACE;AAAA,QAAA;AAAA,UACC,OAAAlB;AAAA,UACA,iBAAiBY,EAAgB,YAAY,SAAYT;AAAA,UACzD,gBAAAK;AAAA,UACA,eAAenB;AAAA,UACf,eAAeJ;AAAA,UACf,oBAAoBS;AAAA,UACpB,wBAAwBN;AAAA,UACxB,iBAAAsB;AAAA,UACA,yBAAAf;AAAA,UACA,qBAAqBmB,EAAK,EAAE,gCAAgC;AAAA,UAC5D,sBAAsBA,EAAK,EAAE,iCAAiC;AAAA,QAAA;AAAA,MAAA;AAAA,IAChE;AAAA,EAAA;AAGN;;;;"}