@vizzly/dashboard 0.15.0-dev-65c3e5d7491389a56cc8409b046f92683dd4725f → 0.15.0

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 (59) hide show
  1. package/dist/charts/src/useXAxisLabelCount.d.ts +1 -1
  2. package/dist/charts/src/v2/components/Axis/AxisBottom.d.ts +1 -1
  3. package/dist/charts/src/v2/components/BarChart/BarChart.d.ts +2 -2
  4. package/dist/charts/src/v2/components/ChartWrapper/ChartWrapper.d.ts +2 -4
  5. package/dist/charts/src/v2/components/Tooltip/Tooltip.d.ts +1 -2
  6. package/dist/charts/src/v2/components/WaterfallChart/Tooltip.d.ts +2 -2
  7. package/dist/charts/src/v2/utils/components/BarGroup.d.ts +4 -4
  8. package/dist/charts/src/v2/utils/components/BarStacked.d.ts +4 -4
  9. package/dist/dashboard.cjs.development.js +1604 -1124
  10. package/dist/dashboard.cjs.production.min.js +1 -1
  11. package/dist/dashboard.esm.js +1605 -1125
  12. package/dist/results-driver/src/driver/VizzlyQuery/AreaChart/toQueries.d.ts +1 -1
  13. package/dist/results-driver/src/driver/VizzlyQuery/AreaChartV2/toQueries.d.ts +1 -1
  14. package/dist/results-driver/src/driver/VizzlyQuery/BarChart/toQueries.d.ts +1 -1
  15. package/dist/results-driver/src/driver/VizzlyQuery/BarChartV2/toQueries.d.ts +1 -1
  16. package/dist/results-driver/src/driver/VizzlyQuery/BasicTable/toQueries.d.ts +1 -1
  17. package/dist/results-driver/src/driver/VizzlyQuery/FunnelChart/toQueries.d.ts +1 -1
  18. package/dist/results-driver/src/driver/VizzlyQuery/HorizontalBarChart/toQueries.d.ts +1 -1
  19. package/dist/results-driver/src/driver/VizzlyQuery/LineChart/toQueries.d.ts +1 -1
  20. package/dist/results-driver/src/driver/VizzlyQuery/LineChartV2/toQueries.d.ts +1 -1
  21. package/dist/results-driver/src/driver/VizzlyQuery/PieChart/toQueries.d.ts +1 -1
  22. package/dist/results-driver/src/driver/VizzlyQuery/PivotTable/toQueries.d.ts +1 -1
  23. package/dist/results-driver/src/driver/VizzlyQuery/RadarChart/toQueries.d.ts +1 -1
  24. package/dist/results-driver/src/driver/VizzlyQuery/RichText/toQueries.d.ts +1 -1
  25. package/dist/results-driver/src/driver/VizzlyQuery/SunburstChart/toQueries.d.ts +1 -1
  26. package/dist/results-driver/src/driver/VizzlyQuery/WaterfallChart/toQueries.d.ts +1 -1
  27. package/dist/shared-logic/src/AdditionalFilter/types.d.ts +1 -4
  28. package/dist/shared-logic/src/BubbleChart/types.d.ts +0 -7
  29. package/dist/shared-logic/src/BubbleChartV2/buildBubbleChartRepresentation.d.ts +7 -4
  30. package/dist/shared-logic/src/BubbleChartV2/getScaleAndTicks.d.ts +3 -4
  31. package/dist/shared-logic/src/BubbleChartV2/types.d.ts +0 -8
  32. package/dist/shared-logic/src/ChartsV2/adjustTicks.d.ts +3 -3
  33. package/dist/shared-logic/src/Component/types.d.ts +1 -0
  34. package/dist/shared-logic/src/CustomField/SimpleMath/index.d.ts +1 -1
  35. package/dist/shared-logic/src/Filter/Filter.d.ts +1 -1
  36. package/dist/shared-logic/src/Filter/Where.d.ts +6 -0
  37. package/dist/shared-logic/src/Filter/types.d.ts +4 -2
  38. package/dist/shared-logic/src/JSQueryEngine/types.d.ts +8 -2
  39. package/dist/shared-logic/src/Query/Query.d.ts +3 -9
  40. package/dist/shared-logic/src/Query/buildFromQueryAttributes.d.ts +1 -1
  41. package/dist/shared-logic/src/Query/types.d.ts +109 -6
  42. package/dist/shared-logic/src/TimeDimension/TimeDimension.d.ts +1 -3
  43. package/dist/shared-logic/src/api/queryEngine/getRunQueriesCallback.d.ts +1 -1
  44. package/dist/shared-ui/src/api/useQueryEffect.d.ts +1 -2
  45. package/dist/shared-ui/src/base/Panel/Panel.d.ts +1 -1
  46. package/dist/shared-ui/src/components/BarChartV2/BarChartV2View.d.ts +3 -3
  47. package/dist/shared-ui/src/components/Component/types.d.ts +2 -0
  48. package/dist/shared-ui/src/components/Component.d.ts +2 -0
  49. package/dist/shared-ui/src/components/Studio/StudioApp/Cell.d.ts +2 -0
  50. package/dist/shared-ui/src/components/WaterfallChart/WaterfallChartView.d.ts +3 -3
  51. package/dist/shared-ui/src/components/useComponentEffect.d.ts +2 -2
  52. package/dist/shared-ui/src/contexts/DashboardContext/types.d.ts +17 -1
  53. package/dist/shared-ui/src/library/Editor/useEditor.d.ts +2 -0
  54. package/dist/shared-ui/src/library/Library/ComponentInLibrary.d.ts +1 -0
  55. package/dist/shared-ui/src/library/Library/Library.d.ts +4 -0
  56. package/dist/shared-ui/src/library/Library/types.d.ts +2 -0
  57. package/package.json +3 -3
  58. package/dist/shared-logic/src/PivotConfigForMetricAxis/index.d.ts +0 -3
  59. package/dist/shared-logic/src/Result/formattedResultToSeriesForMetricAxis.d.ts +0 -25
@@ -33,7 +33,7 @@ import { LegendItem as LegendItem$1, LegendLabel } from '@visx/legend';
33
33
  import { scaleOrdinal, scaleQuantize, scaleLinear, scalePoint, scaleTime, scaleBand } from '@visx/scale';
34
34
  import Ordinal from '@visx/legend/lib/legends/Ordinal';
35
35
  import { curveNatural, curveMonotoneX, curveMonotoneY, curveLinear, curveStep, curveStepBefore, curveStepAfter } from '@visx/curve';
36
- import { Line as Line$1, LinePath, BarGroup as BarGroup$2, BarStack as BarStack$1, AreaStack as AreaStack$1, AreaClosed, LineRadial } from '@visx/shape';
36
+ import { Line as Line$1, LinePath, BarStack as BarStack$1, BarGroup as BarGroup$2, AreaStack as AreaStack$1, AreaClosed, LineRadial } from '@visx/shape';
37
37
  import { Mercator, Graticule } from '@visx/geo';
38
38
  import { feature } from 'topojson-client';
39
39
  import ParentSize$1 from '@visx/responsive/lib/components/ParentSize';
@@ -1108,6 +1108,33 @@ var FieldNotFoundInDataSet = /*#__PURE__*/function (_ValidationError) {
1108
1108
  return FieldNotFoundInDataSet;
1109
1109
  }(ValidationError);
1110
1110
 
1111
+ var timeDimensionsConstants = QueryEngineConfig.Constants.timeDimensionsConstants;
1112
+
1113
+ // All the aggregates Vizzly supports somewhere...
1114
+ // Not necessarily all the aggregates that are supported because each
1115
+ // integration could support different aggregates
1116
+
1117
+ var id$1 = function id(metric) {
1118
+ if (!(metric != null && metric.truncate) || (metric == null ? void 0 : metric.truncate) == 'none') return metric == null ? void 0 : metric.field;
1119
+ return metric.field + "_" + metric.truncate;
1120
+ };
1121
+ var decodeId$1 = function decodeId(metric, supportedTimeTruncFunctions) {
1122
+ var parts = metric.split('_');
1123
+ var truncate = parts.pop();
1124
+ if (truncate && !isSupportedTimeTruncFunction(supportedTimeTruncFunctions, truncate)) {
1125
+ return null;
1126
+ }
1127
+ var field = parts.join('_');
1128
+ return {
1129
+ field: field,
1130
+ truncate: truncate != null ? truncate : ''
1131
+ };
1132
+ };
1133
+ var vizzlyManagedTimeDimensions = timeDimensionsConstants;
1134
+ var isSupportedTimeTruncFunction = function isSupportedTimeTruncFunction(supportedTimeFunctions, proposedFunction) {
1135
+ return [].concat(Object.keys(supportedTimeFunctions), ['none']).includes(proposedFunction);
1136
+ };
1137
+
1111
1138
  var filterIsDate = function filterIsDate(filter) {
1112
1139
  var isoDateRegex = /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z$/;
1113
1140
  if (!isoDateRegex.test(filter.value)) {
@@ -1342,6 +1369,103 @@ function extractValue(variables, key) {
1342
1369
  return variables[key].value;
1343
1370
  }
1344
1371
 
1372
+ var addAndFilters = function addAndFilters(filter, filterToAddToAll) {
1373
+ if (!filter || isEmpty$2(filter)) filter = [[]];
1374
+ return [].concat(filter).map(function (andFilter) {
1375
+ return [].concat(andFilter, filterToAddToAll);
1376
+ });
1377
+ };
1378
+ var filterAttributeToQueryFilter = function filterAttributeToQueryFilter(filters, queryEngineConfig, dataSet, params) {
1379
+ return filters.map(function (andFilters) {
1380
+ return [].concat(andFilters).flatMap(function (andFilter) {
1381
+ var _andFilter$function;
1382
+ // Stop unsupported time functions being used.
1383
+ if (andFilter["function"] && !isSupportedTimeTruncFunction(queryEngineConfig.supportedTimeTruncFunctions, andFilter["function"])) {
1384
+ throw "Query engine does not support the query function " + andFilter["function"] + ".";
1385
+ }
1386
+ var dataSetField = findField(dataSet, andFilter.field);
1387
+ var field = {
1388
+ type: 'field',
1389
+ value: andFilter.field,
1390
+ "function": (_andFilter$function = andFilter["function"]) != null ? _andFilter$function : 'none'
1391
+ };
1392
+ if (isCustomField(dataSetField)) {
1393
+ var _andFilter$function2;
1394
+ field = toQueryMeasure({
1395
+ field: dataSetField.id,
1396
+ "function": (_andFilter$function2 = andFilter["function"]) != null ? _andFilter$function2 : 'none'
1397
+ }, dataSetField, queryEngineConfig, dataSet, false, params);
1398
+ }
1399
+ // If `array_contains` operation has multiple. Then split these out into individual
1400
+ // checks.
1401
+ if ((andFilter.op == 'array_contains' || andFilter.op == 'array_does_not_contain') && Array.isArray(andFilter.value)) {
1402
+ return [].concat(andFilter.value).map(function (value) {
1403
+ return {
1404
+ field: field,
1405
+ op: andFilter.op,
1406
+ value: value
1407
+ };
1408
+ });
1409
+ }
1410
+ var value = useValue(andFilter.value, params.variables);
1411
+ if (isRelativeDateDefined(andFilter.value)) {
1412
+ value = calculateRelativeDate(andFilter.value);
1413
+ }
1414
+ if (filterIsDate(andFilter)) {
1415
+ value = getUTCDate(andFilter.value);
1416
+ }
1417
+ return [{
1418
+ field: field,
1419
+ op: andFilter.op,
1420
+ value: value
1421
+ }];
1422
+ });
1423
+ });
1424
+ };
1425
+ var isAvailable = function isAvailable(filter) {
1426
+ return filter && isArray(filter) && isArray(filter[0]);
1427
+ };
1428
+ var isAdditionalFilter = function isAdditionalFilter(value) {
1429
+ return value && isArray(value) && isArray(value[0]) && 'field' in value[0][0] && 'op' in value[0][0] && 'value' in value[0][0];
1430
+ };
1431
+
1432
+ var combineFilters = function combineFilters(array1, array2) {
1433
+ var validArray1 = array1.length > 0 && array1[0] ? array1 : [[]];
1434
+ var validArray2 = array2.length > 0 && array2[0] ? array2 : [[]];
1435
+
1436
+ // If array1 has more than one sub-array, loop through each sub-array in array1
1437
+ if (validArray1.length > 1) {
1438
+ return validArray1.map(function (subArray) {
1439
+ return [].concat(validArray2[0] || [], subArray || []);
1440
+ });
1441
+ }
1442
+ // Otherwise, if array2 has more than one sub-array, loop through array2
1443
+ else if (validArray2.length > 1) {
1444
+ return validArray2.map(function (subArray) {
1445
+ return [].concat(validArray1[0] || [], subArray || []);
1446
+ });
1447
+ }
1448
+ // Default: merge both single sub-arrays
1449
+ else {
1450
+ return [[].concat(validArray1[0] || [], validArray2[0] || [])];
1451
+ }
1452
+ };
1453
+ function combineForCustomMetricFilters(filters, customFilters) {
1454
+ var combinedFilters = [];
1455
+ if (customFilters && isAvailable(customFilters)) {
1456
+ customFilters.forEach(function (orFilterGroup) {
1457
+ combinedFilters = [].concat(combinedFilters, addAndFilters(filters != null ? filters : [], orFilterGroup));
1458
+ });
1459
+ } else {
1460
+ combinedFilters = filters != null ? filters : [];
1461
+ }
1462
+ return combinedFilters;
1463
+ }
1464
+
1465
+ var generateId = function generateId() {
1466
+ return v4().replace(/-/g, '');
1467
+ };
1468
+
1345
1469
  /** Upcasts from an old global filter, to a new "additional filter" */
1346
1470
  var upcastToAdditionalFilter = function upcastToAdditionalFilter(globalFilter) {
1347
1471
  if (globalFilter.type == 'globalSelectFilter') {
@@ -1771,125 +1895,6 @@ var fromFilterConfig = function fromFilterConfig(filterConfig, dataSet, timeRang
1771
1895
  return filters;
1772
1896
  };
1773
1897
 
1774
- var addAndFilters = function addAndFilters(filter, filterToAddToAll) {
1775
- if (isEmpty$2(filterToAddToAll)) return [].concat(filter);
1776
- if (!filter || isEmpty$2(filter)) filter = [[]];
1777
- return [].concat(filter).map(function (andFilter) {
1778
- return [].concat(andFilter, filterToAddToAll);
1779
- });
1780
- };
1781
- var filterAttributeToQueryFilter = function filterAttributeToQueryFilter(filterAttrs, queryEngineConfig, dataSet, params) {
1782
- var _params$filterConfig;
1783
- // Either build using the filter attributes passed in, or take the viewFilters in the filter config.
1784
- // They represent the same thing, however some view-filters are passed around in the filter config
1785
- // to reduce custom metrics arguments being passed around.
1786
- var filter = filterAttrs.length > 0 ? filterAttrs : ((_params$filterConfig = params.filterConfig) == null ? void 0 : _params$filterConfig.viewFilters) || [];
1787
- var extraFilters = fromFilterConfig(params.filterConfig, dataSet, params.timeRangeOptions);
1788
- var combinedFilters = addAndFilters(filter, extraFilters);
1789
- if (Array.isArray(filter)) {
1790
- return {
1791
- type: 'orWhere',
1792
- value: combinedFilters.map(function (andFilters) {
1793
- return {
1794
- type: 'andWhere',
1795
- value: andFilters.map(function (filter) {
1796
- var dataSetField = findField(dataSet, filter.field);
1797
- var field = {
1798
- type: 'field',
1799
- value: filter.field,
1800
- "function": filter["function"] || 'none'
1801
- };
1802
- if (isCustomField(dataSetField)) {
1803
- var _filter$function;
1804
- field = toQueryMeasure({
1805
- field: dataSetField.id,
1806
- "function": (_filter$function = filter["function"]) != null ? _filter$function : 'none'
1807
- }, dataSetField, queryEngineConfig, dataSet, false, params);
1808
- }
1809
-
1810
- // If the value is an array, and we're checking that all values ARE or ARE NOT in a field, then we need to split
1811
- // out this check into multiple filters, as a value in a filter cannot be an array.
1812
- if ((filter.op == 'array_contains' || filter.op == 'array_does_not_contain') && Array.isArray(filter.value)) {
1813
- return {
1814
- type: 'andWhere',
1815
- value: [].concat(filter.value).map(function (value) {
1816
- return {
1817
- type: 'where',
1818
- value: {
1819
- field: field,
1820
- op: filter.op,
1821
- value: value
1822
- }
1823
- };
1824
- })
1825
- };
1826
- }
1827
- var value = useValue(filter.value, params.variables);
1828
- if (isRelativeDateDefined(filter.value)) {
1829
- value = calculateRelativeDate(filter.value);
1830
- }
1831
- if (filterIsDate(filter)) {
1832
- value = getUTCDate(filter.value);
1833
- }
1834
- return {
1835
- type: 'where',
1836
- value: {
1837
- field: field,
1838
- op: filter.op,
1839
- value: value
1840
- }
1841
- };
1842
- })
1843
- };
1844
- })
1845
- };
1846
- }
1847
- return filter;
1848
- };
1849
- var isAvailable = function isAvailable(filter) {
1850
- return filter && isArray(filter) && isArray(filter[0]);
1851
- };
1852
- var isAdditionalFilter = function isAdditionalFilter(value) {
1853
- return value && isArray(value) && isArray(value[0]) && 'field' in value[0][0] && 'op' in value[0][0] && 'value' in value[0][0];
1854
- };
1855
-
1856
- var combineFilters = function combineFilters(array1, array2) {
1857
- var validArray1 = array1.length > 0 && array1[0] ? array1 : [[]];
1858
- var validArray2 = array2.length > 0 && array2[0] ? array2 : [[]];
1859
-
1860
- // If array1 has more than one sub-array, loop through each sub-array in array1
1861
- if (validArray1.length > 1) {
1862
- return validArray1.map(function (subArray) {
1863
- return [].concat(validArray2[0] || [], subArray || []);
1864
- });
1865
- }
1866
- // Otherwise, if array2 has more than one sub-array, loop through array2
1867
- else if (validArray2.length > 1) {
1868
- return validArray2.map(function (subArray) {
1869
- return [].concat(validArray1[0] || [], subArray || []);
1870
- });
1871
- }
1872
- // Default: merge both single sub-arrays
1873
- else {
1874
- return [[].concat(validArray1[0] || [], validArray2[0] || [])];
1875
- }
1876
- };
1877
- function combineForCustomMetricFilters(filters, customFilters) {
1878
- var combinedFilters = [];
1879
- if (customFilters && isAvailable(customFilters)) {
1880
- customFilters.forEach(function (orFilterGroup) {
1881
- combinedFilters = [].concat(combinedFilters, addAndFilters(filters != null ? filters : [], orFilterGroup));
1882
- });
1883
- } else {
1884
- combinedFilters = filters != null ? filters : [];
1885
- }
1886
- return combinedFilters;
1887
- }
1888
-
1889
- var generateId = function generateId() {
1890
- return v4().replace(/-/g, '');
1891
- };
1892
-
1893
1898
  /**
1894
1899
  * Creates a new custom percentage field.
1895
1900
  */
@@ -1916,7 +1921,7 @@ var init$1 = function init(publicName, denominatorFieldId, denominatorAggregate,
1916
1921
  var build$2 = function build(customField, queryEngineConfig, dataSet, _queryHasDimension, params) {
1917
1922
  var _params$filterConfig$, _params$filterConfig, _customField$numerato, _customField$numerato2, _customField$denomina, _customField$denomina2;
1918
1923
  var localAndDashboardFilters = fromFilterConfig(params.filterConfig, dataSet, params.timeRangeOptions);
1919
- var _buildPercentageFilte = buildPercentageFilters(addAndFilters((_params$filterConfig$ = params == null || (_params$filterConfig = params.filterConfig) == null ? void 0 : _params$filterConfig.viewFilters) != null ? _params$filterConfig$ : [], localAndDashboardFilters), customField),
1924
+ var _buildPercentageFilte = buildPercentageFilters(addAndFilters((_params$filterConfig$ = params == null || (_params$filterConfig = params.filterConfig) == null ? void 0 : _params$filterConfig.advancedFilter) != null ? _params$filterConfig$ : [], localAndDashboardFilters), customField),
1920
1925
  combinedNominatorFilters = _buildPercentageFilte.combinedNominatorFilters,
1921
1926
  combinedDenominatorFilters = _buildPercentageFilte.combinedDenominatorFilters;
1922
1927
  var left = {
@@ -1938,36 +1943,24 @@ var build$2 = function build(customField, queryEngineConfig, dataSet, _queryHasD
1938
1943
  filter: filterAttributeToQueryFilter(combinedDenominatorFilters || [], queryEngineConfig, dataSet, params)
1939
1944
  }
1940
1945
  };
1941
- var denominatorForWithinGroupingScope = buildSide(right, isAvailable(customField.denominatorFilter) ? filterAttributeToQueryFilter(combinedDenominatorFilters, queryEngineConfig, dataSet, params) : {
1942
- type: 'andWhere',
1943
- value: []
1944
- });
1946
+ var denominatorForWithinGroupingScope = buildSide(right, isAvailable(customField.denominatorFilter) ? filterAttributeToQueryFilter(combinedDenominatorFilters, queryEngineConfig, dataSet, params) : []);
1945
1947
  return {
1946
1948
  type: 'maths',
1947
- left: buildSide(left, isAvailable(customField.numeratorFilter) ? filterAttributeToQueryFilter(combinedNominatorFilters, queryEngineConfig, dataSet, params) : {
1948
- type: 'andWhere',
1949
- value: []
1950
- }),
1949
+ left: buildSide(left, isAvailable(customField.numeratorFilter) ? filterAttributeToQueryFilter(combinedNominatorFilters, queryEngineConfig, dataSet, params) : []),
1951
1950
  op: '/',
1952
1951
  right: customField.denominatorScope === 'withinGrouping' ? denominatorForWithinGroupingScope : denominatorForAllScope
1953
1952
  };
1954
1953
  };
1955
1954
  var buildSide = function buildSide(field, filter) {
1956
- var alwaysTrueFilter = {
1957
- type: 'andWhere',
1958
- value: [{
1959
- type: 'where',
1960
- value: {
1961
- field: {
1962
- type: 'number',
1963
- value: 2
1964
- },
1965
- op: '=',
1966
- value: 2
1967
- }
1968
- }]
1969
- };
1970
- var hasNumeratorFilter = filter.type === 'where' || filter.value.length > 0;
1955
+ var alwaysTrueFilter = [[{
1956
+ value: 1,
1957
+ op: '=',
1958
+ field: {
1959
+ type: 'number',
1960
+ value: 1
1961
+ }
1962
+ }]];
1963
+ var hasNumeratorFilter = filter.length > 0 && filter[0].length > 0;
1971
1964
  if (!hasNumeratorFilter) {
1972
1965
  return {
1973
1966
  type: 'field',
@@ -2341,7 +2334,7 @@ var buildIfLogic = function buildIfLogic(ifLogic, dataSet, localAndDashboardFilt
2341
2334
  var cases = function () {
2342
2335
  var thenCases = ifLogic.cases.map(function (c) {
2343
2336
  var _params$filterConfig$, _params$filterConfig;
2344
- var customMetricFilter = combineForCustomMetricFilters(addAndFilters((_params$filterConfig$ = params == null || (_params$filterConfig = params.filterConfig) == null ? void 0 : _params$filterConfig.viewFilters) != null ? _params$filterConfig$ : [], localAndDashboardFilters), c.filter);
2337
+ var customMetricFilter = combineForCustomMetricFilters(addAndFilters((_params$filterConfig$ = params == null || (_params$filterConfig = params.filterConfig) == null ? void 0 : _params$filterConfig.advancedFilter) != null ? _params$filterConfig$ : [], localAndDashboardFilters), c.filter);
2345
2338
  return {
2346
2339
  returns: buildMetric(c.returns, dataSet, params, measureAttribute),
2347
2340
  filter: filterAttributeToQueryFilter(customMetricFilter, queryEngineConfig, dataSet, params)
@@ -2649,33 +2642,6 @@ var mergeAttributes = function mergeAttributes(partial, existingProps) {
2649
2642
  return _doMerge(existingProps, partial);
2650
2643
  };
2651
2644
 
2652
- var timeDimensionsConstants = QueryEngineConfig.Constants.timeDimensionsConstants;
2653
-
2654
- // All the aggregates Vizzly supports somewhere...
2655
- // Not necessarily all the aggregates that are supported because each
2656
- // integration could support different aggregates
2657
-
2658
- var id$1 = function id(metric) {
2659
- if (!(metric != null && metric.truncate) || (metric == null ? void 0 : metric.truncate) == 'none') return metric == null ? void 0 : metric.field;
2660
- return metric.field + "_" + metric.truncate;
2661
- };
2662
- var decodeId$1 = function decodeId(metric, supportedTimeTruncFunctions) {
2663
- var parts = metric.split('_');
2664
- var truncate = parts.pop();
2665
- if (truncate && !isSupportedTimeTruncFunction(supportedTimeTruncFunctions, truncate)) {
2666
- return null;
2667
- }
2668
- var field = parts.join('_');
2669
- return {
2670
- field: field,
2671
- truncate: truncate != null ? truncate : ''
2672
- };
2673
- };
2674
- var vizzlyManagedTimeDimensions = timeDimensionsConstants;
2675
- var isSupportedTimeTruncFunction = function isSupportedTimeTruncFunction(supportedTimeFunctions, proposedFunction) {
2676
- return [].concat(Object.keys(supportedTimeFunctions), ['none']).includes(proposedFunction);
2677
- };
2678
-
2679
2645
  var id$2 = id;
2680
2646
  var decodeId$2 = decodeId;
2681
2647
  var hasAggregate = function hasAggregate(metric) {
@@ -10553,7 +10519,7 @@ var WaterfallChart = function WaterfallChart(config) {
10553
10519
  return removeField$1(attrs, fieldId, config.queryEngineConfig);
10554
10520
  },
10555
10521
  isRunnable: function isRunnable(hydrated) {
10556
- return hydrated.measure.length > 0 && (hydrated.dimension.length > 0 || hydrated.timeDimension !== null);
10522
+ return hydrated.measure.length > 0;
10557
10523
  },
10558
10524
  autoGenerate: function autoGenerate(dataSet) {
10559
10525
  var _DataSet$buildQueryAt = buildQueryAttributes(dataSet, config.queryEngineConfig, 'waterfallChart'),
@@ -10578,8 +10544,7 @@ var WaterfallChart = function WaterfallChart(config) {
10578
10544
  getValues: function getValues(attrs) {
10579
10545
  return attrs.measure;
10580
10546
  },
10581
- testId: 'metric-input',
10582
- maxAllowed: 1
10547
+ testId: 'metric-input'
10583
10548
  }), _extends({}, namespace(CONSTANTS$l, 'field_x_axis'), {
10584
10549
  fieldFilterOptions: {
10585
10550
  forComponent: 'waterfallChart',
@@ -10592,7 +10557,7 @@ var WaterfallChart = function WaterfallChart(config) {
10592
10557
  getValues: function getValues(attrs) {
10593
10558
  return getGroupingWithTimeDimension(attrs);
10594
10559
  },
10595
- maxAllowed: 1,
10560
+ maxAllowed: 2,
10596
10561
  testId: 'add-dimension'
10597
10562
  }), namespace(CONSTANTS$l, 'sort'), namespace(CONSTANTS$l, 'filter'), namespace(CONSTANTS$l, 'custom_metrics'), namespace(CONSTANTS$l, 'limit')];
10598
10563
  },
@@ -14553,7 +14518,7 @@ var buildDefaults = function buildDefaults(partialFeatureToggles) {
14553
14518
  };
14554
14519
  };
14555
14520
 
14556
- var ALL_COMPONENT_TYPES = ['barChart', 'barChartV2', 'horizontalBarChart', 'funnelChart', 'areaChart', 'areaChartV2', 'lineChart', 'lineChartV2', 'comboChartV2', 'scatterChart', 'bubbleChart', 'bubbleChartV2', 'pieChart', 'sunburstChart', 'singleStat', 'dataTable', 'basicTable', 'comboChart', 'mercatorMap', 'progress', 'richText', 'custom', 'waterfallChart', 'radarChart'];
14521
+ var ALL_COMPONENT_TYPES = ['barChart', 'bubbleChart', 'bubbleChartV2', 'horizontalBarChart', 'funnelChart', 'areaChart', 'areaChartV2', 'lineChart', 'lineChartV2', 'barChartV2', 'comboChartV2', 'scatterChart', 'pieChart', 'sunburstChart', 'singleStat', 'dataTable', 'basicTable', 'comboChart', 'mercatorMap', 'progress', 'richText', 'custom', 'waterfallChart', 'radarChart'];
14557
14522
  var ALL_VIZZLY_COMPONENT_TYPES = /*#__PURE__*/[].concat(ALL_COMPONENT_TYPES).filter(function (type) {
14558
14523
  return type != 'custom';
14559
14524
  });
@@ -14563,6 +14528,7 @@ var initial = function initial(attributes) {
14563
14528
  return {
14564
14529
  attributes: attributes,
14565
14530
  localFilters: [],
14531
+ results: [],
14566
14532
  colSpan: POPULATE_ONE_CELL,
14567
14533
  reports: []
14568
14534
  };
@@ -15006,12 +14972,10 @@ var load$2 = function load$1(dumped, componentInterfaceConfig) {
15006
14972
  delete dumped['addOns'];
15007
14973
  // @ts-ignore
15008
14974
  delete attributes['addOns'];
15009
-
15010
- // @ts-ignore
15011
- delete attributes['results'];
15012
14975
  return _extends({}, dumped, {
15013
14976
  localFilters: localFilters,
15014
- attributes: attributes
14977
+ attributes: attributes,
14978
+ results: []
15015
14979
  });
15016
14980
  };
15017
14981
  var dump$2 = function dump$1(hydrated) {
@@ -15038,6 +15002,7 @@ var saveable = function saveable(component, protectedComponent) {
15038
15002
  }),
15039
15003
  localFilters: (_component$localFilte = component.localFilters) != null ? _component$localFilte : [],
15040
15004
  colSpan: 1,
15005
+ results: [],
15041
15006
  reports: []
15042
15007
  };
15043
15008
  };
@@ -15513,6 +15478,8 @@ var init$b = function init(overrides, includeComponentTypes, excludeComponentTyp
15513
15478
  var temporaryExcludedComponentTypes = [];
15514
15479
  // TODO: Remove this once RichText is supported in the UI
15515
15480
  temporaryExcludedComponentTypes.push('richText');
15481
+ // TODO: Remove this once representation charts (aka v2 charts) are finished and working as expected
15482
+ temporaryExcludedComponentTypes.push('areaChartV2', 'barChartV2', 'bubbleChartV2', 'comboChartV2', 'lineChartV2', 'radarChart', 'waterfallChart');
15516
15483
  var allowedView = filterIncludedAndExcludedViews(ALL_VIZZLY_COMPONENT_TYPES, includeComponentTypes, excludeComponentTypes ? [].concat(excludeComponentTypes, temporaryExcludedComponentTypes) : [].concat(temporaryExcludedComponentTypes));
15517
15484
  return allowedView.filter(function (view) {
15518
15485
  var hasSupportForPreAggregatedDataSets = !!getComponentInterface(view).setDataAttributesFromPreAggregatedDataSet;
@@ -23104,6 +23071,18 @@ var pickComponentFromLibraryForDisplay = function pickComponentFromLibraryForDis
23104
23071
  pickFromComponentLibrary: null
23105
23072
  });
23106
23073
  };
23074
+ var setResultsForComponentInDisplay = function setResultsForComponentInDisplay(state, action) {
23075
+ var results = action.results,
23076
+ rowIndex = action.rowIndex,
23077
+ cellIndex = action.cellIndex;
23078
+ var currentComponent = state.dashboard.display[rowIndex].components[cellIndex];
23079
+ if (!currentComponent) throw 'We can only set results on an existing component on the dashboard.';
23080
+ var newComponent = _extends({}, currentComponent, {
23081
+ results: results
23082
+ });
23083
+ var newState = _setComponentInDisplayHelper(state, newComponent, rowIndex, cellIndex);
23084
+ return _extends({}, newState);
23085
+ };
23107
23086
  var updateComponentLibraryAttributes = function updateComponentLibraryAttributes(state, action) {
23108
23087
  var libraryIndex = action.libraryIndex,
23109
23088
  attributes = action.attributes;
@@ -23117,6 +23096,31 @@ var updateComponentLibraryAttributes = function updateComponentLibraryAttributes
23117
23096
  })
23118
23097
  });
23119
23098
  };
23099
+ var setResultsForComponentInEditor = function setResultsForComponentInEditor(state, action) {
23100
+ if (!state.componentEditor) throw 'Cannot set results for a closed editor.';
23101
+ if (!state.componentEditor.component) throw 'Cannot set results for a non-existant component in editor.';
23102
+ var results = action.results;
23103
+ return _extends({}, state, {
23104
+ componentEditor: _extends({}, state.componentEditor, {
23105
+ component: _extends({}, state.componentEditor.component, {
23106
+ results: results
23107
+ })
23108
+ })
23109
+ });
23110
+ };
23111
+ var setResultsForComponentInLibrary = function setResultsForComponentInLibrary(state, action) {
23112
+ var libraryIndex = action.libraryIndex,
23113
+ results = action.results;
23114
+ var componentLibrary = [].concat(state.dashboard.componentLibrary);
23115
+ componentLibrary[libraryIndex] = _extends({}, componentLibrary[libraryIndex], {
23116
+ results: results
23117
+ });
23118
+ return _extends({}, state, {
23119
+ dashboard: _extends({}, state.dashboard, {
23120
+ componentLibrary: componentLibrary
23121
+ })
23122
+ });
23123
+ };
23120
23124
  var clearModal = function clearModal(state, _action) {
23121
23125
  return _extends({}, state, {
23122
23126
  pickFromComponentLibrary: null,
@@ -23512,6 +23516,12 @@ var reducer = function reducer(pipelineTransformationOptions) {
23512
23516
  return clearModal(state);
23513
23517
  case 'updateEditorComponent':
23514
23518
  return updateEditorComponent(state, action);
23519
+ case 'setResultsForComponentInDisplay':
23520
+ return setResultsForComponentInDisplay(state, action);
23521
+ case 'setResultsForComponentInLibrary':
23522
+ return setResultsForComponentInLibrary(state, action);
23523
+ case 'setResultsForComponentInEditor':
23524
+ return setResultsForComponentInEditor(state, action);
23515
23525
  case 'pickComponentFromLibraryForDisplay':
23516
23526
  return pickComponentFromLibraryForDisplay(state, action);
23517
23527
  case 'setDashboard':
@@ -25900,15 +25910,149 @@ var filterStyles = /*#__PURE__*/Object.assign(function () {
25900
25910
  complete: complete
25901
25911
  });
25902
25912
 
25913
+ var Clause = /*#__PURE__*/function (Clause) {
25914
+ Clause["AND_WHERE"] = "andWhere";
25915
+ Clause["OR_WHERE"] = "orWhere";
25916
+ Clause["WHERE"] = "where";
25917
+ return Clause;
25918
+ }({});
25919
+
25920
+ // export type WhereClause = SqlAST.MultiWhereToken<any>;
25921
+
25922
+ var filterConfigToWhere = function filterConfigToWhere(dataSet, queryEngineConfig, params) {
25923
+ if (!params) return undefined;
25924
+ var filterConfig = params.filterConfig;
25925
+ if (!params || !filterConfig || (!filterConfig.globalFilters || filterConfig.globalFilters.length === 0) && (!filterConfig.localFilters || filterConfig.localFilters.length === 0) && (!filterConfig.advancedFilter || filterConfig.advancedFilter.length === 0 || filterConfig.advancedFilter.every(function (arr) {
25926
+ return arr.length === 0;
25927
+ }))) {
25928
+ return undefined;
25929
+ }
25930
+ var dash = buildAndWhere(dataSet, queryEngineConfig, params, filterConfig.globalFilters);
25931
+ var local = buildAndWhere(dataSet, queryEngineConfig, params, filterConfig.localFilters);
25932
+ var advancedFilters = buildFromFiltersArray(dataSet, queryEngineConfig, params, filterConfig.advancedFilter);
25933
+ var combinedAndWhere = [dash, local, advancedFilters].filter(Boolean).filter(function (whereClause) {
25934
+ return whereClause && whereClause.value.length > 0;
25935
+ });
25936
+ if (combinedAndWhere.length === 0) return undefined;
25937
+ return {
25938
+ type: Clause.AND_WHERE,
25939
+ value: combinedAndWhere
25940
+ };
25941
+ };
25942
+ var buildAndWhere = function buildAndWhere(dataSet, queryEngineConfig, params, additionalFilters) {
25943
+ if (!additionalFilters || additionalFilters.length === 0) return undefined;
25944
+ var whereClauses = [];
25945
+ additionalFilters.forEach(function (additionalFilter) {
25946
+ if (additionalFilter.type === DATE_AND_TIME_FILTER || additionalFilter.type === DATE_FILTER) {
25947
+ toRelativeQueryAttributesFilters(additionalFilter, dataSet).forEach(function (f) {
25948
+ whereClauses.push(buildWhereFromSingleFilter(dataSet, f, queryEngineConfig, params));
25949
+ });
25950
+ }
25951
+ if (Array.isArray(additionalFilter.value) && additionalFilter.value.length > 1 && isAdditionalFilter(additionalFilter.value)) {
25952
+ additionalFilter.appliesToFields.flatMap(function (field) {
25953
+ if (field.dataSetId != dataSet.id) return [];
25954
+ var convertedToWhere = buildFromFiltersArray(dataSet, queryEngineConfig, params, additionalFilter.value);
25955
+ if (convertedToWhere) {
25956
+ whereClauses.push(convertedToWhere);
25957
+ }
25958
+ return;
25959
+ });
25960
+ } else {
25961
+ toQueryAttributesFilter(dataSet, additionalFilter, params.timeRangeOptions).forEach(function (f) {
25962
+ whereClauses.push(buildWhereFromSingleFilter(dataSet, f, queryEngineConfig, params));
25963
+ });
25964
+ }
25965
+ });
25966
+ return {
25967
+ type: Clause.AND_WHERE,
25968
+ value: whereClauses
25969
+ };
25970
+ };
25971
+ var buildWhereFromSingleFilter = function buildWhereFromSingleFilter(dataSet, f, queryEngineConfig, params) {
25972
+ var field;
25973
+ if (f["function"] && !isSupportedTimeTruncFunction(queryEngineConfig.supportedTimeTruncFunctions, f["function"])) {
25974
+ throw "Query engine does not support the query function " + f["function"] + ".";
25975
+ }
25976
+ var dataSetField = findField(dataSet, f.field);
25977
+ if (isCustomField(dataSetField)) {
25978
+ var _f$function;
25979
+ field = toQueryMeasure({
25980
+ field: dataSetField.id,
25981
+ "function": (_f$function = f["function"]) != null ? _f$function : 'none'
25982
+ }, dataSetField, queryEngineConfig, dataSet, false, params);
25983
+ } else {
25984
+ var _decodedField$functio;
25985
+ var decodedField = decodeId(f.field, queryEngineConfig);
25986
+ field = {
25987
+ type: 'field',
25988
+ value: decodedField.field,
25989
+ "function": (_decodedField$functio = decodedField["function"]) != null ? _decodedField$functio : 'none'
25990
+ };
25991
+ }
25992
+ if ((f.op == 'array_contains' || f.op == 'array_does_not_contain') && Array.isArray(f.value)) {
25993
+ return arrayContainsFilters(f, dataSet, queryEngineConfig, params);
25994
+ }
25995
+ var value = useValue(f.value, params.variables);
25996
+ if (isRelativeDateDefined(f.value)) {
25997
+ value = calculateRelativeDate(f.value);
25998
+ }
25999
+ if (filterIsDate(f)) {
26000
+ value = getUTCDate(f.value);
26001
+ }
26002
+ return {
26003
+ type: Clause.WHERE,
26004
+ value: {
26005
+ op: f.op,
26006
+ value: value,
26007
+ field: field
26008
+ }
26009
+ };
26010
+ };
26011
+ var buildFromFiltersArray = function buildFromFiltersArray(dataSet, queryEngineConfig, params, filters) {
26012
+ if (!filters || filters.length === 0 || filters.every(function (arr) {
26013
+ return arr.length === 0;
26014
+ })) {
26015
+ return undefined;
26016
+ }
26017
+ if (filters.length === 1) return buildFromFilters(filters[0], dataSet, queryEngineConfig, params);
26018
+ return {
26019
+ type: Clause.OR_WHERE,
26020
+ value: filters.map(function (filter) {
26021
+ return buildFromFilters(filter, dataSet, queryEngineConfig, params);
26022
+ })
26023
+ };
26024
+ };
26025
+ var buildFromFilters = function buildFromFilters(filter, dataSet, queryEngineConfig, params) {
26026
+ return {
26027
+ type: Clause.AND_WHERE,
26028
+ value: filter.map(function (filter) {
26029
+ if ((filter.op == 'array_contains' || filter.op == 'array_does_not_contain') && Array.isArray(filter.value)) {
26030
+ return arrayContainsFilters(filter, dataSet, queryEngineConfig, params);
26031
+ }
26032
+ return buildWhereFromSingleFilter(dataSet, filter, queryEngineConfig, params);
26033
+ })
26034
+ };
26035
+ };
26036
+ var arrayContainsFilters = function arrayContainsFilters(filter, dataSet, queryEngineConfig, params) {
26037
+ return {
26038
+ type: Clause.AND_WHERE,
26039
+ value: [].concat(filter.value).map(function (value) {
26040
+ return buildWhereFromSingleFilter(dataSet, _extends({}, filter, {
26041
+ value: value
26042
+ }), queryEngineConfig, params);
26043
+ })
26044
+ };
26045
+ };
26046
+
25903
26047
  var addMeasure = function addMeasure(current, toAdd) {
25904
26048
  return [[].concat(current, [toAdd]), current.length];
25905
26049
  };
25906
- var buildFromQueryAttributes = function buildFromQueryAttributes(dataSet, measureAttr, filterAttr, orderAttr, dimensionAttr, timeDimensionAttr, limitAttr, offsetAttr, queryEngineConfig, params) {
26050
+ var buildFromQueryAttributes = function buildFromQueryAttributes(dataSet, measureAttr, orderAttr, dimensionAttr, timeDimensionAttr, limitAttr, offsetAttr, queryEngineConfig, params, prebuiltFilters) {
25907
26051
  var measureDescription = [];
25908
26052
  var measure = [];
25909
26053
  var group = [];
25910
26054
  var order = [];
25911
- var filters = filterAttributeToQueryFilter(filterAttr, queryEngineConfig, dataSet, params);
26055
+ var filters = buildFilters(dataSet, queryEngineConfig, params, prebuiltFilters);
25912
26056
  if (timeDimensionAttr) {
25913
26057
  // Add the measure for the time field.
25914
26058
  var addedAt = undefined;
@@ -25966,19 +26110,24 @@ var buildFromQueryAttributes = function buildFromQueryAttributes(dataSet, measur
25966
26110
  field: findField(dataSet, individualMeasure.field)
25967
26111
  }]);
25968
26112
  });
25969
- orderAttr.forEach(function (orderItem) {
26113
+ orderAttr.forEach(function (apiQueryOrderItem) {
25970
26114
  var index = measure.findIndex(function (individualMeasure) {
25971
26115
  if (individualMeasure.type == 'field') {
25972
- var sameFunction = individualMeasure["function"] == orderItem["function"];
25973
- var sameField = individualMeasure.value == orderItem.field;
26116
+ var sameFunction = individualMeasure["function"] == apiQueryOrderItem["function"];
26117
+ // const isTimeFunc = Object.keys(queryEngineConfig.supportedTimeTruncFunctions).includes(
26118
+ // individualMeasure.function
26119
+ // );
26120
+ var sameField = individualMeasure.value == apiQueryOrderItem.field;
25974
26121
  return sameField && sameFunction;
26122
+
26123
+ // return found;
25975
26124
  }
25976
26125
  return false;
25977
26126
  });
25978
26127
  if (index >= 0) {
25979
26128
  order = [].concat(order, [{
25980
26129
  index: index,
25981
- direction: orderItem.direction
26130
+ direction: apiQueryOrderItem.direction
25982
26131
  }]);
25983
26132
  }
25984
26133
  });
@@ -26003,6 +26152,7 @@ var buildFromQueryAttributes = function buildFromQueryAttributes(dataSet, measur
26003
26152
  dataSetId: dataSet.id,
26004
26153
  measure: measure,
26005
26154
  group: group,
26155
+ // TODO: Fix this type
26006
26156
  filter: filters,
26007
26157
  order: order,
26008
26158
  limit: limitAttr,
@@ -26011,6 +26161,19 @@ var buildFromQueryAttributes = function buildFromQueryAttributes(dataSet, measur
26011
26161
  measureDescription: measureDescription
26012
26162
  };
26013
26163
  };
26164
+ var buildFilters = function buildFilters(dataSet, queryEngineConfig, params, prebuiltFilters) {
26165
+ if (prebuiltFilters && prebuiltFilters.length > 0) {
26166
+ var filter = [];
26167
+ prebuiltFilters.forEach(function (andFilters) {
26168
+ var newAndFilters = filterAttributeToQueryFilter([andFilters], queryEngineConfig, dataSet, params);
26169
+ filter = [].concat(filter, [newAndFilters[0]]);
26170
+ });
26171
+ return filter;
26172
+ }
26173
+ var whereClause = filterConfigToWhere(dataSet, queryEngineConfig, params);
26174
+ if (whereClause) return whereClause;
26175
+ return [];
26176
+ };
26014
26177
 
26015
26178
  var build$c = buildFromQueryAttributes;
26016
26179
  var hasDimensions = function hasDimensions(query) {
@@ -26038,10 +26201,7 @@ var buildUniqueArrayValuesPreparedQuery = function buildUniqueArrayValuesPrepare
26038
26201
  preparedQueryType: 'uniqueArrayValues',
26039
26202
  dataSetId: dataSetId,
26040
26203
  fieldId: dataSetField.id,
26041
- filter: optionsFilters || {
26042
- type: 'andWhere',
26043
- value: []
26044
- }
26204
+ filter: optionsFilters || []
26045
26205
  },
26046
26206
  resultFields: [{
26047
26207
  id: dataSetField.id,
@@ -26088,16 +26248,9 @@ var watchDataSetFieldChanges = function watchDataSetFieldChanges(dataSet, querya
26088
26248
  // Custom fields are the only ones that can have their definition changed. So
26089
26249
  // we only need to watch them.
26090
26250
  var watchedCustomFields = watchFields.flatMap(function (fieldId) {
26091
- try {
26092
- var dataSetField = findField(dataSet, fieldId);
26093
- if (isCustomField(dataSetField)) return [dataSetField];
26094
- return [];
26095
- } catch (err) {
26096
- if (err instanceof FieldNotFoundInDataSet) {
26097
- return [];
26098
- }
26099
- throw err;
26100
- }
26251
+ var dataSetField = findField(dataSet, fieldId);
26252
+ if (isCustomField(dataSetField)) return [dataSetField];
26253
+ return [];
26101
26254
  });
26102
26255
  return JSON.stringify(watchedCustomFields);
26103
26256
  } else {
@@ -26257,70 +26410,78 @@ var useVariablesInDataSet = function useVariablesInDataSet(dataSet, queryable, v
26257
26410
  // How to make sure the queries run when a field in a data set has been changed.
26258
26411
  // need to pass in the data sets here
26259
26412
 
26260
- var useQueryEffect = function useQueryEffect(queries, runQueriesCallback, filterConfig, dataSet, componentType, variables) {
26261
- var _useState = useState([]),
26262
- results = _useState[0],
26263
- setResults = _useState[1];
26264
- var _useState2 = useState(false),
26265
- queriesAreChanging = _useState2[0],
26266
- setQueriesAreChanging = _useState2[1];
26413
+ var useQueryEffect = function useQueryEffect(queries, runQueriesCallback, onResultsCallback, filterConfig, dataSet, componentType, variables) {
26414
+ var _useState = useState(false),
26415
+ queriesAreChanging = _useState[0],
26416
+ setQueriesAreChanging = _useState[1];
26267
26417
  var _useVariablesInDataSe = useVariablesInDataSet(dataSet, queries, variables),
26268
26418
  noOfVariableChanges = _useVariablesInDataSe.noOfVariableChanges;
26269
- var watchCustomFieldChangesKey = watchDataSetFieldChanges(dataSet, queries);
26270
- useEffect(function () {
26271
- var abortController = new AbortController();
26272
- var fetch$1 = /*#__PURE__*/function () {
26273
- var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
26274
- var hasResults;
26275
- return _regeneratorRuntime().wrap(function _callee$(_context) {
26276
- while (1) switch (_context.prev = _context.next) {
26277
- case 0:
26278
- setQueriesAreChanging(true);
26279
- _context.next = 3;
26280
- return fetch(queries, runQueriesCallback, abortController.signal, filterConfig);
26281
- case 3:
26282
- hasResults = _context.sent;
26283
- if (hasResults) {
26284
- setQueriesAreChanging(false);
26285
- if (!abortController.signal.aborted) {
26286
- // Only set the results if the signal was not aborted...
26287
- setResults(hasResults);
26288
- }
26289
- } else {
26290
- if (Array.isArray(queries)) {
26291
- setResults(queries.map(function (_q) {
26292
- return null;
26293
- }));
26419
+ try {
26420
+ var watchCustomFieldChangesKey = watchDataSetFieldChanges(dataSet, queries);
26421
+ useEffect(function () {
26422
+ var abortController = new AbortController();
26423
+ var fetch$1 = /*#__PURE__*/function () {
26424
+ var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
26425
+ var hasResults;
26426
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
26427
+ while (1) switch (_context.prev = _context.next) {
26428
+ case 0:
26429
+ setQueriesAreChanging(true);
26430
+ _context.next = 3;
26431
+ return fetch(queries, runQueriesCallback, abortController.signal, filterConfig);
26432
+ case 3:
26433
+ hasResults = _context.sent;
26434
+ if (hasResults) {
26435
+ setQueriesAreChanging(false);
26436
+ if (!abortController.signal.aborted) {
26437
+ // Only set the results if the signal was not aborted...
26438
+ onResultsCallback(hasResults);
26439
+ }
26294
26440
  } else {
26295
- setResults([null]);
26441
+ if (Array.isArray(queries)) {
26442
+ onResultsCallback(queries.map(function (_q) {
26443
+ return null;
26444
+ }));
26445
+ } else {
26446
+ onResultsCallback([null]);
26447
+ }
26296
26448
  }
26297
- }
26298
- case 5:
26299
- case "end":
26300
- return _context.stop();
26301
- }
26302
- }, _callee);
26303
- }));
26304
- return function fetch() {
26305
- return _ref.apply(this, arguments);
26449
+ case 5:
26450
+ case "end":
26451
+ return _context.stop();
26452
+ }
26453
+ }, _callee);
26454
+ }));
26455
+ return function fetch() {
26456
+ return _ref.apply(this, arguments);
26457
+ };
26458
+ }();
26459
+ fetch$1();
26460
+ return function () {
26461
+ abortController.abort('useQueryEffect unmounted');
26306
26462
  };
26307
- }();
26308
- fetch$1();
26309
- return function () {
26310
- abortController.abort('useQueryEffect unmounted');
26463
+ }, [JSON.stringify({
26464
+ componentType: componentType,
26465
+ dataSetId: dataSet.id,
26466
+ queries: queries,
26467
+ filterConfig: filterConfig,
26468
+ watchCustomFieldChangesKey: watchCustomFieldChangesKey,
26469
+ noOfVariableChanges: noOfVariableChanges
26470
+ })]);
26471
+ return {
26472
+ queriesAreChanging: queriesAreChanging
26311
26473
  };
26312
- }, [JSON.stringify({
26313
- componentType: componentType,
26314
- dataSetId: dataSet.id,
26315
- queries: queries,
26316
- filterConfig: filterConfig,
26317
- watchCustomFieldChangesKey: watchCustomFieldChangesKey,
26318
- noOfVariableChanges: noOfVariableChanges
26319
- })]);
26320
- return {
26321
- results: results,
26322
- queriesAreChanging: queriesAreChanging
26323
- };
26474
+ } catch (err) {
26475
+ setQueriesAreChanging(false);
26476
+ if (err instanceof FieldNotFoundInDataSet) {
26477
+ return {
26478
+ queriesAreChanging: false
26479
+ };
26480
+ }
26481
+
26482
+ // Re-throw
26483
+ throw err;
26484
+ }
26324
26485
  };
26325
26486
 
26326
26487
  /** Fetches unique field values for a given field. */
@@ -26329,6 +26490,9 @@ var useUniqueFieldValues = function useUniqueFieldValues(dataSet, fieldId) {
26329
26490
  runQueriesCallback = _useDashboardContext.runQueriesCallback;
26330
26491
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
26331
26492
  variables = _useDashboardBehaviou.variables;
26493
+ var _useState = useState(undefined),
26494
+ result = _useState[0],
26495
+ setResult = _useState[1];
26332
26496
  var queries = [];
26333
26497
  var dataSetField = findField(dataSet, fieldId);
26334
26498
  if (dataSetField.dataType == 'string[]') {
@@ -26340,9 +26504,10 @@ var useUniqueFieldValues = function useUniqueFieldValues(dataSet, fieldId) {
26340
26504
  var filterQuery = buildFilterQuery(dataSet, fieldId);
26341
26505
  queries = [filterQuery];
26342
26506
  }
26343
- var _useQueryEffect = useQueryEffect(queries, runQueriesCallback, {}, dataSet, undefined, variables),
26344
- _useQueryEffect$resul = _useQueryEffect.results,
26345
- result = _useQueryEffect$resul[0];
26507
+ useQueryEffect(queries, runQueriesCallback, function (results) {
26508
+ if (results === null) setResult(null);
26509
+ if (results) setResult(results[0]);
26510
+ }, {}, dataSet, undefined, variables);
26346
26511
  return {
26347
26512
  result: result != null ? result : null,
26348
26513
  loading: result === undefined,
@@ -26764,7 +26929,7 @@ var useEditor = function useEditor() {
26764
26929
  /* Infinite re-render loop
26765
26930
  - When chaning dataset
26766
26931
  - If not using default metric / grouping
26767
- - Only when switching to 'Stock data' not to another dataset
26932
+ - Only when switching to 'Stock data' not to another dataset
26768
26933
  */
26769
26934
 
26770
26935
  dispatch({
@@ -26781,6 +26946,12 @@ var useEditor = function useEditor() {
26781
26946
  return _ref2.apply(this, arguments);
26782
26947
  };
26783
26948
  }();
26949
+ var setResults = function setResults(results) {
26950
+ dispatch({
26951
+ type: 'setResultsForComponentInEditor',
26952
+ results: results
26953
+ });
26954
+ };
26784
26955
  var setDataSets = function setDataSets(dataSets) {
26785
26956
  dispatch({
26786
26957
  type: 'setDataSets',
@@ -26852,6 +27023,7 @@ var useEditor = function useEditor() {
26852
27023
  numberFormatOptions: numberFormatOptions,
26853
27024
  setAttributes: setAttributes,
26854
27025
  setPartialAttributes: setPartialAttributes,
27026
+ setResults: setResults,
26855
27027
  mode: mode,
26856
27028
  origin: origin,
26857
27029
  componentEditor: componentEditor,
@@ -33242,28 +33414,26 @@ var Legend = function Legend(props) {
33242
33414
  });
33243
33415
  };
33244
33416
 
33245
- var useXAxisLabelCount = function useXAxisLabelCount(override, forceXAxisAsTime, horizontal) {
33417
+ var useXAxisLabelCount = function useXAxisLabelCount(override, forceXAxisAsTime) {
33246
33418
  var ref = useRef(null);
33247
33419
  var _useState = useState(0),
33248
- size = _useState[0],
33249
- setSize = _useState[1];
33420
+ width = _useState[0],
33421
+ setWidth = _useState[1];
33250
33422
  useEffect(function () {
33251
33423
  var handleResize = throttle(function () {
33252
- if (!ref.current) return;
33253
- var measurement = horizontal ? ref.current.clientHeight : ref.current.clientWidth;
33254
- setSize(measurement);
33424
+ setWidth(ref.current ? ref.current.clientWidth : 0);
33255
33425
  }, 100);
33256
33426
  handleResize();
33257
- window.addEventListener('resize', handleResize);
33427
+ window.addEventListener('resize', function () {
33428
+ return handleResize;
33429
+ });
33258
33430
  return function () {
33259
33431
  window.removeEventListener('resize', handleResize);
33260
- handleResize.cancel();
33261
33432
  };
33262
33433
  });
33263
- if (override !== 'auto') return [ref, override];
33264
- var approximateTickCount = Math.min(size < 1000 ? parseInt(("" + size)[0]) : 12, 12);
33265
- var multiplier = horizontal || forceXAxisAsTime ? 4 : 1;
33266
- return [ref, approximateTickCount * multiplier];
33434
+ var approximateXTickCount = Math.min(width < 1000 ? parseInt(("" + width)[0]) : 12, 12);
33435
+ if (override != 'auto') return [ref, override];
33436
+ return [ref, approximateXTickCount * (forceXAxisAsTime ? 4 : 1)];
33267
33437
  };
33268
33438
 
33269
33439
  var buildTooltipStyles = function buildTooltipStyles(_ref) {
@@ -34005,7 +34175,7 @@ var VizzlyXYChart = function VizzlyXYChart(props) {
34005
34175
  scaleToFit: 'shrink-only'
34006
34176
  };
34007
34177
  };
34008
- var _useXAxisLabelCount = useXAxisLabelCount(approxXAxisLabelCount, props == null ? void 0 : props.forceXAxisAsTime, props == null ? void 0 : props.horizontal),
34178
+ var _useXAxisLabelCount = useXAxisLabelCount(approxXAxisLabelCount, !(props != null && props.horizontal) && (props == null ? void 0 : props.forceXAxisAsTime)),
34009
34179
  widthRef = _useXAxisLabelCount[0],
34010
34180
  approximateXTickCount = _useXAxisLabelCount[1];
34011
34181
  var _useState = useState(undefined),
@@ -35247,6 +35417,9 @@ var HeadlineStats = function HeadlineStats(props) {
35247
35417
  var _props$component$attr, _props$component$attr2, _attributes$viewId, _props$dashboardBehav;
35248
35418
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
35249
35419
  queryEngineConfig = _useDashboardBehaviou.queryEngineConfig;
35420
+ var _useState = useState([]),
35421
+ results = _useState[0],
35422
+ setResults = _useState[1];
35250
35423
  var comparisonEnabled = Object.keys(props.component.attributes.timeDimension || {}).length !== 0 && ((_props$component$attr = props.component.attributes.headline) == null ? void 0 : _props$component$attr.func) === 'current';
35251
35424
  var deltaTimeDimension = function () {
35252
35425
  if (!comparisonEnabled) return null;
@@ -35268,12 +35441,11 @@ var HeadlineStats = function HeadlineStats(props) {
35268
35441
  measure: measure,
35269
35442
  filter: props.component.attributes.filter
35270
35443
  });
35271
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
35444
+ var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, setResults, {
35272
35445
  localFilters: props.component.localFilters,
35273
35446
  globalFilters: props.globalFilters
35274
35447
  }, props.dataSet, undefined, props.dashboardBehaviour.variables),
35275
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
35276
- results = _useQueryEffect.results;
35448
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
35277
35449
  return jsx(View, {
35278
35450
  minHeight: comparisonEnabled ? 80 : 56,
35279
35451
  children: jsx(SingleStatView, _extends({}, attributes, {
@@ -35561,14 +35733,17 @@ var AreaChart$4 = function AreaChart(props) {
35561
35733
  onDrilldown = _useState[0],
35562
35734
  setOnDrilldown = _useState[1];
35563
35735
  var _props$component = props.component,
35736
+ results = _props$component.results,
35564
35737
  attributes = _props$component.attributes,
35565
35738
  localFilters = _props$component.localFilters;
35566
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
35739
+ var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, props.setResults, {
35567
35740
  localFilters: props.component.localFilters,
35568
35741
  globalFilters: props.globalFilters
35569
35742
  }, props.dataSet, undefined, props.dashboardBehaviour.variables),
35570
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
35571
- results = _useQueryEffect.results;
35743
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
35744
+ var componentInterface = getComponentInterface(props.component.attributes.type, {
35745
+ queryEngineConfig: props.dashboardBehaviour.queryEngineConfig
35746
+ });
35572
35747
  return jsxs(Fragment, {
35573
35748
  children: [jsx(memoized, _extends({
35574
35749
  id: props.id
@@ -36801,18 +36976,16 @@ var usePreAggregatedDataSet = function usePreAggregatedDataSet(dataSet, attribut
36801
36976
  })]);
36802
36977
  };
36803
36978
 
36804
- var useComponentEffect = function useComponentEffect(attributes, dataSet, queryEngineConfig, filterConfig, updateComponentAttributes, runQueriesCallback, variables) {
36979
+ var useComponentEffect = function useComponentEffect(attributes, dataSet, queryEngineConfig, filterConfig, updateComponentAttributes, runQueriesCallback, setResults, variables) {
36805
36980
  var queryable = attributes;
36806
36981
  if (dataSet.preAggregated) {
36807
36982
  queryable = [buildViewOnlyQuery(dataSet)];
36808
36983
  }
36809
36984
  usePreAggregatedDataSet(dataSet, attributes, queryEngineConfig, updateComponentAttributes);
36810
- var _useQueryEffect = useQueryEffect(queryable, runQueriesCallback, filterConfig, dataSet, attributes.type, variables),
36811
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
36812
- results = _useQueryEffect.results;
36985
+ var _useQueryEffect = useQueryEffect(queryable, runQueriesCallback, setResults, filterConfig, dataSet, attributes.type, variables),
36986
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
36813
36987
  return {
36814
- queriesAreChanging: queriesAreChanging,
36815
- results: results
36988
+ queriesAreChanging: queriesAreChanging
36816
36989
  };
36817
36990
  };
36818
36991
 
@@ -36864,7 +37037,9 @@ function useDrilldownSelection(results, attributes, setAttributes, dataSet, quer
36864
37037
 
36865
37038
  var BarChart$4 = function BarChart(props) {
36866
37039
  var _props$dashboardBehav;
36867
- var localFilters = props.component.localFilters;
37040
+ var _props$component = props.component,
37041
+ localFilters = _props$component.localFilters,
37042
+ results = _props$component.results;
36868
37043
  var dashboardBehaviour = props.dashboardBehaviour;
36869
37044
  var _useState = useState(props.component.attributes),
36870
37045
  attributes = _useState[0],
@@ -36875,18 +37050,17 @@ var BarChart$4 = function BarChart(props) {
36875
37050
  setDrilldownSelections([]);
36876
37051
  }
36877
37052
  }, [JSON.stringify(props.component.attributes)]);
36878
- var _useComponentEffect = useComponentEffect(attributes, props.dataSet, props.dashboardBehaviour.queryEngineConfig, {
36879
- localFilters: localFilters,
36880
- globalFilters: props.globalFilters
36881
- }, props.updateComponentAttributes, props.runQueriesCallback, props.dashboardBehaviour.variables),
36882
- queriesAreChanging = _useComponentEffect.queriesAreChanging,
36883
- results = _useComponentEffect.results;
36884
37053
  var _useDrilldownSelectio = useDrilldownSelection(results, attributes, function (newAttributes) {
36885
37054
  return setAttributes(newAttributes);
36886
37055
  }, props.dataSet, dashboardBehaviour.queryEngineConfig),
36887
37056
  onDrilldownChange = _useDrilldownSelectio.onDrilldownChange,
36888
37057
  setDrilldownSelections = _useDrilldownSelectio.setDrilldownSelections,
36889
37058
  drilldownSelections = _useDrilldownSelectio.drilldownSelections;
37059
+ var _useComponentEffect = useComponentEffect(drilldownSelections.length > 0 ? attributes : props.component.attributes, props.dataSet, props.dashboardBehaviour.queryEngineConfig, {
37060
+ localFilters: localFilters,
37061
+ globalFilters: props.globalFilters
37062
+ }, props.updateComponentAttributes, props.runQueriesCallback, props.setResults, props.dashboardBehaviour.variables),
37063
+ queriesAreChanging = _useComponentEffect.queriesAreChanging;
36890
37064
  var runViewClickQuery = /*#__PURE__*/function () {
36891
37065
  var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(queries, existingField) {
36892
37066
  var filter, attributes, abortController, queryResults;
@@ -37193,14 +37367,14 @@ var LineChart$4 = function LineChart(props) {
37193
37367
  onDrilldown = _useState[0],
37194
37368
  setOnDrilldown = _useState[1];
37195
37369
  var _props$component = props.component,
37370
+ results = _props$component.results,
37196
37371
  attributes = _props$component.attributes,
37197
37372
  localFilters = _props$component.localFilters;
37198
37373
  var _useComponentEffect = useComponentEffect(attributes, props.dataSet, props.dashboardBehaviour.queryEngineConfig, {
37199
37374
  localFilters: localFilters,
37200
37375
  globalFilters: props.globalFilters
37201
- }, props.updateComponentAttributes, props.runQueriesCallback, props.dashboardBehaviour.variables),
37202
- queriesAreChanging = _useComponentEffect.queriesAreChanging,
37203
- results = _useComponentEffect.results;
37376
+ }, props.updateComponentAttributes, props.runQueriesCallback, props.setResults, props.dashboardBehaviour.variables),
37377
+ queriesAreChanging = _useComponentEffect.queriesAreChanging;
37204
37378
  return jsxs(Fragment, {
37205
37379
  children: [jsx(memoized$1, _extends({
37206
37380
  id: props.id
@@ -37414,14 +37588,14 @@ var memoized$2 = /*#__PURE__*/memo(ScatterChartView, shouldUpdate);
37414
37588
  var ScatterChart$3 = function ScatterChart(props) {
37415
37589
  var _props$dashboardBehav;
37416
37590
  var _props$component = props.component,
37591
+ results = _props$component.results,
37417
37592
  attributes = _props$component.attributes,
37418
37593
  localFilters = _props$component.localFilters;
37419
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
37594
+ var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, props.setResults, {
37420
37595
  localFilters: localFilters,
37421
37596
  globalFilters: props.globalFilters
37422
37597
  }, props.dataSet, undefined, props.dashboardBehaviour.variables),
37423
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
37424
- results = _useQueryEffect.results;
37598
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
37425
37599
  return jsx(memoized$2, _extends({
37426
37600
  id: props.id
37427
37601
  }, attributes, {
@@ -38797,7 +38971,9 @@ var memoized$3 = /*#__PURE__*/memo(PieChartView, shouldUpdate);
38797
38971
 
38798
38972
  var PieChart$3 = function PieChart(props) {
38799
38973
  var _props$dashboardBehav;
38800
- var localFilters = props.component.localFilters;
38974
+ var _props$component = props.component,
38975
+ results = _props$component.results,
38976
+ localFilters = _props$component.localFilters;
38801
38977
  var dashboardBehaviour = props.dashboardBehaviour;
38802
38978
  var _useState = useState(props.component.attributes),
38803
38979
  attributes = _useState[0],
@@ -38808,18 +38984,17 @@ var PieChart$3 = function PieChart(props) {
38808
38984
  setDrilldownSelections([]);
38809
38985
  }
38810
38986
  }, [JSON.stringify(props.component.attributes)]);
38811
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
38812
- localFilters: localFilters,
38813
- globalFilters: props.globalFilters
38814
- }, props.dataSet, undefined, props.dashboardBehaviour.variables),
38815
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
38816
- results = _useQueryEffect.results;
38817
38987
  var _useDrilldownSelectio = useDrilldownSelection(results, attributes, function (newAttributes) {
38818
38988
  return setAttributes(newAttributes);
38819
38989
  }, props.dataSet, dashboardBehaviour.queryEngineConfig),
38820
38990
  onDrilldownChange = _useDrilldownSelectio.onDrilldownChange,
38821
38991
  setDrilldownSelections = _useDrilldownSelectio.setDrilldownSelections,
38822
38992
  drilldownSelections = _useDrilldownSelectio.drilldownSelections;
38993
+ var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, props.setResults, {
38994
+ localFilters: localFilters,
38995
+ globalFilters: props.globalFilters
38996
+ }, props.dataSet, undefined, props.dashboardBehaviour.variables),
38997
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
38823
38998
  var runViewClickQuery = /*#__PURE__*/function () {
38824
38999
  var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(queries, existingField) {
38825
39000
  var filter, attributes, abortController, queryResults;
@@ -42949,14 +43124,14 @@ var memoized$4 = /*#__PURE__*/memo(BubbleChartView, shouldUpdate);
42949
43124
  var BubbleChart$3 = function BubbleChart(props) {
42950
43125
  var _props$dashboardBehav;
42951
43126
  var _props$component = props.component,
43127
+ results = _props$component.results,
42952
43128
  attributes = _props$component.attributes,
42953
43129
  localFilters = _props$component.localFilters;
42954
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
43130
+ var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, props.setResults, {
42955
43131
  localFilters: localFilters,
42956
43132
  globalFilters: props.globalFilters
42957
43133
  }, props.dataSet, undefined, props.dashboardBehaviour.variables),
42958
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
42959
- results = _useQueryEffect.results;
43134
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
42960
43135
  return jsx(memoized$4, _extends({
42961
43136
  id: props.id
42962
43137
  }, attributes, {
@@ -43319,9 +43494,7 @@ var Tooltip$1 = function Tooltip(_ref) {
43319
43494
  xKey = _ref.xKey,
43320
43495
  yKeys = _ref.yKeys,
43321
43496
  theme = _ref.theme,
43322
- items = _ref.items,
43323
- _ref$shouldShowColorL = _ref.shouldShowColorLegend,
43324
- shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
43497
+ items = _ref.items;
43325
43498
  var tooltipRef = useRef(null);
43326
43499
  var _useState = useState({
43327
43500
  left: tooltipLeft
@@ -43370,7 +43543,7 @@ var Tooltip$1 = function Tooltip(_ref) {
43370
43543
  fontSize: '15px',
43371
43544
  width: '100%',
43372
43545
  minWidth: MIN_TOOLTIP_WIDTH
43373
- }, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA6FqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {tooltipData[legendItem.yKey].formattedValue\n                              ? tooltipData[legendItem.yKey].formattedValue\n                              : tooltipData[legendItem.yKey].value}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */"),
43546
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJGcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEJ1YmJsZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQnViYmxlQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuXG5jb25zdCBNSU5fVE9PTFRJUF9XSURUSCA9IDE4MDtcbmNvbnN0IFRPT0xUSVBfT0ZGU0VUID0gMjA7XG5jb25zdCBTQ1JPTExCQVJfV0lEVEggPSA0MDtcblxuaW50ZXJmYWNlIFRvb2x0aXBQcm9wczxUPiB7XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIHNob3dSb3VuZGVkVG90YWw6IGJvb2xlYW47XG4gIHRvb2x0aXBEYXRhOiB7XG4gICAgW2tleUlkOiBzdHJpbmddOiBEYXRhSXRlbTtcbiAgfTtcbiAgdG9vbHRpcExlZnQ6IG51bWJlcjtcbiAgdG9vbHRpcFRvcDogbnVtYmVyO1xuICB4S2V5OiBzdHJpbmc7XG4gIHlLZXlzPzogc3RyaW5nW107XG4gIGl0ZW1zOiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xuICAgIHZpc2libGVZS2V5czogc3RyaW5nW107XG4gIH1bXTtcbiAgdGhlbWU6IENTU1Byb3BlcnRpZXM7XG59XG5cbmV4cG9ydCBjb25zdCBUb29sdGlwID0gKHtcbiAga2V5cyxcbiAgc2hvd1JvdW5kZWRUb3RhbCxcbiAgdG9vbHRpcERhdGEsXG4gIHRvb2x0aXBMZWZ0LFxuICB0b29sdGlwVG9wLFxuICB4S2V5LFxuICB5S2V5cyxcbiAgdGhlbWUsXG4gIGl0ZW1zLFxufTogVG9vbHRpcFByb3BzPExpbmVTdHlsZXMgfCBCYXJTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPikgPT4ge1xuICBjb25zdCB0b29sdGlwUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcbiAgY29uc3QgW3Bvc2l0aW9uLCBzZXRQb3NpdGlvbl0gPSB1c2VTdGF0ZTx7IGxlZnQ6IG51bWJlciB9Pih7XG4gICAgbGVmdDogdG9vbHRpcExlZnQsXG4gIH0pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgYWRqdXN0VG9vbHRpcFBvc2l0aW9uID0gKCkgPT4ge1xuICAgICAgY29uc3QgdG9vbHRpcEVsZW1lbnQgPSB0b29sdGlwUmVmLmN1cnJlbnQ7XG5cbiAgICAgIGlmICh0b29sdGlwRWxlbWVudCkge1xuICAgICAgICBjb25zdCBzY3JlZW5XaWR0aCA9IHdpbmRvdy5pbm5lcldpZHRoO1xuXG4gICAgICAgIGNvbnN0IHJlY3QgPSB0b29sdGlwRWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcblxuICAgICAgICBsZXQgd2lkdGggPSByZWN0LndpZHRoO1xuXG4gICAgICAgIGlmICh3aWR0aCA8IE1JTl9UT09MVElQX1dJRFRIKSB7XG4gICAgICAgICAgd2lkdGggPSBNSU5fVE9PTFRJUF9XSURUSDtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBsZWZ0ID0gdG9vbHRpcExlZnQgKyBUT09MVElQX09GRlNFVDtcblxuICAgICAgICBpZiAodG9vbHRpcExlZnQgKyB3aWR0aCA+IHNjcmVlbldpZHRoIC0gU0NST0xMQkFSX1dJRFRIKSB7XG4gICAgICAgICAgbGVmdCA9IHRvb2x0aXBMZWZ0IC0gd2lkdGggLSBUT09MVElQX09GRlNFVDtcbiAgICAgICAgfVxuXG4gICAgICAgIHNldFBvc2l0aW9uKHsgbGVmdCB9KTtcbiAgICAgIH1cbiAgICB9O1xuXG4gICAgYWRqdXN0VG9vbHRpcFBvc2l0aW9uKCk7XG4gIH0sIFt0b29sdGlwTGVmdF0pO1xuXG4gIHJldHVybiBjcmVhdGVQb3J0YWwoXG4gICAgPGRpdlxuICAgICAgcmVmPXt0b29sdGlwUmVmfVxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICAgIGxlZnQ6IHBvc2l0aW9uLmxlZnQsXG4gICAgICAgIHRvcDogdG9vbHRpcFRvcCxcbiAgICAgICAgekluZGV4OiAyMTQ3NDgzNjQ3ICogMTAsXG4gICAgICAgIC4uLnRoZW1lLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7IHdvcmRCcmVhazogJ2JyZWFrLWFsbCcgfX0+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBsaW5lSGVpZ2h0OiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBsZXR0ZXJTcGFjaW5nOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBmb250V2VpZ2h0OiAnYm9sZCcsXG4gICAgICAgICAgICBmb250U2l6ZTogJzE1cHgnLFxuICAgICAgICAgICAgd2lkdGg6ICcxMDAlJyxcbiAgICAgICAgICAgIG1pbldpZHRoOiBNSU5fVE9PTFRJUF9XSURUSCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIHt0b29sdGlwRGF0YVt4S2V5XT8uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIHlLZXlzICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */"),
43374
43547
  children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
43375
43548
  }), jsx("table", {
43376
43549
  cellPadding: 0,
@@ -43381,7 +43554,7 @@ var Tooltip$1 = function Tooltip(_ref) {
43381
43554
  } : {
43382
43555
  name: "9a1sa-Tooltip",
43383
43556
  styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
43384
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA4GqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {tooltipData[legendItem.yKey].formattedValue\n                              ? tooltipData[legendItem.yKey].formattedValue\n                              : tooltipData[legendItem.yKey].value}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */",
43557
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBHcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEJ1YmJsZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQnViYmxlQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuXG5jb25zdCBNSU5fVE9PTFRJUF9XSURUSCA9IDE4MDtcbmNvbnN0IFRPT0xUSVBfT0ZGU0VUID0gMjA7XG5jb25zdCBTQ1JPTExCQVJfV0lEVEggPSA0MDtcblxuaW50ZXJmYWNlIFRvb2x0aXBQcm9wczxUPiB7XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIHNob3dSb3VuZGVkVG90YWw6IGJvb2xlYW47XG4gIHRvb2x0aXBEYXRhOiB7XG4gICAgW2tleUlkOiBzdHJpbmddOiBEYXRhSXRlbTtcbiAgfTtcbiAgdG9vbHRpcExlZnQ6IG51bWJlcjtcbiAgdG9vbHRpcFRvcDogbnVtYmVyO1xuICB4S2V5OiBzdHJpbmc7XG4gIHlLZXlzPzogc3RyaW5nW107XG4gIGl0ZW1zOiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xuICAgIHZpc2libGVZS2V5czogc3RyaW5nW107XG4gIH1bXTtcbiAgdGhlbWU6IENTU1Byb3BlcnRpZXM7XG59XG5cbmV4cG9ydCBjb25zdCBUb29sdGlwID0gKHtcbiAga2V5cyxcbiAgc2hvd1JvdW5kZWRUb3RhbCxcbiAgdG9vbHRpcERhdGEsXG4gIHRvb2x0aXBMZWZ0LFxuICB0b29sdGlwVG9wLFxuICB4S2V5LFxuICB5S2V5cyxcbiAgdGhlbWUsXG4gIGl0ZW1zLFxufTogVG9vbHRpcFByb3BzPExpbmVTdHlsZXMgfCBCYXJTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPikgPT4ge1xuICBjb25zdCB0b29sdGlwUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcbiAgY29uc3QgW3Bvc2l0aW9uLCBzZXRQb3NpdGlvbl0gPSB1c2VTdGF0ZTx7IGxlZnQ6IG51bWJlciB9Pih7XG4gICAgbGVmdDogdG9vbHRpcExlZnQsXG4gIH0pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgYWRqdXN0VG9vbHRpcFBvc2l0aW9uID0gKCkgPT4ge1xuICAgICAgY29uc3QgdG9vbHRpcEVsZW1lbnQgPSB0b29sdGlwUmVmLmN1cnJlbnQ7XG5cbiAgICAgIGlmICh0b29sdGlwRWxlbWVudCkge1xuICAgICAgICBjb25zdCBzY3JlZW5XaWR0aCA9IHdpbmRvdy5pbm5lcldpZHRoO1xuXG4gICAgICAgIGNvbnN0IHJlY3QgPSB0b29sdGlwRWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcblxuICAgICAgICBsZXQgd2lkdGggPSByZWN0LndpZHRoO1xuXG4gICAgICAgIGlmICh3aWR0aCA8IE1JTl9UT09MVElQX1dJRFRIKSB7XG4gICAgICAgICAgd2lkdGggPSBNSU5fVE9PTFRJUF9XSURUSDtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBsZWZ0ID0gdG9vbHRpcExlZnQgKyBUT09MVElQX09GRlNFVDtcblxuICAgICAgICBpZiAodG9vbHRpcExlZnQgKyB3aWR0aCA+IHNjcmVlbldpZHRoIC0gU0NST0xMQkFSX1dJRFRIKSB7XG4gICAgICAgICAgbGVmdCA9IHRvb2x0aXBMZWZ0IC0gd2lkdGggLSBUT09MVElQX09GRlNFVDtcbiAgICAgICAgfVxuXG4gICAgICAgIHNldFBvc2l0aW9uKHsgbGVmdCB9KTtcbiAgICAgIH1cbiAgICB9O1xuXG4gICAgYWRqdXN0VG9vbHRpcFBvc2l0aW9uKCk7XG4gIH0sIFt0b29sdGlwTGVmdF0pO1xuXG4gIHJldHVybiBjcmVhdGVQb3J0YWwoXG4gICAgPGRpdlxuICAgICAgcmVmPXt0b29sdGlwUmVmfVxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgICAgIGxlZnQ6IHBvc2l0aW9uLmxlZnQsXG4gICAgICAgIHRvcDogdG9vbHRpcFRvcCxcbiAgICAgICAgekluZGV4OiAyMTQ3NDgzNjQ3ICogMTAsXG4gICAgICAgIC4uLnRoZW1lLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2IHN0eWxlPXt7IHdvcmRCcmVhazogJ2JyZWFrLWFsbCcgfX0+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBsaW5lSGVpZ2h0OiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBsZXR0ZXJTcGFjaW5nOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBmb250V2VpZ2h0OiAnYm9sZCcsXG4gICAgICAgICAgICBmb250U2l6ZTogJzE1cHgnLFxuICAgICAgICAgICAgd2lkdGg6ICcxMDAlJyxcbiAgICAgICAgICAgIG1pbldpZHRoOiBNSU5fVE9PTFRJUF9XSURUSCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIHt0b29sdGlwRGF0YVt4S2V5XT8uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIHlLZXlzICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */",
43385
43558
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
43386
43559
  }),
43387
43560
  children: jsxs("tbody", {
@@ -43395,7 +43568,7 @@ var Tooltip$1 = function Tooltip(_ref) {
43395
43568
  return null;
43396
43569
  }
43397
43570
  return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxs("tr", {
43398
- children: [shouldShowColorLegend && jsx("td", {
43571
+ children: [jsx("td", {
43399
43572
  style: {
43400
43573
  verticalAlign: 'middle',
43401
43574
  padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
@@ -43423,7 +43596,7 @@ var Tooltip$1 = function Tooltip(_ref) {
43423
43596
  },
43424
43597
  children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
43425
43598
  })]
43426
- }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
43599
+ }, legendItem.yKey);
43427
43600
  })
43428
43601
  }, index);
43429
43602
  }), showRoundedTotal && yKeys && jsxs("tr", {
@@ -43608,64 +43781,33 @@ var Legend$1 = function Legend(_ref) {
43608
43781
  });
43609
43782
  };
43610
43783
 
43611
- var ASSUMED_AVERAGE_CHAR_WIDTH = 7.1;
43612
-
43784
+ var ASSUMED_AVERAGE_CHAR_WIDTH = 4;
43613
43785
  function calculateWordWidth(word, avgCharWidth) {
43614
43786
  return word.length * avgCharWidth;
43615
43787
  }
43616
- function getTicksIntervals(numElements) {
43617
- var divisors = [];
43618
- for (var i = 1; i <= Math.sqrt(numElements - 1); i++) {
43619
- if ((numElements - 1) % i !== 0) {
43620
- continue;
43621
- }
43622
- divisors.push(i);
43623
- var divisor = (numElements - 1) / i;
43624
- if (i === divisor) {
43625
- continue;
43626
- }
43627
- divisors.push(divisor);
43628
- }
43629
- divisors.sort(function (a, b) {
43630
- return b - a;
43631
- });
43632
- return divisors;
43633
- }
43634
- function isTickIntervalValid(interval, maxWidth, wordWidths) {
43635
- var totalWidth = 0;
43636
- for (var i = 0; i < wordWidths.length; i += interval) {
43637
- var spacing = i > 0 ? 12 : 0; // Add spacing only after the first tick
43638
- totalWidth += wordWidths[i] + spacing;
43639
- }
43640
- return totalWidth <= maxWidth;
43641
- }
43788
+
43789
+ /** Reduce width proportionally to simulate spacing / padding between ticks. */
43790
+ var widthWithSpacing = function widthWithSpacing(width) {
43791
+ var THIRTY_PERCENT = 0.3;
43792
+ return width - width * THIRTY_PERCENT;
43793
+ };
43642
43794
  function howManyTicksFitInWidth(ticks, maxWidth, avgCharWidth) {
43643
43795
  if (avgCharWidth === void 0) {
43644
43796
  avgCharWidth = ASSUMED_AVERAGE_CHAR_WIDTH;
43645
43797
  }
43646
- var ticksIntervals = getTicksIntervals(ticks.length);
43647
- var ticksWidths = ticks.map(function (tick) {
43648
- var _tick$formattedValue;
43649
- return calculateWordWidth((_tick$formattedValue = tick == null ? void 0 : tick.formattedValue) != null ? _tick$formattedValue : '', avgCharWidth);
43650
- });
43651
- var optimalInterval = ticksIntervals[ticksIntervals.length - 1]; // Default to showing only first and last marks if none fit
43652
- var left = 0;
43653
- var right = ticksIntervals.length - 1;
43654
-
43655
- // Binary search for the largest step that fits all elements
43656
- while (left <= right) {
43657
- var mid = Math.floor((left + right) / 2);
43658
- var step = ticksIntervals[mid];
43659
- if (isTickIntervalValid(step, maxWidth, ticksWidths)) {
43660
- optimalInterval = step; // Found a valid step, try to find a larger one
43661
- left = mid + 1;
43798
+ var fittedTicks = [];
43799
+ var currentWidth = 0;
43800
+ for (var _iterator = _createForOfIteratorHelperLoose(ticks), _step; !(_step = _iterator()).done;) {
43801
+ var tick = _step.value;
43802
+ var word = (tick == null ? void 0 : tick.formattedValue) || '';
43803
+ var wordWidth = calculateWordWidth(word, avgCharWidth);
43804
+ if (currentWidth + wordWidth <= widthWithSpacing(maxWidth)) {
43805
+ fittedTicks.push(tick);
43806
+ currentWidth += wordWidth + avgCharWidth; // Add space between words
43662
43807
  } else {
43663
- right = mid - 1;
43808
+ break; // Stop if adding the word exceeds maxWidth
43664
43809
  }
43665
43810
  }
43666
- var fittedTicks = ticks.filter(function (_, index) {
43667
- return index % optimalInterval === 0;
43668
- });
43669
43811
  return fittedTicks.length;
43670
43812
  }
43671
43813
  function determineYTicks(ticks, height) {
@@ -43702,14 +43844,16 @@ function pickEquallySpaced(arr, numPicks) {
43702
43844
  return result;
43703
43845
  }
43704
43846
  function adjustTicks(representation, width, height, xKeyField) {
43705
- var _representation$x$tic, _representation$y$tic;
43706
43847
  representation = cloneDeep(representation);
43707
43848
 
43708
43849
  // TODO; take this from the theme override...
43709
43850
  var averageCharacterWidth = ASSUMED_AVERAGE_CHAR_WIDTH;
43710
- var numberOfXTicksFittingIntoSpace = howManyTicksFitInWidth((_representation$x$tic = representation.x.ticks) != null ? _representation$x$tic : [], width, averageCharacterWidth);
43851
+ var numberOfXTicksFittingIntoSpace = howManyTicksFitInWidth(representation.x.ticks || [], width, averageCharacterWidth);
43852
+
43853
+ // @ts-ignore
43711
43854
  representation.x.ticks = getEvenlySpacedTicks(representation.x.ticks, numberOfXTicksFittingIntoSpace, xKeyField);
43712
- representation.y.ticks = determineYTicks((_representation$y$tic = representation.y.ticks) != null ? _representation$y$tic : [], height);
43855
+ // @ts-ignore
43856
+ representation.y.ticks = determineYTicks(representation.y.ticks || [], height);
43713
43857
  return representation;
43714
43858
  }
43715
43859
  function toNumeric(value) {
@@ -43742,9 +43886,9 @@ function getEvenlySpacedNumericTicks(sorted, count) {
43742
43886
  var _toNumeric3;
43743
43887
  var closest = sorted[0];
43744
43888
  var minDiff = Math.abs(((_toNumeric3 = toNumeric(sorted[0].scaleValue)) != null ? _toNumeric3 : 0) - target);
43745
- for (var _iterator = _createForOfIteratorHelperLoose(sorted), _step; !(_step = _iterator()).done;) {
43889
+ for (var _iterator2 = _createForOfIteratorHelperLoose(sorted), _step2; !(_step2 = _iterator2()).done;) {
43746
43890
  var _toNumeric4;
43747
- var tick = _step.value;
43891
+ var tick = _step2.value;
43748
43892
  var numericVal = (_toNumeric4 = toNumeric(tick.scaleValue)) != null ? _toNumeric4 : 0;
43749
43893
  var diff = Math.abs(numericVal - target);
43750
43894
  if (diff < minDiff) {
@@ -43766,9 +43910,16 @@ function getEvenlySpacedStringTicks(ticks, count) {
43766
43910
  return result;
43767
43911
  }
43768
43912
  function getEvenlySpacedTicks(ticks, count, xKeyField) {
43913
+ if (count === void 0) {
43914
+ count = 4;
43915
+ }
43769
43916
  if (ticks.length === 0) return [];
43770
43917
  if ((xKeyField == null ? void 0 : xKeyField.dataType) === 'number' || (xKeyField == null ? void 0 : xKeyField.dataType) === 'date_time') {
43771
- return getEvenlySpacedNumericTicks(ticks, count);
43918
+ var sorted = [].concat(ticks).sort(function (a, b) {
43919
+ var _toNumeric5, _toNumeric6;
43920
+ return ((_toNumeric5 = toNumeric(a.scaleValue)) != null ? _toNumeric5 : 0) - ((_toNumeric6 = toNumeric(b.scaleValue)) != null ? _toNumeric6 : 0);
43921
+ });
43922
+ return getEvenlySpacedNumericTicks(sorted, count);
43772
43923
  } else {
43773
43924
  return getEvenlySpacedStringTicks(ticks, count);
43774
43925
  }
@@ -44049,33 +44200,24 @@ var GridRows = function GridRows(_ref) {
44049
44200
  });
44050
44201
  };
44051
44202
 
44052
- var _excluded$g = ["children", "width", "height", "showLegend", "onMouseMove", "onMouseLeave"];
44053
44203
  function _EMOTION_STRINGIFIED_CSS_ERROR__$8() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
44054
- var ChartWrapper$1 = function ChartWrapper(_ref) {
44055
- var children = _ref.children,
44056
- width = _ref.width,
44057
- height = _ref.height,
44058
- showLegend = _ref.showLegend,
44059
- onMouseMove = _ref.onMouseMove,
44060
- onMouseLeave = _ref.onMouseLeave,
44061
- svgProps = _objectWithoutPropertiesLoose(_ref, _excluded$g);
44062
- return jsx("svg", _extends({
44063
- width: width,
44064
- height: height - (showLegend ? 40 : 0),
44065
- onMouseMove: onMouseMove,
44066
- onMouseLeave: onMouseLeave,
44204
+ var ChartWrapper$1 = function ChartWrapper(props) {
44205
+ return jsx("svg", {
44206
+ width: props.width,
44207
+ height: props.height - (props.showLegend ? 40 : 0),
44208
+ onMouseMove: props.onMouseMove,
44209
+ onMouseLeave: props.onMouseLeave,
44067
44210
  className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44068
44211
  name: "4zleql",
44069
44212
  styles: "display:block"
44070
44213
  } : {
44071
44214
  name: "fx4tbw-ChartWrapper",
44072
44215
  styles: "display:block;label:ChartWrapper;",
44073
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxudHlwZSBDaGFydFdyYXBwZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHNob3dMZWdlbmQ6IGJvb2xlYW47XG4gIG9uTW91c2VNb3ZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG4gIG9uTW91c2VMZWF2ZT86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyPFNWR1NWR0VsZW1lbnQ+O1xufSAmIFJlYWN0LlNWR1Byb3BzPFNWR1NWR0VsZW1lbnQ+O1xuXG5leHBvcnQgY29uc3QgQ2hhcnRXcmFwcGVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIHNob3dMZWdlbmQsXG4gIG9uTW91c2VNb3ZlLFxuICBvbk1vdXNlTGVhdmUsXG4gIC4uLnN2Z1Byb3BzXG59OiBDaGFydFdyYXBwZXJQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIGhlaWdodD17aGVpZ2h0IC0gKHNob3dMZWdlbmQgPyA0MCA6IDApfVxuICAgICAgb25Nb3VzZU1vdmU9e29uTW91c2VNb3ZlfVxuICAgICAgb25Nb3VzZUxlYXZlPXtvbk1vdXNlTGVhdmV9XG4gICAgICBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdibG9jaycgfSl9XG4gICAgICB7Li4uc3ZnUHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvc3ZnPlxuICApO1xufTtcbiJdfQ== */",
44216
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxuZXhwb3J0IGNvbnN0IENoYXJ0V3JhcHBlciA9IChwcm9wczoge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlO1xuICB3aWR0aDogbnVtYmVyO1xuICBoZWlnaHQ6IG51bWJlcjtcbiAgc2hvd0xlZ2VuZDogYm9vbGVhbjtcbiAgb25Nb3VzZU1vdmU/OiBSZWFjdC5Nb3VzZUV2ZW50SGFuZGxlcjxTVkdTVkdFbGVtZW50PjtcbiAgb25Nb3VzZUxlYXZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG59KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPHN2Z1xuICAgICAgd2lkdGg9e3Byb3BzLndpZHRofVxuICAgICAgaGVpZ2h0PXtwcm9wcy5oZWlnaHQgLSAocHJvcHMuc2hvd0xlZ2VuZCA/IDQwIDogMCl9XG4gICAgICBvbk1vdXNlTW92ZT17cHJvcHMub25Nb3VzZU1vdmV9XG4gICAgICBvbk1vdXNlTGVhdmU9e3Byb3BzLm9uTW91c2VMZWF2ZX1cbiAgICAgIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2Jsb2NrJyB9KX1cbiAgICA+XG4gICAgICB7cHJvcHMuY2hpbGRyZW59XG4gICAgPC9zdmc+XG4gICk7XG59O1xuIl19 */",
44074
44217
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
44075
- })
44076
- }, svgProps, {
44077
- children: children
44078
- }));
44218
+ }),
44219
+ children: props.children
44220
+ });
44079
44221
  };
44080
44222
 
44081
44223
  var CrosshairCircle = function CrosshairCircle(_ref) {
@@ -44140,7 +44282,7 @@ var Line = function Line(_ref) {
44140
44282
  });
44141
44283
  };
44142
44284
 
44143
- var _excluded$h = ["tooltipOpen"];
44285
+ var _excluded$g = ["tooltipOpen"];
44144
44286
  function useTooltip$1(initialTooltipState) {
44145
44287
  var _useState = useState(_extends({
44146
44288
  tooltipOpen: false
@@ -44149,7 +44291,7 @@ function useTooltip$1(initialTooltipState) {
44149
44291
  setTooltipState = _useState[1];
44150
44292
  var showTooltip = useCallback(function (showArgs) {
44151
44293
  return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
44152
- var show = _objectWithoutPropertiesLoose(_ref, _excluded$h);
44294
+ var show = _objectWithoutPropertiesLoose(_ref, _excluded$g);
44153
44295
  return _extends({}, showArgs(show), {
44154
44296
  tooltipOpen: true
44155
44297
  });
@@ -44481,7 +44623,58 @@ function Lines(_ref2) {
44481
44623
  });
44482
44624
  }
44483
44625
 
44484
- var BAR_RADIUS = 2;
44626
+ var PADDING = {
44627
+ paddingOuter: 0.05,
44628
+ paddingInner: 0.3
44629
+ };
44630
+
44631
+ function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
44632
+ return useMemo(function () {
44633
+ if (xScaleDataType === 'string') {
44634
+ return scaleBand(_extends({
44635
+ range: [0, innerWidth],
44636
+ domain: xScaleKey ? [].concat(data.map(function (d) {
44637
+ return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
44638
+ })) : []
44639
+ }, PADDING));
44640
+ }
44641
+ if (xScaleDataType === 'date_time' && xScaleKey) {
44642
+ return scaleBand(_extends({
44643
+ range: [0, innerWidth],
44644
+ domain: data.map(function (d) {
44645
+ return new Date(d[xScaleKey].value);
44646
+ })
44647
+ }, PADDING));
44648
+ }
44649
+ if (xScaleDataType === 'number' && xScaleKey) {
44650
+ return scaleBand(_extends({
44651
+ range: [0, innerWidth],
44652
+ domain: data.map(function (d) {
44653
+ return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
44654
+ })
44655
+ }, PADDING));
44656
+ }
44657
+ return null;
44658
+ }, [innerWidth, data]);
44659
+ }
44660
+
44661
+ var useBottomAxisBaseLineShift = function useBottomAxisBaseLineShift(_ref) {
44662
+ var showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
44663
+ hasBottomTitle = _ref.hasBottomTitle,
44664
+ hasLeftTitle = _ref.hasLeftTitle;
44665
+ if (!showDetailedSubGroupingLabels) {
44666
+ return {
44667
+ bottomAxisBaselineShift: 0,
44668
+ bottomOffset: 0,
44669
+ leftOffset: 0
44670
+ };
44671
+ }
44672
+ return {
44673
+ bottomAxisBaselineShift: hasBottomTitle ? -65 : -60,
44674
+ bottomOffset: hasBottomTitle ? -15 : 10,
44675
+ leftOffset: hasLeftTitle ? -10 : 0
44676
+ };
44677
+ };
44485
44678
 
44486
44679
  function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
44487
44680
  var _bars$find;
@@ -44507,6 +44700,73 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
44507
44700
  return fill;
44508
44701
  }
44509
44702
 
44703
+ var BAR_RADIUS = 2;
44704
+
44705
+ var BarStacked = function BarStacked(_ref) {
44706
+ var xScaleDataType = _ref.xScaleDataType,
44707
+ data = _ref.data,
44708
+ xScaleKey = _ref.xScaleKey,
44709
+ yScale = _ref.yScale,
44710
+ keys = _ref.keys,
44711
+ bars = _ref.bars,
44712
+ conditionalFormattingRules = _ref.conditionalFormattingRules,
44713
+ xScale = _ref.xScale,
44714
+ height = _ref.height,
44715
+ width = _ref.width;
44716
+ var handleGetXValue = function handleGetXValue(d) {
44717
+ var xValue = d[xScaleKey];
44718
+ if (xScaleDataType === 'string') return String(xValue);
44719
+ if (xScaleDataType === 'date_time') {
44720
+ return new Date(xValue);
44721
+ }
44722
+ if (xScaleDataType === 'number') {
44723
+ return Number(xValue);
44724
+ }
44725
+ return String(xValue);
44726
+ };
44727
+ return jsx(BarStack$1, {
44728
+ x: handleGetXValue,
44729
+ xScale: xScale,
44730
+ yScale: yScale,
44731
+ data: data,
44732
+ keys: keys,
44733
+ color: function color() {
44734
+ return '';
44735
+ },
44736
+ height: height,
44737
+ width: width,
44738
+ offset: "none",
44739
+ children: function children(barStacks) {
44740
+ return barStacks.map(function (barStack) {
44741
+ return barStack.bars.map(function (bar) {
44742
+ return jsx(Bar, {
44743
+ bar: bar,
44744
+ barStack: barStack,
44745
+ bars: bars,
44746
+ conditionalFormattingRules: conditionalFormattingRules
44747
+ }, bar.key.toString());
44748
+ });
44749
+ });
44750
+ }
44751
+ });
44752
+ };
44753
+ var Bar = function Bar(_ref2) {
44754
+ var bar = _ref2.bar,
44755
+ barStack = _ref2.barStack,
44756
+ bars = _ref2.bars,
44757
+ conditionalFormattingRules = _ref2.conditionalFormattingRules;
44758
+ var BAR_PADDING = 1.5;
44759
+ if (bar.height < 3) return null;
44760
+ return jsx("rect", {
44761
+ x: bar.x,
44762
+ y: bar.y,
44763
+ width: bar.width,
44764
+ height: bar.height - BAR_PADDING,
44765
+ fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
44766
+ rx: BAR_RADIUS
44767
+ }, "bar-stack-" + barStack.index + "-" + bar.index);
44768
+ };
44769
+
44510
44770
  function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
44511
44771
  function BarGroup(_ref) {
44512
44772
  var data = _ref.data,
@@ -44556,7 +44816,7 @@ function BarGroup(_ref) {
44556
44816
  return jsx(Group$2, {
44557
44817
  left: barGroup.x0,
44558
44818
  children: barGroup.bars.map(function (bar) {
44559
- return jsx(Bar, {
44819
+ return jsx(Bar$1, {
44560
44820
  bar: bar,
44561
44821
  barGroup: barGroup,
44562
44822
  bars: bars,
@@ -44574,7 +44834,7 @@ function BarGroup(_ref) {
44574
44834
  }
44575
44835
  });
44576
44836
  }
44577
- var Bar = function Bar(_ref2) {
44837
+ var Bar$1 = function Bar(_ref2) {
44578
44838
  var bar = _ref2.bar,
44579
44839
  barGroup = _ref2.barGroup,
44580
44840
  bars = _ref2.bars,
@@ -44588,7 +44848,6 @@ var Bar = function Bar(_ref2) {
44588
44848
  var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
44589
44849
  return jsxs(Fragment, {
44590
44850
  children: [showBar && jsx(BarRect, {
44591
- barRectKey: "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
44592
44851
  x: bar.x,
44593
44852
  y: bar.y,
44594
44853
  width: bar.width,
@@ -44598,7 +44857,7 @@ var Bar = function Bar(_ref2) {
44598
44857
  return _onClick(e, barGroup, bar);
44599
44858
  },
44600
44859
  enableHover: enableHover
44601
- }), jsx(BarLabel, {
44860
+ }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key)), jsx(BarLabel, {
44602
44861
  bar: bar,
44603
44862
  barGroup: barGroup,
44604
44863
  yLabelPosition: yLabelPosition,
@@ -44615,7 +44874,7 @@ var BarRect = function BarRect(_ref3) {
44615
44874
  y = _ref3.y,
44616
44875
  width = _ref3.width,
44617
44876
  height = _ref3.height,
44618
- barRectKey = _ref3.barRectKey,
44877
+ key = _ref3.key,
44619
44878
  enableHover = _ref3.enableHover;
44620
44879
  var _useState = useState(fill),
44621
44880
  fillColor = _useState[0],
@@ -44626,7 +44885,7 @@ var BarRect = function BarRect(_ref3) {
44626
44885
  } : {
44627
44886
  name: "1ltmijl-classes",
44628
44887
  styles: "cursor:pointer;label:classes;",
44629
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AA4KgC","file":"BarGroup.tsx","sourcesContent":["import { css } from '@emotion/css';\nimport { Group } from '@visx/group';\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';\nimport { Fragment, useState } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS';\nimport { getBarFill } from '../getBarFill';\n\nexport type BarGroupProps = {\n  data: ChartDataDefinition[];\n  keys: string[];\n  height: number;\n  xKey: string;\n  xScaleDataType: DataType;\n  xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n  innerXScale: ScaleBand<string> | undefined;\n  yScale: ScaleLinear<number, number, never>;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  bars: ShapeDefinition<BarStyles>[];\n  enableHover?: boolean;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nexport function BarGroup({\n  data,\n  keys,\n  height,\n  xKey,\n  xScaleDataType,\n  xScale,\n  innerXScale,\n  yScale,\n  onClick,\n  conditionalFormattingRules,\n  bars,\n  enableHover,\n  yAxisLabels,\n  yLabelPosition,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: BarGroupProps) {\n  const getGroupPosition = (d: DatumObject) => {\n    const xValue = d[xKey as keyof typeof d];\n\n    if (xScaleDataType === 'string') return String(xValue);\n\n    if (xScaleDataType === 'date_time') {\n      return new Date(String(xValue));\n    }\n\n    if (xScaleDataType === 'number') {\n      return Number(xValue);\n    }\n\n    return String(xValue);\n  };\n\n  return (\n    <VisxBarGroup<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      height={height}\n      x0={getGroupPosition}\n      // @ts-ignore\n      x0Scale={xScale}\n      // @ts-ignore\n      x1Scale={innerXScale}\n      yScale={yScale}\n      color={() => ''}\n    >\n      {(barGroups) => {\n        return barGroups.map((barGroup) => (\n          <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n            {barGroup.bars.map((bar) => (\n              <Bar\n                key={`bar-${bar.index}-${bar.x}`}\n                bar={bar}\n                barGroup={barGroup}\n                bars={bars}\n                conditionalFormattingRules={conditionalFormattingRules}\n                enableHover={enableHover}\n                labelStyle={labelStyle}\n                onClick={onClick}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                yAxisLabels={yAxisLabels}\n                yLabelPosition={yLabelPosition}\n              />\n            ))}\n          </Group>\n        ));\n      }}\n    </VisxBarGroup>\n  );\n}\n\ntype BarProps = {\n  bar: any;\n  barGroup: any;\n  bars: ShapeDefinition<BarStyles>[];\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  enableHover?: boolean;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n};\n\nconst Bar = ({\n  bar,\n  barGroup,\n  bars,\n  conditionalFormattingRules,\n  enableHover,\n  labelStyle,\n  onClick,\n  showDetailedSubGroupingLabels,\n  yAxisLabels,\n  yLabelPosition,\n}: BarProps) => {\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n  return (\n    <Fragment>\n      {showBar && (\n        <BarRect\n          barRectKey={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n          x={bar.x}\n          y={bar.y}\n          width={bar.width}\n          height={bar.height}\n          fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n          onClick={(e) => onClick(e, barGroup, bar)}\n          enableHover={enableHover}\n        />\n      )}\n\n      <BarLabel\n        bar={bar}\n        barGroup={barGroup}\n        yLabelPosition={yLabelPosition}\n        yAxisLabels={yAxisLabels}\n        showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n        labelStyle={labelStyle}\n      />\n    </Fragment>\n  );\n};\n\ntype BarRectProps = {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  barRectKey: string;\n  enableHover?: boolean;\n};\n\nconst BarRect = ({ onClick, fill, x, y, width, height, barRectKey, enableHover }: BarRectProps) => {\n  const [fillColor, setFillColor] = useState(fill);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setFillColor(lightenColor(fill, 0.8));\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setFillColor(fill);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={onClick}\n      onMouseEnter={handleOnMouseEnter}\n      onMouseLeave={handleOnMouseLeave}\n      className={classes}\n    />\n  );\n};\n\ntype BarLabelProps = {\n  bar: any;\n  barGroup: any;\n  yLabelPosition?: number;\n  yAxisLabels?: string[];\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n  bar,\n  barGroup,\n  yLabelPosition,\n  yAxisLabels,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: BarLabelProps) => {\n  if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n  const label = yAxisLabels[bar.index];\n  const columnLabel = label.split('•')[0];\n\n  let formattedColumnLabel: string;\n  if (columnLabel.length >= 13) {\n    formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n  } else {\n    formattedColumnLabel = columnLabel.slice(0, 13);\n  }\n\n  const labelXGap = 4;\n  const labelXPosition = bar.x + bar.width / 2 + labelXGap;\n\n  const labelYGap = 15;\n  const labelYPosition = yLabelPosition + labelYGap;\n\n  const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n  return (\n    <text\n      key={labelKey}\n      x={labelXPosition}\n      y={labelYPosition}\n      style={labelStyle}\n      transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n      textAnchor=\"end\"\n    >\n      {formattedColumnLabel}\n    </text>\n  );\n};\n"]} */",
44888
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AAmLkC","file":"BarGroup.tsx","sourcesContent":["import { css } from \"@emotion/css\";\nimport { Fragment, useState } from \"react\";\nimport { lightenColor } from \"../../../styles/color.functions\";\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS'\nimport { getBarFill } from \"../getBarFill\";\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from \"shared-logic/src/ChartsV2/types\";\nimport { BarStyles } from \"shared-logic/src/BarChartV2/types\";\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { ScaleLinear, ScaleBand } from '@visx/vendor/d3-scale';\nimport { DataType } from \"shared-logic/src/Field/types\";\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { Group } from '@visx/group';\n\nexport type BarGroupProps = {\n    data: ChartDataDefinition[];\n    keys: string[];\n    height: number;\n    xKey: string;\n    xScaleDataType: DataType;\n    xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n    innerXScale: ScaleBand<string> | undefined;\n    yScale: ScaleLinear<number, number, never>;\n    onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n    conditionalFormattingRules: ConditionalFormattingRule[];\n    bars: ShapeDefinition<BarStyles>[];\n    enableHover?: boolean;\n    yAxisLabels?: string[];\n    yLabelPosition?: number;\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n};\n\nexport function BarGroup({\n    data,\n    keys,\n    height,\n    xKey,\n    xScaleDataType,\n    xScale,\n    innerXScale,\n    yScale,\n    onClick,\n    conditionalFormattingRules,\n    bars,\n    enableHover,\n    yAxisLabels,\n    yLabelPosition,\n    showDetailedSubGroupingLabels,\n    labelStyle,\n}: BarGroupProps) {\n    const getGroupPosition = (d: DatumObject) => {\n        const xValue = d[xKey as keyof typeof d];\n\n        if (xScaleDataType === 'string') return String(xValue);\n\n        if (xScaleDataType === 'date_time') {\n            return new Date(String(xValue));\n        }\n\n        if (xScaleDataType === 'number') {\n            return Number(xValue);\n        }\n\n        return String(xValue);\n    };\n\n    return (\n        <VisxBarGroup<DatumObject>\n            data={data as DatumObject[]}\n            keys={keys}\n            height={height}\n            x0={getGroupPosition}\n            // @ts-ignore\n            x0Scale={xScale}\n            // @ts-ignore\n            x1Scale={innerXScale}\n            yScale={yScale}\n            color={() => ''}\n        >\n            {barGroups => {\n                return barGroups.map(barGroup => (\n                    <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n                        {barGroup.bars.map(bar => (\n                            <Bar\n                                key={`bar-${bar.index}-${bar.x}`}\n                                bar={bar}\n                                barGroup={barGroup}\n                                bars={bars}\n                                conditionalFormattingRules={conditionalFormattingRules}\n                                enableHover={enableHover}\n                                labelStyle={labelStyle}\n                                onClick={onClick}\n                                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                                yAxisLabels={yAxisLabels}\n                                yLabelPosition={yLabelPosition}\n                            />\n                        ))}\n                    </Group>\n                ));\n            }}\n        </VisxBarGroup>\n    );\n}\n\ntype BarProps = {\n    bar: any,\n    barGroup: any,\n    bars: ShapeDefinition<BarStyles>[];\n    conditionalFormattingRules: ConditionalFormattingRule[];\n    enableHover?: boolean;\n    onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n    yAxisLabels?: string[];\n    yLabelPosition?: number;\n}\n\nconst Bar = ({\n    bar,\n    barGroup,\n    bars,\n    conditionalFormattingRules,\n    enableHover,\n    labelStyle,\n    onClick,\n    showDetailedSubGroupingLabels,\n    yAxisLabels,\n    yLabelPosition,\n}: BarProps) => {\n    const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n    return (\n        <Fragment>\n            {showBar && <BarRect\n                key={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n                x={bar.x}\n                y={bar.y}\n                width={bar.width}\n                height={bar.height}\n                fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n                onClick={e => onClick(e, barGroup, bar)}\n                enableHover={enableHover}\n            />}\n            \n            <BarLabel\n                bar={bar}\n                barGroup={barGroup}\n                yLabelPosition={yLabelPosition}\n                yAxisLabels={yAxisLabels}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                labelStyle={labelStyle}\n            />\n        </Fragment>\n    );\n};\n\ntype BarRectProps = {\n    onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n    fill?: string;\n    x: number;\n    y: number;\n    width: number;\n    height: number;\n    key: string;\n    enableHover?: boolean;\n};\n\nconst BarRect = ({\n    onClick,\n    fill,\n    x,\n    y,\n    width,\n    height,\n    key,\n    enableHover,\n}: BarRectProps) => {\n    const [fillColor, setFillColor] = useState(fill);\n\n    const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n    const handleOnMouseEnter = () => {\n        if (enableHover) {\n            setFillColor(lightenColor(fill, 0.8));\n        }\n    }\n\n    const handleOnMouseLeave = () => {\n        if (enableHover) {\n            setFillColor(fill);\n        }\n    }\n\n    return (\n        <rect\n            key={key}\n            x={x}\n            y={y}\n            width={width}\n            height={height}\n            fill={fillColor}\n            rx={BAR_RADIUS}\n            onClick={onClick}\n            onMouseEnter={handleOnMouseEnter}\n            onMouseLeave={handleOnMouseLeave}\n            className={classes}\n        />\n    );\n};\n\ntype BarLabelProps = {\n    bar: any;\n    barGroup: any;\n    yLabelPosition?: number;\n    yAxisLabels?: string[];\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n    bar,\n    barGroup,\n    yLabelPosition,\n    yAxisLabels,\n    showDetailedSubGroupingLabels,\n    labelStyle,\n}: BarLabelProps) => {\n    if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n    const label = yAxisLabels[bar.index];\n    const columnLabel = label.split('•')[0];\n\n    let formattedColumnLabel: string;\n    if (columnLabel.length >= 13) {\n        formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n    } else {\n        formattedColumnLabel = columnLabel.slice(0, 13);\n    }\n\n    const labelXGap = 4;\n    const labelXPosition = bar.x + (bar.width / 2) + labelXGap;\n\n    const labelYGap = 15;\n    const labelYPosition = yLabelPosition + labelYGap;\n\n    const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n    return <text\n        key={labelKey}\n        x={labelXPosition}\n        y={labelYPosition}\n        style={labelStyle}\n        transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n        textAnchor='end'\n    >\n        {formattedColumnLabel}\n    </text>\n}"]} */",
44630
44889
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
44631
44890
  }) : '';
44632
44891
  var handleOnMouseEnter = function handleOnMouseEnter() {
@@ -44650,7 +44909,7 @@ var BarRect = function BarRect(_ref3) {
44650
44909
  onMouseEnter: handleOnMouseEnter,
44651
44910
  onMouseLeave: handleOnMouseLeave,
44652
44911
  className: classes
44653
- }, barRectKey);
44912
+ }, key);
44654
44913
  };
44655
44914
  var BarLabel = function BarLabel(_ref4) {
44656
44915
  var bar = _ref4.bar,
@@ -44683,124 +44942,6 @@ var BarLabel = function BarLabel(_ref4) {
44683
44942
  }, labelKey);
44684
44943
  };
44685
44944
 
44686
- var BarStacked = function BarStacked(_ref) {
44687
- var xScaleDataType = _ref.xScaleDataType,
44688
- data = _ref.data,
44689
- xScaleKey = _ref.xScaleKey,
44690
- yScale = _ref.yScale,
44691
- keys = _ref.keys,
44692
- bars = _ref.bars,
44693
- conditionalFormattingRules = _ref.conditionalFormattingRules,
44694
- xScale = _ref.xScale,
44695
- height = _ref.height,
44696
- width = _ref.width;
44697
- var handleGetXValue = function handleGetXValue(d) {
44698
- var xValue = d[xScaleKey];
44699
- if (xScaleDataType === 'string') return String(xValue);
44700
- if (xScaleDataType === 'date_time') {
44701
- return new Date(xValue);
44702
- }
44703
- if (xScaleDataType === 'number') {
44704
- return Number(xValue);
44705
- }
44706
- return String(xValue);
44707
- };
44708
- return jsx(BarStack$1, {
44709
- x: handleGetXValue,
44710
- xScale: xScale,
44711
- yScale: yScale,
44712
- data: data,
44713
- keys: keys,
44714
- color: function color() {
44715
- return '';
44716
- },
44717
- height: height,
44718
- width: width,
44719
- offset: "none",
44720
- children: function children(barStacks) {
44721
- return barStacks.map(function (barStack) {
44722
- return barStack.bars.map(function (bar) {
44723
- return jsx(Bar$1, {
44724
- bar: bar,
44725
- barStack: barStack,
44726
- bars: bars,
44727
- conditionalFormattingRules: conditionalFormattingRules
44728
- }, bar.key.toString() + "-" + bar.index + "-" + bar.x);
44729
- });
44730
- });
44731
- }
44732
- });
44733
- };
44734
- var Bar$1 = function Bar(_ref2) {
44735
- var bar = _ref2.bar,
44736
- barStack = _ref2.barStack,
44737
- bars = _ref2.bars,
44738
- conditionalFormattingRules = _ref2.conditionalFormattingRules;
44739
- var BAR_PADDING = 1.5;
44740
- if (bar.height < 3) return null;
44741
- return jsx("rect", {
44742
- x: bar.x,
44743
- y: bar.y,
44744
- width: bar.width,
44745
- height: bar.height - BAR_PADDING,
44746
- fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
44747
- rx: BAR_RADIUS
44748
- }, "bar-stack-" + barStack.index + "-" + bar.index);
44749
- };
44750
-
44751
- var useBottomAxisBaseLineShift = function useBottomAxisBaseLineShift(_ref) {
44752
- var showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
44753
- hasBottomTitle = _ref.hasBottomTitle,
44754
- hasLeftTitle = _ref.hasLeftTitle;
44755
- if (!showDetailedSubGroupingLabels) {
44756
- return {
44757
- bottomAxisBaselineShift: 0,
44758
- bottomOffset: 0,
44759
- leftOffset: 0
44760
- };
44761
- }
44762
- return {
44763
- bottomAxisBaselineShift: hasBottomTitle ? -65 : -60,
44764
- bottomOffset: hasBottomTitle ? -15 : 10,
44765
- leftOffset: hasLeftTitle ? -10 : 0
44766
- };
44767
- };
44768
-
44769
- var PADDING = {
44770
- paddingOuter: 0.05,
44771
- paddingInner: 0.3
44772
- };
44773
-
44774
- function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
44775
- return useMemo(function () {
44776
- if (xScaleDataType === 'string') {
44777
- return scaleBand(_extends({
44778
- range: [0, innerWidth],
44779
- domain: xScaleKey ? [].concat(data.map(function (d) {
44780
- return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
44781
- })) : []
44782
- }, PADDING));
44783
- }
44784
- if (xScaleDataType === 'date_time' && xScaleKey) {
44785
- return scaleBand(_extends({
44786
- range: [0, innerWidth],
44787
- domain: data.map(function (d) {
44788
- return new Date(d[xScaleKey].value);
44789
- })
44790
- }, PADDING));
44791
- }
44792
- if (xScaleDataType === 'number' && xScaleKey) {
44793
- return scaleBand(_extends({
44794
- range: [0, innerWidth],
44795
- domain: data.map(function (d) {
44796
- return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
44797
- })
44798
- }, PADDING));
44799
- }
44800
- return null;
44801
- }, [innerWidth, data]);
44802
- }
44803
-
44804
44945
  var BarChart$5 = function BarChart(_ref) {
44805
44946
  var _theme$axis;
44806
44947
  var chart = _ref.chart,
@@ -44822,7 +44963,7 @@ var BarChart$5 = function BarChart(_ref) {
44822
44963
  tooltipData = _useTooltip.tooltipData,
44823
44964
  hideTooltip = _useTooltip.hideTooltip,
44824
44965
  showTooltip = _useTooltip.showTooltip;
44825
- var showDetailedSubGroupingLabels = !options.stacked && numberOfDimensions === 2 && width > 450;
44966
+ var showDetailedSubGroupingLabels = numberOfDimensions === 2 && width > 450;
44826
44967
  var hasBottomTitle = chart.x.title != null;
44827
44968
  var hasLeftTitle = chart.y.title != null;
44828
44969
  var _useBottomAxisBaseLin = useBottomAxisBaseLineShift({
@@ -44835,7 +44976,7 @@ var BarChart$5 = function BarChart(_ref) {
44835
44976
  leftOffset = _useBottomAxisBaseLin.leftOffset;
44836
44977
  var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, hasLeftTitle, hasBottomTitle, showDetailedSubGroupingLabels);
44837
44978
  var innerWidth = width - margin.left - margin.right;
44838
- var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 50 : 0) - (showDetailedSubGroupingLabels ? 50 : 0) + (options.axis.showXAxisLabels ? 0 : 25);
44979
+ var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 50 : 0) - (showDetailedSubGroupingLabels ? 50 : 0);
44839
44980
  var xKey = chart.x.key;
44840
44981
  var xScaleKey = chart.x.scale.key;
44841
44982
  var xScaleDataType = chart.x.scale.dataType;
@@ -45429,7 +45570,6 @@ function Area(_ref3) {
45429
45570
  });
45430
45571
  }
45431
45572
 
45432
- var MAX_BUBBLE_RADIUS = 30;
45433
45573
  var BubbleChart$4 = function BubbleChart(_ref) {
45434
45574
  var _theme$axis;
45435
45575
  var chart = _ref.chart,
@@ -45451,34 +45591,25 @@ var BubbleChart$4 = function BubbleChart(_ref) {
45451
45591
  var zValues = chart.z ? chart.data.map(function (d) {
45452
45592
  return d[chart.z];
45453
45593
  }).map(function (d) {
45454
- return d == null ? void 0 : d.value;
45594
+ return d.value;
45455
45595
  }) : [];
45456
45596
  var normaliseArray = function normaliseArray(array, min, max) {
45457
45597
  var arrayMin = Math.min.apply(Math, array);
45458
45598
  var arrayMax = Math.max.apply(Math, array);
45459
- if (arrayMin === arrayMax) {
45460
- return array.map(function () {
45461
- return min;
45462
- });
45463
- }
45464
45599
  return array.map(function (value) {
45465
45600
  return (value - arrayMin) / (arrayMax - arrayMin) * (max - min) + min;
45466
45601
  });
45467
45602
  };
45468
- var scaledSizeValues = normaliseArray(zValues, 5, MAX_BUBBLE_RADIUS);
45603
+ var scaledSizeValues = normaliseArray(zValues, 5, 30);
45469
45604
  var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);
45470
45605
  var _useState = useState(chart.lines.map(function (legendItem) {
45471
45606
  return legendItem.yKey;
45472
- }).filter(function (yKey) {
45473
- return yKey !== chart.groupByKey;
45474
45607
  })),
45475
45608
  visibleYKeys = _useState[0],
45476
45609
  setVisibleYKeys = _useState[1];
45477
45610
  useEffect(function () {
45478
45611
  setVisibleYKeys(chart.lines.map(function (legendItem) {
45479
45612
  return legendItem.yKey;
45480
- }).filter(function (yKey) {
45481
- return yKey !== chart.groupByKey;
45482
45613
  }));
45483
45614
  return function () {
45484
45615
  setVisibleYKeys([]);
@@ -45504,13 +45635,13 @@ var BubbleChart$4 = function BubbleChart(_ref) {
45504
45635
  if (xScaleDataType === 'date_time') {
45505
45636
  return scaleTime({
45506
45637
  range: [0, innerWidth],
45507
- domain: chart.x.scale.ordering === 'desc' ? [chart.x.scale.max, chart.x.scale.min] : [chart.x.scale.min, chart.x.scale.max]
45638
+ domain: chart.x.scale.ordering === 'asc' ? [chart.x.scale.min, chart.x.scale.max] : [chart.x.scale.max, chart.x.scale.min]
45508
45639
  });
45509
45640
  }
45510
45641
  if (xScaleDataType === 'number') {
45511
45642
  return scaleLinear({
45512
45643
  range: [0, innerWidth],
45513
- domain: chart.x.scale.ordering === 'desc' ? [chart.x.scale.max, chart.x.scale.min] : [chart.x.scale.min, chart.x.scale.max],
45644
+ domain: chart.x.scale.ordering === 'asc' ? [chart.x.scale.min, chart.x.scale.max] : [chart.x.scale.max, chart.x.scale.min],
45514
45645
  nice: true
45515
45646
  });
45516
45647
  }
@@ -45549,18 +45680,11 @@ var BubbleChart$4 = function BubbleChart(_ref) {
45549
45680
  var yTickValues = chart.y.ticks.map(function (tick) {
45550
45681
  return Number(tick.value);
45551
45682
  });
45552
- var tooltipItems = [{
45683
+ var legendTooltipItems = [{
45553
45684
  legendItems: chart.lines,
45554
45685
  visibleYKeys: visibleYKeys,
45555
45686
  conditionalFormattingRules: chart.conditionalFormattingRules
45556
45687
  }];
45557
- var legendItems = chart.legend.items.map(function (legendItem) {
45558
- return {
45559
- legendItems: [legendItem],
45560
- visibleYKeys: [legendItem.yKey],
45561
- conditionalFormattingRules: chart.conditionalFormattingRules
45562
- };
45563
- });
45564
45688
  return jsxs(React__default.Fragment, {
45565
45689
  children: [jsxs(ChartWrapper$1, {
45566
45690
  width: width,
@@ -45638,20 +45762,20 @@ var BubbleChart$4 = function BubbleChart(_ref) {
45638
45762
  width: innerWidth
45639
45763
  })]
45640
45764
  }), options.showLegend && jsx(Legend$1, {
45641
- items: legendItems,
45642
- keys: chart.legend.keys,
45765
+ items: legendTooltipItems,
45766
+ setVisibleYKeys: setVisibleYKeys,
45767
+ keys: chart.keys,
45643
45768
  marginLeft: margin.left - margin.leftTitleOffset
45644
45769
  }), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
45645
- items: tooltipItems,
45770
+ items: legendTooltipItems,
45646
45771
  tooltipData: tooltipData,
45647
45772
  tooltipLeft: tooltipLeft,
45648
45773
  tooltipTop: tooltipTop,
45649
- xKey: chart.groupByKey,
45774
+ xKey: xKey,
45650
45775
  keys: chart.keys,
45651
45776
  yKeys: chart.y.keys,
45652
45777
  showRoundedTotal: options.showRoundedTotal,
45653
- theme: themeCSS.popoverMenus,
45654
- shouldShowColorLegend: false
45778
+ theme: themeCSS.popoverMenus
45655
45779
  })]
45656
45780
  });
45657
45781
  };
@@ -45662,9 +45786,6 @@ function Bubbles(_ref2) {
45662
45786
  xScale = _ref2.xScale,
45663
45787
  yScale = _ref2.yScale,
45664
45788
  chart = _ref2.chart;
45665
- var getBubbleColor = function getBubbleColor(index) {
45666
- return chart.legend.items[index % chart.legend.items.length].color;
45667
- };
45668
45789
  return jsx(Fragment, {
45669
45790
  children: data.map(function (d, index) {
45670
45791
  var _ref3, _yScale2;
@@ -45672,7 +45793,10 @@ function Bubbles(_ref2) {
45672
45793
  r: d.bubbleSize,
45673
45794
  cx: (_ref3 = xScale(d[xScaleKey])) != null ? _ref3 : 0,
45674
45795
  cy: (_yScale2 = yScale(d[yKeys[0]])) != null ? _yScale2 : 0,
45675
- fill: getBubbleColor(index)
45796
+ fill: chart.lines[0].color,
45797
+ style: {
45798
+ zIndex: -d.bubbleSize
45799
+ }
45676
45800
  }, "bubble_chart_" + index);
45677
45801
  })
45678
45802
  });
@@ -45947,21 +46071,6 @@ var RadarChart$2 = function RadarChart(_ref) {
45947
46071
  });
45948
46072
  };
45949
46073
 
45950
- var init$d = function init(xMeasure, yMeasure) {
45951
- return {
45952
- x: xMeasure.map(function (measure) {
45953
- return id(measure);
45954
- }),
45955
- y: yMeasure.map(function (measure) {
45956
- return id(measure);
45957
- }),
45958
- detailed: {
45959
- x: xMeasure,
45960
- y: yMeasure
45961
- }
45962
- };
45963
- };
45964
-
45965
46074
  var getStyleDefinition = function getStyleDefinition(_ref) {
45966
46075
  var colors = _ref.colors,
45967
46076
  yKeys = _ref.yKeys;
@@ -46040,7 +46149,7 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
46040
46149
  yKeys = _ref.yKeys,
46041
46150
  xScaleDataType = _ref.xScaleDataType,
46042
46151
  nullValue = _ref.nullValue,
46043
- approxYAxisLabelCount = _ref.approxYAxisLabelCount,
46152
+ tickCountYAxis = _ref.tickCountYAxis,
46044
46153
  formattingFunctionX = _ref.formattingFunctionX,
46045
46154
  formattingFunctionY = _ref.formattingFunctionY,
46046
46155
  order = _ref.order,
@@ -46057,18 +46166,32 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
46057
46166
  keys: xScale.key === null ? [] : [xScale.key],
46058
46167
  dataType: xScale.dataType
46059
46168
  });
46169
+ if (xKey) {
46170
+ xTicks = data.map(function (dataItem) {
46171
+ var _dataItem$xKey, _dataItem$xScale$key, _dataItem$xScale$key2;
46172
+ var xValue = (_dataItem$xKey = dataItem[xKey]) != null && _dataItem$xKey.value ? dataItem[xKey].value : null;
46173
+ var xformattedValue = formattingFunctionX(xValue, nullValue);
46174
+ var xScaleValue = xScale.key !== null && (_dataItem$xScale$key = dataItem[xScale.key]) != null && _dataItem$xScale$key.value ? (_dataItem$xScale$key2 = dataItem[xScale.key]) == null ? void 0 : _dataItem$xScale$key2.value : '';
46175
+ var xScaleValueAdjusted = xScale.dataType === 'date_time' ? new Date(xScaleValue) : xScale.dataType === 'string' ? String(xScaleValue) : xScale.dataType === 'number' ? Number(xScaleValue) : xScaleValue;
46176
+ return {
46177
+ value: xValue !== null ? xValue : '',
46178
+ formattedValue: xformattedValue !== null ? "" + xformattedValue : null,
46179
+ scaleValue: xScaleValueAdjusted
46180
+ };
46181
+ });
46182
+ }
46183
+ // ----- Y Axis ("number") -----
46184
+
46060
46185
  var y = getMinAndMax({
46061
46186
  data: data,
46062
46187
  keys: yKeys,
46063
46188
  dataType: 'number',
46064
46189
  goalLines: goalLines
46065
46190
  });
46066
- var maxY = y.max ? y.max * 1.1 : y.max || 1;
46191
+ var maxY = y.max || 0;
46067
46192
  var minY = Math.min(y.min || 0, 0);
46068
- var tickCountYAxis = approxYAxisLabelCount === 'auto' ? 10 : approxYAxisLabelCount;
46069
46193
  var yTickInterval = getNiceInterval((maxY - minY) / (tickCountYAxis - 1));
46070
- var i = 0;
46071
- while (yTickInterval * i <= maxY + yTickInterval) {
46194
+ for (var i = 0; i < tickCountYAxis; i++) {
46072
46195
  var _value = yTickInterval * i;
46073
46196
  var formattedValue = formattingFunctionY(_value, nullValue);
46074
46197
  yTicks.push({
@@ -46076,29 +46199,14 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
46076
46199
  formattedValue: formattedValue,
46077
46200
  scaleValue: _value
46078
46201
  });
46079
- i++;
46080
- }
46081
- var maxX = x.max ? x.max * 1.05 : x.max || 1;
46082
- var minX = Math.min(x.min || 0, 0);
46083
- var xTickInterval = getNiceInterval((maxX - minX) / (10 - 1));
46084
- i = 0;
46085
- while (xTickInterval * i <= maxX + xTickInterval) {
46086
- var _value2 = xTickInterval * i;
46087
- var _formattedValue = formattingFunctionX(_value2, nullValue);
46088
- xTicks.push({
46089
- value: _value2,
46090
- formattedValue: _formattedValue,
46091
- scaleValue: _value2
46092
- });
46093
- i++;
46094
46202
  }
46095
46203
  return {
46096
46204
  x: {
46097
46205
  ticks: xTicks,
46098
46206
  scale: {
46099
46207
  dataType: xScale.dataType,
46100
- max: maxX,
46101
- min: minX,
46208
+ max: x.max,
46209
+ min: x.min,
46102
46210
  key: xScale.key,
46103
46211
  ordering: xScale.ordering
46104
46212
  }
@@ -46107,7 +46215,7 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
46107
46215
  ticks: yTicks,
46108
46216
  scale: {
46109
46217
  dataType: 'number',
46110
- key: yKeys[0],
46218
+ key: null,
46111
46219
  ordering: 'asc',
46112
46220
  max: maxY,
46113
46221
  min: minY
@@ -46145,6 +46253,223 @@ var getGoalLines = function getGoalLines(_ref) {
46145
46253
  });
46146
46254
  };
46147
46255
 
46256
+ var buildTrendAndForecast = function buildTrendAndForecast(_ref) {
46257
+ var data = _ref.data,
46258
+ forecastUnits = _ref.forecastUnits,
46259
+ xKey = _ref.xKey,
46260
+ yKey = _ref.yKey,
46261
+ timeUnit = _ref.timeUnit,
46262
+ includeForecast = _ref.includeForecast;
46263
+ var forecastKey = yKey + "_forecast";
46264
+ var trendKey = yKey + "_trend";
46265
+ var trendData = [];
46266
+ var forecastData = [];
46267
+ var values = data.map(function (point) {
46268
+ return Number(point[yKey].value);
46269
+ });
46270
+ var dates = data.map(function (point) {
46271
+ return new Date(point[xKey].value);
46272
+ });
46273
+ var n = values.length;
46274
+ var daysSinceStart = dates.map(function (date) {
46275
+ return (date.getTime() - dates[0].getTime()) / 86400000;
46276
+ });
46277
+ var meanX = daysSinceStart.reduce(function (a, b) {
46278
+ return a + b;
46279
+ }, 0) / n;
46280
+ var meanY = values.reduce(function (a, b) {
46281
+ return a + b;
46282
+ }, 0) / n;
46283
+ var numerator = 0,
46284
+ denominator = 0;
46285
+ for (var i = 0; i < n; i++) {
46286
+ numerator += (daysSinceStart[i] - meanX) * (values[i] - meanY);
46287
+ denominator += Math.pow(daysSinceStart[i] - meanX, 2);
46288
+ }
46289
+ var slope = numerator / denominator;
46290
+ var intercept = meanY - slope * meanX;
46291
+ var forecastDate = new Date(dates[n - 1]); // Start from the last date in the data
46292
+
46293
+ for (var _i = 0; _i < n + (includeForecast ? forecastUnits : 0); _i++) {
46294
+ var x = void 0;
46295
+ if (_i < n) {
46296
+ // Use existing dates for current trend values
46297
+ x = dates[_i];
46298
+ } else if (includeForecast) {
46299
+ // Generate future dates for forecast values if includeForecast is true
46300
+ switch (timeUnit) {
46301
+ case 'week':
46302
+ forecastDate.setDate(forecastDate.getDate() + 7);
46303
+ break;
46304
+ case 'month':
46305
+ forecastDate.setMonth(forecastDate.getMonth() + 1);
46306
+ break;
46307
+ case 'quarter':
46308
+ forecastDate.setMonth(forecastDate.getMonth() + 3);
46309
+ break;
46310
+ case 'year':
46311
+ forecastDate.setFullYear(forecastDate.getFullYear() + 1);
46312
+ break;
46313
+ }
46314
+ x = new Date(forecastDate);
46315
+ } else {
46316
+ continue; // Skip this iteration if forecasting is not included
46317
+ }
46318
+ var dayCount = (x.getTime() - dates[0].getTime()) / 86400000; // 1 day in milliseconds
46319
+ var forecastedValue = slope * dayCount + intercept;
46320
+ var currentValue = slope * dayCount + intercept;
46321
+ if (_i >= n - 1) {
46322
+ if (_i === n - 1) {
46323
+ trendData.push({
46324
+ date: x.toISOString(),
46325
+ value: parseFloat(currentValue.toFixed(2))
46326
+ });
46327
+ }
46328
+ if (includeForecast) {
46329
+ forecastData.push({
46330
+ date: x.toISOString(),
46331
+ value: parseFloat(forecastedValue.toFixed(2))
46332
+ });
46333
+ }
46334
+ } else {
46335
+ trendData.push({
46336
+ date: x.toISOString(),
46337
+ value: parseFloat(currentValue.toFixed(2))
46338
+ });
46339
+ }
46340
+ }
46341
+ return {
46342
+ trendData: trendData,
46343
+ trendKey: trendKey,
46344
+ forecastData: forecastData,
46345
+ forecastKey: forecastKey
46346
+ };
46347
+ };
46348
+
46349
+ var getTrendsAndForecastsData = function getTrendsAndForecastsData(_ref) {
46350
+ var _trendsAndForecasts$;
46351
+ var chartData = _ref.chartData,
46352
+ formattingFunctionX = _ref.formattingFunctionX,
46353
+ formattingFunctionY = _ref.formattingFunctionY,
46354
+ keys = _ref.keys,
46355
+ nullValue = _ref.nullValue,
46356
+ orderFunction = _ref.orderFunction,
46357
+ trendsAndForecasts = _ref.trendsAndForecasts,
46358
+ xAxisPostfix = _ref.xAxisPostfix,
46359
+ xAxisPrefix = _ref.xAxisPrefix,
46360
+ xKey = _ref.xKey,
46361
+ xScaleDataType = _ref.xScaleDataType,
46362
+ yAxisPostfix = _ref.yAxisPostfix,
46363
+ yAxisPrefix = _ref.yAxisPrefix,
46364
+ yKeys = _ref.yKeys;
46365
+ if (!trendsAndForecasts || trendsAndForecasts.length === 0 || xScaleDataType !== 'date_time') return {
46366
+ chartData: chartData
46367
+ };
46368
+ if (!orderFunction || !['week', 'month', 'quarter', 'year'].includes(orderFunction)) return {
46369
+ chartData: chartData
46370
+ };
46371
+
46372
+ // ----- Technically we should do a loop here but at the moment we'll only have one trend/forecast so use trendsAndForecasts[0] -----
46373
+
46374
+ var includeForecast = trendsAndForecasts[0].type === 'Forecast';
46375
+ var forecastUnits = trendsAndForecasts[0].type === 'Forecast' ? (_trendsAndForecasts$ = trendsAndForecasts[0].value) != null ? _trendsAndForecasts$ : 0 : 0;
46376
+ var yKey = yKeys[0];
46377
+ var newKeys = cloneDeep(keys);
46378
+ var _buildTrendAndForecas = buildTrendAndForecast({
46379
+ data: chartData,
46380
+ forecastUnits: forecastUnits,
46381
+ xKey: xKey,
46382
+ yKey: yKey,
46383
+ timeUnit: orderFunction,
46384
+ includeForecast: includeForecast
46385
+ }),
46386
+ trendData = _buildTrendAndForecas.trendData,
46387
+ trendKey = _buildTrendAndForecas.trendKey,
46388
+ forecastData = _buildTrendAndForecas.forecastData,
46389
+ forecastKey = _buildTrendAndForecas.forecastKey;
46390
+
46391
+ // ----- Add Trend To Existing Data Array And Trend Key -----
46392
+
46393
+ var newData = chartData.map(function (dataItem) {
46394
+ var date = dataItem[xKey].value;
46395
+ var trend = trendData.find(function (trendItem) {
46396
+ return trendItem.date === date;
46397
+ });
46398
+ if (trend) {
46399
+ var trendDataItem = {
46400
+ value: trend.value,
46401
+ formattedValue: "" + yAxisPrefix + formattingFunctionY(trend.value, nullValue) + yAxisPostfix
46402
+ };
46403
+ if (includeForecast && forecastData.length > 0) {
46404
+ var _extends2;
46405
+ return _extends({}, dataItem, (_extends2 = {}, _extends2[trendKey] = trendDataItem, _extends2[forecastKey] = {
46406
+ value: null,
46407
+ formattedValue: null
46408
+ }, _extends2));
46409
+ } else {
46410
+ var _extends3;
46411
+ return _extends({}, dataItem, (_extends3 = {}, _extends3[trendKey] = trendDataItem, _extends3));
46412
+ }
46413
+ }
46414
+ return null;
46415
+ });
46416
+
46417
+ // ----- Add New Array Items For Forecast & Forecast Key -----
46418
+
46419
+ if (includeForecast && forecastData.length > 0) {
46420
+ var _loop = function _loop() {
46421
+ var _forecastIncrement;
46422
+ var forecastDataItem = forecastData[index];
46423
+ var forecastIncrement = (_forecastIncrement = {}, _forecastIncrement[xKey] = {
46424
+ value: forecastDataItem.date,
46425
+ formattedValue: "" + xAxisPrefix + formattingFunctionX(forecastDataItem.date, nullValue) + xAxisPostfix
46426
+ }, _forecastIncrement[trendKey] = {
46427
+ value: null,
46428
+ formattedValue: null
46429
+ }, _forecastIncrement[forecastKey] = {
46430
+ value: forecastDataItem.value,
46431
+ formattedValue: "" + yAxisPrefix + formattingFunctionY(forecastDataItem.value, nullValue) + yAxisPostfix
46432
+ }, _forecastIncrement);
46433
+ yKeys.forEach(function (key) {
46434
+ forecastIncrement[key] = {
46435
+ value: null,
46436
+ formattedValue: null
46437
+ };
46438
+ });
46439
+ newData.push(forecastIncrement);
46440
+ };
46441
+ for (var index = 0; index < forecastUnits; index++) {
46442
+ _loop();
46443
+ }
46444
+ }
46445
+
46446
+ // ----- Update Keys -----
46447
+
46448
+ var newYKeys = includeForecast && forecastData.length > 0 ? [].concat(yKeys, [trendKey, forecastKey]) : [].concat(yKeys, [trendKey]);
46449
+ newKeys[trendKey] = {
46450
+ key: trendKey,
46451
+ keyFormatted: newKeys[yKey].keyFormatted + " \u2022 Trend",
46452
+ dataType: 'number'
46453
+ };
46454
+ if (includeForecast && forecastData.length > 0) {
46455
+ newKeys[forecastKey] = {
46456
+ key: forecastKey,
46457
+ keyFormatted: newKeys[yKey].keyFormatted + " \u2022 Forecast",
46458
+ dataType: 'number'
46459
+ };
46460
+ }
46461
+
46462
+ // ----- Create style definitions for trend and forecast in the form of legend items to append to getStyleDefinition() -----
46463
+
46464
+ // TODO
46465
+
46466
+ return {
46467
+ newChartData: newData,
46468
+ newYKeys: newYKeys,
46469
+ newKeys: newKeys
46470
+ };
46471
+ };
46472
+
46148
46473
  /**
46149
46474
  * When provided with a result, and formatting parameters, it returns a
46150
46475
  * populated result including the formatted value to show.
@@ -46241,28 +46566,77 @@ var formatResult = function formatResult(result, params) {
46241
46566
  };
46242
46567
  };
46243
46568
 
46244
- var formattedResultToSeries = function formattedResultToSeries(formattedResult, pivotConfig, zFieldId) {
46569
+ var formattedResultToSeries = function formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter, zFieldId) {
46570
+ var _formattedResult$fiel, _formattedResult$fiel2;
46245
46571
  var keys = {};
46246
- formattedResult.fields.forEach(function (field) {
46247
- keys[field.id] = {
46248
- key: field.id,
46249
- dataType: field.dataType,
46250
- outputDataType: field.outputDataType,
46251
- keyFormatted: field["function"] === 'none' ? field.publicName : field.publicName + " (" + field["function"] + ")"
46252
- };
46572
+
46573
+ // Collect the result fields which are going to be used on the Y axis.
46574
+ var yResultFields = formattedResult.fields.filter(function (resultField) {
46575
+ var isNotXPivot = !pivotConfig.x.includes(resultField.id);
46576
+ var isNotYPivot = !pivotConfig.y.includes(resultField.id);
46577
+ return isNotXPivot && isNotYPivot;
46253
46578
  });
46579
+ var xPivotFields = formattedResult.fields.filter(function (resultField) {
46580
+ return pivotConfig.x.includes(resultField.id);
46581
+ });
46582
+ var yPivotFields = formattedResult.fields.filter(function (resultField) {
46583
+ return pivotConfig.y.includes(resultField.id);
46584
+ });
46585
+ var pivotedData = {};
46586
+ var xKeyOrdering = [];
46587
+ var yKeys = {};
46588
+ formattedResult.contentMapped.forEach(function (row) {
46589
+ xPivotFields.forEach(function (xPivotField) {
46590
+ var _extends2;
46591
+ var uniqueXValue = xPivotField.id + ":" + row[xPivotField.id].value;
46592
+ xKeyOrdering.push(uniqueXValue);
46593
+
46594
+ // Add any existing values, and the x key itself
46595
+
46596
+ var yPivotPrefix = yPivotFields.map(function (yPivotField) {
46597
+ return yPivotField.id + ":" + row[yPivotField.id].value;
46598
+ }).join('_');
46599
+ pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends2 = {}, _extends2[xPivotField.id] = row[xPivotField.id], _extends2));
46600
+ yResultFields.forEach(function (yResultField) {
46601
+ var _extends3;
46602
+ var key = yPivotFields.length > 0 ? [yPivotPrefix, yResultField.id].join('_') : yResultField.id;
46603
+ yKeys[key] = true;
46604
+ keys[key] = {
46605
+ key: key,
46606
+ dataType: yResultField.dataType,
46607
+ outputDataType: yResultField.outputDataType,
46608
+ keyFormatted: seriesLabelFormatter({
46609
+ yResultField: yResultField,
46610
+ yPivotFields: yPivotFields,
46611
+ row: row
46612
+ })
46613
+ };
46614
+ pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends3 = {}, _extends3[key] = row[yResultField.id], _extends3));
46615
+ });
46616
+ });
46617
+ });
46618
+ var seriesDataFlattened = uniq(xKeyOrdering).map(function (xKey) {
46619
+ return pivotedData[xKey];
46620
+ });
46621
+ var mappedXKeys = xPivotFields.map(function (r) {
46622
+ return r.id;
46623
+ });
46624
+ var mappedYKeys = Object.keys(yKeys);
46625
+ var mappedZKey = (_formattedResult$fiel = (_formattedResult$fiel2 = formattedResult.fields.find(function (resultField) {
46626
+ return resultField.fieldId === zFieldId;
46627
+ })) == null ? void 0 : _formattedResult$fiel2.id) != null ? _formattedResult$fiel : '';
46254
46628
  var formattedResultReturn = {
46255
- xKeys: pivotConfig.x,
46256
- yKeys: pivotConfig.y,
46257
- zKey: zFieldId,
46629
+ xKeys: mappedXKeys,
46630
+ yKeys: mappedYKeys,
46631
+ zKey: mappedZKey,
46258
46632
  keys: keys,
46259
- seriesData: formattedResult.contentMapped
46633
+ seriesData: seriesDataFlattened
46260
46634
  };
46261
46635
  return formattedResultReturn;
46262
46636
  };
46263
46637
 
46264
46638
  var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_ref) {
46265
- var _pivotConfig$x$, _xKeys$, _formattedResult$fiel, _formattedResult$fiel2, _axisTitles$x, _axisTitles$y;
46639
+ var _pivotConfig$x$, _xKeys$, _axisTitles$x, _axisTitles$y;
46266
46640
  var axisTitles = _ref.axisTitles,
46267
46641
  colors = _ref.colors,
46268
46642
  conditionalFormattingAttributes = _ref.conditionalFormattingAttributes,
@@ -46274,6 +46648,7 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46274
46648
  order = _ref.order,
46275
46649
  pivotConfig = _ref.pivotConfig,
46276
46650
  result = _ref.result,
46651
+ trendsAndForecasts = _ref.trendsAndForecasts,
46277
46652
  xAxisFormat = _ref.xAxisFormat,
46278
46653
  xAxisPostfix = _ref.xAxisPostfix,
46279
46654
  xAxisPrefix = _ref.xAxisPrefix,
@@ -46281,6 +46656,7 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46281
46656
  yAxisPostfix = _ref.yAxisPostfix,
46282
46657
  yAxisPrefix = _ref.yAxisPrefix,
46283
46658
  approxYAxisLabelCount = _ref.approxYAxisLabelCount,
46659
+ seriesLabelFormatter = _ref.seriesLabelFormatter,
46284
46660
  _valueAlias = _ref.valueAlias,
46285
46661
  zFieldId = _ref.zFieldId;
46286
46662
  var allPrefixes = {};
@@ -46363,6 +46739,7 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46363
46739
  var xKeyField = result.fields.find(function (field) {
46364
46740
  return field.id === xKeyTemp;
46365
46741
  });
46742
+ var orderFunction = order.length > 0 ? order[0]["function"] : undefined;
46366
46743
 
46367
46744
  // ----- Formatting -----
46368
46745
 
@@ -46379,7 +46756,7 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46379
46756
  var formattingFunctionY = function formattingFunctionY(value) {
46380
46757
  // Use any y axis field as they are all formatted in the same way (for now...);
46381
46758
  var nonPivotField = formattedResult.fields.find(function (resultField) {
46382
- return pivotConfig.y.includes(resultField.id);
46759
+ return ![].concat(pivotConfig.x, pivotConfig.y).includes(resultField.id);
46383
46760
  });
46384
46761
  if (!nonPivotField) return '';
46385
46762
  return formattedResult.formatterFunc(value, {
@@ -46391,23 +46768,33 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46391
46768
 
46392
46769
  // ----- Keys & Prep -----
46393
46770
  var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
46394
- var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, zFieldId),
46771
+ var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter, zFieldId),
46395
46772
  keys = _formattedResultToSer.keys,
46396
46773
  yKeys = _formattedResultToSer.yKeys,
46397
46774
  xKeys = _formattedResultToSer.xKeys,
46398
46775
  zKey = _formattedResultToSer.zKey,
46399
46776
  chartData = _formattedResultToSer.seriesData;
46400
- var sortedChartData = chartData.sort(function (a, b) {
46401
- var _order$, _a$pivotConfig$x$, _b$pivotConfig$x$;
46402
- var isDescending = ((_order$ = order[0]) == null ? void 0 : _order$.direction) === 'desc';
46403
- var xValueA = (_a$pivotConfig$x$ = a[pivotConfig.x[0]]) == null ? void 0 : _a$pivotConfig$x$.value;
46404
- var xValueB = (_b$pivotConfig$x$ = b[pivotConfig.x[0]]) == null ? void 0 : _b$pivotConfig$x$.value;
46405
- if (xValueA < xValueB) return isDescending ? 1 : -1;
46406
- if (xValueA > xValueB) return isDescending ? -1 : 1;
46407
- return 0;
46408
- });
46409
46777
  var xKey = (_xKeys$ = xKeys[0]) != null ? _xKeys$ : null;
46410
46778
 
46779
+ // ----- Trends & Forecasts -----
46780
+
46781
+ var trendsAndForecastData = getTrendsAndForecastsData({
46782
+ chartData: chartData,
46783
+ formattingFunctionX: formattingFunctionX,
46784
+ formattingFunctionY: formattingFunctionY,
46785
+ keys: keys,
46786
+ nullValue: nullValue,
46787
+ trendsAndForecasts: trendsAndForecasts,
46788
+ xAxisPostfix: xAxisPostfix,
46789
+ xKey: xKey,
46790
+ yKeys: yKeys,
46791
+ xAxisPrefix: xAxisPrefix,
46792
+ xScaleDataType: xScaleDataType,
46793
+ yAxisPostfix: yAxisPostfix,
46794
+ yAxisPrefix: yAxisPrefix,
46795
+ orderFunction: orderFunction
46796
+ });
46797
+
46411
46798
  // ----- Goal Lines -----
46412
46799
 
46413
46800
  var goalLines = getGoalLines({
@@ -46418,11 +46805,11 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46418
46805
  // ----- Ticks -----
46419
46806
 
46420
46807
  var ticks = getScaleAndTicks({
46421
- data: sortedChartData,
46808
+ data: chartData,
46422
46809
  xKey: xKey,
46423
46810
  xScaleDataType: xScaleDataType,
46424
46811
  yKeys: yKeys,
46425
- approxYAxisLabelCount: approxYAxisLabelCount,
46812
+ tickCountYAxis: approxYAxisLabelCount,
46426
46813
  formattingFunctionX: formattingFunctionX,
46427
46814
  formattingFunctionY: formattingFunctionY,
46428
46815
  nullValue: nullValue,
@@ -46432,36 +46819,9 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46432
46819
 
46433
46820
  // ----- Lines -----
46434
46821
 
46435
- var groupByKey = (_formattedResult$fiel = (_formattedResult$fiel2 = formattedResult.fields.find(function (field) {
46436
- return field["function"] === 'none';
46437
- })) == null ? void 0 : _formattedResult$fiel2.id) != null ? _formattedResult$fiel : '';
46438
46822
  var styleDefinition = getStyleDefinition({
46439
- colors: colors,
46440
- yKeys: [].concat(yKeys, [xKey, zKey])
46441
- });
46442
-
46443
- // ----- Legend -----
46444
- var colorScale = themeToColorScale(colors, sortedChartData.length);
46445
- var legendItems = sortedChartData.map(function (d, index) {
46446
- var _d$groupByKey, _colorScale;
46447
- return {
46448
- yKey: (_d$groupByKey = d[groupByKey]) == null ? void 0 : _d$groupByKey.value,
46449
- color: (_colorScale = colorScale[index % colorScale.length]) != null ? _colorScale : '',
46450
- style: {
46451
- strokeWidth: 3,
46452
- strokeDasharray: null,
46453
- type: 'line'
46454
- }
46455
- };
46456
- });
46457
- var legendKeys = {};
46458
- sortedChartData.forEach(function (row) {
46459
- var _row$groupByKey, _row$groupByKey$value, _row$groupByKey2, _row$groupByKey$forma, _row$groupByKey3;
46460
- legendKeys[(_row$groupByKey = row[groupByKey]) == null ? void 0 : _row$groupByKey.value] = {
46461
- key: (_row$groupByKey$value = (_row$groupByKey2 = row[groupByKey]) == null ? void 0 : _row$groupByKey2.value) != null ? _row$groupByKey$value : '',
46462
- dataType: 'string',
46463
- keyFormatted: (_row$groupByKey$forma = (_row$groupByKey3 = row[groupByKey]) == null ? void 0 : _row$groupByKey3.formattedValue) != null ? _row$groupByKey$forma : ''
46464
- };
46823
+ colors: colors != null ? colors : ['#feae4a', '#5fbaff', '#e15e9d'],
46824
+ yKeys: yKeys
46465
46825
  });
46466
46826
 
46467
46827
  // ----- Conditional Formatting -----
@@ -46500,24 +46860,21 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
46500
46860
  title: (_axisTitles$y = axisTitles == null ? void 0 : axisTitles.y) != null ? _axisTitles$y : null
46501
46861
  },
46502
46862
  z: zKey,
46503
- data: sortedChartData,
46863
+ data: chartData,
46504
46864
  lines: styleDefinition,
46505
46865
  conditionalFormattingRules: conditionalFormattingRules,
46506
- goalLines: goalLines,
46507
- groupByKey: groupByKey,
46508
- legend: {
46509
- keys: legendKeys,
46510
- items: legendItems
46511
- }
46866
+ goalLines: goalLines
46512
46867
  };
46513
46868
  return chart;
46514
46869
  };
46515
46870
 
46516
46871
  var BubbleChartV2View = function BubbleChartV2View(props) {
46517
- var _props$library, _props$attributes$vie, _props$result, _props$result2, _props$result3;
46872
+ var _props$library, _props$attributes$vie;
46518
46873
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
46519
46874
  textOverride = _useDashboardBehaviou.textOverride,
46520
- valueAlias = _useDashboardBehaviou.valueAlias;
46875
+ valueAlias = _useDashboardBehaviou.valueAlias,
46876
+ labelFormat = _useDashboardBehaviou.labelFormat,
46877
+ queryEngineConfig = _useDashboardBehaviou.queryEngineConfig;
46521
46878
  var headerProps = {
46522
46879
  displayTitle: props.attributes.displayTitle,
46523
46880
  displaySubject: props.attributes.displaySubject,
@@ -46538,12 +46895,12 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
46538
46895
  var showHeadline = headlineAvailable(props.attributes.order, props.attributes.headline, null);
46539
46896
  var theme = useTheme();
46540
46897
  var BubbleChartV2Component = getComponentInterface(props.attributes.type);
46541
- var pivotConfig = init$d(props.attributes.xMeasure, props.attributes.measure);
46898
+ var pivotConfig = init$c(props.attributes);
46542
46899
  var chartRepresentation = null;
46543
46900
  if (!isLoading(props.result) && !hasFailed(props.result) && !isEmpty(props.result) && BubbleChartV2Component.isRunnable(props.attributes)) {
46544
46901
  var _theme$charts$colors, _theme$charts, _props$attributes$goa;
46545
46902
  chartRepresentation = buildBubbleChartRepresentation({
46546
- zFieldId: id(props.attributes.zMeasure[0]),
46903
+ zFieldId: props.attributes.zMeasure[0].field,
46547
46904
  axisTitles: props.attributes.axisTitles,
46548
46905
  xAxisPostfix: props.attributes.xAxisPostfix,
46549
46906
  xAxisPrefix: props.attributes.xAxisPrefix,
@@ -46551,7 +46908,7 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
46551
46908
  yAxisPrefix: props.attributes.yAxisPrefix,
46552
46909
  yAxisFormat: props.attributes.yAxisFormat,
46553
46910
  xAxisFormat: props.attributes.xAxisFormat,
46554
- approxYAxisLabelCount: props.attributes.approxYAxisLabelCount,
46911
+ approxYAxisLabelCount: props.attributes.approxYAxisLabelCount === 'auto' ? 10 : props.attributes.approxYAxisLabelCount,
46555
46912
  colors: (_theme$charts$colors = theme == null || (_theme$charts = theme.charts) == null ? void 0 : _theme$charts.colors) != null ? _theme$charts$colors : DEFAULT_CHART_COLORS,
46556
46913
  valueAlias: valueAlias,
46557
46914
  nullValue: checkForNullValue(props.attributes.dataSetId, props.attributes.dimension, props.attributes.timeDimension, textOverride, valueAlias),
@@ -46562,7 +46919,27 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
46562
46919
  dateTimeFormatOptions: props.dateTimeFormatOptions,
46563
46920
  goalLineAttributes: (_props$attributes$goa = props.attributes.goalLines) != null ? _props$attributes$goa : [],
46564
46921
  conditionalFormattingAttributes: props.attributes.conditionalFormattingRules,
46565
- defaultFormats: props.defaultFormats
46922
+ trendsAndForecasts: props.attributes.trends,
46923
+ defaultFormats: props.defaultFormats,
46924
+ seriesLabelFormatter: function seriesLabelFormatter(labelFormatParams) {
46925
+ var _queryEngineConfig$su, _queryEngineConfig$su2, _queryEngineConfig$su3;
46926
+ var yResultField = labelFormatParams.yResultField,
46927
+ yPivotFields = labelFormatParams.yPivotFields,
46928
+ row = labelFormatParams.row;
46929
+ var formattedFunctionName = ((_queryEngineConfig$su = queryEngineConfig.supportedAggregates[yResultField["function"]]) == null ? void 0 : _queryEngineConfig$su.publicName) || ((_queryEngineConfig$su2 = queryEngineConfig.supportedTimeTruncFunctions[yResultField["function"]]) == null ? void 0 : _queryEngineConfig$su2.publicName) || ((_queryEngineConfig$su3 = queryEngineConfig.supportedTransformationFunctions[yResultField["function"]]) == null ? void 0 : _queryEngineConfig$su3.publicName);
46930
+ var formattedFunction = yResultField["function"] === 'none' ? '' : " \u2022 " + formattedFunctionName;
46931
+ var defaultLabelFormat = "" + yPivotFields.map(function (field) {
46932
+ return row[field.id].formattedValue;
46933
+ }).join(' • ') + (yPivotFields.length === 0 ? '' : ' • ') + yResultField.publicName + formattedFunction;
46934
+ if (!labelFormat) return defaultLabelFormat;
46935
+ return labelFormat({
46936
+ viewId: props.attributes.viewId,
46937
+ fieldId: yResultField.fieldId,
46938
+ func: yResultField["function"],
46939
+ type: 'bubbleChartV2',
46940
+ defaultLabel: defaultLabelFormat
46941
+ }) || defaultLabelFormat;
46942
+ }
46566
46943
  });
46567
46944
  }
46568
46945
 
@@ -46572,16 +46949,6 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
46572
46949
  title: "Missing parameters"
46573
46950
  });
46574
46951
  }
46575
- if (((_props$result = props.result) == null ? void 0 : _props$result.fields.filter(function (r) {
46576
- return pivotConfig.x.includes(r.id);
46577
- }).length) === 0) return jsx(LoadingComponent, {});
46578
- if (((_props$result2 = props.result) == null ? void 0 : _props$result2.fields.filter(function (r) {
46579
- return pivotConfig.y.includes(r.id);
46580
- }).length) === 0) return jsx(LoadingComponent, {});
46581
- if (((_props$result3 = props.result) == null ? void 0 : _props$result3.fields.filter(function (r) {
46582
- var _Field$id;
46583
- return (_Field$id = id(props.attributes.zMeasure[0])) == null ? void 0 : _Field$id.includes(r.id);
46584
- }).length) === 0) return jsx(LoadingComponent, {});
46585
46952
  if (isLoading(props.result)) return jsx(LoadingComponent, {});
46586
46953
  if (hasFailed(props.result)) return jsx(FailedToLoadDataNotice, {});
46587
46954
  if (isEmpty(props.result)) return jsx(NoResultContentToShowNotice, _extends({}, headerProps));
@@ -46631,15 +46998,15 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
46631
46998
 
46632
46999
  var BubbleChartV2$1 = function BubbleChartV2(props) {
46633
47000
  var _props$component = props.component,
47001
+ results = _props$component.results,
46634
47002
  attributes = _props$component.attributes,
46635
47003
  localFilters = _props$component.localFilters;
46636
47004
  var dashboardBehaviour = props.dashboardBehaviour;
46637
47005
  var _useComponentEffect = useComponentEffect(attributes, props.dataSet, dashboardBehaviour.queryEngineConfig, {
46638
47006
  localFilters: localFilters,
46639
47007
  globalFilters: props.globalFilters
46640
- }, props.updateComponentAttributes, props.runQueriesCallback, dashboardBehaviour.variables),
46641
- queriesAreChanging = _useComponentEffect.queriesAreChanging,
46642
- results = _useComponentEffect.results;
47008
+ }, props.updateComponentAttributes, props.runQueriesCallback, props.setResults, dashboardBehaviour.variables),
47009
+ queriesAreChanging = _useComponentEffect.queriesAreChanging;
46643
47010
  return jsx(BubbleChartV2View, {
46644
47011
  id: props.id,
46645
47012
  attributes: attributes,
@@ -46793,76 +47160,7 @@ function getStyleDefinition$1(_ref) {
46793
47160
  });
46794
47161
  }
46795
47162
 
46796
- var formattedResultToSeries$1 = function formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter, zFieldId) {
46797
- var _formattedResult$fiel, _formattedResult$fiel2;
46798
- var keys = {};
46799
-
46800
- // Collect the result fields which are going to be used on the Y axis.
46801
- var yResultFields = formattedResult.fields.filter(function (resultField) {
46802
- var isNotXPivot = !pivotConfig.x.includes(resultField.id);
46803
- var isNotYPivot = !pivotConfig.y.includes(resultField.id);
46804
- return isNotXPivot && isNotYPivot;
46805
- });
46806
- var xPivotFields = formattedResult.fields.filter(function (resultField) {
46807
- return pivotConfig.x.includes(resultField.id);
46808
- });
46809
- var yPivotFields = formattedResult.fields.filter(function (resultField) {
46810
- return pivotConfig.y.includes(resultField.id);
46811
- });
46812
- var pivotedData = {};
46813
- var xKeyOrdering = [];
46814
- var yKeys = {};
46815
- formattedResult.contentMapped.forEach(function (row) {
46816
- xPivotFields.forEach(function (xPivotField) {
46817
- var _extends2;
46818
- var uniqueXValue = xPivotField.id + ":" + row[xPivotField.id].value;
46819
- xKeyOrdering.push(uniqueXValue);
46820
-
46821
- // Add any existing values, and the x key itself
46822
-
46823
- var yPivotPrefix = yPivotFields.map(function (yPivotField) {
46824
- return yPivotField.id + ":" + row[yPivotField.id].value;
46825
- }).join('_');
46826
- pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends2 = {}, _extends2[xPivotField.id] = row[xPivotField.id], _extends2));
46827
- yResultFields.forEach(function (yResultField) {
46828
- var _extends3;
46829
- var key = yPivotFields.length > 0 ? [yPivotPrefix, yResultField.id].join('_') : yResultField.id;
46830
- yKeys[key] = true;
46831
- keys[key] = {
46832
- key: key,
46833
- dataType: yResultField.dataType,
46834
- outputDataType: yResultField.outputDataType,
46835
- keyFormatted: seriesLabelFormatter({
46836
- yResultField: yResultField,
46837
- yPivotFields: yPivotFields,
46838
- row: row
46839
- })
46840
- };
46841
- pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends3 = {}, _extends3[key] = row[yResultField.id], _extends3));
46842
- });
46843
- });
46844
- });
46845
- var seriesDataFlattened = uniq(xKeyOrdering).map(function (xKey) {
46846
- return pivotedData[xKey];
46847
- });
46848
- var mappedXKeys = xPivotFields.map(function (r) {
46849
- return r.id;
46850
- });
46851
- var mappedYKeys = Object.keys(yKeys);
46852
- var mappedZKey = (_formattedResult$fiel = (_formattedResult$fiel2 = formattedResult.fields.find(function (resultField) {
46853
- return resultField.fieldId === zFieldId;
46854
- })) == null ? void 0 : _formattedResult$fiel2.id) != null ? _formattedResult$fiel : '';
46855
- var formattedResultReturn = {
46856
- xKeys: mappedXKeys,
46857
- yKeys: mappedYKeys,
46858
- zKey: mappedZKey,
46859
- keys: keys,
46860
- seriesData: seriesDataFlattened
46861
- };
46862
- return formattedResultReturn;
46863
- };
46864
-
46865
- var buildTrendAndForecast = function buildTrendAndForecast(_ref) {
47163
+ var buildTrendAndForecast$1 = function buildTrendAndForecast(_ref) {
46866
47164
  var data = _ref.data,
46867
47165
  forecastUnits = _ref.forecastUnits,
46868
47166
  xKey = _ref.xKey,
@@ -46955,7 +47253,7 @@ var buildTrendAndForecast = function buildTrendAndForecast(_ref) {
46955
47253
  };
46956
47254
  };
46957
47255
 
46958
- var getTrendsAndForecastsData = function getTrendsAndForecastsData(_ref) {
47256
+ var getTrendsAndForecastsData$1 = function getTrendsAndForecastsData(_ref) {
46959
47257
  var _trendsAndForecasts$;
46960
47258
  var chartData = _ref.chartData,
46961
47259
  formattingFunctionX = _ref.formattingFunctionX,
@@ -46984,7 +47282,7 @@ var getTrendsAndForecastsData = function getTrendsAndForecastsData(_ref) {
46984
47282
  var forecastUnits = trendsAndForecasts[0].type === 'Forecast' ? (_trendsAndForecasts$ = trendsAndForecasts[0].value) != null ? _trendsAndForecasts$ : 0 : 0;
46985
47283
  var yKey = yKeys[0];
46986
47284
  var newKeys = cloneDeep(keys);
46987
- var _buildTrendAndForecas = buildTrendAndForecast({
47285
+ var _buildTrendAndForecas = buildTrendAndForecast$1({
46988
47286
  data: chartData,
46989
47287
  forecastUnits: forecastUnits,
46990
47288
  xKey: xKey,
@@ -47423,7 +47721,7 @@ var buildLineChartRepresentation = function buildLineChartRepresentation(_ref) {
47423
47721
 
47424
47722
  // ----- Keys & Prep -----
47425
47723
  var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
47426
- var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
47724
+ var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
47427
47725
  keys = _formattedResultToSer.keys,
47428
47726
  yKeys = _formattedResultToSer.yKeys,
47429
47727
  xKeys = _formattedResultToSer.xKeys,
@@ -47433,7 +47731,7 @@ var buildLineChartRepresentation = function buildLineChartRepresentation(_ref) {
47433
47731
  // ----- Trends & Forecasts -----
47434
47732
 
47435
47733
  var orderFunction = order.length > 0 ? order[0]["function"] : undefined;
47436
- var trendsAndForecastData = getTrendsAndForecastsData({
47734
+ var trendsAndForecastData = getTrendsAndForecastsData$1({
47437
47735
  chartData: chartData,
47438
47736
  formattingFunctionX: function formattingFunctionX$1(value) {
47439
47737
  return formattingFunctionX(value, formattedResult, xKeyField);
@@ -47665,15 +47963,15 @@ var LineChartV2View = function LineChartV2View(props) {
47665
47963
 
47666
47964
  var LineChartV2 = function LineChartV2(props) {
47667
47965
  var _props$component = props.component,
47966
+ results = _props$component.results,
47668
47967
  attributes = _props$component.attributes,
47669
47968
  localFilters = _props$component.localFilters;
47670
47969
  var dashboardBehaviour = props.dashboardBehaviour;
47671
47970
  var _useComponentEffect = useComponentEffect(attributes, props.dataSet, dashboardBehaviour.queryEngineConfig, {
47672
47971
  localFilters: localFilters,
47673
47972
  globalFilters: props.globalFilters
47674
- }, props.updateComponentAttributes, props.runQueriesCallback, dashboardBehaviour.variables),
47675
- queriesAreChanging = _useComponentEffect.queriesAreChanging,
47676
- results = _useComponentEffect.results;
47973
+ }, props.updateComponentAttributes, props.runQueriesCallback, props.setResults, dashboardBehaviour.variables),
47974
+ queriesAreChanging = _useComponentEffect.queriesAreChanging;
47677
47975
  return jsx(LineChartV2View, {
47678
47976
  id: props.id,
47679
47977
  attributes: attributes,
@@ -47802,7 +48100,7 @@ var buildAreaChartRepresentation = function buildAreaChartRepresentation(_ref) {
47802
48100
 
47803
48101
  // ----- Keys & Prep -----
47804
48102
  var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
47805
- var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
48103
+ var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
47806
48104
  keys = _formattedResultToSer.keys,
47807
48105
  yKeys = _formattedResultToSer.yKeys,
47808
48106
  xKeys = _formattedResultToSer.xKeys,
@@ -48037,15 +48335,15 @@ var AreaChartV2View = function AreaChartV2View(props) {
48037
48335
 
48038
48336
  var AreaChartV2 = function AreaChartV2(props) {
48039
48337
  var _props$component = props.component,
48338
+ results = _props$component.results,
48040
48339
  attributes = _props$component.attributes,
48041
48340
  localFilters = _props$component.localFilters;
48042
48341
  var dashboardBehaviour = props.dashboardBehaviour;
48043
48342
  var _useComponentEffect = useComponentEffect(attributes, props.dataSet, dashboardBehaviour.queryEngineConfig, {
48044
48343
  localFilters: localFilters,
48045
48344
  globalFilters: props.globalFilters
48046
- }, props.updateComponentAttributes, props.runQueriesCallback, dashboardBehaviour.variables),
48047
- queriesAreChanging = _useComponentEffect.queriesAreChanging,
48048
- results = _useComponentEffect.results;
48345
+ }, props.updateComponentAttributes, props.runQueriesCallback, props.setResults, dashboardBehaviour.variables),
48346
+ queriesAreChanging = _useComponentEffect.queriesAreChanging;
48049
48347
  return jsx(AreaChartV2View, {
48050
48348
  id: props.id,
48051
48349
  attributes: attributes,
@@ -48154,7 +48452,7 @@ var buildBarChartRepresentation = function buildBarChartRepresentation(_ref) {
48154
48452
 
48155
48453
  // ----- Keys & Prep -----
48156
48454
  var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
48157
- var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
48455
+ var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
48158
48456
  keys = _formattedResultToSer.keys,
48159
48457
  yKeys = _formattedResultToSer.yKeys,
48160
48458
  xKeys = _formattedResultToSer.xKeys,
@@ -48430,7 +48728,9 @@ var BarChartV2View = function BarChartV2View(props) {
48430
48728
  };
48431
48729
 
48432
48730
  var BarChartV2 = function BarChartV2(props) {
48433
- var localFilters = props.component.localFilters;
48731
+ var _props$component = props.component,
48732
+ results = _props$component.results,
48733
+ localFilters = _props$component.localFilters;
48434
48734
  var dashboardBehaviour = props.dashboardBehaviour;
48435
48735
  var _useState = useState(props.component.attributes),
48436
48736
  attributes = _useState[0],
@@ -48441,18 +48741,17 @@ var BarChartV2 = function BarChartV2(props) {
48441
48741
  setDrilldownSelections([]);
48442
48742
  }
48443
48743
  }, [JSON.stringify(props.component.attributes)]);
48444
- var _useComponentEffect = useComponentEffect(attributes, props.dataSet, dashboardBehaviour.queryEngineConfig, {
48445
- localFilters: localFilters,
48446
- globalFilters: props.globalFilters
48447
- }, props.updateComponentAttributes, props.runQueriesCallback, dashboardBehaviour.variables),
48448
- queriesAreChanging = _useComponentEffect.queriesAreChanging,
48449
- results = _useComponentEffect.results;
48450
48744
  var _useDrilldownSelectio = useDrilldownSelection(results, attributes, function (newAttributes) {
48451
48745
  return setAttributes(newAttributes);
48452
48746
  }, props.dataSet, dashboardBehaviour.queryEngineConfig, props.component.attributes.type === 'barChartV2'),
48453
48747
  onDrilldownChange = _useDrilldownSelectio.onDrilldownChange,
48454
48748
  setDrilldownSelections = _useDrilldownSelectio.setDrilldownSelections,
48455
48749
  drilldownSelections = _useDrilldownSelectio.drilldownSelections;
48750
+ var _useComponentEffect = useComponentEffect(attributes, props.dataSet, dashboardBehaviour.queryEngineConfig, {
48751
+ localFilters: localFilters,
48752
+ globalFilters: props.globalFilters
48753
+ }, props.updateComponentAttributes, props.runQueriesCallback, props.setResults, dashboardBehaviour.variables),
48754
+ queriesAreChanging = _useComponentEffect.queriesAreChanging;
48456
48755
  return jsx(BarChartV2View, {
48457
48756
  id: props.id,
48458
48757
  attributes: attributes,
@@ -48614,16 +48913,16 @@ var LINE_QUERY_INDEX = 0,
48614
48913
  BAR_QUERY_INDEX = 1;
48615
48914
  var ComboChart$3 = function ComboChart(props) {
48616
48915
  var _props$component = props.component,
48916
+ results = _props$component.results,
48617
48917
  attributes = _props$component.attributes,
48618
48918
  localFilters = _props$component.localFilters;
48619
48919
  var _useDashboardContext = useDashboardContext(),
48620
48920
  dashboard = _useDashboardContext.dashboard;
48621
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
48921
+ var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, props.setResults, {
48622
48922
  localFilters: localFilters,
48623
48923
  globalFilters: props.globalFilters
48624
48924
  }, props.dataSet, undefined, props.dashboardBehaviour.variables),
48625
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
48626
- results = _useQueryEffect.results;
48925
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
48627
48926
  return jsx(ComboChartView$1, _extends({
48628
48927
  id: props.id
48629
48928
  }, attributes, {
@@ -49124,16 +49423,16 @@ var LINE_QUERY_INDEX$1 = 0,
49124
49423
  BAR_QUERY_INDEX$1 = 1;
49125
49424
  var ComboChartV2$1 = function ComboChartV2(props) {
49126
49425
  var _props$component = props.component,
49426
+ results = _props$component.results,
49127
49427
  attributes = _props$component.attributes,
49128
49428
  localFilters = _props$component.localFilters;
49129
49429
  var _useDashboardContext = useDashboardContext(),
49130
49430
  dashboard = _useDashboardContext.dashboard;
49131
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
49431
+ var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, props.setResults, {
49132
49432
  localFilters: localFilters,
49133
49433
  globalFilters: props.globalFilters
49134
49434
  }, props.dataSet, undefined, props.dashboardBehaviour.variables),
49135
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
49136
- results = _useQueryEffect.results;
49435
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
49137
49436
  return jsx(ComboChartView$2, _extends({
49138
49437
  id: props.id
49139
49438
  }, attributes, {
@@ -50925,6 +51224,9 @@ var DataTableRow = function DataTableRow(props) {
50925
51224
  useEffect(function () {
50926
51225
  return setSelectedRow(undefined);
50927
51226
  }, [props.queriesAreChanging]);
51227
+ var _useState = useState(),
51228
+ results = _useState[0],
51229
+ _setResults = _useState[1];
50928
51230
  var expanded = selectedRow !== undefined;
50929
51231
  var hasDrilldown = drilldown && (drilldown == null ? void 0 : drilldown.length) > 0;
50930
51232
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
@@ -50950,7 +51252,13 @@ var DataTableRow = function DataTableRow(props) {
50950
51252
  renderTableCell: handleRenderTableCell
50951
51253
  }))
50952
51254
  }), (props == null ? void 0 : props.drilldownInputProps) && expanded && hasDrilldown && jsx(DrilldownRow, {
51255
+ setResults: function setResults(value) {
51256
+ return _setResults({
51257
+ results: value
51258
+ });
51259
+ },
50953
51260
  dataSet: dataSet,
51261
+ result: results == null ? void 0 : results.results[0],
50954
51262
  drilldownInputProps: props == null ? void 0 : props.drilldownInputProps,
50955
51263
  drilldown: drilldown,
50956
51264
  selectedRow: selectedRow,
@@ -50963,10 +51271,10 @@ var DataTableRow = function DataTableRow(props) {
50963
51271
  });
50964
51272
  };
50965
51273
  var DrilldownRow = function DrilldownRow(props) {
50966
- var _tableRepresentation$;
50967
- var _useState = useState(0),
50968
- offset = _useState[0],
50969
- setOffset = _useState[1];
51274
+ var _props$result, _tableRepresentation$;
51275
+ var _useState2 = useState(0),
51276
+ offset = _useState2[0],
51277
+ setOffset = _useState2[1];
50970
51278
  var _props$drilldownInput = props.drilldownInputProps,
50971
51279
  component = _props$drilldownInput.component,
50972
51280
  runQueriesCallback = _props$drilldownInput.runQueriesCallback;
@@ -50980,12 +51288,10 @@ var DrilldownRow = function DrilldownRow(props) {
50980
51288
  variables = _useDashboardBehaviou2.variables,
50981
51289
  valueAlias = _useDashboardBehaviou2.valueAlias;
50982
51290
  var updatedAttributes = buildDrilldownAttributes(component.attributes, decodeId(props.drilldown[0].subsetDimension, queryEngineConfig), props.dimension, props.selectedRow, offset);
50983
- var _useQueryEffect = useQueryEffect(updatedAttributes, runQueriesCallback, {
50984
- localFilters: component.localFilters,
50985
- globalFilters: props.drilldownInputProps.globalFilters
50986
- }, props.dataSet, undefined, variables),
50987
- _useQueryEffect$resul = _useQueryEffect.results,
50988
- result = _useQueryEffect$resul[0];
51291
+ useQueryEffect(updatedAttributes, runQueriesCallback, props == null ? void 0 : props.setResults, {
51292
+ localFilters: component.localFilters,
51293
+ globalFilters: props.drilldownInputProps.globalFilters
51294
+ }, props.dataSet, undefined, variables);
50989
51295
  var nullReplacementWithFieldId = function nullReplacementWithFieldId(fieldId) {
50990
51296
  return checkForNullValue(props.dataSet.id, [{
50991
51297
  field: fieldId,
@@ -50995,7 +51301,7 @@ var DrilldownRow = function DrilldownRow(props) {
50995
51301
  var tableRepresentation = useMemo(function () {
50996
51302
  return buildTableRepresentation({
50997
51303
  type: updatedAttributes.type,
50998
- result: result,
51304
+ result: props.result,
50999
51305
  exportNames: updatedAttributes.exportNames,
51000
51306
  prefixes: updatedAttributes.prefixes,
51001
51307
  dateTimeFormat: updatedAttributes.dateTimeFormat,
@@ -51015,10 +51321,10 @@ var DrilldownRow = function DrilldownRow(props) {
51015
51321
  hiddenFields: updatedAttributes.hiddenFields,
51016
51322
  valueAlias: valueAlias
51017
51323
  });
51018
- }, [updatedAttributes.type, result, updatedAttributes.exportNames, updatedAttributes.prefixes, updatedAttributes.dateTimeFormat, dateTimeFormatOptions, updatedAttributes.numberFormat, numberFormatOptions, queryEngineConfig.supportedAggregates, queryEngineConfig.supportedTimeTruncFunctions, undefined, updatedAttributes.measure, updatedAttributes.xMeasure, updatedAttributes.yMeasure, updatedAttributes.dimension]);
51324
+ }, [updatedAttributes.type, props.result, updatedAttributes.exportNames, updatedAttributes.prefixes, updatedAttributes.dateTimeFormat, dateTimeFormatOptions, updatedAttributes.numberFormat, numberFormatOptions, queryEngineConfig.supportedAggregates, queryEngineConfig.supportedTimeTruncFunctions, undefined, updatedAttributes.measure, updatedAttributes.xMeasure, updatedAttributes.yMeasure, updatedAttributes.dimension]);
51019
51325
  var TableFooter = useMemo(function () {
51020
51326
  return jsx(Fragment$1, {
51021
- children: result && jsx(Pagination, {
51327
+ children: props.result && jsx(Pagination, {
51022
51328
  offset: offset,
51023
51329
  limit: limit,
51024
51330
  onNext: function onNext() {
@@ -51038,10 +51344,10 @@ var DrilldownRow = function DrilldownRow(props) {
51038
51344
  textOverride: textOverride
51039
51345
  })
51040
51346
  });
51041
- }, [offset, limit, result == null ? void 0 : result.content.length, setOffset, tableRepresentation == null ? void 0 : tableRepresentation.content.length]);
51347
+ }, [offset, limit, (_props$result = props.result) == null ? void 0 : _props$result.content.length, setOffset, tableRepresentation == null ? void 0 : tableRepresentation.content.length]);
51042
51348
  var hidePaginations = offset === 0 && ((_tableRepresentation$ = tableRepresentation == null ? void 0 : tableRepresentation.content.length) != null ? _tableRepresentation$ : 0) < (limit != null ? limit : 0);
51043
51349
  var columnsNumber = props == null ? void 0 : props.tableRowProps.row.length;
51044
- if (isLoading(result)) return jsx(Table.TR, {
51350
+ if (isLoading(props.result)) return jsx(Table.TR, {
51045
51351
  level: 2,
51046
51352
  children: jsx(Table.TH, {
51047
51353
  colSpan: columnsNumber,
@@ -51050,7 +51356,7 @@ var DrilldownRow = function DrilldownRow(props) {
51050
51356
  })
51051
51357
  })
51052
51358
  });
51053
- if (hasFailed(result)) return jsx(FailedToLoadDataNotice, {});
51359
+ if (hasFailed(props.result)) return jsx(FailedToLoadDataNotice, {});
51054
51360
  return jsxs(Fragment, {
51055
51361
  children: [(tableRepresentation == null ? void 0 : tableRepresentation.content) && jsx(Fragment, {
51056
51362
  children: (tableRepresentation == null ? void 0 : tableRepresentation.content.length) > 0 ? jsx(Fragment, {
@@ -51506,14 +51812,14 @@ var DataTableView$1 = (function (props) {
51506
51812
 
51507
51813
  var DataTable$2 = function DataTable(props) {
51508
51814
  var _props$component = props.component,
51815
+ results = _props$component.results,
51509
51816
  attributes = _props$component.attributes,
51510
51817
  localFilters = _props$component.localFilters;
51511
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
51818
+ var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, props.setResults, {
51512
51819
  localFilters: localFilters,
51513
51820
  globalFilters: props.globalFilters
51514
51821
  }, props.dataSet, undefined, props.dashboardBehaviour.variables),
51515
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
51516
- results = _useQueryEffect.results;
51822
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
51517
51823
  var onNext = function onNext() {
51518
51824
  var _attributes$limit, _attributes$offset, _results$0$content$le, _results$;
51519
51825
  if (!hasNext({
@@ -51775,13 +52081,14 @@ var FunnelChart$2 = function FunnelChart(props) {
51775
52081
  var _useState = useState(props.component.attributes),
51776
52082
  attributes = _useState[0],
51777
52083
  setAttributes = _useState[1];
51778
- var localFilters = props.component.localFilters;
52084
+ var _props$component = props.component,
52085
+ localFilters = _props$component.localFilters,
52086
+ results = _props$component.results;
51779
52087
  var _useComponentEffect = useComponentEffect(attributes, props.dataSet, props.dashboardBehaviour.queryEngineConfig, {
51780
52088
  localFilters: localFilters,
51781
52089
  globalFilters: props.globalFilters
51782
- }, props.updateComponentAttributes, props.runQueriesCallback),
51783
- queriesAreChanging = _useComponentEffect.queriesAreChanging,
51784
- results = _useComponentEffect.results;
52090
+ }, props.updateComponentAttributes, props.runQueriesCallback, props.setResults),
52091
+ queriesAreChanging = _useComponentEffect.queriesAreChanging;
51785
52092
  useEffect(function () {
51786
52093
  if (!queriesAreChanging) {
51787
52094
  setAttributes(props.component.attributes);
@@ -51891,14 +52198,14 @@ var View$2 = (function (props) {
51891
52198
 
51892
52199
  var MercatorMap$3 = function MercatorMap(props) {
51893
52200
  var _props$component = props.component,
52201
+ results = _props$component.results,
51894
52202
  attributes = _props$component.attributes,
51895
52203
  localFilters = _props$component.localFilters;
51896
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
52204
+ var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, props.setResults, {
51897
52205
  localFilters: localFilters,
51898
52206
  globalFilters: props.globalFilters
51899
52207
  }, props.dataSet, undefined, props.dashboardBehaviour.variables),
51900
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
51901
- results = _useQueryEffect.results;
52208
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
51902
52209
  return jsx(View$2, _extends({}, attributes, {
51903
52210
  id: props.id,
51904
52211
  result: results && results[0],
@@ -52157,14 +52464,14 @@ ProgressView$1.defaultProps = defaultProps$9;
52157
52464
  var Progress$2 = function Progress(props) {
52158
52465
  var _props$dashboardBehav;
52159
52466
  var _props$component = props.component,
52467
+ results = _props$component.results,
52160
52468
  attributes = _props$component.attributes,
52161
52469
  localFilters = _props$component.localFilters;
52162
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
52470
+ var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, props.setResults, {
52163
52471
  localFilters: localFilters,
52164
52472
  globalFilters: props.globalFilters
52165
52473
  }, props.dataSet, undefined, props.dashboardBehaviour.variables),
52166
- queriesAreChanging = _useQueryEffect.queriesAreChanging,
52167
- results = _useQueryEffect.results;
52474
+ queriesAreChanging = _useQueryEffect.queriesAreChanging;
52168
52475
  return jsx(ProgressView$1, _extends({}, attributes, {
52169
52476
  id: props.id,
52170
52477
  dataSet: props.dataSet,
@@ -52371,7 +52678,7 @@ var buildRadarChartRepresentation = function buildRadarChartRepresentation(_ref)
52371
52678
  }).formattedValue;
52372
52679
  };
52373
52680
  var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
52374
- var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
52681
+ var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
52375
52682
  keys = _formattedResultToSer.keys,
52376
52683
  yKeys = _formattedResultToSer.yKeys,
52377
52684
  xKeys = _formattedResultToSer.xKeys,
@@ -52653,17 +52960,18 @@ var RadarChart$3 = function RadarChart(_ref) {
52653
52960
  runQueriesCallback = _ref.runQueriesCallback,
52654
52961
  setLocalFilters = _ref.setLocalFilters,
52655
52962
  _setPartialAttributes = _ref.setPartialAttributes,
52963
+ setResults = _ref.setResults,
52656
52964
  updateComponentAttributes = _ref.updateComponentAttributes;
52657
- var localFilters = component.localFilters;
52965
+ var localFilters = component.localFilters,
52966
+ results = component.results;
52658
52967
  var _useState = useState(component.attributes),
52659
52968
  attributes = _useState[0],
52660
52969
  setAttributes = _useState[1];
52661
52970
  var _useComponentEffect = useComponentEffect(component.attributes, dataSet, dashboardBehaviour.queryEngineConfig, {
52662
52971
  localFilters: localFilters,
52663
52972
  globalFilters: globalFilters
52664
- }, updateComponentAttributes, runQueriesCallback, dashboardBehaviour.variables),
52665
- queriesAreChanging = _useComponentEffect.queriesAreChanging,
52666
- results = _useComponentEffect.results;
52973
+ }, updateComponentAttributes, runQueriesCallback, setResults, dashboardBehaviour.variables),
52974
+ queriesAreChanging = _useComponentEffect.queriesAreChanging;
52667
52975
  useEffect(function () {
52668
52976
  if (!queriesAreChanging) {
52669
52977
  setAttributes(component.attributes);
@@ -52736,14 +53044,14 @@ var RichText$2 = function RichText(_props) {
52736
53044
  var SingleStat$2 = function SingleStat(props) {
52737
53045
  var _props$dashboardBehav;
52738
53046
  var _props$component = props.component,
53047
+ results = _props$component.results,
52739
53048
  attributes = _props$component.attributes,
52740
53049
  localFilters = _props$component.localFilters;
52741
53050
  var _useComponentEffect = useComponentEffect(attributes, props.dataSet, props.dashboardBehaviour.queryEngineConfig, {
52742
53051
  localFilters: localFilters,
52743
53052
  globalFilters: props.globalFilters
52744
- }, props.updateComponentAttributes, props.runQueriesCallback, props.dashboardBehaviour.variables),
52745
- queriesAreChanging = _useComponentEffect.queriesAreChanging,
52746
- results = _useComponentEffect.results;
53053
+ }, props.updateComponentAttributes, props.runQueriesCallback, props.setResults, props.dashboardBehaviour.variables),
53054
+ queriesAreChanging = _useComponentEffect.queriesAreChanging;
52747
53055
  return jsx(SingleStatView, _extends({}, attributes, {
52748
53056
  id: props.id,
52749
53057
  dataSet: props.dataSet,
@@ -52902,10 +53210,8 @@ var SunburstChartView = function SunburstChartView(props) {
52902
53210
  setTooltipLabel = _useState5[1];
52903
53211
  var xScale = scaleLinear$1().domain(xDomain).range(xRange);
52904
53212
  var yScale = scaleSqrt().domain(yDomain).range(yRange);
52905
- var width = props.width * 3 / 6;
52906
- var height = props.height * 0.9;
52907
- var minDimension = Math.min(props.width, props.height);
52908
- var centeredRatio = minDimension / 2.5;
53213
+ var width = props.width * 3 / 5;
53214
+ var height = 500;
52909
53215
  var sunburstChartComponent = getComponentInterface(props.attributes.type);
52910
53216
  var headerProps = {
52911
53217
  displayTitle: props.attributes.displayTitle,
@@ -52925,8 +53231,8 @@ var SunburstChartView = function SunburstChartView(props) {
52925
53231
  order: props.attributes.order
52926
53232
  };
52927
53233
  useEffect(function () {
52928
- setYRange([yRange[0], centeredRatio]);
52929
- }, [centeredRatio]);
53234
+ setYRange([yRange[0], width / 2]);
53235
+ }, [width]);
52930
53236
  var arc$1 = arc().startAngle(function (d) {
52931
53237
  return Math.max(0, Math.min(2 * Math.PI, xScale(d.x0)));
52932
53238
  }).endAngle(function (d) {
@@ -52939,7 +53245,7 @@ var SunburstChartView = function SunburstChartView(props) {
52939
53245
  var handleClick = function handleClick(d) {
52940
53246
  setXDomain([d.x0, d.x1]);
52941
53247
  setYDomain([d.y0, 1]);
52942
- setYRange([d.y0 ? 20 : 0, centeredRatio]);
53248
+ setYRange([d.y0 ? 20 : 0, width / 2]);
52943
53249
  };
52944
53250
  var handleUpdate = function handleUpdate(t, xd, yd, yr) {
52945
53251
  xScale.domain(xd(t));
@@ -53026,7 +53332,7 @@ var SunburstChartView = function SunburstChartView(props) {
53026
53332
  height: height,
53027
53333
  children: jsx(Partition, {
53028
53334
  top: 0,
53029
- left: centerX + DEFAULT_MARGINS.left,
53335
+ left: centerX * 2 / 3,
53030
53336
  root: root,
53031
53337
  children: jsx(Spring, {
53032
53338
  reset: true,
@@ -53106,12 +53412,13 @@ var SunburstChartView = function SunburstChartView(props) {
53106
53412
  };
53107
53413
 
53108
53414
  var SunburstChart$2 = function SunburstChart(props) {
53109
- var attributes = props.component.attributes;
53110
- var _useQueryEffect = useQueryEffect(attributes, props.runQueriesCallback, {
53111
- localFilters: props.component.localFilters,
53112
- globalFilters: props.globalFilters
53113
- }, props.dataSet, undefined, props.dashboardBehaviour.variables),
53114
- results = _useQueryEffect.results;
53415
+ var _props$component = props.component,
53416
+ results = _props$component.results,
53417
+ attributes = _props$component.attributes;
53418
+ useQueryEffect(attributes, props.runQueriesCallback, props.setResults, {
53419
+ localFilters: props.component.localFilters,
53420
+ globalFilters: props.globalFilters
53421
+ }, props.dataSet, undefined, props.dashboardBehaviour.variables);
53115
53422
  var params = {
53116
53423
  defaultFormats: props.dashboardBehaviour.defaultFormats,
53117
53424
  dateTimeFormatOptions: props.dashboardBehaviour.dateTimeFormatOptions,
@@ -53142,246 +53449,6 @@ var SunburstChart$2 = function SunburstChart(props) {
53142
53449
  });
53143
53450
  };
53144
53451
 
53145
- function getNiceInterval$3(interval) {
53146
- // Round the interval to a "nice" value (1, 2, 5, etc.)
53147
- var exponent = Math.floor(Math.log10(interval));
53148
- var fraction = interval / Math.pow(10, exponent);
53149
- var niceFraction;
53150
- if (fraction <= 1.5) niceFraction = 1;else if (fraction <= 3) niceFraction = 2;else if (fraction <= 7) niceFraction = 5;else niceFraction = 10;
53151
- return niceFraction * Math.pow(10, exponent);
53152
- }
53153
-
53154
- var getYTicks = function getYTicks(_ref) {
53155
- var yMinValue = _ref.yMinValue,
53156
- yMaxValue = _ref.yMaxValue,
53157
- approxYAxisLabelCount = _ref.approxYAxisLabelCount,
53158
- formattingFunctionY = _ref.formattingFunctionY;
53159
- var yTicks = [];
53160
- var yTickInterval = getNiceInterval$3((yMaxValue - yMinValue) / (approxYAxisLabelCount - 1));
53161
- for (var i = 0; i < approxYAxisLabelCount; i++) {
53162
- var value = (yMinValue + i) * yTickInterval;
53163
- var formattedValue = formattingFunctionY(value);
53164
- yTicks.push({
53165
- value: value,
53166
- formattedValue: formattedValue,
53167
- scaleValue: value
53168
- });
53169
- }
53170
- return yTicks;
53171
- };
53172
-
53173
- var getRepresentationData = function getRepresentationData(_ref) {
53174
- var content = _ref.content,
53175
- xKey = _ref.xKey,
53176
- yKey = _ref.yKey,
53177
- approxYAxisLabelCount = _ref.approxYAxisLabelCount,
53178
- showTotalBar = _ref.showTotalBar,
53179
- formattingFunctionY = _ref.formattingFunctionY;
53180
- var data = [];
53181
- var steps = [];
53182
- var xTicks = [];
53183
- var yValueSum = 0;
53184
- var yMinValue = 0;
53185
- var yMaxValue = 0;
53186
- content.forEach(function (dataItem, index) {
53187
- var _dataItem$xValueIndex, _dataItem$xValueIndex2, _dataItem$yValueIndex, _dataItem$yValueIndex2, _data$push;
53188
- var xValueIndex = 0;
53189
- var yValueIndex = 1;
53190
- var xValue = (_dataItem$xValueIndex = dataItem[xValueIndex]) == null ? void 0 : _dataItem$xValueIndex.value;
53191
- var xFormattedValue = (_dataItem$xValueIndex2 = dataItem[xValueIndex]) == null ? void 0 : _dataItem$xValueIndex2.formattedValue;
53192
- var yValue = Number((_dataItem$yValueIndex = (_dataItem$yValueIndex2 = dataItem[yValueIndex]) == null ? void 0 : _dataItem$yValueIndex2.value) != null ? _dataItem$yValueIndex : 0);
53193
- var yValueDiff = yValue;
53194
- if (index > 0) {
53195
- var _content$yValueIndex;
53196
- var prevYValue = Number((_content$yValueIndex = content[index - 1][yValueIndex]) == null ? void 0 : _content$yValueIndex.value);
53197
- yValueDiff = yValue - prevYValue;
53198
- }
53199
- var prevYValueSum = yValueSum;
53200
- yValueSum += yValueDiff;
53201
- data.push((_data$push = {}, _data$push[xKey] = {
53202
- value: xValue,
53203
- formattedValue: xFormattedValue
53204
- }, _data$push[yKey] = {
53205
- value: yValueDiff,
53206
- formattedValue: formattingFunctionY(yValueDiff)
53207
- }, _data$push));
53208
- xTicks.push({
53209
- value: xValue,
53210
- formattedValue: xFormattedValue,
53211
- scaleValue: xValue
53212
- });
53213
- steps.push({
53214
- x: xValue,
53215
- y: yValue,
53216
- start: prevYValueSum,
53217
- end: yValueSum
53218
- });
53219
- yMinValue = Math.floor(Math.min(yMinValue, yValue));
53220
- yMaxValue = Math.ceil(Math.max(yMaxValue, yValue));
53221
- });
53222
- if (showTotalBar) {
53223
- var _data$push2;
53224
- var totalLabel = 'Total';
53225
- steps.push({
53226
- x: totalLabel,
53227
- y: yValueSum,
53228
- start: 0,
53229
- end: yValueSum
53230
- });
53231
- data.push((_data$push2 = {}, _data$push2[xKey] = {
53232
- value: totalLabel,
53233
- formattedValue: totalLabel
53234
- }, _data$push2[yKey] = {
53235
- value: yValueSum,
53236
- formattedValue: formattingFunctionY(yValueSum)
53237
- }, _data$push2));
53238
- xTicks.push({
53239
- value: totalLabel,
53240
- formattedValue: totalLabel,
53241
- scaleValue: totalLabel
53242
- });
53243
- }
53244
- var yTicks = getYTicks({
53245
- yMinValue: yMinValue,
53246
- yMaxValue: yMaxValue,
53247
- approxYAxisLabelCount: approxYAxisLabelCount,
53248
- formattingFunctionY: formattingFunctionY
53249
- });
53250
- return {
53251
- data: data,
53252
- steps: steps,
53253
- xTicks: xTicks,
53254
- yTicks: yTicks,
53255
- yMinValue: yMinValue,
53256
- yMaxValue: yMaxValue
53257
- };
53258
- };
53259
-
53260
- var buildWaterfallChartRepresentation = function buildWaterfallChartRepresentation(_ref) {
53261
- var _formattedResult$fiel, _formattedResult$fiel2, _axisTitles$x, _axisTitles$y;
53262
- var approxYAxisLabelCount = _ref.approxYAxisLabelCount,
53263
- axisTitles = _ref.axisTitles,
53264
- dateTimeFormatOptions = _ref.dateTimeFormatOptions,
53265
- defaultFormats = _ref.defaultFormats,
53266
- nullValue = _ref.nullValue,
53267
- numberFormatOptions = _ref.numberFormatOptions,
53268
- pivotConfig = _ref.pivotConfig,
53269
- result = _ref.result,
53270
- showTotalBar = _ref.showTotalBar,
53271
- _valueAlias = _ref.valueAlias,
53272
- xAxisFormat = _ref.xAxisFormat,
53273
- xAxisPrefix = _ref.xAxisPrefix,
53274
- xAxisPostfix = _ref.xAxisPostfix,
53275
- yAxisFormat = _ref.yAxisFormat,
53276
- yAxisPrefix = _ref.yAxisPrefix,
53277
- yAxisPostfix = _ref.yAxisPostfix;
53278
- var activeDateTimeFormats = {};
53279
- var _buildFieldFormatMaps = buildFieldFormatMaps(result, pivotConfig, xAxisPrefix, xAxisPostfix, xAxisFormat, yAxisPrefix, yAxisPostfix, yAxisFormat, nullValue, numberFormatOptions),
53280
- allPrefixes = _buildFieldFormatMaps.allPrefixes,
53281
- allPostfixes = _buildFieldFormatMaps.allPostfixes,
53282
- nullValues = _buildFieldFormatMaps.nullValues,
53283
- activeNumberFormats = _buildFieldFormatMaps.activeNumberFormats;
53284
- var params = {
53285
- defaultFormats: defaultFormats,
53286
- dateTimeFormatOptions: dateTimeFormatOptions,
53287
- numberFormatOptions: numberFormatOptions,
53288
- valueAlias: function valueAlias(params) {
53289
- if (typeof _valueAlias === 'function') {
53290
- return String(_valueAlias({
53291
- fieldId: id({
53292
- field: params.fieldId,
53293
- "function": params["function"]
53294
- }),
53295
- value: params.value
53296
- }));
53297
- }
53298
- return undefined;
53299
- },
53300
- nullValue: nullValues,
53301
- prefixes: allPrefixes,
53302
- postfixes: allPostfixes,
53303
- activeNumberFormats: activeNumberFormats,
53304
- activeDateTimeFormats: activeDateTimeFormats
53305
- };
53306
- var formattedResult = formatResult(result, params);
53307
- var formattingFunctionY = function formattingFunctionY(value) {
53308
- // Use any y axis field as they are all formatted in the same way (for now...);
53309
- var nonPivotField = formattedResult.fields.find(function (resultField) {
53310
- return ![].concat(pivotConfig.x, pivotConfig.y).includes(resultField.id);
53311
- });
53312
- if (!nonPivotField) return '';
53313
- return formattedResult.formatterFunc(value, {
53314
- fieldId: nonPivotField.fieldId,
53315
- "function": nonPivotField["function"],
53316
- outputDataType: nonPivotField.outputDataType
53317
- }).formattedValue;
53318
- };
53319
- var keys = formattedResult.fields.map(function (field) {
53320
- var _ref2;
53321
- var key = field.fieldId;
53322
- var keyFormatted = field.publicName;
53323
- var dataType = field.dataType;
53324
- return _ref2 = {}, _ref2[key] = {
53325
- key: key,
53326
- keyFormatted: keyFormatted,
53327
- dataType: dataType
53328
- }, _ref2;
53329
- });
53330
- var xKey = (_formattedResult$fiel = formattedResult.fields[0]) == null ? void 0 : _formattedResult$fiel.fieldId;
53331
- var yKey = (_formattedResult$fiel2 = formattedResult.fields[1]) == null ? void 0 : _formattedResult$fiel2.fieldId;
53332
- var content = formattedResult.content;
53333
- var _getRepresentationDat = getRepresentationData({
53334
- content: content,
53335
- xKey: xKey,
53336
- yKey: yKey,
53337
- approxYAxisLabelCount: approxYAxisLabelCount,
53338
- showTotalBar: showTotalBar,
53339
- formattingFunctionY: formattingFunctionY
53340
- }),
53341
- data = _getRepresentationDat.data,
53342
- steps = _getRepresentationDat.steps,
53343
- xTicks = _getRepresentationDat.xTicks,
53344
- yTicks = _getRepresentationDat.yTicks,
53345
- yMinValue = _getRepresentationDat.yMinValue,
53346
- yMaxValue = _getRepresentationDat.yMaxValue;
53347
- var chartRepresentation = {
53348
- keys: _extends({}, keys[0], keys[1]),
53349
- x: {
53350
- title: (_axisTitles$x = axisTitles == null ? void 0 : axisTitles.x) != null ? _axisTitles$x : null,
53351
- ticks: xTicks,
53352
- prefix: xAxisPrefix,
53353
- postfix: xAxisPostfix,
53354
- key: xKey,
53355
- scale: {
53356
- dataType: 'string',
53357
- key: xKey,
53358
- ordering: null,
53359
- min: null,
53360
- max: null
53361
- }
53362
- },
53363
- y: {
53364
- title: (_axisTitles$y = axisTitles == null ? void 0 : axisTitles.y) != null ? _axisTitles$y : null,
53365
- ticks: yTicks,
53366
- key: yKey,
53367
- prefix: yAxisPrefix,
53368
- postfix: yAxisPostfix,
53369
- scale: {
53370
- dataType: 'number',
53371
- key: null,
53372
- ordering: 'asc',
53373
- min: yMinValue,
53374
- max: yMaxValue
53375
- }
53376
- },
53377
- data: data
53378
- };
53379
- return {
53380
- waterfallChartRepresentation: chartRepresentation,
53381
- waterfallChartSteps: steps
53382
- };
53383
- };
53384
-
53385
53452
  var ASSUMED_AVERAGE_CHAR_WIDTH$2 = 8.8;
53386
53453
  function calculateWordWidth$1(word, avgCharWidth) {
53387
53454
  if (avgCharWidth === void 0) {
@@ -53391,7 +53458,7 @@ function calculateWordWidth$1(word, avgCharWidth) {
53391
53458
  }
53392
53459
 
53393
53460
  /** Reduce width proportionally to simulate spacing / padding between ticks. */
53394
- var widthWithSpacing = function widthWithSpacing(width) {
53461
+ var widthWithSpacing$1 = function widthWithSpacing(width) {
53395
53462
  var THIRTY_PERCENT = 0.3;
53396
53463
  return width - width * THIRTY_PERCENT;
53397
53464
  };
@@ -53405,7 +53472,7 @@ function howManyTicksFitInWidth$1(ticks, maxWidth, avgCharWidth) {
53405
53472
  var tick = _step.value;
53406
53473
  var word = (tick == null ? void 0 : tick.formattedValue) || '';
53407
53474
  var wordWidth = calculateWordWidth$1(word, avgCharWidth);
53408
- if (currentWidth + wordWidth <= widthWithSpacing(maxWidth)) {
53475
+ if (currentWidth + wordWidth <= widthWithSpacing$1(maxWidth)) {
53409
53476
  fittedTicks.push(tick);
53410
53477
  currentWidth += wordWidth + avgCharWidth; // Add space between words
53411
53478
  } else {
@@ -53483,7 +53550,7 @@ var Tooltip$2 = function Tooltip(_ref) {
53483
53550
  if (!showTooltip || !tooltipData) return null;
53484
53551
  var value = tooltipData[yKey].value;
53485
53552
  var isPositiveValue = Number(value) > 0;
53486
- return /*#__PURE__*/createPortal(jsx(TooltipWithBounds, {
53553
+ return jsx(TooltipWithBounds, {
53487
53554
  left: tooltipLeft,
53488
53555
  top: tooltipTop,
53489
53556
  style: theme,
@@ -53518,7 +53585,7 @@ var Tooltip$2 = function Tooltip(_ref) {
53518
53585
  })]
53519
53586
  })]
53520
53587
  })
53521
- }, Math.random()), document.body);
53588
+ }, Math.random());
53522
53589
  };
53523
53590
  var IconNarrowRight$1 = function IconNarrowRight() {
53524
53591
  var style = {
@@ -53526,7 +53593,7 @@ var IconNarrowRight$1 = function IconNarrowRight() {
53526
53593
  height: 20,
53527
53594
  display: 'block'
53528
53595
  };
53529
- var fill = '#12B76A';
53596
+ var fill = "#12B76A";
53530
53597
  return jsx("svg", {
53531
53598
  fill: "none",
53532
53599
  xmlns: "http://www.w3.org/2000/svg",
@@ -53546,7 +53613,7 @@ var IconTrendingDown$1 = function IconTrendingDown() {
53546
53613
  height: 20,
53547
53614
  display: 'block'
53548
53615
  };
53549
- var fill = '#F04438';
53616
+ var fill = "#F04438";
53550
53617
  return jsx("svg", {
53551
53618
  fill: "none",
53552
53619
  xmlns: "http://www.w3.org/2000/svg",
@@ -53604,7 +53671,7 @@ var Legend$2 = function Legend(_ref) {
53604
53671
  });
53605
53672
  };
53606
53673
 
53607
- var _excluded$i = ["formattedValue"],
53674
+ var _excluded$h = ["formattedValue"],
53608
53675
  _excluded2$4 = ["formattedValue"];
53609
53676
  var AXIS_TITLE_STYLES$1 = {
53610
53677
  opacity: '0.75',
@@ -53714,8 +53781,8 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
53714
53781
  return Number(tick.value);
53715
53782
  });
53716
53783
  var xTickValues = formattedChartDataForBarChart.x.ticks.length > 0 ? formattedChartDataForBarChart.x.ticks.map(function (tick) {
53717
- var _String;
53718
- return (_String = String(tick.scaleValue)) != null ? _String : '';
53784
+ var _tick$scaleValue;
53785
+ return (_tick$scaleValue = tick.scaleValue) != null ? _tick$scaleValue : 0;
53719
53786
  }) : undefined;
53720
53787
  var handleMouseMove = useCallback(function (event) {
53721
53788
  if (!xKey || !xScaleKey || xScale === null) return;
@@ -53748,7 +53815,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
53748
53815
  tick = matchingTickValue || null;
53749
53816
  } else {
53750
53817
  var _matchingTickValue = formattedChartDataForBarChart.x.ticks.find(function (tickValue) {
53751
- return String(tickValue.scaleValue) === value;
53818
+ return tickValue.scaleValue === value;
53752
53819
  });
53753
53820
  tick = _matchingTickValue || null;
53754
53821
  }
@@ -53773,10 +53840,10 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
53773
53840
  return '';
53774
53841
  }, [formattedChartDataForBarChart.y.ticks]);
53775
53842
  var getBarGroupPosition = useCallback(function (d) {
53776
- if (xScaleKey == null || d == null) return '';
53843
+ if (xScaleKey == null || d == null) return;
53777
53844
  var xValue = d[xScaleKey];
53778
- if (xScaleDataType === 'string') return String(xValue);
53779
- return '';
53845
+ if (xScaleDataType === 'string') return xValue;
53846
+ return;
53780
53847
  }, [xScaleKey, xScaleDataType]);
53781
53848
  if (width === 0 || height === 0 || xScale == null) return null;
53782
53849
  return jsxs(Fragment$1, {
@@ -53814,7 +53881,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
53814
53881
  tickValues: xTickValues,
53815
53882
  tickComponent: function tickComponent(_ref2) {
53816
53883
  var formattedValue = _ref2.formattedValue,
53817
- tickProps = _objectWithoutPropertiesLoose(_ref2, _excluded$i);
53884
+ tickProps = _objectWithoutPropertiesLoose(_ref2, _excluded$h);
53818
53885
  return jsx(Text, _extends({
53819
53886
  style: themeCSS.labels
53820
53887
  }, tickProps, {
@@ -53926,6 +53993,245 @@ var Bar$2 = function Bar(_ref4) {
53926
53993
  });
53927
53994
  };
53928
53995
 
53996
+ function getNiceInterval$3(interval) {
53997
+ // Round the interval to a "nice" value (1, 2, 5, etc.)
53998
+ var exponent = Math.floor(Math.log10(interval));
53999
+ var fraction = interval / Math.pow(10, exponent);
54000
+ var niceFraction;
54001
+ if (fraction <= 1.5) niceFraction = 1;else if (fraction <= 3) niceFraction = 2;else if (fraction <= 7) niceFraction = 5;else niceFraction = 10;
54002
+ return niceFraction * Math.pow(10, exponent);
54003
+ }
54004
+
54005
+ var getYTicks = function getYTicks(_ref) {
54006
+ var yMinValue = _ref.yMinValue,
54007
+ yMaxValue = _ref.yMaxValue,
54008
+ approxYAxisLabelCount = _ref.approxYAxisLabelCount,
54009
+ formattingFunctionY = _ref.formattingFunctionY;
54010
+ var yTicks = [];
54011
+ var yTickInterval = getNiceInterval$3((yMaxValue - yMinValue) / (approxYAxisLabelCount - 1));
54012
+ for (var i = 0; i < approxYAxisLabelCount; i++) {
54013
+ var value = (yMinValue + i) * yTickInterval;
54014
+ var formattedValue = formattingFunctionY(value);
54015
+ yTicks.push({
54016
+ value: value,
54017
+ formattedValue: formattedValue,
54018
+ scaleValue: value
54019
+ });
54020
+ }
54021
+ return yTicks;
54022
+ };
54023
+
54024
+ var getRepresentationData = function getRepresentationData(_ref) {
54025
+ var content = _ref.content,
54026
+ xKey = _ref.xKey,
54027
+ yKey = _ref.yKey,
54028
+ approxYAxisLabelCount = _ref.approxYAxisLabelCount,
54029
+ showTotalBar = _ref.showTotalBar,
54030
+ formattingFunctionY = _ref.formattingFunctionY;
54031
+ var data = [];
54032
+ var steps = [];
54033
+ var xTicks = [];
54034
+ var yValueSum = 0;
54035
+ var yMinValue = 0;
54036
+ var yMaxValue = 0;
54037
+ content.forEach(function (dataItem, index) {
54038
+ var _data$push;
54039
+ var xValueIndex = 0;
54040
+ var yValueIndex = 1;
54041
+ var xValue = dataItem[xValueIndex].value;
54042
+ var xFormattedValue = dataItem[xValueIndex].formattedValue;
54043
+ var yValue = Number(dataItem[yValueIndex].value);
54044
+ var yValueDiff = yValue;
54045
+ if (index > 0) {
54046
+ var prevYValue = Number(content[index - 1][yValueIndex].value);
54047
+ yValueDiff = yValue - prevYValue;
54048
+ }
54049
+ var prevYValueSum = yValueSum;
54050
+ yValueSum += yValueDiff;
54051
+ data.push((_data$push = {}, _data$push[xKey] = {
54052
+ value: xValue,
54053
+ formattedValue: xFormattedValue
54054
+ }, _data$push[yKey] = {
54055
+ value: yValueDiff,
54056
+ formattedValue: formattingFunctionY(yValueDiff)
54057
+ }, _data$push));
54058
+ xTicks.push({
54059
+ value: xValue,
54060
+ formattedValue: xFormattedValue,
54061
+ scaleValue: xValue
54062
+ });
54063
+ steps.push({
54064
+ x: xValue,
54065
+ y: yValue,
54066
+ start: prevYValueSum,
54067
+ end: yValueSum
54068
+ });
54069
+ yMinValue = Math.floor(Math.min(yMinValue, yValue));
54070
+ yMaxValue = Math.ceil(Math.max(yMaxValue, yValue));
54071
+ });
54072
+ if (showTotalBar) {
54073
+ var _data$push2;
54074
+ var totalLabel = 'Total';
54075
+ steps.push({
54076
+ x: totalLabel,
54077
+ y: yValueSum,
54078
+ start: 0,
54079
+ end: yValueSum
54080
+ });
54081
+ data.push((_data$push2 = {}, _data$push2[xKey] = {
54082
+ value: totalLabel,
54083
+ formattedValue: totalLabel
54084
+ }, _data$push2[yKey] = {
54085
+ value: yValueSum,
54086
+ formattedValue: formattingFunctionY(yValueSum)
54087
+ }, _data$push2));
54088
+ xTicks.push({
54089
+ value: totalLabel,
54090
+ formattedValue: totalLabel,
54091
+ scaleValue: totalLabel
54092
+ });
54093
+ }
54094
+ var yTicks = getYTicks({
54095
+ yMinValue: yMinValue,
54096
+ yMaxValue: yMaxValue,
54097
+ approxYAxisLabelCount: approxYAxisLabelCount,
54098
+ formattingFunctionY: formattingFunctionY
54099
+ });
54100
+ return {
54101
+ data: data,
54102
+ steps: steps,
54103
+ xTicks: xTicks,
54104
+ yTicks: yTicks,
54105
+ yMinValue: yMinValue,
54106
+ yMaxValue: yMaxValue
54107
+ };
54108
+ };
54109
+
54110
+ var buildWaterfallChartRepresentation = function buildWaterfallChartRepresentation(_ref) {
54111
+ var _formattedResult$fiel, _formattedResult$fiel2, _axisTitles$x, _axisTitles$y;
54112
+ var approxYAxisLabelCount = _ref.approxYAxisLabelCount,
54113
+ axisTitles = _ref.axisTitles,
54114
+ dateTimeFormatOptions = _ref.dateTimeFormatOptions,
54115
+ defaultFormats = _ref.defaultFormats,
54116
+ nullValue = _ref.nullValue,
54117
+ numberFormatOptions = _ref.numberFormatOptions,
54118
+ pivotConfig = _ref.pivotConfig,
54119
+ result = _ref.result,
54120
+ showTotalBar = _ref.showTotalBar,
54121
+ _valueAlias = _ref.valueAlias,
54122
+ xAxisFormat = _ref.xAxisFormat,
54123
+ xAxisPrefix = _ref.xAxisPrefix,
54124
+ xAxisPostfix = _ref.xAxisPostfix,
54125
+ yAxisFormat = _ref.yAxisFormat,
54126
+ yAxisPrefix = _ref.yAxisPrefix,
54127
+ yAxisPostfix = _ref.yAxisPostfix;
54128
+ var activeDateTimeFormats = {};
54129
+ var _buildFieldFormatMaps = buildFieldFormatMaps(result, pivotConfig, xAxisPrefix, xAxisPostfix, xAxisFormat, yAxisPrefix, yAxisPostfix, yAxisFormat, nullValue, numberFormatOptions),
54130
+ allPrefixes = _buildFieldFormatMaps.allPrefixes,
54131
+ allPostfixes = _buildFieldFormatMaps.allPostfixes,
54132
+ nullValues = _buildFieldFormatMaps.nullValues,
54133
+ activeNumberFormats = _buildFieldFormatMaps.activeNumberFormats;
54134
+ var params = {
54135
+ defaultFormats: defaultFormats,
54136
+ dateTimeFormatOptions: dateTimeFormatOptions,
54137
+ numberFormatOptions: numberFormatOptions,
54138
+ valueAlias: function valueAlias(params) {
54139
+ if (typeof _valueAlias === 'function') {
54140
+ return String(_valueAlias({
54141
+ fieldId: id({
54142
+ field: params.fieldId,
54143
+ "function": params["function"]
54144
+ }),
54145
+ value: params.value
54146
+ }));
54147
+ }
54148
+ return undefined;
54149
+ },
54150
+ nullValue: nullValues,
54151
+ prefixes: allPrefixes,
54152
+ postfixes: allPostfixes,
54153
+ activeNumberFormats: activeNumberFormats,
54154
+ activeDateTimeFormats: activeDateTimeFormats
54155
+ };
54156
+ var formattedResult = formatResult(result, params);
54157
+ var formattingFunctionY = function formattingFunctionY(value) {
54158
+ // Use any y axis field as they are all formatted in the same way (for now...);
54159
+ var nonPivotField = formattedResult.fields.find(function (resultField) {
54160
+ return ![].concat(pivotConfig.x, pivotConfig.y).includes(resultField.id);
54161
+ });
54162
+ if (!nonPivotField) return '';
54163
+ return formattedResult.formatterFunc(value, {
54164
+ fieldId: nonPivotField.fieldId,
54165
+ "function": nonPivotField["function"],
54166
+ outputDataType: nonPivotField.outputDataType
54167
+ }).formattedValue;
54168
+ };
54169
+ var keys = formattedResult.fields.map(function (field) {
54170
+ var _ref2;
54171
+ var key = field.fieldId;
54172
+ var keyFormatted = field.publicName;
54173
+ var dataType = field.dataType;
54174
+ return _ref2 = {}, _ref2[key] = {
54175
+ key: key,
54176
+ keyFormatted: keyFormatted,
54177
+ dataType: dataType
54178
+ }, _ref2;
54179
+ });
54180
+ var xKey = (_formattedResult$fiel = formattedResult.fields[0]) == null ? void 0 : _formattedResult$fiel.fieldId;
54181
+ var yKey = (_formattedResult$fiel2 = formattedResult.fields[1]) == null ? void 0 : _formattedResult$fiel2.fieldId;
54182
+ var content = formattedResult.content;
54183
+ var _getRepresentationDat = getRepresentationData({
54184
+ content: content,
54185
+ xKey: xKey,
54186
+ yKey: yKey,
54187
+ approxYAxisLabelCount: approxYAxisLabelCount,
54188
+ showTotalBar: showTotalBar,
54189
+ formattingFunctionY: formattingFunctionY
54190
+ }),
54191
+ data = _getRepresentationDat.data,
54192
+ steps = _getRepresentationDat.steps,
54193
+ xTicks = _getRepresentationDat.xTicks,
54194
+ yTicks = _getRepresentationDat.yTicks,
54195
+ yMinValue = _getRepresentationDat.yMinValue,
54196
+ yMaxValue = _getRepresentationDat.yMaxValue;
54197
+ var chartRepresentation = {
54198
+ keys: _extends({}, keys[0], keys[1]),
54199
+ x: {
54200
+ title: (_axisTitles$x = axisTitles == null ? void 0 : axisTitles.x) != null ? _axisTitles$x : null,
54201
+ ticks: xTicks,
54202
+ prefix: xAxisPrefix,
54203
+ postfix: xAxisPostfix,
54204
+ key: xKey,
54205
+ scale: {
54206
+ dataType: 'string',
54207
+ key: xKey,
54208
+ ordering: null,
54209
+ min: null,
54210
+ max: null
54211
+ }
54212
+ },
54213
+ y: {
54214
+ title: (_axisTitles$y = axisTitles == null ? void 0 : axisTitles.y) != null ? _axisTitles$y : null,
54215
+ ticks: yTicks,
54216
+ key: yKey,
54217
+ prefix: yAxisPrefix,
54218
+ postfix: yAxisPostfix,
54219
+ scale: {
54220
+ dataType: 'number',
54221
+ key: null,
54222
+ ordering: 'asc',
54223
+ min: yMinValue,
54224
+ max: yMaxValue
54225
+ }
54226
+ },
54227
+ data: data
54228
+ };
54229
+ return {
54230
+ waterfallChartRepresentation: chartRepresentation,
54231
+ waterfallChartSteps: steps
54232
+ };
54233
+ };
54234
+
53929
54235
  var WaterfallChartView = function WaterfallChartView(props) {
53930
54236
  var approxXAxisLabelCount = props.approxXAxisLabelCount,
53931
54237
  approxYAxisLabelCount = props.approxYAxisLabelCount,
@@ -53993,7 +54299,6 @@ var WaterfallChartView = function WaterfallChartView(props) {
53993
54299
  title: "Missing parameters"
53994
54300
  });
53995
54301
  if (isLoading(result)) return jsx(LoadingComponent, {});
53996
- if (isLoadingResult(result)) return jsx(LoadingComponent, {});
53997
54302
  if (hasFailed(result)) return jsx(FailedToLoadDataNotice, {});
53998
54303
  if (isEmpty(result)) return jsx(NoResultContentToShowNotice, _extends({}, headerProps));
53999
54304
  var showHeadline = headlineAvailable(order, headline, timeDimension);
@@ -54064,9 +54369,6 @@ var WaterfallChartView = function WaterfallChartView(props) {
54064
54369
  })
54065
54370
  });
54066
54371
  };
54067
- function isLoadingResult(result) {
54068
- return result != null && result.content[0].length ? (result == null ? void 0 : result.content[0].length) < 2 : false;
54069
- }
54070
54372
  var WaterfallChartView$1 = /*#__PURE__*/memo(WaterfallChartView, shouldUpdate);
54071
54373
 
54072
54374
  var WaterfallChart$3 = function WaterfallChart(_ref) {
@@ -54079,17 +54381,18 @@ var WaterfallChart$3 = function WaterfallChart(_ref) {
54079
54381
  runQueriesCallback = _ref.runQueriesCallback,
54080
54382
  setLocalFilters = _ref.setLocalFilters,
54081
54383
  _setPartialAttributes = _ref.setPartialAttributes,
54384
+ setResults = _ref.setResults,
54082
54385
  updateComponentAttributes = _ref.updateComponentAttributes;
54083
- var localFilters = component.localFilters;
54386
+ var localFilters = component.localFilters,
54387
+ results = component.results;
54084
54388
  var _useState = useState(component.attributes),
54085
54389
  attributes = _useState[0],
54086
54390
  setAttributes = _useState[1];
54087
54391
  var _useComponentEffect = useComponentEffect(component.attributes, dataSet, dashboardBehaviour.queryEngineConfig, {
54088
54392
  localFilters: localFilters,
54089
54393
  globalFilters: globalFilters
54090
- }, updateComponentAttributes, runQueriesCallback, dashboardBehaviour.variables),
54091
- queriesAreChanging = _useComponentEffect.queriesAreChanging,
54092
- results = _useComponentEffect.results;
54394
+ }, updateComponentAttributes, runQueriesCallback, setResults, dashboardBehaviour.variables),
54395
+ queriesAreChanging = _useComponentEffect.queriesAreChanging;
54093
54396
  useEffect(function () {
54094
54397
  if (!queriesAreChanging) {
54095
54398
  setAttributes(component.attributes);
@@ -54188,6 +54491,7 @@ var Component = function Component(props) {
54188
54491
  dataSet: dataSet,
54189
54492
  runQueriesCallback: props.runQueriesCallback,
54190
54493
  component: props.component,
54494
+ setResults: props.setResults,
54191
54495
  globalFilters: dashboard.globalFilters,
54192
54496
  dashboardBehaviour: dashboardBehaviour,
54193
54497
  sm: smallVersion,
@@ -54211,6 +54515,7 @@ var Component = function Component(props) {
54211
54515
  dataSet: dataSet,
54212
54516
  runQueriesCallback: props.runQueriesCallback,
54213
54517
  component: props.component,
54518
+ setResults: props.setResults,
54214
54519
  globalFilters: dashboard.globalFilters,
54215
54520
  dashboardBehaviour: dashboardBehaviour,
54216
54521
  sm: smallVersion,
@@ -54237,6 +54542,7 @@ var Component = function Component(props) {
54237
54542
  },
54238
54543
  runQueriesCallback: props.runQueriesCallback,
54239
54544
  component: props.component,
54545
+ setResults: props.setResults,
54240
54546
  globalFilters: dashboard.globalFilters,
54241
54547
  dashboardBehaviour: dashboardBehaviour,
54242
54548
  library: props == null ? void 0 : props.library,
@@ -54262,6 +54568,7 @@ var Component = function Component(props) {
54262
54568
  return _updateComponentAttributes(newAttributes);
54263
54569
  },
54264
54570
  component: props.component,
54571
+ setResults: props.setResults,
54265
54572
  globalFilters: dashboard.globalFilters,
54266
54573
  dashboardBehaviour: dashboardBehaviour,
54267
54574
  sm: smallVersion,
@@ -54287,6 +54594,7 @@ var Component = function Component(props) {
54287
54594
  dataSet: dataSet,
54288
54595
  runQueriesCallback: props.runQueriesCallback,
54289
54596
  component: props.component,
54597
+ setResults: props.setResults,
54290
54598
  globalFilters: dashboard.globalFilters,
54291
54599
  dashboardBehaviour: dashboardBehaviour,
54292
54600
  sm: smallVersion,
@@ -54316,6 +54624,7 @@ var Component = function Component(props) {
54316
54624
  },
54317
54625
  runQueriesCallback: props.runQueriesCallback,
54318
54626
  component: props.component,
54627
+ setResults: props.setResults,
54319
54628
  globalFilters: dashboard.globalFilters,
54320
54629
  dashboardBehaviour: dashboardBehaviour,
54321
54630
  sm: smallVersion,
@@ -54342,6 +54651,7 @@ var Component = function Component(props) {
54342
54651
  },
54343
54652
  runQueriesCallback: props.runQueriesCallback,
54344
54653
  component: props.component,
54654
+ setResults: props.setResults,
54345
54655
  globalFilters: dashboard.globalFilters,
54346
54656
  dashboardBehaviour: dashboardBehaviour,
54347
54657
  library: props == null ? void 0 : props.library,
@@ -54367,6 +54677,7 @@ var Component = function Component(props) {
54367
54677
  },
54368
54678
  runQueriesCallback: props.runQueriesCallback,
54369
54679
  component: props.component,
54680
+ setResults: props.setResults,
54370
54681
  globalFilters: dashboard.globalFilters,
54371
54682
  dashboardBehaviour: dashboardBehaviour,
54372
54683
  library: props == null ? void 0 : props.library,
@@ -54392,6 +54703,7 @@ var Component = function Component(props) {
54392
54703
  },
54393
54704
  runQueriesCallback: props.runQueriesCallback,
54394
54705
  component: props.component,
54706
+ setResults: props.setResults,
54395
54707
  globalFilters: dashboard.globalFilters,
54396
54708
  dashboardBehaviour: dashboardBehaviour,
54397
54709
  library: props == null ? void 0 : props.library,
@@ -54414,6 +54726,7 @@ var Component = function Component(props) {
54414
54726
  dataSet: dataSet,
54415
54727
  runQueriesCallback: props.runQueriesCallback,
54416
54728
  component: props.component,
54729
+ setResults: props.setResults,
54417
54730
  globalFilters: dashboard.globalFilters,
54418
54731
  dashboardBehaviour: dashboardBehaviour,
54419
54732
  library: props == null ? void 0 : props.library,
@@ -54437,6 +54750,7 @@ var Component = function Component(props) {
54437
54750
  dataSet: dataSet,
54438
54751
  runQueriesCallback: props.runQueriesCallback,
54439
54752
  component: props.component,
54753
+ setResults: props.setResults,
54440
54754
  globalFilters: dashboard.globalFilters,
54441
54755
  dashboardBehaviour: dashboardBehaviour,
54442
54756
  library: props == null ? void 0 : props.library,
@@ -54460,6 +54774,7 @@ var Component = function Component(props) {
54460
54774
  dataSet: dataSet,
54461
54775
  runQueriesCallback: props.runQueriesCallback,
54462
54776
  component: props.component,
54777
+ setResults: props.setResults,
54463
54778
  globalFilters: dashboard.globalFilters,
54464
54779
  dashboardBehaviour: dashboardBehaviour,
54465
54780
  library: props == null ? void 0 : props.library,
@@ -54483,6 +54798,7 @@ var Component = function Component(props) {
54483
54798
  dataSet: dataSet,
54484
54799
  runQueriesCallback: props.runQueriesCallback,
54485
54800
  component: props.component,
54801
+ setResults: props.setResults,
54486
54802
  globalFilters: dashboard.globalFilters,
54487
54803
  dashboardBehaviour: dashboardBehaviour,
54488
54804
  library: props == null ? void 0 : props.library,
@@ -54509,6 +54825,7 @@ var Component = function Component(props) {
54509
54825
  dataSet: dataSet,
54510
54826
  runQueriesCallback: props.runQueriesCallback,
54511
54827
  component: props.component,
54828
+ setResults: props.setResults,
54512
54829
  globalFilters: dashboard.globalFilters,
54513
54830
  dashboardBehaviour: dashboardBehaviour,
54514
54831
  library: props == null ? void 0 : props.library,
@@ -54532,6 +54849,7 @@ var Component = function Component(props) {
54532
54849
  dataSet: dataSet,
54533
54850
  runQueriesCallback: props.runQueriesCallback,
54534
54851
  component: props.component,
54852
+ setResults: props.setResults,
54535
54853
  globalFilters: dashboard.globalFilters,
54536
54854
  updateComponentAttributes: function updateComponentAttributes(newAttributes) {
54537
54855
  return _updateComponentAttributes(newAttributes);
@@ -54558,6 +54876,7 @@ var Component = function Component(props) {
54558
54876
  dataSet: dataSet,
54559
54877
  runQueriesCallback: props.runQueriesCallback,
54560
54878
  component: props.component,
54879
+ setResults: props.setResults,
54561
54880
  globalFilters: dashboard.globalFilters,
54562
54881
  dashboardBehaviour: dashboardBehaviour,
54563
54882
  sm: smallVersion,
@@ -54605,6 +54924,7 @@ var Component = function Component(props) {
54605
54924
  dataSet: dataSet,
54606
54925
  runQueriesCallback: props.runQueriesCallback,
54607
54926
  component: props.component,
54927
+ setResults: props.setResults,
54608
54928
  globalFilters: dashboard.globalFilters,
54609
54929
  dashboardBehaviour: dashboardBehaviour
54610
54930
  })
@@ -54627,6 +54947,7 @@ var Component = function Component(props) {
54627
54947
  return _updateComponentAttributes(newAttributes);
54628
54948
  },
54629
54949
  component: props.component,
54950
+ setResults: props.setResults,
54630
54951
  globalFilters: dashboard.globalFilters,
54631
54952
  dashboardBehaviour: dashboardBehaviour,
54632
54953
  sm: smallVersion,
@@ -54653,6 +54974,7 @@ var Component = function Component(props) {
54653
54974
  dataSet: dataSet,
54654
54975
  runQueriesCallback: props.runQueriesCallback,
54655
54976
  component: props.component,
54977
+ setResults: props.setResults,
54656
54978
  globalFilters: dashboard.globalFilters,
54657
54979
  dashboardBehaviour: dashboardBehaviour,
54658
54980
  library: props == null ? void 0 : props.library,
@@ -54680,6 +55002,7 @@ var Component = function Component(props) {
54680
55002
  return _updateComponentAttributes(newAttributes);
54681
55003
  },
54682
55004
  component: props.component,
55005
+ setResults: props.setResults,
54683
55006
  globalFilters: dashboard.globalFilters,
54684
55007
  dashboardBehaviour: dashboardBehaviour,
54685
55008
  library: props == null ? void 0 : props.library,
@@ -54705,6 +55028,7 @@ var Component = function Component(props) {
54705
55028
  return _updateComponentAttributes(newAttributes);
54706
55029
  },
54707
55030
  component: props.component,
55031
+ setResults: props.setResults,
54708
55032
  globalFilters: dashboard.globalFilters,
54709
55033
  dashboardBehaviour: dashboardBehaviour,
54710
55034
  library: props == null ? void 0 : props.library,
@@ -57510,6 +57834,18 @@ var ModalType = /*#__PURE__*/function (ModalType) {
57510
57834
  ----------------------------------------------
57511
57835
  */
57512
57836
 
57837
+ /*
57838
+ ----------------------------------------------
57839
+ ----------------------------------------------
57840
+ ----------------------------------------------
57841
+
57842
+ Setting results
57843
+
57844
+ ----------------------------------------------
57845
+ ----------------------------------------------
57846
+ ----------------------------------------------
57847
+ */
57848
+
57513
57849
  /*
57514
57850
  ----------------------------------------------
57515
57851
  ----------------------------------------------
@@ -58547,6 +58883,65 @@ var ParametersModalView = function ParametersModalView(props) {
58547
58883
  });
58548
58884
  };
58549
58885
 
58886
+ var ViewRawResultsModal = function ViewRawResultsModal(props) {
58887
+ var _useDashboardBehaviou = useDashboardBehaviourContext(),
58888
+ textOverride = _useDashboardBehaviou.textOverride;
58889
+ var _useToastContext = useToastContext(),
58890
+ addToast = _useToastContext.addToast;
58891
+ return jsxs(Modal, {
58892
+ width: "4xl",
58893
+ isOpen: props == null ? void 0 : props.show,
58894
+ onClose: function onClose() {
58895
+ return props == null ? void 0 : props.onClose(false);
58896
+ },
58897
+ children: [jsx(Modal.Header, {
58898
+ title: textOverride('json_results', 'Data in raw JSON format'),
58899
+ show: true
58900
+ }), jsx(Modal.Content, {
58901
+ children: jsx(View, {
58902
+ maxHeight: "400px",
58903
+ overflowY: "scroll",
58904
+ children: jsx("pre", {
58905
+ "data-testid": "raw-results-" + props.rowIndex + "-" + props.cellIndex,
58906
+ children: JSON.stringify(props.results, null, 2)
58907
+ })
58908
+ })
58909
+ }), jsx(Modal.Footer, {
58910
+ buttons: "end",
58911
+ children: jsxs(ButtonGroup, {
58912
+ children: [jsx(Button, {
58913
+ secondary: true,
58914
+ testId: "modal-close-btn",
58915
+ onClick: function onClick() {
58916
+ return props == null ? void 0 : props.onClose(false);
58917
+ },
58918
+ children: textOverride('close', 'Close')
58919
+ }), jsx(Button, {
58920
+ primary: true,
58921
+ testId: "modal-copy-json-results-btn",
58922
+ onClick: function onClick() {
58923
+ var copied = copy(JSON.stringify(props.results));
58924
+ if (copied) {
58925
+ addToast(function () {
58926
+ return jsx(ToastSuccess, {
58927
+ message: "Copied results"
58928
+ });
58929
+ });
58930
+ } else {
58931
+ addToast(function () {
58932
+ return jsx(ToastError, {
58933
+ message: "Failed to copy results"
58934
+ });
58935
+ });
58936
+ }
58937
+ },
58938
+ children: textOverride('copy', 'Copy')
58939
+ })]
58940
+ })
58941
+ })]
58942
+ });
58943
+ };
58944
+
58550
58945
  var ViewRawAttributesModal = function ViewRawAttributesModal(props) {
58551
58946
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
58552
58947
  textOverride = _useDashboardBehaviou.textOverride;
@@ -58928,6 +59323,7 @@ var PopulatedCell = function PopulatedCell(props) {
58928
59323
  localFiltersModal = _useState2[0],
58929
59324
  showLocalFiltersModal = _useState2[1];
58930
59325
  var _useState3 = useState(false),
59326
+ viewRawJSONResults = _useState3[0],
58931
59327
  showViewRawJSONResults = _useState3[1];
58932
59328
  var _useState4 = useState(false),
58933
59329
  viewRawAttributes = _useState4[0],
@@ -59102,6 +59498,7 @@ var PopulatedCell = function PopulatedCell(props) {
59102
59498
  isBeingSizeAdjusted: props.isBeingSizeAdjusted,
59103
59499
  runQueriesCallback: props.runQueriesCallback,
59104
59500
  component: props.component,
59501
+ setResults: props.setResults,
59105
59502
  updateComponentAttributes: props.updateComponentAttributes,
59106
59503
  height: props.height
59107
59504
  }), !showComponent && jsx(LoadingComponent, {})]
@@ -59127,6 +59524,14 @@ var PopulatedCell = function PopulatedCell(props) {
59127
59524
  onClose: function onClose() {
59128
59525
  return showParametersModal(false);
59129
59526
  }
59527
+ }), jsx(ViewRawResultsModal, {
59528
+ cellIndex: props.cellIndex,
59529
+ rowIndex: props.rowIndex,
59530
+ show: viewRawJSONResults,
59531
+ results: props.component.results,
59532
+ onClose: function onClose() {
59533
+ return showViewRawJSONResults(false);
59534
+ }
59130
59535
  }), jsx(ViewRawAttributesModal, {
59131
59536
  cellIndex: props.cellIndex,
59132
59537
  rowIndex: props.rowIndex,
@@ -59156,6 +59561,7 @@ var PopulatedCell = function PopulatedCell(props) {
59156
59561
  isBeingSizeAdjusted: props.isBeingSizeAdjusted,
59157
59562
  runQueriesCallback: props.runQueriesCallback,
59158
59563
  component: props.component,
59564
+ setResults: props.setResults,
59159
59565
  updateComponentAttributes: props.updateComponentAttributes,
59160
59566
  height: props.height
59161
59567
  })
@@ -59821,6 +60227,14 @@ var ResizableRowCell = function ResizableRowCell(props) {
59821
60227
  });
59822
60228
  },
59823
60229
  height: props.height,
60230
+ setResults: function setResults(results) {
60231
+ dispatch({
60232
+ type: 'setResultsForComponentInDisplay',
60233
+ rowIndex: rowIndex,
60234
+ cellIndex: cellIndex,
60235
+ results: results
60236
+ });
60237
+ },
59824
60238
  onEdit: function onEdit() {
59825
60239
  trackEvent('component.startEditing');
59826
60240
  dispatch({
@@ -61125,6 +61539,9 @@ var ComponentInLibrary = function ComponentInLibrary(props) {
61125
61539
  setLocalFilters: function setLocalFilters() {},
61126
61540
  runQueriesCallback: props.runQueriesCallback,
61127
61541
  component: component,
61542
+ setResults: function setResults(results) {
61543
+ return props.setResults(results, libraryIndex);
61544
+ },
61128
61545
  updateComponentAttributes: props.updateComponentAttributes,
61129
61546
  library: true
61130
61547
  })]
@@ -61447,6 +61864,7 @@ var ViewsInLibrary = function ViewsInLibrary(props) {
61447
61864
  refIndex = _ref.refIndex;
61448
61865
  return jsx(ComponentInLibrary, {
61449
61866
  updateComponentAttributes: props.updateComponentAttributes,
61867
+ setResults: props.setResults,
61450
61868
  component: item.component,
61451
61869
  libraryIndex: refIndex,
61452
61870
  onSelectComponent: props == null ? void 0 : props.onSelectComponent,
@@ -61489,6 +61907,20 @@ var Library = function Library() {
61489
61907
  featureToggles = _useDashboardBehaviou.featureToggles,
61490
61908
  textOverride = _useDashboardBehaviou.textOverride;
61491
61909
  var canEditComponentLibrary = featureToggles.canEditComponentLibrary;
61910
+ var setResults = function setResults(results, libraryIndex) {
61911
+ dispatch({
61912
+ type: 'setResultsForComponentInLibrary',
61913
+ results: results,
61914
+ libraryIndex: libraryIndex
61915
+ });
61916
+ };
61917
+ var setFocussedComponentResults = function setFocussedComponentResults(results) {
61918
+ dispatch({
61919
+ type: 'setResultsForComponentInLibrary',
61920
+ results: results,
61921
+ libraryIndex: selectedLibraryIndex
61922
+ });
61923
+ };
61492
61924
  var selectComponentFromLibrary = function selectComponentFromLibrary() {
61493
61925
  dispatch({
61494
61926
  type: 'pickComponentFromLibraryForDisplay',
@@ -61556,8 +61988,10 @@ var Library = function Library() {
61556
61988
  onClose: clearModal,
61557
61989
  onSelect: selectComponentFromLibrary,
61558
61990
  updateComponentAttributes: updateComponentAttributes,
61991
+ setFocussedComponentResults: setFocussedComponentResults,
61559
61992
  dashboard: dashboard,
61560
61993
  selectedLibraryIndex: selectedLibraryIndex,
61994
+ setResults: setResults,
61561
61995
  canEditComponentLibrary: canEditComponentLibrary,
61562
61996
  onEdit: startEditingSelectedComponent,
61563
61997
  onDelete: setShowDeleteConfirmationModal,
@@ -61600,6 +62034,7 @@ var ViewLibraryDisplay = function ViewLibraryDisplay(props) {
61600
62034
  "data-component": "library-content",
61601
62035
  children: jsx(ViewsInLibrary, {
61602
62036
  runQueriesCallback: props == null ? void 0 : props.runQueriesCallback,
62037
+ setResults: props == null ? void 0 : props.setResults,
61603
62038
  components: props.dashboard.componentLibrary,
61604
62039
  onSelectComponent: function onSelectComponent(index) {
61605
62040
  return props == null ? void 0 : props.onSelectComponent(index);
@@ -64851,12 +65286,14 @@ var handleFeedbackMessage = function handleFeedbackMessage(_ref) {
64851
65286
 
64852
65287
  // By using message ids we ensure there will only be 1 message of a type, and it can be easily removed
64853
65288
  var chartDimensionMessageId = 'grouping';
65289
+ var limitWarningMessageId = 'limit';
64854
65290
  var EditorComponent = function EditorComponent(props) {
64855
65291
  var _theme$editor$gap, _theme$editor, _theme$editor2, _props$usingBeta, _theme$editor3;
64856
65292
  var theme = useTheme();
64857
65293
  var editorFeedback = useEditorFeedback();
64858
65294
  var _props$editor = props.editor,
64859
65295
  setAttributes = _props$editor.setAttributes,
65296
+ setResults = _props$editor.setResults,
64860
65297
  runQueriesCallback = _props$editor.runQueriesCallback,
64861
65298
  component = _props$editor.component,
64862
65299
  dataSet = _props$editor.dataSet,
@@ -64877,25 +65314,26 @@ var EditorComponent = function EditorComponent(props) {
64877
65314
  editorFeedback.removeFeedbackMessage(chartDimensionMessageId);
64878
65315
  };
64879
65316
  }, [component.attributes]);
64880
-
64881
- // useEffect(() => {
64882
- // handleFeedbackMessage({
64883
- // message: {
64884
- // id: limitWarningMessageId,
64885
- // type: 'info',
64886
- // children: `More data is available for this view. Increase 'Limit' (Advanced Options) to show all data.`,
64887
- // },
64888
- // showCondition: component.results.some((result) => result?.hasMoreResults),
64889
- // hideCondition: !component.results.some((result) => result?.hasMoreResults),
64890
- // addFeedbackMessage: editorFeedback.addFeedbackMessage,
64891
- // removeFeedbackMessage: editorFeedback.removeFeedbackMessage,
64892
- // });
64893
-
64894
- // return () => {
64895
- // editorFeedback.removeFeedbackMessage(limitWarningMessageId);
64896
- // };
64897
- // }, [component.results]);
64898
-
65317
+ useEffect(function () {
65318
+ handleFeedbackMessage({
65319
+ message: {
65320
+ id: limitWarningMessageId,
65321
+ type: 'info',
65322
+ children: "More data is available for this view. Increase 'Limit' (Advanced Options) to show all data."
65323
+ },
65324
+ showCondition: component.results.some(function (result) {
65325
+ return result == null ? void 0 : result.hasMoreResults;
65326
+ }),
65327
+ hideCondition: !component.results.some(function (result) {
65328
+ return result == null ? void 0 : result.hasMoreResults;
65329
+ }),
65330
+ addFeedbackMessage: editorFeedback.addFeedbackMessage,
65331
+ removeFeedbackMessage: editorFeedback.removeFeedbackMessage
65332
+ });
65333
+ return function () {
65334
+ editorFeedback.removeFeedbackMessage(limitWarningMessageId);
65335
+ };
65336
+ }, [component.results]);
64899
65337
  return jsx(RichTextEditorContextProvider, {
64900
65338
  setContent: function setContent(content) {
64901
65339
  // @ts-ignore
@@ -64934,6 +65372,7 @@ var EditorComponent = function EditorComponent(props) {
64934
65372
  isBeingSizeAdjusted: false,
64935
65373
  setLocalFilters: props.editor.setLocalFilters,
64936
65374
  runQueriesCallback: runQueriesCallback,
65375
+ setResults: setResults,
64937
65376
  component: component,
64938
65377
  updateComponentAttributes: setAttributes,
64939
65378
  editor: true
@@ -64947,10 +65386,10 @@ var EditorComponent = function EditorComponent(props) {
64947
65386
 
64948
65387
  var EditorModal = function EditorModal(props) {
64949
65388
  var _theme$modals, _theme$modals2;
65389
+ var editor = useEditor();
64950
65390
  var _React$useState = React__default.useState(false),
64951
65391
  ai = _React$useState[0],
64952
65392
  openAI = _React$useState[1];
64953
- var editor = useEditor();
64954
65393
  var usingBeta = useBetaFeatures();
64955
65394
  var _useAIBehaviour = useAIBehaviour(),
64956
65395
  fetchSuggestions = _useAIBehaviour.fetchSuggestions;
@@ -69980,7 +70419,7 @@ var fromToken = function fromToken(token) {
69980
70419
  });
69981
70420
  };
69982
70421
 
69983
- var init$e = function init(dashboardSessionToken, dataAccessToken, queryEngineAccessToken, dashboardAdminOverrideToken) {
70422
+ var init$d = function init(dashboardSessionToken, dataAccessToken, queryEngineAccessToken, dashboardAdminOverrideToken) {
69984
70423
  var dashboardAccessContent = fromToken(dashboardSessionToken);
69985
70424
  if (!('scope' in dashboardAccessContent)) {
69986
70425
  dashboardAccessContent.scope = 'read_write';
@@ -70046,7 +70485,7 @@ var fetchIdentityConfig = /*#__PURE__*/function () {
70046
70485
  throw new FailedToLoadIdentity('Failed to fetch identity config.');
70047
70486
  case 6:
70048
70487
  dashboardAdminOverride = isClientSide() ? getDashboardAdminOverride(window.location.href) : null;
70049
- identityConfig = init$e(tokens.dashboardAccessToken, tokens.dataAccessToken, tokens.queryEngineAccessToken, dashboardAdminOverride);
70488
+ identityConfig = init$d(tokens.dashboardAccessToken, tokens.dataAccessToken, tokens.queryEngineAccessToken, dashboardAdminOverride);
70050
70489
  return _context.abrupt("return", {
70051
70490
  identityConfig: identityConfig,
70052
70491
  tokens: tokens
@@ -70854,6 +71293,7 @@ var buildComponentLibrary = function buildComponentLibrary(cells) {
70854
71293
  newComponentLibrary.push({
70855
71294
  attributes: cell.component.attributes,
70856
71295
  localFilters: (_cell$localFilters2 = cell.localFilters) != null ? _cell$localFilters2 : [],
71296
+ results: [],
70857
71297
  colSpan: 1,
70858
71298
  reports: []
70859
71299
  });
@@ -71221,6 +71661,32 @@ var TimeoutWaitingForVizzlyInstance = /*#__PURE__*/function (_Error) {
71221
71661
  return TimeoutWaitingForVizzlyInstance;
71222
71662
  }( /*#__PURE__*/_wrapNativeSuper(Error));
71223
71663
 
71664
+ var joiOptions$1 = {
71665
+ convert: false,
71666
+ stripUnknown: false,
71667
+ allowUnknown: true
71668
+ };
71669
+ var validateQuery = function validateQuery(params, queryEngineConfig) {
71670
+ var validationResult = Joi.array().items(schema(queryEngineConfig)).validate(params, joiOptions$1);
71671
+ if (validationResult.error) {
71672
+ throw new ServicesValidationError(validationResult.error.message);
71673
+ }
71674
+ };
71675
+ var filterSchema$1 = function filterSchema(queryEngineConfig) {
71676
+ var _Joi$string;
71677
+ return Joi.array().items(Joi.alternatives()["try"](Joi.object({
71678
+ field: Joi.string().required().description('The ID of the field from the data set to reference.'),
71679
+ op: (_Joi$string = Joi.string()).valid.apply(_Joi$string, Object.keys(queryEngineConfig.supportedOperators)).required(),
71680
+ value: Joi.any().required()
71681
+ }).description('A filter object to apply to the data set.'), Joi.array()));
71682
+ };
71683
+ var schema = function schema(queryEngineConfig) {
71684
+ return Joi.object(_extends({}, querySchema(queryEngineConfig, {}), {
71685
+ filter: filterSchema$1(queryEngineConfig),
71686
+ timeDimension: Joi.alternatives(timeDimensionSchema(queryEngineConfig.supportedTimeTruncFunctions), Joi.valid(null))
71687
+ }));
71688
+ };
71689
+
71224
71690
  var validateDashboardJoiOptions = {
71225
71691
  convert: false,
71226
71692
  stripUnknown: false,
@@ -71298,7 +71764,7 @@ var toQueries = function toQueries(dataSets, queryAttributes, queryEngineConfig,
71298
71764
  var queries = queryAttributes.map(function (qA) {
71299
71765
  var dataSet = find(dataSets, qA.dataSetId);
71300
71766
  if (!dataSet) throw 'Data set not found for query attributes query';
71301
- return buildFromQueryAttributes(dataSet, qA.measure, qA.filter, qA.order, qA.dimension, qA.timeDimension, qA.limit, qA.offset, queryEngineConfig, params);
71767
+ return buildFromQueryAttributes(dataSet, qA.measure, qA.order, qA.dimension, qA.timeDimension, qA.limit, qA.offset, queryEngineConfig, params, qA.filter);
71302
71768
  });
71303
71769
  return {
71304
71770
  queries: queries.map(function (q) {
@@ -71356,7 +71822,7 @@ function getOptionsOrders(dataSetField) {
71356
71822
  }
71357
71823
 
71358
71824
  var commonToQueries = function commonToQueries(attributes, dataSet, queryEngineConfig, params) {
71359
- var _Query$build = build$c(dataSet, attributes.measure, attributes.filter, attributes.order, attributes.dimension,
71825
+ var _Query$build = build$c(dataSet, attributes.measure, attributes.order, attributes.dimension,
71360
71826
  // @ts-ignore
71361
71827
  attributes.timeDimension || null, attributes.limit, attributes.offset, queryEngineConfig, params),
71362
71828
  query = _Query$build.query,
@@ -71381,8 +71847,8 @@ var toQueries$6 = commonToQueries;
71381
71847
  var toQueries$7 = commonToQueries;
71382
71848
 
71383
71849
  var buildMainQueries = function buildMainQueries(attributes, dataSet, queryEngineConfig, params) {
71384
- var line = build$c(dataSet, attributes.lineMeasure, attributes.filter, attributes.order, attributes.lineDimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params);
71385
- var bar = build$c(dataSet, attributes.barMeasure, attributes.filter, attributes.order, attributes.barDimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params);
71850
+ var line = build$c(dataSet, attributes.lineMeasure, attributes.order, attributes.lineDimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params);
71851
+ var bar = build$c(dataSet, attributes.barMeasure, attributes.order, attributes.barDimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params);
71386
71852
  return {
71387
71853
  bar: bar,
71388
71854
  line: line
@@ -71409,8 +71875,8 @@ var toQueries$b = commonToQueries;
71409
71875
  var toQueries$c = commonToQueries;
71410
71876
 
71411
71877
  var buildMainQueries$1 = function buildMainQueries(attributes, dataSet, queryEngineConfig, params) {
71412
- var line = build$c(dataSet, attributes.lineMeasure, attributes.filter, attributes.order, attributes.lineDimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params);
71413
- var bar = build$c(dataSet, attributes.barMeasure, attributes.filter, attributes.order, attributes.barDimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params);
71878
+ var line = build$c(dataSet, attributes.lineMeasure, attributes.order, attributes.lineDimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params);
71879
+ var bar = build$c(dataSet, attributes.barMeasure, attributes.order, attributes.barDimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params);
71414
71880
  return {
71415
71881
  bar: bar,
71416
71882
  line: line
@@ -71429,7 +71895,7 @@ var toQueries$d = function toQueries(attributes, dataSet, queryEngineConfig, par
71429
71895
  };
71430
71896
 
71431
71897
  var buildMainQuery = function buildMainQuery(attributes, dataSet, queryEngineConfig, params) {
71432
- var _Query$build = build$c(dataSet, attributes.measure, attributes.filter, [], [], null, 1, attributes.offset, queryEngineConfig, params),
71898
+ var _Query$build = build$c(dataSet, attributes.measure, [], [], null, 1, attributes.offset, queryEngineConfig, params),
71433
71899
  query = _Query$build.query,
71434
71900
  measureDescription = _Query$build.measureDescription;
71435
71901
 
@@ -71457,7 +71923,7 @@ var buildMainQuery = function buildMainQuery(attributes, dataSet, queryEngineCon
71457
71923
  };
71458
71924
  var buildDeltaQuery = function buildDeltaQuery(dataSet, attributes, queryEngineConfig, params) {
71459
71925
  if (!attributes.deltaTimeDimension) return null;
71460
- return build$c(dataSet, attributes.measure, attributes.filter, [{
71926
+ return build$c(dataSet, attributes.measure, [{
71461
71927
  field: attributes.deltaTimeDimension.field,
71462
71928
  direction: 'asc',
71463
71929
  "function": attributes.deltaTimeDimension.truncate
@@ -71489,7 +71955,7 @@ var toQueries$f = function toQueries(attributes, dataSet, queryEngineConfig, par
71489
71955
  var measures = [];
71490
71956
  attributes.xMeasure && measures.push(attributes.xMeasure);
71491
71957
  attributes.yMeasure && measures.push(attributes.yMeasure);
71492
- var _Query$build = build$c(dataSet, measures, attributes.filter, attributes.order, attributes.dimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params),
71958
+ var _Query$build = build$c(dataSet, measures, attributes.order, attributes.dimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params),
71493
71959
  query = _Query$build.query,
71494
71960
  measureDescription = _Query$build.measureDescription;
71495
71961
  var resultFields = toResultFields([measureDescription], queryEngineConfig);
@@ -71503,7 +71969,7 @@ var toQueries$g = function toQueries(attributes, dataSet, queryEngineConfig, par
71503
71969
  var measures = [];
71504
71970
  attributes.xMeasure && measures.push(attributes.xMeasure);
71505
71971
  attributes.yMeasure && measures.push(attributes.yMeasure);
71506
- var _Query$build = build$c(dataSet, measures, attributes.filter, attributes.order, attributes.dimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params),
71972
+ var _Query$build = build$c(dataSet, measures, attributes.order, attributes.dimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params),
71507
71973
  query = _Query$build.query,
71508
71974
  measureDescription = _Query$build.measureDescription;
71509
71975
  var resultFields = toResultFields([measureDescription], queryEngineConfig);
@@ -71515,7 +71981,7 @@ var toQueries$g = function toQueries(attributes, dataSet, queryEngineConfig, par
71515
71981
 
71516
71982
  var toQueries$h = function toQueries(attributes, dataSet, queryEngineConfig, params) {
71517
71983
  var measures = [].concat(attributes.measure || [], attributes.xMeasure || [], attributes.zMeasure || []);
71518
- var _Query$build = build$c(dataSet, measures, attributes.filter, attributes.order, attributes.dimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params),
71984
+ var _Query$build = build$c(dataSet, measures, attributes.order, attributes.dimension, attributes.timeDimension, attributes.limit, attributes.offset, queryEngineConfig, params),
71519
71985
  query = _Query$build.query,
71520
71986
  measureDescription = _Query$build.measureDescription;
71521
71987
  var resultFields = toResultFields([measureDescription], queryEngineConfig);
@@ -71627,7 +72093,20 @@ var buildVizzlyQuery = function buildVizzlyQuery(thing, queryEngineConfig, param
71627
72093
  queriesToSend = [_query];
71628
72094
  resultFields = [_rF];
71629
72095
  } else if (Array.isArray(thing)) {
71630
- var _fromQueryAttributes = toQueries(params.dataSets, thing, queryEngineConfig, params),
72096
+ var queriesInAttributesFormat = [].concat(thing).map(function (queryAttributes) {
72097
+ var dataSet = find(params.dataSets, queryAttributes.dataSetId);
72098
+ if (!dataSet) throw 'Data set not found for query-attributes query';
72099
+ return _extends({}, queryAttributes, {
72100
+ // TODO; this means that services queries that povide a query, cannot work... GTDEV-6947
72101
+ filter: [],
72102
+ whereClause: filterConfigToWhere(dataSet, queryEngineConfig, _extends({}, params, {
72103
+ filterConfig: _extends({}, params.filterConfig, {
72104
+ advancedFilter: queryAttributes.filter
72105
+ })
72106
+ }))
72107
+ });
72108
+ });
72109
+ var _fromQueryAttributes = toQueries(params.dataSets, queriesInAttributesFormat, queryEngineConfig, params),
71631
72110
  q = _fromQueryAttributes.queries,
71632
72111
  _rF2 = _fromQueryAttributes.resultFields;
71633
72112
  queriesToSend = q;
@@ -71639,7 +72118,7 @@ var buildVizzlyQuery = function buildVizzlyQuery(thing, queryEngineConfig, param
71639
72118
  if (!_dataSet) throw 'Data set not found for view attributes query';
71640
72119
  var _buildVizzlyViewQueri = buildVizzlyViewQueries(thing, _dataSet, queryEngineConfig, _extends({}, params, {
71641
72120
  filterConfig: _extends({}, params.filterConfig, {
71642
- viewFilters: thing.filter
72121
+ advancedFilter: thing.filter
71643
72122
  })
71644
72123
  })),
71645
72124
  _q = _buildVizzlyViewQueri.queries,
@@ -71676,7 +72155,7 @@ var set = function set(cacheKey, item, expiryInSeconds) {
71676
72155
  var key = JSON.stringify(cacheKey);
71677
72156
  var expires = new Date();
71678
72157
  expires.setSeconds(expires.getSeconds() + expiryInSeconds);
71679
- logDebug('Browser cache new object set.', key);
72158
+ logDebug("Browser cache new object set.", key);
71680
72159
  cache$1[key] = {
71681
72160
  item: item,
71682
72161
  expires: expires
@@ -71686,10 +72165,10 @@ var get = function get(cacheKey) {
71686
72165
  var key = JSON.stringify(cacheKey);
71687
72166
  var retrieved = cache$1[key];
71688
72167
  if (!retrieved) {
71689
- logDebug('Browser cache miss.', cacheKey);
72168
+ logDebug("Browser cache miss.", cacheKey);
71690
72169
  return null;
71691
72170
  }
71692
- logDebug('Browser cache hit.', cacheKey);
72171
+ logDebug("Browser cache hit.", cacheKey);
71693
72172
  var item = retrieved.item,
71694
72173
  expires = retrieved.expires;
71695
72174
  var now = new Date();
@@ -71701,7 +72180,7 @@ var get = function get(cacheKey) {
71701
72180
  return null;
71702
72181
  };
71703
72182
  var clear$1 = function clear() {
71704
- logDebug('Browser cache cleared.');
72183
+ logDebug("Browser cache cleared.");
71705
72184
  cache$1 = {};
71706
72185
  };
71707
72186
 
@@ -72865,6 +73344,7 @@ var VizzlyServices = /*#__PURE__*/function () {
72865
73344
  instanceId = params.instanceId;
72866
73345
  }
72867
73346
  service = VizzlyServices._instanceStore[instanceId];
73347
+ validateQuery(queries, service.queryEngineConfig);
72868
73348
  queryEngineEndpoint = function () {
72869
73349
  if (params != null && params.queryEngineEndpoint) {
72870
73350
  return params.queryEngineEndpoint;
@@ -72910,14 +73390,14 @@ var VizzlyServices = /*#__PURE__*/function () {
72910
73390
  return _ref.apply(this, arguments);
72911
73391
  };
72912
73392
  }();
72913
- _context11.next = 9;
73393
+ _context11.next = 10;
72914
73394
  return fetch();
72915
- case 9:
73395
+ case 10:
72916
73396
  _context11.t0 = _context11.sent;
72917
73397
  return _context11.abrupt("return", {
72918
73398
  results: _context11.t0
72919
73399
  });
72920
- case 11:
73400
+ case 12:
72921
73401
  case "end":
72922
73402
  return _context11.stop();
72923
73403
  }
@@ -73143,7 +73623,7 @@ VizzlyServices.HorizontalBarChart = HorizontalBarChart$2;
73143
73623
  VizzlyServices.MercatorMap = MercatorMap$4;
73144
73624
  VizzlyServices.SingleStat = SingleStat$3;
73145
73625
  VizzlyServices.Progress = Progress$3;
73146
- VizzlyServices.WaterfallChart = WaterfallChart$4; // export type Query = Omit<SQLQuery, 'timeZone'> & { timeZone?: string };
73626
+ VizzlyServices.WaterfallChart = WaterfallChart$4;
73147
73627
  // @ts-ignore
73148
73628
  if (typeof window !== 'undefined' && !window.Vizzly) {
73149
73629
  // @ts-ignore
@@ -75997,7 +76477,7 @@ var GlobalProviderContents = function GlobalProviderContents(props) {
75997
76477
  });
75998
76478
  };
75999
76479
 
76000
- var _excluded$j = ["view"];
76480
+ var _excluded$i = ["view"];
76001
76481
  var Dashboard$2 = function Dashboard(props) {
76002
76482
  var handleOnError = function handleOnError(error, errorInfo) {
76003
76483
  return (props == null ? void 0 : props.onError) && (props == null ? void 0 : props.onError(error, errorInfo));
@@ -76018,7 +76498,7 @@ var Editor$1 = function Editor(props) {
76018
76498
  var handleOnError = function handleOnError(error, errorInfo) {
76019
76499
  return (props == null ? void 0 : props.onError) && (props == null ? void 0 : props.onError(error, errorInfo));
76020
76500
  };
76021
- var resetProps = _objectWithoutPropertiesLoose(props, _excluded$j);
76501
+ var resetProps = _objectWithoutPropertiesLoose(props, _excluded$i);
76022
76502
  return jsxs(ErrorBoundary, {
76023
76503
  renderOnError: function renderOnError() {
76024
76504
  return jsx("p", {