@embeddable.com/remarkable-pro 0.0.23 → 0.0.25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (131) hide show
  1. package/dist/BarChartDefaultHorizontalPro.js +5 -5
  2. package/dist/BarChartDefaultHorizontalPro.js.map +1 -1
  3. package/dist/BarChartDefaultPro.js +5 -5
  4. package/dist/BarChartDefaultPro.js.map +1 -1
  5. package/dist/BarChartGroupedHorizontalPro.js +4 -4
  6. package/dist/BarChartGroupedPro.js +4 -4
  7. package/dist/BarChartStackedHorizontalPro.js +4 -4
  8. package/dist/BarChartStackedPro.js +4 -4
  9. package/dist/{ChartCard-B3B1rFYh.js → ChartCard-BHPN4_tz.js} +22 -22
  10. package/dist/{ChartCard-B3B1rFYh.js.map → ChartCard-BHPN4_tz.js.map} +1 -1
  11. package/dist/{Color.type.emb-sebikYGW.js → Color.type.emb-DWdIUAm5.js} +2600 -2590
  12. package/dist/{Color.type.emb-sebikYGW.js.map → Color.type.emb-DWdIUAm5.js.map} +1 -1
  13. package/dist/ColorEditor.js +1 -1
  14. package/dist/ComparisonPeriodSelectFieldPro.js +3 -3
  15. package/dist/DateRangePickerCustomPro.js +10 -9
  16. package/dist/DateRangePickerCustomPro.js.map +1 -1
  17. package/dist/DateRangeSelectFieldPro.js +3 -3
  18. package/dist/DonutChartPro.js +4 -4
  19. package/dist/DonutLabelChartPro.js +4 -4
  20. package/dist/{EditorCard-DpSCsmZJ.js → EditorCard-ZXwl5-DV.js} +3 -3
  21. package/dist/{EditorCard-DpSCsmZJ.js.map → EditorCard-ZXwl5-DV.js.map} +1 -1
  22. package/dist/GranularitySelectFieldPro.js +20 -19
  23. package/dist/GranularitySelectFieldPro.js.map +1 -1
  24. package/dist/HeatMapPro.js +4 -4
  25. package/dist/{IconCalendarFilled-Bfm3jkzE.js → IconCalendarFilled-Bl7kPqxG.js} +2 -2
  26. package/dist/{IconCalendarFilled-Bfm3jkzE.js.map → IconCalendarFilled-Bl7kPqxG.js.map} +1 -1
  27. package/dist/KpiChartNumberComparisonPro.js +4 -4
  28. package/dist/KpiChartNumberPro.js +4 -4
  29. package/dist/LineChartComparisonDefaultPro.js +4 -4
  30. package/dist/LineChartDefaultPro.js +4 -4
  31. package/dist/LineChartGroupedPro.js +4 -4
  32. package/dist/MultiSelectFieldPro.js +4 -4
  33. package/dist/PieChartPro.js +4 -4
  34. package/dist/PivotTablePro.js +4 -4
  35. package/dist/SingleSelectFieldPro.js +4 -4
  36. package/dist/TableChartPaginated.js +4 -4
  37. package/dist/TableScrollable.js +17 -17
  38. package/dist/bars.utils-DLqiVSYV.js +154 -0
  39. package/dist/bars.utils-DLqiVSYV.js.map +1 -0
  40. package/dist/{charts.utils-udVhj9f6.js → charts.utils-lvlkFPJk.js} +4 -4
  41. package/dist/{charts.utils-udVhj9f6.js.map → charts.utils-lvlkFPJk.js.map} +1 -1
  42. package/dist/{component.inputs.constants-Ds7YpNhT.js → component.inputs.constants-DO_jX-yc.js} +43 -43
  43. package/dist/{component.inputs.constants-Ds7YpNhT.js.map → component.inputs.constants-DO_jX-yc.js.map} +1 -1
  44. package/dist/components/charts/bars/bars.utils.d.ts.map +1 -1
  45. package/dist/components/charts/lines/LineChartComparisonDefaultPro/LineChartComparisonDefaultPro.utils.d.ts.map +1 -1
  46. package/dist/components/charts/lines/LineChartDefaultPro/LineChartDefaultPro.utils.d.ts.map +1 -1
  47. package/dist/components/charts/lines/LineChartGroupedPro/LineChartGroupedPro.utils.d.ts.map +1 -1
  48. package/dist/components/charts/pies/pies.utils.d.ts.map +1 -1
  49. package/dist/components/charts/tables/tables.utils.d.ts.map +1 -1
  50. package/dist/components/editors/ComparisonPeriodSelectFieldPro/index.d.ts.map +1 -1
  51. package/dist/components/editors/GranularitySelectFieldPro/index.d.ts.map +1 -1
  52. package/dist/components/editors/MultiSelectFieldPro/index.d.ts.map +1 -1
  53. package/dist/components/editors/SingleSelectFieldPro/index.d.ts.map +1 -1
  54. package/dist/components/editors/dates/DateRangePickerCustomPro/index.d.ts.map +1 -1
  55. package/dist/components/editors/dates/DateRangePickerPresetsPro/index.d.ts.map +1 -1
  56. package/dist/embeddable-components.json +28 -28
  57. package/dist/{formatter.utils-tS15PLXn.js → formatter.utils-CBCUxVH8.js} +2 -2
  58. package/dist/{formatter.utils-tS15PLXn.js.map → formatter.utils-CBCUxVH8.js.map} +1 -1
  59. package/dist/{index--Dbq1zrZ.js → index-0eDJ_Ho5.js} +5 -5
  60. package/dist/{index--Dbq1zrZ.js.map → index-0eDJ_Ho5.js.map} +1 -1
  61. package/dist/index-BRX2mrGM.js +124 -0
  62. package/dist/index-BRX2mrGM.js.map +1 -0
  63. package/dist/{index-CbL0nET2.js → index-BRuc7lF2.js} +5 -5
  64. package/dist/{index-CbL0nET2.js.map → index-BRuc7lF2.js.map} +1 -1
  65. package/dist/{index-t7YCtFvf.js → index-BSK_5Rq3.js} +5 -5
  66. package/dist/{index-t7YCtFvf.js.map → index-BSK_5Rq3.js.map} +1 -1
  67. package/dist/{index-BWbZ-eYD.js → index-ByFoIwAq.js} +5 -5
  68. package/dist/{index-BWbZ-eYD.js.map → index-ByFoIwAq.js.map} +1 -1
  69. package/dist/{index-Bqp4yCd3.js → index-CRWWARnB.js} +5 -5
  70. package/dist/{index-Bqp4yCd3.js.map → index-CRWWARnB.js.map} +1 -1
  71. package/dist/{index-DzPftkGV.js → index-CVIirzal.js} +5 -5
  72. package/dist/{index-DzPftkGV.js.map → index-CVIirzal.js.map} +1 -1
  73. package/dist/index-Cj1Zuh74.js +165 -0
  74. package/dist/index-Cj1Zuh74.js.map +1 -0
  75. package/dist/{index-DxpfQVmG.js → index-Cn_Rs8nk.js} +5 -5
  76. package/dist/{index-DxpfQVmG.js.map → index-Cn_Rs8nk.js.map} +1 -1
  77. package/dist/{index-CCdQwMMN.js → index-CpUKjpYd.js} +11 -10
  78. package/dist/{index-CCdQwMMN.js.map → index-CpUKjpYd.js.map} +1 -1
  79. package/dist/{index-BUk63KEk.js → index-CzM9TqMe.js} +6 -6
  80. package/dist/{index-BUk63KEk.js.map → index-CzM9TqMe.js.map} +1 -1
  81. package/dist/{index-D9J4M9sd.js → index-D9LxkwlG.js} +5 -5
  82. package/dist/{index-D9J4M9sd.js.map → index-D9LxkwlG.js.map} +1 -1
  83. package/dist/index-DDeRZxp1.js +334 -0
  84. package/dist/index-DDeRZxp1.js.map +1 -0
  85. package/dist/index-DLT2A69c.js +47 -0
  86. package/dist/{index-CBgU-nlM.js.map → index-DLT2A69c.js.map} +1 -1
  87. package/dist/index-DMtpdR9I.js +170 -0
  88. package/dist/index-DMtpdR9I.js.map +1 -0
  89. package/dist/{index-DxpjYqqB.js → index-DZYPPNrI.js} +5 -5
  90. package/dist/{index-DxpjYqqB.js.map → index-DZYPPNrI.js.map} +1 -1
  91. package/dist/{index-BMiribI6.js → index-EOl5XOZN.js} +6 -6
  92. package/dist/{index-BMiribI6.js.map → index-EOl5XOZN.js.map} +1 -1
  93. package/dist/{index-DtGheuiZ.js → index-L5_Ts7FG.js} +5 -5
  94. package/dist/{index-DtGheuiZ.js.map → index-L5_Ts7FG.js.map} +1 -1
  95. package/dist/{index-CTC3YNmw.js → index-Rxsr4tZ-.js} +13 -12
  96. package/dist/{index-CTC3YNmw.js.map → index-Rxsr4tZ-.js.map} +1 -1
  97. package/dist/{index-D6h8s36F.js → index-Uhz2U4Dp.js} +5 -5
  98. package/dist/{index-D6h8s36F.js.map → index-Uhz2U4Dp.js.map} +1 -1
  99. package/dist/{index-CDtF3MO_.js → index-s4oA7Iyp.js} +8 -8
  100. package/dist/{index-CDtF3MO_.js.map → index-s4oA7Iyp.js.map} +1 -1
  101. package/dist/index.js +30 -30
  102. package/dist/pies.utils-BxCBtjpf.js +77 -0
  103. package/dist/pies.utils-BxCBtjpf.js.map +1 -0
  104. package/dist/{preview.data.constants-tDMYNi0n.js → preview.data.constants-CXMriS2F.js} +2 -2
  105. package/dist/{preview.data.constants-tDMYNi0n.js.map → preview.data.constants-CXMriS2F.js.map} +1 -1
  106. package/dist/styles.utils-u6uj51UE.js +59 -0
  107. package/dist/styles.utils-u6uj51UE.js.map +1 -0
  108. package/dist/{tables.utils-33eWJN_a.js → tables.utils-DMLGNJ4g.js} +5 -4
  109. package/dist/{tables.utils-33eWJN_a.js.map → tables.utils-DMLGNJ4g.js.map} +1 -1
  110. package/dist/theme/styles/styles.utils.d.ts +12 -0
  111. package/dist/theme/styles/styles.utils.d.ts.map +1 -1
  112. package/dist/theme/theme.types.d.ts +10 -0
  113. package/dist/theme/theme.types.d.ts.map +1 -1
  114. package/dist/{timeRange.utils-Dz0fdD_b.js → timeRange.utils-C_oRVExZ.js} +2 -2
  115. package/dist/{timeRange.utils-Dz0fdD_b.js.map → timeRange.utils-C_oRVExZ.js.map} +1 -1
  116. package/package.json +2 -2
  117. package/dist/bars.utils-DJnFf-V0.js +0 -146
  118. package/dist/bars.utils-DJnFf-V0.js.map +0 -1
  119. package/dist/index-APU1GD5M.js +0 -166
  120. package/dist/index-APU1GD5M.js.map +0 -1
  121. package/dist/index-BsWftigv.js +0 -123
  122. package/dist/index-BsWftigv.js.map +0 -1
  123. package/dist/index-CBgU-nlM.js +0 -46
  124. package/dist/index-Nj7bJ8tg.js +0 -161
  125. package/dist/index-Nj7bJ8tg.js.map +0 -1
  126. package/dist/index-h3GKi8po.js +0 -332
  127. package/dist/index-h3GKi8po.js.map +0 -1
  128. package/dist/object.utils-D_Zzon-H.js +0 -37
  129. package/dist/object.utils-D_Zzon-H.js.map +0 -1
  130. package/dist/pies.utils-Dgs6TAkX.js +0 -73
  131. package/dist/pies.utils-Dgs6TAkX.js.map +0 -1
@@ -1,3 +1,15 @@
1
+ import { Dimension, Measure } from '@embeddable.com/core';
2
+ import { Theme } from '../theme.types';
1
3
  export declare const injectCssVariables: (styles: Record<string, string>) => () => void;
2
4
  export declare const getColor: (key: string, value: string, palette: string[], idx: number) => string;
5
+ type GetDimensionMeasureColorProps = {
6
+ dimensionOrMeasure: Dimension | Measure;
7
+ theme: Theme;
8
+ value: string;
9
+ color: 'background' | 'border';
10
+ index: number;
11
+ chartColors: string[];
12
+ };
13
+ export declare const getDimensionMeasureColor: ({ dimensionOrMeasure, theme, color, value, index, chartColors, }: GetDimensionMeasureColorProps) => any;
14
+ export {};
3
15
  //# sourceMappingURL=styles.utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"styles.utils.d.ts","sourceRoot":"","sources":["../../../src/theme/styles/styles.utils.ts"],"names":[],"mappings":"AAUA,eAAO,MAAM,kBAAkB,GAAI,QAAQ,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,eAgBhE,CAAC;AAkCF,eAAO,MAAM,QAAQ,GAAI,KAAK,MAAM,EAAE,OAAO,MAAM,EAAE,SAAS,MAAM,EAAE,EAAE,KAAK,MAAM,KAAG,MA0BrF,CAAC"}
1
+ {"version":3,"file":"styles.utils.d.ts","sourceRoot":"","sources":["../../../src/theme/styles/styles.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAavC,eAAO,MAAM,kBAAkB,GAAI,QAAQ,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,eAgBhE,CAAC;AAkCF,eAAO,MAAM,QAAQ,GAAI,KAAK,MAAM,EAAE,OAAO,MAAM,EAAE,SAAS,MAAM,EAAE,EAAE,KAAK,MAAM,KAAG,MA0BrF,CAAC;AAEF,KAAK,6BAA6B,GAAG;IACnC,kBAAkB,EAAE,SAAS,GAAG,OAAO,CAAC;IACxC,KAAK,EAAE,KAAK,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,YAAY,GAAG,QAAQ,CAAC;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,EAAE,CAAC;CACvB,CAAC;AAEF,eAAO,MAAM,wBAAwB,GAAI,kEAOtC,6BAA6B,QA6B/B,CAAC"}
@@ -11,7 +11,17 @@ export type ThemeI18n = {
11
11
  translations: Resource;
12
12
  };
13
13
  export type ThemeChartsLegendPosition = 'top' | 'right' | 'bottom' | 'left';
14
+ export type ThemeChartsColors = {
15
+ borderColor: string;
16
+ backgroundColor: string;
17
+ };
18
+ export type ThemeChartsColorMap = {
19
+ dimensionValue?: Record<string, string>;
20
+ measure?: Record<string, string>;
21
+ };
14
22
  export type ThemeCharts = {
23
+ backgroundColorMap?: ThemeChartsColorMap;
24
+ borderColorMap?: ThemeChartsColorMap;
15
25
  backgroundColors?: string[];
16
26
  borderColors?: string[];
17
27
  legendPosition: ThemeChartsLegendPosition;
@@ -1 +1 @@
1
- {"version":3,"file":"theme.types.d.ts","sourceRoot":"","sources":["../../src/theme/theme.types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"theme.types.d.ts","sourceRoot":"","sources":["../../src/theme/theme.types.ts"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { c as i } from "./component.inputs.constants-Ds7YpNhT.js";
1
+ import { c as i } from "./component.inputs.constants-DO_jX-yc.js";
2
2
  const f = (o, t, s) => {
3
3
  var d;
4
4
  if (!o || !t)
@@ -17,4 +17,4 @@ export {
17
17
  v as a,
18
18
  f as g
19
19
  };
20
- //# sourceMappingURL=timeRange.utils-Dz0fdD_b.js.map
20
+ //# sourceMappingURL=timeRange.utils-C_oRVExZ.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"timeRange.utils-Dz0fdD_b.js","sources":["../src/components/utils/timeRange.utils.ts"],"sourcesContent":["import { TimeRange } from '@embeddable.com/core';\nimport { Theme } from '../../theme/theme.types';\nimport { resolveI18nString } from '../component.utils';\n\nexport const getComparisonPeriodDateRange = (\n primaryDateRange: TimeRange,\n comparisonPeriod: string | undefined,\n theme: Theme,\n): TimeRange => {\n if (!primaryDateRange || !comparisonPeriod) {\n return undefined;\n }\n\n const primaryDateRangeRange = primaryDateRange?.relativeTimeString\n ? theme.defaults.dateRangesOptions\n .find((option) => option.value === primaryDateRange?.relativeTimeString)\n ?.getRange()\n : primaryDateRange;\n\n const comparisonPeriodOption = theme.defaults.comparisonPeriodsOptions.find(\n (option) => option.value === comparisonPeriod,\n );\n\n return comparisonPeriodOption?.getRange(primaryDateRangeRange);\n};\n\nexport const getComparisonPeriodLabel = (\n comparisonPeriod: string | undefined,\n theme: Theme,\n): string => {\n const option = theme.defaults.comparisonPeriodsOptions.find(\n (option) => option.value === comparisonPeriod,\n );\n return option ? resolveI18nString(option.label) : '';\n};\n"],"names":["getComparisonPeriodDateRange","primaryDateRange","comparisonPeriod","theme","primaryDateRangeRange","_a","option","comparisonPeriodOption","getComparisonPeriodLabel","resolveI18nString"],"mappings":";AAIO,MAAMA,IAA+B,CAC1CC,GACAC,GACAC,MACc;;AACd,MAAI,CAACF,KAAoB,CAACC;AACxB;AAGF,QAAME,IAAwBH,KAAA,QAAAA,EAAkB,sBAC5CI,IAAAF,EAAM,SAAS,kBACZ,KAAK,CAACG,MAAWA,EAAO,WAAUL,KAAA,gBAAAA,EAAkB,mBAAkB,MADzE,gBAAAI,EAEI,aACJJ,GAEEM,IAAyBJ,EAAM,SAAS,yBAAyB;AAAA,IACrE,CAACG,MAAWA,EAAO,UAAUJ;AAAA,EAAA;AAG/B,SAAOK,KAAA,gBAAAA,EAAwB,SAASH;AAC1C,GAEaI,IAA2B,CACtCN,GACAC,MACW;AACX,QAAMG,IAASH,EAAM,SAAS,yBAAyB;AAAA,IACrD,CAACG,MAAWA,EAAO,UAAUJ;AAAA,EAAA;AAE/B,SAAOI,IAASG,EAAkBH,EAAO,KAAK,IAAI;AACpD;"}
1
+ {"version":3,"file":"timeRange.utils-C_oRVExZ.js","sources":["../src/components/utils/timeRange.utils.ts"],"sourcesContent":["import { TimeRange } from '@embeddable.com/core';\nimport { Theme } from '../../theme/theme.types';\nimport { resolveI18nString } from '../component.utils';\n\nexport const getComparisonPeriodDateRange = (\n primaryDateRange: TimeRange,\n comparisonPeriod: string | undefined,\n theme: Theme,\n): TimeRange => {\n if (!primaryDateRange || !comparisonPeriod) {\n return undefined;\n }\n\n const primaryDateRangeRange = primaryDateRange?.relativeTimeString\n ? theme.defaults.dateRangesOptions\n .find((option) => option.value === primaryDateRange?.relativeTimeString)\n ?.getRange()\n : primaryDateRange;\n\n const comparisonPeriodOption = theme.defaults.comparisonPeriodsOptions.find(\n (option) => option.value === comparisonPeriod,\n );\n\n return comparisonPeriodOption?.getRange(primaryDateRangeRange);\n};\n\nexport const getComparisonPeriodLabel = (\n comparisonPeriod: string | undefined,\n theme: Theme,\n): string => {\n const option = theme.defaults.comparisonPeriodsOptions.find(\n (option) => option.value === comparisonPeriod,\n );\n return option ? resolveI18nString(option.label) : '';\n};\n"],"names":["getComparisonPeriodDateRange","primaryDateRange","comparisonPeriod","theme","primaryDateRangeRange","_a","option","comparisonPeriodOption","getComparisonPeriodLabel","resolveI18nString"],"mappings":";AAIO,MAAMA,IAA+B,CAC1CC,GACAC,GACAC,MACc;;AACd,MAAI,CAACF,KAAoB,CAACC;AACxB;AAGF,QAAME,IAAwBH,KAAA,QAAAA,EAAkB,sBAC5CI,IAAAF,EAAM,SAAS,kBACZ,KAAK,CAACG,MAAWA,EAAO,WAAUL,KAAA,gBAAAA,EAAkB,mBAAkB,MADzE,gBAAAI,EAEI,aACJJ,GAEEM,IAAyBJ,EAAM,SAAS,yBAAyB;AAAA,IACrE,CAACG,MAAWA,EAAO,UAAUJ;AAAA,EAAA;AAG/B,SAAOK,KAAA,gBAAAA,EAAwB,SAASH;AAC1C,GAEaI,IAA2B,CACtCN,GACAC,MACW;AACX,QAAMG,IAASH,EAAM,SAAS,yBAAyB;AAAA,IACrD,CAACG,MAAWA,EAAO,UAAUJ;AAAA,EAAA;AAE/B,SAAOI,IAASG,EAAkBH,EAAO,KAAK,IAAI;AACpD;"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@embeddable.com/remarkable-pro",
3
3
  "author": "embeddable (https://embeddable.com)",
4
- "version": "0.0.23",
4
+ "version": "0.0.25",
5
5
  "repository": {
6
6
  "type": "git",
7
7
  "url": "https://github.com/embeddable-hq/remarkable-pro"
@@ -59,7 +59,7 @@
59
59
  "@changesets/cli": "^2.29.6",
60
60
  "@embeddable.com/core": "^2.13.4",
61
61
  "@embeddable.com/react": "^2.13.0",
62
- "@embeddable.com/remarkable-ui": "^2.0.28",
62
+ "@embeddable.com/remarkable-ui": "^2.0.29",
63
63
  "@tabler/icons-react": "^3.34.1",
64
64
  "chart.js": "^4.5.0",
65
65
  "chartjs-plugin-datalabels": "^2.2.0",
@@ -1,146 +0,0 @@
1
- import { d as N, C as P, e as v } from "./Color.type.emb-sebikYGW.js";
2
- import { r as x, g as F } from "./charts.utils-udVhj9f6.js";
3
- import { g as h } from "./formatter.utils-tS15PLXn.js";
4
- import { g as p, a as g } from "./object.utils-D_Zzon-H.js";
5
- const I = (c, d) => {
6
- var b;
7
- const m = h(d), { data: o = [], dimension: i, groupDimension: l, measure: t } = c, r = [...new Set(o.map((n) => n[i.name]).filter((n) => n != null))].sort(), a = `${l.name}${l.nativeType === P && ((b = l.inputs) != null && b.granularity) ? `.${l.inputs.granularity}` : ""}`, e = [...new Set(o.map((n) => n[a]))].filter((n) => n != null), s = p(d), u = v(), C = e.map((n, f) => {
8
- const D = g(
9
- `${s}.charts.backgroundColors`,
10
- `${l.name}.${n}`,
11
- d.charts.backgroundColors ?? u,
12
- f
13
- ), T = g(
14
- `${s}.charts.borderColors`,
15
- `${l.name}.${n}`,
16
- d.charts.borderColors ?? u,
17
- f
18
- );
19
- return {
20
- label: m.data(l, n),
21
- rawLabel: n,
22
- backgroundColor: D,
23
- borderColor: T,
24
- data: r.map((w) => {
25
- const k = o.find(
26
- ($) => $[a] === n && $[i.name] === w
27
- );
28
- return k ? Number(k[t.name]) : 0;
29
- })
30
- };
31
- });
32
- return {
33
- labels: r,
34
- datasets: C
35
- };
36
- }, B = (c, d = x) => {
37
- if (!c.data)
38
- return {
39
- labels: [],
40
- datasets: [{ data: [] }]
41
- };
42
- const m = h(d), o = p(d), i = F(c.data, c.dimension, c.measures, c.maxItems), l = N();
43
- return {
44
- labels: i.map((t) => t[c.dimension.name]),
45
- datasets: c.measures.map((t, r) => {
46
- const a = g(
47
- `${o}.charts.backgroundColors`,
48
- t.name,
49
- d.charts.backgroundColors ?? l,
50
- r
51
- ), e = g(
52
- `${o}.charts.borderColors`,
53
- t.name,
54
- d.charts.borderColors ?? l,
55
- r
56
- );
57
- return {
58
- label: m.dimensionOrMeasureTitle(t),
59
- data: i.map((s) => s[t.name] ?? 0),
60
- backgroundColor: a,
61
- borderColor: e
62
- };
63
- })
64
- };
65
- }, O = (c, d) => {
66
- const { datasets: m } = c.chart.data, o = c.dataIndex, i = m.reduce((l, t) => {
67
- const r = t.data[o];
68
- return l + (r || 0);
69
- }, 0);
70
- return d(i);
71
- }, K = (c, d) => {
72
- const { onBarClicked: m, measures: o, dimension: i, horizontal: l, data: t } = c, r = h(d);
73
- return {
74
- plugins: {
75
- legend: { position: d.charts.legendPosition ?? "bottom" },
76
- datalabels: {
77
- labels: {
78
- total: {
79
- formatter: (a, e) => O(
80
- e,
81
- (s) => r.data(o[0], s)
82
- )
83
- },
84
- value: {
85
- formatter: (a, e) => {
86
- const s = o[e.datasetIndex % o.length];
87
- return r.data(s, a);
88
- }
89
- }
90
- }
91
- },
92
- tooltip: {
93
- callbacks: {
94
- title: (a) => {
95
- var s;
96
- const e = (s = a[0]) == null ? void 0 : s.label;
97
- return r.data(i, e);
98
- },
99
- label: (a) => {
100
- const e = o[a.datasetIndex % o.length], s = a.raw;
101
- return `${r.data(i, a.dataset.label) || ""}: ${r.data(e, s)}`;
102
- }
103
- }
104
- }
105
- },
106
- scales: {
107
- x: {
108
- ticks: {
109
- callback: (a) => {
110
- if (l)
111
- return r.data(o[0], a);
112
- if (!t || !t.labels) return;
113
- const e = t.labels[Number(a)];
114
- return r.data(i, e);
115
- }
116
- }
117
- },
118
- y: {
119
- ticks: {
120
- callback: (a) => {
121
- if (!l)
122
- return r.data(o[0], a);
123
- if (!t || !t.labels) return;
124
- const e = t.labels[Number(a)];
125
- return r.data(i, e);
126
- }
127
- }
128
- }
129
- },
130
- onClick: (a, e, s) => {
131
- var n;
132
- if (!m) return;
133
- const u = e[0], C = u ? s.data.labels[u.index] : null, b = u ? (n = s.data.datasets[u.datasetIndex]) == null ? void 0 : n.rawLabel : null;
134
- m({
135
- axisDimensionValue: C,
136
- groupingDimensionValue: b
137
- });
138
- }
139
- };
140
- };
141
- export {
142
- B as a,
143
- K as b,
144
- I as g
145
- };
146
- //# sourceMappingURL=bars.utils-DJnFf-V0.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"bars.utils-DJnFf-V0.js","sources":["../src/components/charts/bars/bars.utils.ts"],"sourcesContent":["import { CUBE_DIMENSION_TYPE_TIME, DataResponse, Dimension, Measure } from '@embeddable.com/core';\nimport { Theme } from '../../../theme/theme.types';\nimport { remarkableTheme } from '../../../theme/theme.constants';\nimport { ChartData, ChartOptions } from 'chart.js';\nimport { getThemeFormatter } from '../../../theme/formatter/formatter.utils';\nimport { groupTailAsOther } from '../charts.utils';\nimport { getColor } from '../../../theme/styles/styles.utils';\nimport { getChartColors, getChartContrastColors } from '@embeddable.com/remarkable-ui';\nimport { getObjectStableKey } from '../../../utils.ts/object.utils';\nimport { Context } from 'chartjs-plugin-datalabels';\n\nexport const getBarStackedChartProData = (\n props: {\n data: DataResponse['data'];\n dimension: Dimension;\n groupDimension: Dimension;\n measure: Measure;\n },\n theme: Theme,\n): ChartData<'bar'> => {\n const themeFormatter = getThemeFormatter(theme);\n const { data = [], dimension, groupDimension, measure } = props;\n\n const axis = [...new Set(data.map((d) => d[dimension.name]).filter((d) => d != null))].sort();\n const groupDimensionName = `${groupDimension.name}${groupDimension.nativeType === CUBE_DIMENSION_TYPE_TIME && groupDimension.inputs?.granularity ? `.${groupDimension.inputs.granularity}` : ''}`;\n const groupBy = [...new Set(data.map((d) => d[groupDimensionName]))].filter((d) => d != null);\n\n const themeKey = getObjectStableKey(theme);\n const chartContrastColors = getChartContrastColors();\n const datasets = groupBy.map((groupByItem, index) => {\n const backgroundColor = getColor(\n `${themeKey}.charts.backgroundColors`,\n `${groupDimension.name}.${groupByItem}`,\n theme.charts.backgroundColors ?? chartContrastColors,\n index,\n );\n\n const borderColor = getColor(\n `${themeKey}.charts.borderColors`,\n `${groupDimension.name}.${groupByItem}`,\n theme.charts.borderColors ?? chartContrastColors,\n index,\n );\n\n return {\n label: themeFormatter.data(groupDimension, groupByItem),\n rawLabel: groupByItem,\n backgroundColor,\n borderColor,\n data: axis.map((axisItem) => {\n const record = data.find(\n (d) => d[groupDimensionName] === groupByItem && d[dimension.name] === axisItem,\n );\n return record ? Number(record[measure.name]) : 0;\n }),\n };\n });\n\n return {\n labels: axis,\n datasets,\n };\n};\n\nexport const getBarChartProData = (\n props: {\n data: DataResponse['data'];\n dimension: Dimension;\n measures: Measure[];\n maxItems?: number;\n },\n theme: Theme = remarkableTheme,\n): ChartData<'bar'> => {\n if (!props.data) {\n return {\n labels: [],\n datasets: [{ data: [] }],\n };\n }\n\n const themeFormatter = getThemeFormatter(theme);\n const themeKey = getObjectStableKey(theme);\n const groupedData = groupTailAsOther(props.data, props.dimension, props.measures, props.maxItems);\n const chartColors = getChartColors();\n\n return {\n labels: groupedData.map((item) => {\n return item[props.dimension.name];\n }),\n datasets: props.measures.map((measure, index) => {\n const backgroundColor = getColor(\n `${themeKey}.charts.backgroundColors`,\n measure.name,\n theme.charts.backgroundColors ?? chartColors,\n index,\n );\n\n const borderColor = getColor(\n `${themeKey}.charts.borderColors`,\n measure.name,\n theme.charts.borderColors ?? chartColors,\n index,\n );\n\n return {\n label: themeFormatter.dimensionOrMeasureTitle(measure),\n data: groupedData.map((item) => item[measure.name] ?? 0),\n backgroundColor,\n borderColor,\n };\n }),\n };\n};\n\nconst getBarChartProDatalabelTotalFormatter = (\n context: Context,\n formatter: (value: number) => string,\n) => {\n const { datasets } = context.chart.data;\n const i = context.dataIndex;\n\n const total = datasets.reduce((sum, ds) => {\n const val = ds.data[i] as number;\n return sum + (val || 0);\n }, 0);\n\n return formatter(total);\n};\n\nexport const getBarChartProOptions = (\n options: {\n onBarClicked?: (args: {\n axisDimensionValue: string | null;\n groupingDimensionValue: string | null;\n }) => void;\n measures: Measure[];\n dimension: Dimension;\n horizontal: boolean;\n data: ChartData<'bar'>;\n },\n theme: Theme,\n): Partial<ChartOptions<'bar'>> => {\n const { onBarClicked, measures, dimension, horizontal, data } = options;\n\n const themeFormatter = getThemeFormatter(theme);\n return {\n plugins: {\n legend: { position: theme.charts.legendPosition ?? 'bottom' },\n datalabels: {\n labels: {\n total: {\n formatter: (_value: string | number, context: Context) =>\n getBarChartProDatalabelTotalFormatter(context, (value: number) =>\n themeFormatter.data(measures[0]!, value),\n ),\n },\n value: {\n formatter: (value: string | number, context) => {\n const measure = measures[context.datasetIndex % measures.length]!;\n return themeFormatter.data(measure, value);\n },\n },\n },\n },\n tooltip: {\n callbacks: {\n title: (context) => {\n const label = context[0]?.label;\n return themeFormatter.data(dimension, label);\n },\n label: (context) => {\n const measure = measures[context.datasetIndex % measures.length]!;\n const raw = context.raw as number;\n return `${themeFormatter.data(dimension, context.dataset.label) || ''}: ${themeFormatter.data(measure, raw)}`;\n },\n },\n },\n },\n scales: {\n x: {\n ticks: {\n callback: (value) => {\n if (horizontal) {\n return themeFormatter.data(measures[0]!, value);\n }\n\n if (!data || !data.labels) return undefined;\n\n const label = data.labels[Number(value)] as string;\n\n return themeFormatter.data(dimension, label);\n },\n },\n },\n y: {\n ticks: {\n callback: (value) => {\n if (!horizontal) {\n return themeFormatter.data(measures[0]!, value);\n }\n if (!data || !data.labels) return undefined;\n const label = data.labels[Number(value)] as string;\n return themeFormatter.data(dimension, label);\n },\n },\n },\n },\n onClick: (_event, elements, chart) => {\n if (!onBarClicked) return;\n\n const element = elements[0];\n const axisDimensionValue = (element ? chart.data.labels![element.index] : null) as\n | string\n | null;\n const groupingDimensionValue = (\n element\n ? (chart.data.datasets[element.datasetIndex] as { rawLabel?: string | null })?.rawLabel\n : null\n ) as string | null;\n\n onBarClicked({\n axisDimensionValue,\n groupingDimensionValue,\n });\n },\n };\n};\n"],"names":["getBarStackedChartProData","props","theme","themeFormatter","getThemeFormatter","data","dimension","groupDimension","measure","axis","d","groupDimensionName","CUBE_DIMENSION_TYPE_TIME","_a","groupBy","themeKey","getObjectStableKey","chartContrastColors","getChartContrastColors","datasets","groupByItem","index","backgroundColor","getColor","borderColor","axisItem","record","getBarChartProData","remarkableTheme","groupedData","groupTailAsOther","chartColors","getChartColors","item","getBarChartProDatalabelTotalFormatter","context","formatter","i","total","sum","ds","val","getBarChartProOptions","options","onBarClicked","measures","horizontal","_value","value","label","raw","_event","elements","chart","element","axisDimensionValue","groupingDimensionValue"],"mappings":"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"}
@@ -1,166 +0,0 @@
1
- import { e as v, f, m as j, j as L, L as O } from "./Color.type.emb-sebikYGW.js";
2
- import { useTheme as w } from "@embeddable.com/react";
3
- import { a as P, r as S } from "./component.inputs.constants-Ds7YpNhT.js";
4
- import { C as F } from "./ChartCard-B3B1rFYh.js";
5
- import { g as A } from "./formatter.utils-tS15PLXn.js";
6
- import { g as R, a as k } from "./object.utils-D_Zzon-H.js";
7
- import { i as M, s as T } from "./color.utils-BSg_DFOh.js";
8
- import { u as _ } from "./charts.fillGaps.hooks-C7KsWcZb.js";
9
- const B = (o, n) => {
10
- if (!o.data)
11
- return {
12
- labels: [],
13
- datasets: [{ data: [] }]
14
- };
15
- const u = A(n), c = R(n), d = o.data;
16
- return {
17
- labels: d.map((e) => e[o.dimension.name]),
18
- datasets: o.measures.map((e, r) => {
19
- var m, b, C, p;
20
- const h = !!((m = e.inputs) != null && m.connectGaps), l = d.map((g) => g[e.name] ?? (h ? 0 : null)), i = (b = e.inputs) == null ? void 0 : b.lineColor, a = v(), t = M(i) ? i : k(
21
- `${c}.charts.backgroundColors`,
22
- e.name,
23
- n.charts.backgroundColors ?? a,
24
- r
25
- ), s = M(i) ? i : k(
26
- `${c}.charts.borderColors`,
27
- e.name,
28
- n.charts.borderColors ?? a,
29
- r
30
- );
31
- return {
32
- clip: o.hasMinMaxYAxisRange,
33
- label: u.dimensionOrMeasureTitle(e),
34
- data: l,
35
- backgroundColor: T(t, 0.5),
36
- pointBackgroundColor: t,
37
- borderDash: (C = e.inputs) != null && C.dashedLine ? [
38
- f("--em-linechart-line-dash", "0.25rem"),
39
- f("--em-linechart-line-gap", "0.25rem")
40
- ] : void 0,
41
- borderColor: s,
42
- fill: !!((p = e.inputs) != null && p.fillUnderLine)
43
- };
44
- })
45
- };
46
- }, D = (o, n) => {
47
- var l, i;
48
- const { dimension: u, data: c, measures: d, onLineClicked: e } = o, r = A(n);
49
- return j({
50
- plugins: {
51
- datalabels: {
52
- labels: {
53
- value: {
54
- formatter: (a, t) => {
55
- const s = d[t.datasetIndex];
56
- return r.data(s, a);
57
- }
58
- }
59
- }
60
- },
61
- tooltip: {
62
- callbacks: {
63
- title: (a) => {
64
- var s;
65
- const t = (s = a[0]) == null ? void 0 : s.label;
66
- return r.data(u, t);
67
- },
68
- label: (a) => {
69
- const t = d[a.datasetIndex], s = a.raw;
70
- return `${r.data(u, a.dataset.label) || ""}: ${r.data(t, s)}`;
71
- }
72
- }
73
- }
74
- },
75
- scales: {
76
- x: {
77
- ticks: {
78
- callback: (a) => {
79
- if (!c || !c.labels) return;
80
- const t = c.labels[Number(a)];
81
- return r.data(u, t);
82
- }
83
- }
84
- },
85
- y: {
86
- ticks: {
87
- callback: (a) => r.data(d[0], a)
88
- }
89
- }
90
- },
91
- onClick: (a, t, s) => {
92
- if (!e) return;
93
- const m = t[0], b = m ? s.data.labels[m.index] : null;
94
- e({
95
- dimensionValue: b
96
- });
97
- }
98
- }, ((i = (l = n.charts) == null ? void 0 : l.lineChartDefaultPro) == null ? void 0 : i.options) || {});
99
- }, $ = (o) => {
100
- const n = w();
101
- P(n);
102
- const { title: u, description: c, xAxisLabel: d, yAxisLabel: e } = S(o), {
103
- hideMenu: r,
104
- measures: h,
105
- xAxis: l,
106
- reverseXAxis: i,
107
- showLegend: a,
108
- showLogarithmicScale: t,
109
- showTooltips: s,
110
- showValueLabels: m,
111
- yAxisRangeMax: b,
112
- yAxisRangeMin: C,
113
- onLineClicked: p
114
- } = o, g = _({
115
- results: o.results,
116
- dimension: l
117
- }), x = B(
118
- {
119
- data: g.data,
120
- dimension: l,
121
- measures: h,
122
- hasMinMaxYAxisRange: C != null || b != null
123
- },
124
- n
125
- ), y = D(
126
- { data: x, dimension: l, measures: h, onLineClicked: p },
127
- n
128
- );
129
- return /* @__PURE__ */ L.jsx(
130
- F,
131
- {
132
- data: g,
133
- dimensionsAndMeasures: [...h, l],
134
- errorMessage: g.error,
135
- description: c,
136
- title: u,
137
- hideMenu: r,
138
- children: /* @__PURE__ */ L.jsx(
139
- O,
140
- {
141
- data: x,
142
- reverseXAxis: i,
143
- showLegend: a,
144
- showLogarithmicScale: t,
145
- showTooltips: s,
146
- showValueLabels: m,
147
- xAxisLabel: d,
148
- yAxisLabel: e,
149
- yAxisRangeMax: b,
150
- yAxisRangeMin: C,
151
- options: y
152
- }
153
- )
154
- }
155
- );
156
- }, U = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
157
- __proto__: null,
158
- default: $
159
- }, Symbol.toStringTag, { value: "Module" }));
160
- export {
161
- $ as L,
162
- D as a,
163
- B as g,
164
- U as i
165
- };
166
- //# sourceMappingURL=index-APU1GD5M.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-APU1GD5M.js","sources":["../src/components/charts/lines/LineChartDefaultPro/LineChartDefaultPro.utils.ts","../src/components/charts/lines/LineChartDefaultPro/index.tsx"],"sourcesContent":["import { DataResponse, Dimension, Measure } from '@embeddable.com/core';\nimport { Theme } from '../../../../theme/theme.types';\nimport { ChartData, ChartOptions } from 'chart.js';\nimport { getThemeFormatter } from '../../../../theme/formatter/formatter.utils';\nimport { getObjectStableKey } from '../../../../utils.ts/object.utils';\nimport { getChartContrastColors, getStyleNumber } from '@embeddable.com/remarkable-ui';\nimport { getColor } from '../../../../theme/styles/styles.utils';\nimport { mergician } from 'mergician';\nimport { isColorValid, setColorAlpha } from '../../../../utils.ts/color.utils';\nimport { LineChartProOptionsClick } from '../lines.utils';\n\nexport const getLineChartProData = (\n props: {\n data: DataResponse['data'];\n dimension: Dimension;\n measures: Measure[];\n hasMinMaxYAxisRange: boolean;\n },\n theme: Theme,\n): ChartData<'line'> => {\n if (!props.data) {\n return {\n labels: [],\n datasets: [{ data: [] }],\n };\n }\n\n const themeFormatter = getThemeFormatter(theme);\n\n const themeKey = getObjectStableKey(theme);\n const groupedData = props.data;\n\n return {\n labels: groupedData.map((item) => {\n return item[props.dimension.name];\n }),\n datasets: props.measures.map((measure, index) => {\n const zeroFill = Boolean(measure.inputs?.['connectGaps']);\n const values = groupedData.map((item) => item[measure.name] ?? (zeroFill ? 0 : null));\n\n const lineColor = measure.inputs?.['lineColor'];\n const chartContrastColors = getChartContrastColors();\n const backgroundColor = isColorValid(lineColor)\n ? lineColor\n : getColor(\n `${themeKey}.charts.backgroundColors`,\n measure.name,\n theme.charts.backgroundColors ?? chartContrastColors,\n index,\n );\n\n const borderColor = isColorValid(lineColor)\n ? lineColor\n : getColor(\n `${themeKey}.charts.borderColors`,\n measure.name,\n theme.charts.borderColors ?? chartContrastColors,\n index,\n );\n\n return {\n clip: props.hasMinMaxYAxisRange,\n label: themeFormatter.dimensionOrMeasureTitle(measure),\n data: values,\n backgroundColor: setColorAlpha(backgroundColor, 0.5),\n pointBackgroundColor: backgroundColor,\n borderDash: measure.inputs?.['dashedLine']\n ? [\n getStyleNumber('--em-linechart-line-dash', '0.25rem'),\n getStyleNumber('--em-linechart-line-gap', '0.25rem'),\n ]\n : undefined,\n borderColor,\n fill: Boolean(measure.inputs?.['fillUnderLine']),\n } as ChartData<'line'>['datasets'][number];\n }),\n };\n};\n\nexport const getLineChartProOptions = (\n options: {\n dimension: Dimension;\n measures: Measure[];\n data: ChartData<'line'>;\n onLineClicked?: LineChartProOptionsClick;\n },\n theme: Theme,\n): ChartOptions<'line'> => {\n const { dimension, data, measures, onLineClicked } = options;\n const themeFormatter = getThemeFormatter(theme);\n\n const lineChartOptions: ChartOptions<'line'> = {\n plugins: {\n datalabels: {\n labels: {\n value: {\n formatter: (value: string | number, context) => {\n const measure = measures[context.datasetIndex]!;\n return themeFormatter.data(measure, value);\n },\n },\n },\n },\n tooltip: {\n callbacks: {\n title: (context) => {\n const label = context[0]?.label;\n return themeFormatter.data(dimension, label);\n },\n label: (context) => {\n const measure = measures[context.datasetIndex]!;\n const raw = context.raw as number;\n return `${themeFormatter.data(dimension, context.dataset.label) || ''}: ${themeFormatter.data(measure, raw)}`;\n },\n },\n },\n },\n scales: {\n x: {\n ticks: {\n callback: (value) => {\n if (!data || !data.labels) return undefined;\n\n const label = data.labels[Number(value)] as string;\n return themeFormatter.data(dimension, label);\n },\n },\n },\n y: {\n ticks: {\n callback: (value) => {\n return themeFormatter.data(measures[0]!, value);\n },\n },\n },\n },\n onClick: (_event, elements, chart) => {\n if (!onLineClicked) return;\n\n const element = elements[0];\n const dimensionValue = (element ? chart.data.labels![element.index] : null) as string | null;\n\n onLineClicked({\n dimensionValue,\n });\n },\n };\n\n return mergician(lineChartOptions, theme.charts?.lineChartDefaultPro?.options || {});\n};\n","import { useTheme } from '@embeddable.com/react';\nimport { Theme } from '../../../../theme/theme.types';\nimport { DataResponse, Dimension, Measure } from '@embeddable.com/core';\nimport { i18nSetup } from '../../../../theme/i18n/i18n';\nimport { resolveI18nProps } from '../../../component.utils';\nimport { ChartCard, ChartCardHeaderProps } from '../../shared/ChartCard/ChartCard';\nimport { getLineChartProData, getLineChartProOptions } from './LineChartDefaultPro.utils';\nimport { useFillGaps } from '../../charts.fillGaps.hooks';\nimport { LineChartProOptionsClick } from '../lines.utils';\nimport { LineChart } from '@embeddable.com/remarkable-ui';\n\nexport type LineChartProPropsOnLineClicked = { axisDimensionValue: string | null };\n\ntype LineChartProProp = {\n xAxis: Dimension;\n measures: Measure[];\n results: DataResponse;\n reverseXAxis?: boolean;\n showLegend?: boolean;\n showLogarithmicScale?: boolean;\n showTooltips?: boolean;\n showValueLabels?: boolean;\n\n xAxisLabel?: string;\n yAxisLabel?: string;\n yAxisRangeMax?: number;\n yAxisRangeMin?: number;\n onLineClicked?: LineChartProOptionsClick;\n} & ChartCardHeaderProps;\n\nconst LineChartPro = (props: LineChartProProp) => {\n const theme: Theme = useTheme() as Theme;\n i18nSetup(theme);\n\n const { title, description, xAxisLabel, yAxisLabel } = resolveI18nProps(props);\n const {\n hideMenu,\n measures,\n xAxis,\n reverseXAxis,\n showLegend,\n showLogarithmicScale,\n showTooltips,\n showValueLabels,\n yAxisRangeMax,\n yAxisRangeMin,\n onLineClicked,\n } = props;\n\n const results = useFillGaps({\n results: props.results,\n dimension: xAxis,\n });\n\n const data = getLineChartProData(\n {\n data: results.data,\n dimension: xAxis,\n measures,\n hasMinMaxYAxisRange: Boolean(yAxisRangeMin != null || yAxisRangeMax != null),\n },\n theme,\n );\n const options = getLineChartProOptions(\n { data, dimension: xAxis, measures, onLineClicked },\n theme,\n );\n\n return (\n <ChartCard\n data={results}\n dimensionsAndMeasures={[...measures, xAxis]}\n errorMessage={results.error}\n description={description}\n title={title}\n hideMenu={hideMenu}\n >\n <LineChart\n data={data}\n reverseXAxis={reverseXAxis}\n showLegend={showLegend}\n showLogarithmicScale={showLogarithmicScale}\n showTooltips={showTooltips}\n showValueLabels={showValueLabels}\n xAxisLabel={xAxisLabel}\n yAxisLabel={yAxisLabel}\n yAxisRangeMax={yAxisRangeMax}\n yAxisRangeMin={yAxisRangeMin}\n options={options}\n />\n </ChartCard>\n );\n};\n\nexport default LineChartPro;\n"],"names":["getLineChartProData","props","theme","themeFormatter","getThemeFormatter","themeKey","getObjectStableKey","groupedData","item","measure","index","zeroFill","_a","values","lineColor","_b","chartContrastColors","getChartContrastColors","backgroundColor","isColorValid","getColor","borderColor","setColorAlpha","_c","getStyleNumber","_d","getLineChartProOptions","options","dimension","data","measures","onLineClicked","mergician","value","context","label","raw","_event","elements","chart","element","dimensionValue","LineChartPro","useTheme","i18nSetup","title","description","xAxisLabel","yAxisLabel","resolveI18nProps","hideMenu","xAxis","reverseXAxis","showLegend","showLogarithmicScale","showTooltips","showValueLabels","yAxisRangeMax","yAxisRangeMin","results","useFillGaps","jsx","ChartCard","LineChart"],"mappings":"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"}
@@ -1,123 +0,0 @@
1
- import { x as M, y as z, j as a, 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-sebikYGW.js";
2
- import { useTheme as K } from "@embeddable.com/react";
3
- import { g as P, u as U, a as W, c as b, b as X } from "./dates.utils-BF32dTLi.js";
4
- import { c as Y, a as Z, r as $, i as m } from "./component.inputs.constants-Ds7YpNhT.js";
5
- import { E as V } from "./EditorCard-DpSCsmZJ.js";
6
- import { useState as R, useEffect as ee } from "react";
7
- import { I as te } from "./IconCalendarFilled-Bfm3jkzE.js";
8
- const ae = (o) => o.map((n) => ({
9
- rightLabel: P(n.getRange(), n.dateFormat),
10
- value: n.value,
11
- label: Y(n.label)
12
- })), ne = "_dateRangePickerContent_pig22_1", se = "_dateRangePickerContainer_pig22_5", v = {
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, p] = R(!1), [l, c] = R(
19
- W(e)
20
- ), r = n.defaults.dateRangesOptions;
21
- if (ee(() => {
22
- if (!i)
23
- return;
24
- const t = b(e, r);
25
- M(t, e) || s(t);
26
- }, [e, i, s, r]), !i)
27
- return null;
28
- const { description: T, placeholder: C, title: O } = $(o), h = ae(r), L = (t) => {
29
- const g = b(
30
- { relativeTimeString: t },
31
- r
32
- );
33
- s(g), c(void 0);
34
- }, F = (t) => {
35
- s(X(t)), p(!1);
36
- }, I = () => {
37
- c(void 0), s(void 0);
38
- }, _ = (() => {
39
- if (e != null && e.relativeTimeString) {
40
- const t = h.find((g) => g.value === e.relativeTimeString);
41
- if (t)
42
- return t.label;
43
- }
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__ */ a.jsx(V, { title: O, subtitle: T, children: /* @__PURE__ */ a.jsx(
47
- N,
48
- {
49
- open: S,
50
- onOpenChange: p,
51
- triggerComponent: /* @__PURE__ */ a.jsx(
52
- H,
53
- {
54
- startIcon: te,
55
- "aria-label": C,
56
- placeholder: C,
57
- valueLabel: _,
58
- onClear: I,
59
- isClearable: k
60
- }
61
- ),
62
- children: /* @__PURE__ */ a.jsx(q, { fitContent: !0, className: v.dateRangePickerContent, children: x ? /* @__PURE__ */ a.jsxs("div", { className: v.dateRangePickerContainer, children: [
63
- !u && /* @__PURE__ */ a.jsx(
64
- d,
65
- {
66
- label: m.t("editors.dateRangePicker.backToPresets"),
67
- onClick: (t) => {
68
- t.preventDefault(), f(!1);
69
- },
70
- startIcon: /* @__PURE__ */ a.jsx(B, {})
71
- }
72
- ),
73
- /* @__PURE__ */ a.jsx(
74
- G,
75
- {
76
- locale: w,
77
- numberOfMonths: E,
78
- value: l,
79
- onChange: c
80
- }
81
- ),
82
- /* @__PURE__ */ a.jsx(
83
- J,
84
- {
85
- size: "small",
86
- disabled: y,
87
- onClick: () => F(l),
88
- children: m.t("editors.dateRangePicker.apply")
89
- }
90
- )
91
- ] }) : /* @__PURE__ */ a.jsxs(Q, { children: [
92
- /* @__PURE__ */ a.jsx(
93
- d,
94
- {
95
- label: m.t("editors.dateRangePicker.custom"),
96
- onClick: (t) => {
97
- t.preventDefault(), f(!0);
98
- },
99
- endIcon: /* @__PURE__ */ a.jsx(A, {})
100
- }
101
- ),
102
- h.map((t) => /* @__PURE__ */ a.jsx(
103
- d,
104
- {
105
- ...t,
106
- isSelected: (e == null ? void 0 : e.relativeTimeString) === t.value,
107
- onClick: () => L(t.value)
108
- },
109
- t.value
110
- ))
111
- ] }) })
112
- }
113
- ) });
114
- }, ue = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
115
- __proto__: null,
116
- default: oe
117
- }, Symbol.toStringTag, { value: "Module" }));
118
- export {
119
- oe as D,
120
- ae as g,
121
- ue as i
122
- };
123
- //# sourceMappingURL=index-BsWftigv.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-BsWftigv.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 } 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';\nimport { ChartCardHeaderProps } from '../../../charts/shared/ChartCard/ChartCard';\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} & ChartCardHeaderProps;\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 } = 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} subtitle={description}>\n <Dropdown\n open={isOpen}\n onOpenChange={setIsOpen}\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","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":"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"}