@embeddable.com/remarkable-pro 0.0.4 → 0.0.6

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 (117) hide show
  1. package/dist/BarChartDefaultHorizontalPro.js +25 -85
  2. package/dist/BarChartDefaultHorizontalPro.js.map +1 -1
  3. package/dist/BarChartDefaultPro.js +25 -84
  4. package/dist/BarChartDefaultPro.js.map +1 -1
  5. package/dist/BarChartGroupedHorizontalPro.js +33 -102
  6. package/dist/BarChartGroupedHorizontalPro.js.map +1 -1
  7. package/dist/BarChartGroupedPro.js +27 -95
  8. package/dist/BarChartGroupedPro.js.map +1 -1
  9. package/dist/BarChartStackedHorizontalPro.js +28 -98
  10. package/dist/BarChartStackedHorizontalPro.js.map +1 -1
  11. package/dist/BarChartStackedPro.js +28 -97
  12. package/dist/BarChartStackedPro.js.map +1 -1
  13. package/dist/{ChartCard-C7c2rTst.js → ChartCard-hWESZ2Ps.js} +27 -27
  14. package/dist/{ChartCard-C7c2rTst.js.map → ChartCard-hWESZ2Ps.js.map} +1 -1
  15. package/dist/{Color.type.emb-CSPAaucR.js → Color.type.emb-CWTlQmpX.js} +2 -2
  16. package/dist/{Color.type.emb-CSPAaucR.js.map → Color.type.emb-CWTlQmpX.js.map} +1 -1
  17. package/dist/ColorEditor.js +2 -2
  18. package/dist/{ComparisonPeriod.type.emb-DOpJ1iWj.js → ComparisonPeriod.type.emb-A4w1cgoZ.js} +2 -2
  19. package/dist/{ComparisonPeriod.type.emb-DOpJ1iWj.js.map → ComparisonPeriod.type.emb-A4w1cgoZ.js.map} +1 -1
  20. package/dist/ComparisonPeriodSelectFieldPro.js +17 -58
  21. package/dist/ComparisonPeriodSelectFieldPro.js.map +1 -1
  22. package/dist/DateRangeSelectFieldPro.js +3 -3
  23. package/dist/DonutChartPro.js +3 -3
  24. package/dist/DonutLabelChartPro.js +3 -3
  25. package/dist/EditorCard-BZ9OPW3m.js +32 -0
  26. package/dist/{EditorCard-BtlvgP9q.js.map → EditorCard-BZ9OPW3m.js.map} +1 -1
  27. package/dist/HeatMapPro.js +26 -93
  28. package/dist/HeatMapPro.js.map +1 -1
  29. package/dist/KpiChartNumberComparisonPro.js +25 -94
  30. package/dist/KpiChartNumberComparisonPro.js.map +1 -1
  31. package/dist/KpiChartNumberPro.js +14 -31
  32. package/dist/KpiChartNumberPro.js.map +1 -1
  33. package/dist/LineChartComparisonDefaultPro.js +59 -370
  34. package/dist/LineChartComparisonDefaultPro.js.map +1 -1
  35. package/dist/LineChartDefaultPro.js +31 -179
  36. package/dist/LineChartDefaultPro.js.map +1 -1
  37. package/dist/LineChartGroupedPro.js +30 -174
  38. package/dist/LineChartGroupedPro.js.map +1 -1
  39. package/dist/MultiSelectFieldPro.js +3 -3
  40. package/dist/PieChartPro.js +3 -3
  41. package/dist/PivotTablePro.js +23 -145
  42. package/dist/PivotTablePro.js.map +1 -1
  43. package/dist/SingleSelectFieldPro.js +3 -3
  44. package/dist/TableChartPaginated.js +37 -172
  45. package/dist/TableChartPaginated.js.map +1 -1
  46. package/dist/{bars.utils-JRnFN04m.js → bars.utils-wDaeYsgx.js} +7 -7
  47. package/dist/{bars.utils-JRnFN04m.js.map → bars.utils-wDaeYsgx.js.map} +1 -1
  48. package/dist/{charts.utils-DAkS2VK1.js → charts.utils-DvG9esg1.js} +4 -4
  49. package/dist/{charts.utils-DAkS2VK1.js.map → charts.utils-DvG9esg1.js.map} +1 -1
  50. package/dist/{component.constants-h6et83ck.js → component.constants-Dhb2rtRh.js} +2 -2
  51. package/dist/{component.constants-h6et83ck.js.map → component.constants-Dhb2rtRh.js.map} +1 -1
  52. package/dist/components/charts/tables/HeatMapPro/index.d.ts.map +1 -1
  53. package/dist/components/charts/tables/PivotTablePro/PivotPro.utils.d.ts +1 -4
  54. package/dist/components/charts/tables/PivotTablePro/PivotPro.utils.d.ts.map +1 -1
  55. package/dist/components/charts/tables/PivotTablePro/index.d.ts.map +1 -1
  56. package/dist/components/charts/tables/tables.hooks.d.ts +17 -0
  57. package/dist/components/charts/tables/tables.hooks.d.ts.map +1 -0
  58. package/dist/embeddable-components.json +12 -12
  59. package/dist/{formatter.utils-DXzI4Hz_.js → formatter.utils-Bdp9Y-Lv.js} +2 -2
  60. package/dist/{formatter.utils-DXzI4Hz_.js.map → formatter.utils-Bdp9Y-Lv.js.map} +1 -1
  61. package/dist/index-B-x3eR8s.js +83 -0
  62. package/dist/index-B-x3eR8s.js.map +1 -0
  63. package/dist/index-B2-si8wa.js +82 -0
  64. package/dist/index-B2-si8wa.js.map +1 -0
  65. package/dist/{index-DF-AuKua.js → index-B7H0xf_l.js} +15 -14
  66. package/dist/{index-DF-AuKua.js.map → index-B7H0xf_l.js.map} +1 -1
  67. package/dist/index-BPkkRwcA.js +159 -0
  68. package/dist/index-BPkkRwcA.js.map +1 -0
  69. package/dist/{index-CWYH2gE2.js → index-BbEkJ2Zk.js} +5 -5
  70. package/dist/{index-CWYH2gE2.js.map → index-BbEkJ2Zk.js.map} +1 -1
  71. package/dist/index-BxkGSCbn.js +81 -0
  72. package/dist/index-BxkGSCbn.js.map +1 -0
  73. package/dist/index-C4uAHg_1.js +82 -0
  74. package/dist/index-C4uAHg_1.js.map +1 -0
  75. package/dist/index-CA0eQwx6.js +95 -0
  76. package/dist/index-CA0eQwx6.js.map +1 -0
  77. package/dist/index-CEyir5HV.js +326 -0
  78. package/dist/index-CEyir5HV.js.map +1 -0
  79. package/dist/{index-B4S34Z5S.js → index-CGLsIs8j.js} +6 -6
  80. package/dist/{index-B4S34Z5S.js.map → index-CGLsIs8j.js.map} +1 -1
  81. package/dist/{index-BR6dp5RX.js → index-CK9V-wz1.js} +13 -13
  82. package/dist/{index-BR6dp5RX.js.map → index-CK9V-wz1.js.map} +1 -1
  83. package/dist/index-CMy4Riwi.js +152 -0
  84. package/dist/index-CMy4Riwi.js.map +1 -0
  85. package/dist/index-CZ9yuIpZ.js +82 -0
  86. package/dist/index-CZ9yuIpZ.js.map +1 -0
  87. package/dist/{index-C8O2asSv.js → index-CvhDbU54.js} +5 -5
  88. package/dist/{index-C8O2asSv.js.map → index-CvhDbU54.js.map} +1 -1
  89. package/dist/{index-QOVQo6ZK.js → index-D4L5OYNQ.js} +5 -5
  90. package/dist/{index-QOVQo6ZK.js.map → index-D4L5OYNQ.js.map} +1 -1
  91. package/dist/index-DSAnOSq9.js +73 -0
  92. package/dist/index-DSAnOSq9.js.map +1 -0
  93. package/dist/index-DYa6RC1f.js +89 -0
  94. package/dist/index-DYa6RC1f.js.map +1 -0
  95. package/dist/index-DZypsIb4.js +30 -0
  96. package/dist/index-DZypsIb4.js.map +1 -0
  97. package/dist/index-DyLLyX5j.js +56 -0
  98. package/dist/index-DyLLyX5j.js.map +1 -0
  99. package/dist/index-YMH6QSSf.js +163 -0
  100. package/dist/index-YMH6QSSf.js.map +1 -0
  101. package/dist/{index-Czj-HZH9.js → index-cy3SJfGM.js} +5 -5
  102. package/dist/{index-Czj-HZH9.js.map → index-cy3SJfGM.js.map} +1 -1
  103. package/dist/index-uFQScwgQ.js +72 -0
  104. package/dist/index-uFQScwgQ.js.map +1 -0
  105. package/dist/index.d.ts +28 -6
  106. package/dist/index.d.ts.map +1 -1
  107. package/dist/index.js +122 -75
  108. package/dist/index.js.map +1 -1
  109. package/dist/{pies.utils-Bl8jquyV.js → pies.utils-eND-eqpj.js} +5 -5
  110. package/dist/{pies.utils-Bl8jquyV.js.map → pies.utils-eND-eqpj.js.map} +1 -1
  111. package/dist/remarkable-pro.css +1 -1
  112. package/dist/tables.hooks-BQdyUxau.js +45 -0
  113. package/dist/tables.hooks-BQdyUxau.js.map +1 -0
  114. package/dist/{timeRange.utils-CslTQiVA.js → timeRange.utils-DLTzyLvc.js} +2 -2
  115. package/dist/{timeRange.utils-CslTQiVA.js.map → timeRange.utils-DLTzyLvc.js.map} +1 -1
  116. package/package.json +2 -2
  117. package/dist/EditorCard-BtlvgP9q.js +0 -32
@@ -1,8 +1,8 @@
1
- import { m as x, j as m, D as S } from "./index-BR6dp5RX.js";
1
+ import { m as x, j as m, D as S } from "./index-CK9V-wz1.js";
2
2
  import { useTheme as b } from "@embeddable.com/react";
3
- import { g as D, a as v } from "./pies.utils-Bl8jquyV.js";
4
- import { a as _, r as k } from "./component.constants-h6et83ck.js";
5
- import { C as w } from "./ChartCard-C7c2rTst.js";
3
+ import { g as D, a as v } from "./pies.utils-eND-eqpj.js";
4
+ import { a as _, r as k } from "./component.constants-Dhb2rtRh.js";
5
+ import { C as w } from "./ChartCard-hWESZ2Ps.js";
6
6
  const L = (d) => {
7
7
  var r;
8
8
  const e = b();
@@ -59,4 +59,4 @@ export {
59
59
  L as D,
60
60
  V as i
61
61
  };
62
- //# sourceMappingURL=index-CWYH2gE2.js.map
62
+ //# sourceMappingURL=index-BbEkJ2Zk.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index-CWYH2gE2.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 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 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 subtitle={description}\n title={title}\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","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,GAEpBe,IAAOC;AAAA,IACX,EAAE,MAAMR,EAAQ,MAAM,WAAAH,GAAW,SAAAE,GAAS,gBAAAD,EAAA;AAAA,IAC1CL;AAAA,EAAA,GAGIgB,IAAUC;AAAA,IACdC,EAAsBZ,GAASN,CAAK;AAAA,MACpCmB,IAAAnB,EAAM,OAAO,kBAAb,gBAAAmB,EAA4B,YAAW,CAAA;AAAA,EAAC,GAGpCC,IAAqB,CAACC,MAA8B;;AACxD,IAAAT,EAAe;AAAA,MACb,gBAAgBS,MAAU,WAAwBC,KAAAH,IAAAZ,EAAQ,SAAR,gBAAAY,EAAeE,OAAf,OAAZ,SAAYC,EAAwBlB,EAAU;AAAA,IAAI,CACzF;AAAA,EACH;AAEA,SACEmB,gBAAAA,EAAAA;AAAAA,IAACC;AAAA,IAAA;AAAA,MACC,MAAMjB;AAAA,MACN,uBAAuB,CAACH,GAAWE,CAAO;AAAA,MAC1C,cAAcC,EAAQ;AAAA,MACtB,UAAUJ;AAAA,MACV,OAAAQ;AAAA,MAEA,UAAAY,gBAAAA,EAAAA;AAAAA,QAACE;AAAA,QAAA;AAAA,UACC,MAAAX;AAAA,UACA,SAAAE;AAAA,UACA,YAAAR;AAAA,UACA,cAAAC;AAAA,UACA,iBAAAC;AAAA,UACA,gBAAgBU;AAAA,QAAA;AAAA,MAAA;AAAA,IAClB;AAAA,EAAA;AAGN;;;;"}
1
+ {"version":3,"file":"index-BbEkJ2Zk.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 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 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 subtitle={description}\n title={title}\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","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,GAEpBe,IAAOC;AAAA,IACX,EAAE,MAAMR,EAAQ,MAAM,WAAAH,GAAW,SAAAE,GAAS,gBAAAD,EAAA;AAAA,IAC1CL;AAAA,EAAA,GAGIgB,IAAUC;AAAA,IACdC,EAAsBZ,GAASN,CAAK;AAAA,MACpCmB,IAAAnB,EAAM,OAAO,kBAAb,gBAAAmB,EAA4B,YAAW,CAAA;AAAA,EAAC,GAGpCC,IAAqB,CAACC,MAA8B;;AACxD,IAAAT,EAAe;AAAA,MACb,gBAAgBS,MAAU,WAAwBC,KAAAH,IAAAZ,EAAQ,SAAR,gBAAAY,EAAeE,OAAf,OAAZ,SAAYC,EAAwBlB,EAAU;AAAA,IAAI,CACzF;AAAA,EACH;AAEA,SACEmB,gBAAAA,EAAAA;AAAAA,IAACC;AAAA,IAAA;AAAA,MACC,MAAMjB;AAAA,MACN,uBAAuB,CAACH,GAAWE,CAAO;AAAA,MAC1C,cAAcC,EAAQ;AAAA,MACtB,UAAUJ;AAAA,MACV,OAAAQ;AAAA,MAEA,UAAAY,gBAAAA,EAAAA;AAAAA,QAACE;AAAA,QAAA;AAAA,UACC,MAAAX;AAAA,UACA,SAAAE;AAAA,UACA,YAAAR;AAAA,UACA,cAAAC;AAAA,UACA,iBAAAC;AAAA,UACA,gBAAgBU;AAAA,QAAA;AAAA,MAAA;AAAA,IAClB;AAAA,EAAA;AAGN;;;;"}
@@ -0,0 +1,81 @@
1
+ import { m as L, j as m, B as P } from "./index-CK9V-wz1.js";
2
+ import { useTheme as w } from "@embeddable.com/react";
3
+ import { a as M, r as S } from "./component.constants-Dhb2rtRh.js";
4
+ import { C as T } from "./ChartCard-hWESZ2Ps.js";
5
+ import { g as _, b as v } from "./bars.utils-wDaeYsgx.js";
6
+ import { u as G } from "./charts.fillGaps.hooks-YayOXVmt.js";
7
+ const O = (s) => {
8
+ var n, l;
9
+ const e = w();
10
+ M(e);
11
+ const {
12
+ description: u,
13
+ groupBy: t,
14
+ measure: r,
15
+ reverseXAxis: d,
16
+ showLegend: p,
17
+ showLogarithmicScale: c,
18
+ showTooltips: h,
19
+ showTotalLabels: x,
20
+ showValueLabels: g,
21
+ title: b,
22
+ xAxis: o,
23
+ xAxisLabel: f,
24
+ yAxisLabel: C,
25
+ yAxisRangeMax: A,
26
+ yAxisRangeMin: B,
27
+ onBarClicked: j
28
+ } = S(s), a = G({
29
+ results: s.results,
30
+ dimension: s.xAxis
31
+ }), i = _(
32
+ {
33
+ data: a.data,
34
+ dimension: o,
35
+ groupDimension: t,
36
+ measure: r
37
+ },
38
+ e
39
+ ), y = L(
40
+ v(
41
+ { measures: [r], horizontal: !1, onBarClicked: j, data: i, dimension: o },
42
+ e
43
+ ),
44
+ ((l = (n = e.charts) == null ? void 0 : n.barChartGroupedPro) == null ? void 0 : l.options) || {}
45
+ );
46
+ return /* @__PURE__ */ m.jsx(
47
+ T,
48
+ {
49
+ data: a,
50
+ dimensionsAndMeasures: [r, o, t],
51
+ errorMessage: a.error,
52
+ subtitle: u,
53
+ title: b,
54
+ children: /* @__PURE__ */ m.jsx(
55
+ P,
56
+ {
57
+ data: i,
58
+ showLegend: p,
59
+ showTooltips: h,
60
+ showValueLabels: g,
61
+ showLogarithmicScale: c,
62
+ xAxisLabel: f,
63
+ yAxisLabel: C,
64
+ reverseXAxis: d,
65
+ yAxisRangeMin: B,
66
+ yAxisRangeMax: A,
67
+ showTotalLabels: x,
68
+ options: y
69
+ }
70
+ )
71
+ }
72
+ );
73
+ }, I = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
74
+ __proto__: null,
75
+ default: O
76
+ }, Symbol.toStringTag, { value: "Module" }));
77
+ export {
78
+ O as B,
79
+ I as i
80
+ };
81
+ //# sourceMappingURL=index-BxkGSCbn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-BxkGSCbn.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 } 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, Measure } from '@embeddable.com/core';\nimport { useFillGaps } from '../../charts.fillGaps.hooks';\n\ntype BarChartGroupedProProps = {\n description: string;\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 title: string;\n xAxis: Dimension;\n xAxisLabel: string;\n yAxisLabel: string;\n yAxisRangeMax?: number;\n yAxisRangeMin?: number;\n onBarClicked: (args: {\n axisDimensionValue: string | null;\n groupingDimensionValue: string | null;\n }) => void;\n};\n\nconst BarChartGroupedPro = (props: BarChartGroupedProProps) => {\n const theme = useTheme() as Theme;\n i18nSetup(theme);\n\n const {\n description,\n groupBy,\n measure,\n reverseXAxis,\n showLegend,\n showLogarithmicScale,\n showTooltips,\n showTotalLabels,\n showValueLabels,\n title,\n xAxis,\n xAxisLabel,\n yAxisLabel,\n yAxisRangeMax,\n yAxisRangeMin,\n onBarClicked,\n } = resolveI18nProps(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 return (\n <ChartCard\n data={results}\n dimensionsAndMeasures={[measure, xAxis, groupBy]}\n errorMessage={results.error}\n subtitle={description}\n title={title}\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","description","groupBy","measure","reverseXAxis","showLegend","showLogarithmicScale","showTooltips","showTotalLabels","showValueLabels","title","xAxis","xAxisLabel","yAxisLabel","yAxisRangeMax","yAxisRangeMin","onBarClicked","resolveI18nProps","results","useFillGaps","data","getBarStackedChartProData","options","mergician","getBarChartProOptions","_b","_a","jsx","ChartCard","BarChart"],"mappings":";;;;;;AAkCA,MAAMA,IAAqB,CAACC,MAAmC;;AAC7D,QAAMC,IAAQC,EAAA;AACd,EAAAC,EAAUF,CAAK;AAEf,QAAM;AAAA,IACJ,aAAAG;AAAA,IACA,SAAAC;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,OAAAC;AAAA,IACA,YAAAC;AAAA,IACA,YAAAC;AAAA,IACA,eAAAC;AAAA,IACA,eAAAC;AAAA,IACA,cAAAC;AAAA,EAAA,IACEC,EAAiBpB,CAAK,GAEpBqB,IAAUC,EAAY;AAAA,IAC1B,SAAStB,EAAM;AAAA,IACf,WAAWA,EAAM;AAAA,EAAA,CAClB,GAEKuB,IAAOC;AAAA,IACX;AAAA,MACE,MAAMH,EAAQ;AAAA,MACd,WAAWP;AAAA,MACX,gBAAgBT;AAAA,MAChB,SAAAC;AAAA,IAAA;AAAA,IAEFL;AAAA,EAAA,GAGIwB,IAAUC;AAAA,IACdC;AAAA,MACE,EAAE,UAAU,CAACrB,CAAO,GAAG,YAAY,IAAO,cAAAa,GAAc,MAAAI,GAAM,WAAWT,EAAA;AAAA,MACzEb;AAAA,IAAA;AAAA,MAEF2B,KAAAC,IAAA5B,EAAM,WAAN,gBAAA4B,EAAc,uBAAd,gBAAAD,EAAkC,YAAW,CAAA;AAAA,EAAC;AAGhD,SACEE,gBAAAA,EAAAA;AAAAA,IAACC;AAAA,IAAA;AAAA,MACC,MAAMV;AAAA,MACN,uBAAuB,CAACf,GAASQ,GAAOT,CAAO;AAAA,MAC/C,cAAcgB,EAAQ;AAAA,MACtB,UAAUjB;AAAA,MACV,OAAAS;AAAA,MAEA,UAAAiB,gBAAAA,EAAAA;AAAAA,QAACE;AAAA,QAAA;AAAA,UACC,MAAAT;AAAA,UACA,YAAAf;AAAA,UACA,cAAAE;AAAA,UACA,iBAAAE;AAAA,UACA,sBAAAH;AAAA,UACA,YAAAM;AAAA,UACA,YAAAC;AAAA,UACA,cAAAT;AAAA,UACA,eAAAW;AAAA,UACA,eAAAD;AAAA,UACA,iBAAAN;AAAA,UACA,SAAAc;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,EAAA;AAGN;;;;"}
@@ -0,0 +1,82 @@
1
+ import { j as v, K } from "./index-CK9V-wz1.js";
2
+ import { useTheme as T } from "@embeddable.com/react";
3
+ import { a as w, r as A, i } from "./component.constants-Dhb2rtRh.js";
4
+ import { C as M } from "./ChartCard-hWESZ2Ps.js";
5
+ import { g as N } from "./formatter.utils-Bdp9Y-Lv.js";
6
+ import { useEffect as O } from "react";
7
+ import { g as E, a as V } from "./timeRange.utils-DLTzyLvc.js";
8
+ const B = (s) => {
9
+ var c, g, l, p, h, f;
10
+ const t = T();
11
+ w(t);
12
+ const { title: b, description: P } = A(s), {
13
+ changeFontSize: u,
14
+ comparisonPeriod: r,
15
+ comparisonDateRange: C,
16
+ displayChangeAsPercentage: y,
17
+ fontSize: _,
18
+ measure: o,
19
+ primaryDateRange: m,
20
+ results: a,
21
+ resultsComparison: e,
22
+ reversePositiveNegativeColors: L,
23
+ percentageDecimalPlaces: S,
24
+ setComparisonDateRange: j
25
+ } = s;
26
+ O(() => {
27
+ const n = E(
28
+ m,
29
+ r,
30
+ t
31
+ );
32
+ j(n);
33
+ }, [r, JSON.stringify(m), t]);
34
+ const x = (g = (c = a.data) == null ? void 0 : c[0]) == null ? void 0 : g[o.name], D = C ? (p = (l = e == null ? void 0 : e.data) == null ? void 0 : l[0]) == null ? void 0 : p[o.name] : void 0, R = N(t), F = (n) => R.data(o, n), z = `vs ${V(r, t).toLowerCase()}`, d = {
35
+ isLoading: !!(a.isLoading || e != null && e.isLoading),
36
+ data: !(a != null && a.data) && !(e != null && e.data) ? void 0 : [
37
+ ...(h = a.data) != null && h.length ? [{ label: i.t("charts.primaryPeriod"), ...a.data[0] }] : [],
38
+ ...(f = e == null ? void 0 : e.data) != null && f.length ? [{ label: i.t("charts.comparisonPeriod"), ...e.data[0] }] : []
39
+ ]
40
+ };
41
+ return /* @__PURE__ */ v.jsx(
42
+ M,
43
+ {
44
+ data: d,
45
+ dimensionsAndMeasures: [
46
+ // Add a label dimension to distinguish primary and comparison periods in exports
47
+ {
48
+ name: "label",
49
+ title: i.t("charts.label"),
50
+ nativeType: "string",
51
+ __type__: "dimension"
52
+ },
53
+ o
54
+ ],
55
+ errorMessage: a.error,
56
+ subtitle: P,
57
+ title: b,
58
+ children: /* @__PURE__ */ v.jsx(
59
+ K,
60
+ {
61
+ value: x,
62
+ comparisonValue: d.isLoading ? void 0 : D,
63
+ valueFormatter: F,
64
+ valueFontSize: _,
65
+ changeFontSize: u,
66
+ invertChangeColors: L,
67
+ showChangeAsPercentage: y,
68
+ comparisonLabel: z,
69
+ percentageDecimalPlaces: S
70
+ }
71
+ )
72
+ }
73
+ );
74
+ }, Q = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
75
+ __proto__: null,
76
+ default: B
77
+ }, Symbol.toStringTag, { value: "Module" }));
78
+ export {
79
+ B as K,
80
+ Q as i
81
+ };
82
+ //# sourceMappingURL=index-C4uAHg_1.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-C4uAHg_1.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 } 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 description: string;\n displayChangeAsPercentage?: boolean;\n fontSize: number;\n measure: Measure;\n primaryDateRange: TimeRange;\n results: DataResponse;\n resultsComparison: DataResponse | undefined;\n reversePositiveNegativeColors?: boolean;\n title: string;\n percentageDecimalPlaces: number;\n comparisonDateRange: TimeRange;\n setComparisonDateRange: (dateRange: TimeRange) => void;\n};\n\nconst KpiChartNumberComparisonPro = (props: KpiChartNumberComparisonProProp) => {\n const theme: Theme = useTheme() as Theme;\n i18nSetup(theme);\n\n const { title, description } = resolveI18nProps(props);\n const {\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 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 subtitle={description}\n title={title}\n >\n <KpiChart\n value={value}\n comparisonValue={resultsCombined.isLoading ? undefined : comparisonValue}\n valueFormatter={valueFormatter}\n valueFontSize={fontSize}\n changeFontSize={changeFontSize}\n invertChangeColors={reversePositiveNegativeColors}\n showChangeAsPercentage={displayChangeAsPercentage}\n comparisonLabel={comparisonLabel}\n percentageDecimalPlaces={percentageDecimalPlaces}\n />\n </ChartCard>\n );\n};\n\nexport default KpiChartNumberComparisonPro;\n"],"names":["KpiChartNumberComparisonPro","props","theme","useTheme","i18nSetup","title","description","resolveI18nProps","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,MAAgBC,EAAiBN,CAAK,GAC/C;AAAA,IACJ,gBAAAO;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,IACElB;AAEJ,EAAAmB,EAAU,MAAM;AACd,UAAMC,IAAyBC;AAAA,MAC7BR;AAAA,MACAL;AAAA,MACAP;AAAA,IAAA;AAEF,IAAAiB,EAAuBE,CAAsB;AAAA,EAC/C,GAAG,CAACZ,GAAkB,KAAK,UAAUK,CAAgB,GAAGZ,CAAK,CAAC;AAE9D,QAAMqB,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,EAAkB5B,CAAK,GACxC6B,IAAiB,CAACC,MAA0BH,EAAe,KAAKhB,GAASmB,CAAa,GACtFC,IAAkB,MAAMC,EAAyBzB,GAAkBP,CAAK,EAAE,aAAa,IAEvFiC,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,UAAUT;AAAA,MACV,OAAAD;AAAA,MAEA,UAAAkC,gBAAAA,EAAAA;AAAAA,QAACE;AAAA,QAAA;AAAA,UACC,OAAAlB;AAAA,UACA,iBAAiBY,EAAgB,YAAY,SAAYT;AAAA,UACzD,gBAAAK;AAAA,UACA,eAAenB;AAAA,UACf,gBAAAJ;AAAA,UACA,oBAAoBS;AAAA,UACpB,wBAAwBN;AAAA,UACxB,iBAAAsB;AAAA,UACA,yBAAAf;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,EAAA;AAGN;;;;"}
@@ -0,0 +1,95 @@
1
+ import { j as u, H as A } from "./index-CK9V-wz1.js";
2
+ import { useTheme as G } from "@embeddable.com/react";
3
+ import { a as R, r as _ } from "./component.constants-Dhb2rtRh.js";
4
+ import { C as P } from "./ChartCard-hWESZ2Ps.js";
5
+ import { g as c } from "./formatter.utils-Bdp9Y-Lv.js";
6
+ import { u as d } from "./charts.fillGaps.hooks-YayOXVmt.js";
7
+ import { u as k } 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
+ }, B = (e) => {
23
+ var l;
24
+ const s = G();
25
+ R(s);
26
+ const { description: t, title: o } = _(e), {
27
+ measure: i,
28
+ rowDimension: n,
29
+ columnDimension: r,
30
+ maxColor: h,
31
+ midColor: C,
32
+ minColor: D,
33
+ displayNullAs: M,
34
+ columnWidth: w,
35
+ firstColumnWidth: x,
36
+ showValues: T,
37
+ minThreshold: b,
38
+ maxThreshold: g
39
+ } = e, y = Array.from(
40
+ new Set((e.results.data ?? []).filter(Boolean).map((m) => m[r.name]))
41
+ ), j = Array.from(
42
+ new Set((e.results.data ?? []).filter(Boolean).map((m) => m[n.name]))
43
+ ), F = d({
44
+ results: e.results,
45
+ dimension: r
46
+ }), H = d({
47
+ results: F,
48
+ dimension: n
49
+ }), O = k({
50
+ results: H,
51
+ columnOrder: y,
52
+ rowOrder: j,
53
+ columnDimension: r,
54
+ rowDimension: n,
55
+ measures: [i]
56
+ }), S = f({ measure: i }, s), p = a({ dimension: n }, s), v = a({ dimension: r }, s);
57
+ return /* @__PURE__ */ u.jsx(
58
+ P,
59
+ {
60
+ title: o,
61
+ subtitle: t,
62
+ data: e.results,
63
+ dimensionsAndMeasures: [n, r, i],
64
+ errorMessage: (l = e.results) == null ? void 0 : l.error,
65
+ children: /* @__PURE__ */ u.jsx(
66
+ A,
67
+ {
68
+ data: O,
69
+ measure: S,
70
+ rowDimension: p,
71
+ columnDimension: v,
72
+ maxColor: h,
73
+ midColor: C,
74
+ minColor: D,
75
+ showValues: T,
76
+ minThreshold: b,
77
+ maxThreshold: g,
78
+ columnWidth: w,
79
+ firstColumnWidth: x,
80
+ displayNullAs: M
81
+ }
82
+ )
83
+ }
84
+ );
85
+ }, J = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
86
+ __proto__: null,
87
+ default: B,
88
+ getHeatDimension: a,
89
+ getHeatMeasure: f
90
+ }, Symbol.toStringTag, { value: "Module" }));
91
+ export {
92
+ B as H,
93
+ J as i
94
+ };
95
+ //# sourceMappingURL=index-CA0eQwx6.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-CA0eQwx6.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 } 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 description: string;\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 title: string;\n};\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 { description, title } = resolveI18nProps(props);\n const {\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 subtitle={description}\n data={props.results}\n dimensionsAndMeasures={[rowDimension, columnDimension, measure]}\n errorMessage={props.results?.error}\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","description","title","resolveI18nProps","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":";;;;;;;AA6BO,MAAMA,IAAiB,CAC5BC,GACAC,MAE6B;AAC7B,QAAMC,IAAiBC,EAAkBF,CAAK;AAE9C,SAAO;AAAA,IACL,KAAKD,EAAM,QAAQ;AAAA,IACnB,OAAOE,EAAe,wBAAwBF,EAAM,OAAO;AAAA,IAC3D,QAAQ,CAACI,MACAF,EAAe,KAAKF,EAAM,SAASI,CAAK;AAAA,EACjD;AAEJ,GAEaC,IAAmB,CAC9BL,GACAC,MAE+B;AAC/B,QAAMC,IAAiBC,EAAkBF,CAAK;AAE9C,SAAO;AAAA,IACL,KAAKD,EAAM,UAAU;AAAA,IACrB,OAAOE,EAAe,wBAAwBF,EAAM,SAAS;AAAA,IAC7D,QAAQ,CAACI,MAAkBF,EAAe,KAAKF,EAAM,WAAWI,CAAK;AAAA,EAAA;AAEzE,GAEME,IAAa,CAACN,MAA2B;;AAC7C,QAAMC,IAAQM,EAAA;AACd,EAAAC,EAAUP,CAAK;AAEf,QAAM,EAAE,aAAAQ,GAAa,OAAAC,MAAUC,EAAiBX,CAAK,GAC/C;AAAA,IACJ,SAAAY;AAAA,IACA,cAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,UAAAC;AAAA,IACA,UAAAC;AAAA,IACA,UAAAC;AAAA,IACA,eAAAC;AAAA,IACA,aAAAC;AAAA,IACA,kBAAAC;AAAA,IACA,YAAAC;AAAA,IACA,cAAAC;AAAA,IACA,cAAAC;AAAA,EAAA,IACEvB,GAEEwB,IAAc,MAAM;AAAA,IACxB,IAAI,KAAKxB,EAAM,QAAQ,QAAQ,CAAA,GAAI,OAAO,OAAO,EAAE,IAAI,CAACyB,MAAMA,EAAEX,EAAgB,IAAI,CAAC,CAAC;AAAA,EAAA,GAGlFY,IAAW,MAAM;AAAA,IACrB,IAAI,KAAK1B,EAAM,QAAQ,QAAQ,CAAA,GAAI,OAAO,OAAO,EAAE,IAAI,CAACyB,MAAMA,EAAEZ,EAAa,IAAI,CAAC,CAAC;AAAA,EAAA,GAI/Ec,IAAiCC,EAAY;AAAA,IACjD,SAAS5B,EAAM;AAAA,IACf,WAAWc;AAAA,EAAA,CACZ,GAGKe,IAAoCD,EAAY;AAAA,IACpD,SAASD;AAAA,IACT,WAAWd;AAAA,EAAA,CACZ,GAEKiB,IAAUC,EAAyB;AAAA,IACvC,SAASF;AAAA,IACT,aAAAL;AAAA,IACA,UAAAE;AAAA,IACA,iBAAAZ;AAAA,IACA,cAAAD;AAAA,IACA,UAAU,CAACD,CAAO;AAAA,EAAA,CACnB,GAEKoB,IAAgBjC,EAAe,EAAE,SAAAa,EAAA,GAAWX,CAAK,GACjDgC,IAAoB5B,EAAiB,EAAE,WAAWQ,EAAA,GAAgBZ,CAAK,GACvEiC,IAAuB7B,EAAiB,EAAE,WAAWS,EAAA,GAAmBb,CAAK;AAEnF,SACEkC,gBAAAA,EAAAA;AAAAA,IAACC;AAAA,IAAA;AAAA,MACC,OAAA1B;AAAA,MACA,UAAUD;AAAA,MACV,MAAMT,EAAM;AAAA,MACZ,uBAAuB,CAACa,GAAcC,GAAiBF,CAAO;AAAA,MAC9D,eAAcyB,IAAArC,EAAM,YAAN,gBAAAqC,EAAe;AAAA,MAE7B,UAAAF,gBAAAA,EAAAA;AAAAA,QAACG;AAAA,QAAA;AAAA,UACC,MAAMR;AAAA,UACN,SAASE;AAAA,UACT,cAAcC;AAAA,UACd,iBAAiBC;AAAA,UACjB,UAAAnB;AAAA,UACA,UAAAC;AAAA,UACA,UAAAC;AAAA,UACA,YAAAI;AAAA,UACA,cAAAC;AAAA,UACA,cAAAC;AAAA,UACA,aAAAJ;AAAA,UACA,kBAAAC;AAAA,UACA,eAAAF;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,EAAA;AAGN;;;;;;"}
@@ -0,0 +1,326 @@
1
+ import { m as $, a as N, c as S, e as w, f as M, j as R, L as F } from "./index-CK9V-wz1.js";
2
+ import { useTheme as X } from "@embeddable.com/react";
3
+ import { i as Y, a as z, r as E } from "./component.constants-Dhb2rtRh.js";
4
+ import { C as G } from "./ChartCard-hWESZ2Ps.js";
5
+ import { useEffect as K } from "react";
6
+ import { g as V } from "./timeRange.utils-DLTzyLvc.js";
7
+ import { g as P } from "./formatter.utils-Bdp9Y-Lv.js";
8
+ import { g as J, a as U } from "./object.utils-D_Zzon-H.js";
9
+ import { i as q, s as H } from "./color.utils-BSg_DFOh.js";
10
+ import { g as Q } from "./lines.utils-CFEUUo4k.js";
11
+ import { u as B } from "./charts.fillGaps.hooks-YayOXVmt.js";
12
+ const k = "mainAxis", v = "comparisonAxis", j = (u, r) => {
13
+ var O, b, m, L;
14
+ const { data: e, measure: n, dimension: t, index: p, isPreviousPeriod: o, hasMinMaxYAxisRange: x, labels: a } = u, c = e == null ? void 0 : e.map((f) => f[t.name]), i = !!((O = n.inputs) != null && O.connectGaps), g = a ? a.map((f) => {
15
+ const y = e == null ? void 0 : e.find((I) => I[t.name] === f);
16
+ return (y == null ? void 0 : y[n.name]) ?? (i ? 0 : null);
17
+ }) : e == null ? void 0 : e.map((f) => f[n.name] ?? (i ? 0 : null)), h = P(r), A = J(r), s = !!((b = n.inputs) != null && b[o ? "previousLineDashed" : "lineDashed"]), l = N(), d = (m = n.inputs) == null ? void 0 : m[o ? "previousLineColor" : "lineColor"], C = q(d) ? d : U(
18
+ `${A}.charts.backgroundColors`,
19
+ n.name,
20
+ r.charts.backgroundColors ?? l,
21
+ p
22
+ ), D = h.dimensionOrMeasureTitle(n);
23
+ return {
24
+ xAxisID: o ? v : k,
25
+ labels: c,
26
+ rawLabel: D,
27
+ label: (o ? `${Y.t("common.compared")} ` : "") + D,
28
+ data: g,
29
+ backgroundColor: H(C, 0.5),
30
+ pointBackgroundColor: C,
31
+ borderDash: s ? [
32
+ S("--em-linechart-line-dash", "0.25rem"),
33
+ S("--em-linechart-line-gap", "0.25rem")
34
+ ] : void 0,
35
+ borderColor: C,
36
+ fill: (L = n.inputs) == null ? void 0 : L.fillUnderLine,
37
+ clip: x
38
+ };
39
+ }, W = (u, r) => {
40
+ if (!u.data)
41
+ return {
42
+ labels: [],
43
+ datasets: [
44
+ { xAxisID: k, data: [] },
45
+ { xAxisID: v, data: [] }
46
+ ]
47
+ };
48
+ const { data: e, dataComparison: n, dimension: t, measures: p, hasMinMaxYAxisRange: o } = u, a = t.nativeType === "time" ? void 0 : n ? Array.from(
49
+ /* @__PURE__ */ new Set([
50
+ ...e.map((g) => g[t.name]),
51
+ ...(n == null ? void 0 : n.map((g) => g[t.name])) ?? []
52
+ ])
53
+ ) : void 0, c = p.map(
54
+ (g, h) => j(
55
+ {
56
+ data: e,
57
+ measure: g,
58
+ dimension: t,
59
+ labels: a,
60
+ hasMinMaxYAxisRange: o,
61
+ index: h
62
+ },
63
+ r
64
+ )
65
+ ), i = p.map(
66
+ (g, h) => j(
67
+ {
68
+ data: n,
69
+ measure: g,
70
+ dimension: t,
71
+ labels: a,
72
+ hasMinMaxYAxisRange: o,
73
+ index: h,
74
+ isPreviousPeriod: !0
75
+ },
76
+ r
77
+ )
78
+ );
79
+ return {
80
+ labels: a ?? e.map((g) => g[t.name]),
81
+ datasets: [...c, ...i]
82
+ };
83
+ }, Z = (u, r) => {
84
+ const { dimension: e, data: n, measures: t, xAxisLabel: p } = u, o = P(r);
85
+ return {
86
+ plugins: {
87
+ legend: {
88
+ labels: {
89
+ filter: (a, c) => {
90
+ if (!a) return !1;
91
+ const i = c.datasets[a.datasetIndex];
92
+ return Array.isArray(i.data) && i.data.length > 0;
93
+ }
94
+ }
95
+ },
96
+ datalabels: {
97
+ labels: {
98
+ value: {
99
+ formatter: (a, c) => {
100
+ const i = t[c.datasetIndex % t.length];
101
+ return o.data(i, a);
102
+ }
103
+ }
104
+ }
105
+ },
106
+ tooltip: {
107
+ callbacks: {
108
+ title: (a) => a[0] ? o.data(e, a[0].label) : "",
109
+ label: (a) => {
110
+ const c = t[a.datasetIndex % t.length], i = a.raw;
111
+ return `${a.dataset.label}: ${o.data(c, i)}`;
112
+ }
113
+ }
114
+ }
115
+ },
116
+ scales: {
117
+ x: {
118
+ display: !1
119
+ },
120
+ [k]: {
121
+ title: {
122
+ ...M(),
123
+ text: p,
124
+ display: !!p
125
+ },
126
+ grid: { display: !1 },
127
+ ticks: {
128
+ ...w(),
129
+ callback(a) {
130
+ var c;
131
+ return o.data(e, (c = n.labels) == null ? void 0 : c[a]);
132
+ }
133
+ }
134
+ },
135
+ [v]: {
136
+ display: !1
137
+ },
138
+ y: {
139
+ ticks: {
140
+ callback: (a) => o.data(t[0], a)
141
+ }
142
+ }
143
+ }
144
+ };
145
+ }, aa = (u, r) => {
146
+ var h, A;
147
+ const { dimension: e, data: n, measures: t, xAxisLabel: p, showComparisonAxis: o, showDataComparison: x } = u, a = P(r), c = ((h = n.datasets.find((s) => s.xAxisID === k)) == null ? void 0 : h.labels) ?? [], i = ((A = n.datasets.find((s) => s.xAxisID === v)) == null ? void 0 : A.labels) ?? [];
148
+ return {
149
+ plugins: {
150
+ legend: {
151
+ labels: {
152
+ filter: (s, l) => {
153
+ if (!s) return !1;
154
+ const d = l.datasets[s.datasetIndex];
155
+ return Array.isArray(d.data) && d.data.length > 0;
156
+ }
157
+ }
158
+ },
159
+ datalabels: {
160
+ labels: {
161
+ value: {
162
+ formatter: (s, l) => {
163
+ const d = t[l.datasetIndex % t.length];
164
+ return a.data(d, s);
165
+ }
166
+ }
167
+ }
168
+ },
169
+ tooltip: {
170
+ callbacks: {
171
+ title: (s) => {
172
+ const l = s[0];
173
+ if (!x && l)
174
+ return a.data(e, l.label);
175
+ const d = l == null ? void 0 : l.dataIndex;
176
+ if (d === void 0) return "";
177
+ const C = c[d] && a.data(e, c[d]), D = i[d] && a.data(e, i[d]);
178
+ return `${C ?? "-"} vs ${D ?? "-"}`;
179
+ },
180
+ label: (s) => {
181
+ const l = t[s.datasetIndex % t.length], d = s.raw;
182
+ return `${s.dataset.label}: ${a.data(l, d)}`;
183
+ }
184
+ }
185
+ }
186
+ },
187
+ scales: {
188
+ x: { display: !1 },
189
+ [k]: {
190
+ title: {
191
+ ...M(),
192
+ text: p,
193
+ display: !!((!o || i.length === 0) && p)
194
+ },
195
+ grid: { display: !1 },
196
+ ticks: {
197
+ ...w(),
198
+ callback: (s) => a.data(e, c[Number(s)])
199
+ }
200
+ },
201
+ [v]: {
202
+ title: {
203
+ ...M(),
204
+ text: p,
205
+ display: !!p
206
+ },
207
+ grid: { display: !1 },
208
+ display: o && i.length > 0,
209
+ ticks: {
210
+ ...w(),
211
+ callback: (s) => {
212
+ if (i.length === 0)
213
+ return "";
214
+ const l = i[Number(s)];
215
+ return l ? a.data(e, l) : "";
216
+ }
217
+ }
218
+ },
219
+ y: {
220
+ ticks: {
221
+ callback: (s) => a.data(t[0], s)
222
+ }
223
+ }
224
+ }
225
+ };
226
+ }, ea = (u, r) => {
227
+ var p, o;
228
+ const { onLineClicked: e, dimension: n } = u, t = n.nativeType === "time" ? aa : Z;
229
+ return $(
230
+ Q({ onLineClicked: e }),
231
+ t(u, r),
232
+ ((o = (p = r.charts) == null ? void 0 : p.lineChartComparisonDefaultPro) == null ? void 0 : o.options) || {}
233
+ );
234
+ }, ta = (u) => {
235
+ const r = X();
236
+ z(r);
237
+ const { title: e, description: n, xAxisLabel: t, yAxisLabel: p } = E(u), {
238
+ comparisonPeriod: o,
239
+ measures: x,
240
+ xAxis: a,
241
+ reverseXAxis: c,
242
+ showLegend: i,
243
+ showLogarithmicScale: g,
244
+ showTooltips: h,
245
+ showValueLabels: A,
246
+ yAxisRangeMax: s,
247
+ yAxisRangeMin: l,
248
+ primaryDateRange: d,
249
+ comparisonDateRange: C,
250
+ showComparisonAxis: D,
251
+ setComparisonDateRange: T,
252
+ onLineClicked: O
253
+ } = u;
254
+ K(() => {
255
+ const _ = V(
256
+ d,
257
+ o,
258
+ r
259
+ );
260
+ T(_);
261
+ }, [o, JSON.stringify(d), r]);
262
+ const b = B({ results: u.results, dimension: a }), m = B({
263
+ results: u.resultsComparison,
264
+ dimension: a,
265
+ externalDateBounds: C
266
+ }), L = !!(d && o), f = W(
267
+ {
268
+ data: b.data,
269
+ dataComparison: L ? (m == null ? void 0 : m.data) ?? [] : void 0,
270
+ dimension: a,
271
+ measures: x,
272
+ hasMinMaxYAxisRange: l != null || s != null
273
+ },
274
+ r
275
+ ), y = ea(
276
+ {
277
+ data: f,
278
+ dimension: a,
279
+ measures: x,
280
+ xAxisLabel: t,
281
+ showComparisonAxis: D,
282
+ showDataComparison: L,
283
+ onLineClicked: O
284
+ },
285
+ r
286
+ ), I = {
287
+ isLoading: !!(b.isLoading || m != null && m.isLoading),
288
+ data: !(b != null && b.data) && !(m != null && m.data) ? void 0 : [...b.data ?? [], ...(m == null ? void 0 : m.data) ?? []]
289
+ };
290
+ return /* @__PURE__ */ R.jsx(
291
+ G,
292
+ {
293
+ data: I,
294
+ dimensionsAndMeasures: [...x, a],
295
+ errorMessage: b.error || (m == null ? void 0 : m.error),
296
+ subtitle: n,
297
+ title: e,
298
+ children: /* @__PURE__ */ R.jsx(
299
+ F,
300
+ {
301
+ data: f,
302
+ reverseXAxis: c,
303
+ showLegend: i,
304
+ showLogarithmicScale: g,
305
+ showTooltips: h,
306
+ showValueLabels: A,
307
+ xAxisLabel: t,
308
+ yAxisLabel: p,
309
+ yAxisRangeMax: s,
310
+ yAxisRangeMin: l,
311
+ options: y
312
+ }
313
+ )
314
+ }
315
+ );
316
+ }, ga = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
317
+ __proto__: null,
318
+ default: ta
319
+ }, Symbol.toStringTag, { value: "Module" }));
320
+ export {
321
+ ta as L,
322
+ ea as a,
323
+ W as g,
324
+ ga as i
325
+ };
326
+ //# sourceMappingURL=index-CEyir5HV.js.map