@vizzly/dashboard 0.15.0-dev-307a9830cb4e82f036693ccfe2634f74381a2b72 → 0.15.0-dev-927f480c64f078c9b01edc81be29e4e33f862c8d

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.
@@ -29,9 +29,9 @@ import { dropTargetForExternal } from '@atlaskit/pragmatic-drag-and-drop/externa
29
29
  import { DropIndicator } from '@atlaskit/pragmatic-drag-and-drop-react-drop-indicator/box';
30
30
  import { ParentSize } from '@visx/responsive';
31
31
  import { Annotation, AnnotationConnector, AnnotationLabel, DataContext, buildChartTheme, lightTheme, XYChart, Grid as Grid$2, Axis, AreaSeries, AreaStack, BarGroup as BarGroup$1, BarSeries, BarStack, GlyphSeries, LineSeries, Tooltip as Tooltip$3 } from '@visx/xychart';
32
+ import { scaleOrdinal, scaleLinear, scaleQuantize, scalePoint, scaleTime, scaleBand } from '@visx/scale';
32
33
  import { LinearGradient } from '@visx/gradient';
33
34
  import { LegendItem as LegendItem$1, LegendLabel } from '@visx/legend';
34
- import { scaleOrdinal, scaleQuantize, scaleLinear, scalePoint, scaleTime, scaleBand } from '@visx/scale';
35
35
  import Ordinal from '@visx/legend/lib/legends/Ordinal';
36
36
  import { curveNatural, curveMonotoneX, curveMonotoneY, curveLinear, curveStep, curveStepBefore, curveStepAfter } from '@visx/curve';
37
37
  import { Line as Line$1, LinePath, BarGroup as BarGroup$2, BarStack as BarStack$1, AreaStack as AreaStack$1, AreaClosed, LineRadial } from '@visx/shape';
@@ -53,8 +53,8 @@ import { localPoint } from '@visx/event';
53
53
  import { bisector } from '@visx/vendor/d3-array';
54
54
  import { AxisBottom as AxisBottom$1, AxisLeft as AxisLeft$1 } from '@visx/axis';
55
55
  import { Text } from '@visx/text';
56
- import { GridRows as GridRows$1 } from '@visx/grid';
57
56
  import { Annotation as Annotation$1, Label as Label$1 } from '@visx/annotation';
57
+ import { GridRows as GridRows$1 } from '@visx/grid';
58
58
  import { GlyphDot } from '@visx/glyph';
59
59
  import { Point } from '@visx/point';
60
60
  import { interpolate as interpolate$1 } from '@visx/vendor/d3-interpolate';
@@ -4175,7 +4175,7 @@ var attributesSchema$2 = function attributesSchema(config) {
4175
4175
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
4176
4176
  stacked: Joi.valid(true, false, '100%'),
4177
4177
  legend: Joi.valid(true, false),
4178
- // labels: Joi.valid(true, false).optional(),
4178
+ labels: Joi.valid(true, false).optional(),
4179
4179
  type: Joi.valid('lineChartV2').required(),
4180
4180
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
4181
4181
  lineCurve: lineCurveSchema,
@@ -4285,8 +4285,13 @@ var CONSTANTS$2 = {
4285
4285
  title: 'Show Legend',
4286
4286
  description: '',
4287
4287
  namespace: 'legend'
4288
+ },
4289
+ labels: {
4290
+ type: 'labels',
4291
+ title: 'Show Labels',
4292
+ description: '',
4293
+ namespace: 'labels'
4288
4294
  }
4289
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
4290
4295
  }
4291
4296
  },
4292
4297
  axis_labels: {
@@ -4414,6 +4419,7 @@ var LineChart$1 = function LineChart(config) {
4414
4419
  conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
4415
4420
  drilldown: dumped.drilldown,
4416
4421
  legend: dumped.legend,
4422
+ labels: dumped.labels,
4417
4423
  goalLines: dumped.goalLines,
4418
4424
  headline: upcastHeadline(dumped.headline, dumped.timeDimension),
4419
4425
  parameters: upcastParameters(dumped.parameters),
@@ -4452,6 +4458,7 @@ var LineChart$1 = function LineChart(config) {
4452
4458
  conditionalFormattingRules: [],
4453
4459
  drilldown: [],
4454
4460
  legend: true,
4461
+ labels: false,
4455
4462
  goalLines: undefined,
4456
4463
  approxXAxisLabelCount: 'auto',
4457
4464
  approxYAxisLabelCount: 'auto',
@@ -4514,10 +4521,9 @@ var LineChart$1 = function LineChart(config) {
4514
4521
  }), namespace(CONSTANTS$2, 'sort'), namespace(CONSTANTS$2, 'filter'), namespace(CONSTANTS$2, 'custom_metrics'), namespace(CONSTANTS$2, 'limit')];
4515
4522
  },
4516
4523
  formatPanelConfig: function formatPanelConfig() {
4517
- var _CONSTANTS$format_pan;
4524
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
4518
4525
  return [headingConstant(CONSTANTS$2), _extends({}, namespace(CONSTANTS$2, 'chart_styles'), {
4519
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$2.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
4520
- ]
4526
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$2.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$2.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
4521
4527
  }), axisLabelsConstants(CONSTANTS$2), _extends({}, namespace(CONSTANTS$2, 'conditional_formatting'), {
4522
4528
  ruleType: 'lineColor'
4523
4529
  }), namespace(CONSTANTS$2, 'goal_line')
@@ -8643,8 +8649,13 @@ var CONSTANTS$h = {
8643
8649
  title: 'Show Legend',
8644
8650
  description: '',
8645
8651
  namespace: 'legend'
8652
+ },
8653
+ labels: {
8654
+ type: 'labels',
8655
+ title: 'Show Labels',
8656
+ description: '',
8657
+ namespace: 'labels'
8646
8658
  }
8647
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
8648
8659
  }
8649
8660
  },
8650
8661
  axis_labels: {
@@ -8742,7 +8753,7 @@ var FunnelChart = function FunnelChart(config) {
8742
8753
  return hydrated;
8743
8754
  },
8744
8755
  load: function load(dumped) {
8745
- var _dumped$tags;
8756
+ var _dumped$tags, _dumped$labels;
8746
8757
  return _extends({}, dumped, {
8747
8758
  measure: upcastMeasure(dumped.measure),
8748
8759
  order: upcastOrder(dumped.order, dumped.timeDimension),
@@ -8752,6 +8763,7 @@ var FunnelChart = function FunnelChart(config) {
8752
8763
  approxXAxisLabelCount: upcastAxisLabel(dumped.approxXAxisLabelCount),
8753
8764
  approxYAxisLabelCount: upcastAxisLabel(dumped.approxYAxisLabelCount),
8754
8765
  tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
8766
+ labels: (_dumped$labels = dumped.labels) != null ? _dumped$labels : false,
8755
8767
  parameters: upcastParameters(dumped.parameters)
8756
8768
  });
8757
8769
  },
@@ -8783,6 +8795,7 @@ var FunnelChart = function FunnelChart(config) {
8783
8795
  yAxisFormat: null,
8784
8796
  xAxisFormat: null,
8785
8797
  legend: true,
8798
+ labels: false,
8786
8799
  approxXAxisLabelCount: 'auto',
8787
8800
  approxYAxisLabelCount: 'auto',
8788
8801
  axisTitles: undefined,
@@ -8840,10 +8853,9 @@ var FunnelChart = function FunnelChart(config) {
8840
8853
  }), namespace(CONSTANTS$h, 'sort'), namespace(CONSTANTS$h, 'filter'), namespace(CONSTANTS$h, 'custom_metrics'), namespace(CONSTANTS$h, 'limit')];
8841
8854
  },
8842
8855
  formatPanelConfig: function formatPanelConfig() {
8843
- var _CONSTANTS$format_pan;
8856
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
8844
8857
  return [headingConstant(CONSTANTS$h), _extends({}, namespace(CONSTANTS$h, 'chart_styles'), {
8845
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$h.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
8846
- ]
8858
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$h.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$h.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
8847
8859
  }), axisLabelsConstants(CONSTANTS$h), _extends({}, namespace(CONSTANTS$h, 'conditional_formatting'), {
8848
8860
  ruleType: 'backgroundColor'
8849
8861
  }), namespace(CONSTANTS$h, 'headline')];
@@ -9941,7 +9953,7 @@ var attributesSchema$i = function attributesSchema(config) {
9941
9953
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
9942
9954
  stacked: Joi.valid(true, false),
9943
9955
  legend: Joi.valid(true, false),
9944
- // labels: Joi.valid(true, false).optional(),
9956
+ labels: Joi.valid(true, false).optional(),
9945
9957
  type: Joi.valid('barChartV2').required(),
9946
9958
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
9947
9959
  conditionalFormattingRules: conditionalFormattingRulesSchema(config.queryEngineConfig),
@@ -10050,370 +10062,381 @@ var CONSTANTS$k = {
10050
10062
  title: 'Show Legend',
10051
10063
  description: '',
10052
10064
  namespace: 'legend'
10053
- }
10054
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
10055
- }
10056
- },
10057
- axis_labels: {
10058
- type: 'axisLabels',
10059
- title: 'Axis Preferences',
10060
- description: '',
10061
- subSectionDefinition: {
10062
- x: {
10063
- title: 'X Axis',
10064
- description: '',
10065
- namespace: 'x'
10066
10065
  },
10067
- 'x.prefix': {
10068
- title: 'Prefix',
10069
- description: '',
10070
- namespace: 'x.prefix'
10071
- },
10072
- 'x.postfix': {
10073
- title: 'Postfix',
10074
- description: '',
10075
- namespace: 'x.postfix'
10076
- },
10077
- 'x.format': {
10078
- title: 'Format',
10079
- description: '',
10080
- namespace: 'x.format'
10081
- },
10082
- 'x.count': {
10083
- title: 'Label count',
10084
- description: '',
10085
- namespace: 'x.count'
10086
- },
10087
- 'x.axis_title': {
10088
- title: 'Title',
10089
- description: '',
10090
- namespace: 'x.axis_title'
10091
- },
10092
- y: {
10093
- title: 'Y Axis',
10094
- description: '',
10095
- namespace: 'y'
10096
- },
10097
- 'y.prefix': {
10098
- title: 'Prefix',
10099
- description: '',
10100
- namespace: 'y.prefix'
10101
- },
10102
- 'y.postfix': {
10103
- title: 'Postfix',
10104
- description: '',
10105
- namespace: 'y.postfix'
10106
- },
10107
- 'y.format': {
10108
- title: 'Format',
10109
- description: '',
10110
- namespace: 'y.format'
10111
- },
10112
- 'y.count': {
10113
- title: 'Label count',
10114
- description: '',
10115
- namespace: 'y.count'
10116
- },
10117
- 'y.axis_title': {
10118
- title: 'Title',
10119
- description: '',
10120
- namespace: 'y.axis_title'
10121
- }
10122
- }
10123
- },
10124
- conditional_formatting: {
10125
- type: 'conditionalFormatting',
10126
- title: 'Conditional Formatting',
10127
- description: ''
10128
- },
10129
- headline: {
10130
- type: 'headline',
10131
- title: 'Headline',
10132
- description: ''
10133
- },
10134
- goal_line: {
10135
- type: 'goalLine',
10136
- title: 'Goal Lines',
10137
- description: ''
10138
- }
10139
- }
10140
- };
10141
-
10142
- var BarChart$1 = function BarChart(config) {
10143
- return {
10144
- title: 'Bar chart',
10145
- description: 'Ideal for illustrating changes and trends over time with bar graphs.',
10146
- servicesClass: 'BarChart',
10147
- namespace: 'bar_chart',
10148
- dump: function dump(hydrated) {
10149
- return hydrated;
10150
- },
10151
- load: function load(dumped) {
10152
- var _dumped$tags;
10153
- return {
10154
- type: dumped.type,
10155
- measure: upcastMeasure(dumped.measure),
10156
- order: upcastOrder(dumped.order, dumped.timeDimension),
10157
- dimension: upcastStringDimensionsToObject(dumped.dimension),
10158
- // TODO: upcast dumped.timeDimension -> dimension
10159
- displayTitle: dumped.displayTitle,
10160
- displaySubject: dumped.displaySubject,
10161
- protectedByOrganisation: dumped.protectedByOrganisation,
10162
- viewId: upcastViewId(dumped.viewId),
10163
- filter: upcastFilter(dumped.filter),
10164
- dataSetId: dumped.dataSetId,
10165
- limit: dumped.limit,
10166
- timeDimension: null,
10167
- xAxisPostfix: dumped.xAxisPostfix,
10168
- xAxisPrefix: dumped.xAxisPrefix,
10169
- yAxisPostfix: dumped.yAxisPostfix,
10170
- yAxisPrefix: dumped.yAxisPrefix,
10171
- yAxisFormat: dumped.yAxisFormat,
10172
- xAxisFormat: dumped.xAxisFormat,
10173
- conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
10174
- drilldown: dumped.drilldown,
10175
- legend: dumped.legend,
10176
- goalLines: dumped.goalLines,
10177
- headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10178
- parameters: upcastParameters(dumped.parameters),
10179
- approxXAxisLabelCount: upcastAxisLabel(dumped.approxXAxisLabelCount),
10180
- approxYAxisLabelCount: upcastAxisLabel(dumped.approxYAxisLabelCount),
10181
- axisTitles: dumped.axisTitles,
10182
- tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
10183
- stacked: dumped.stacked,
10184
- drilldownOptions: dumped.drilldownOptions
10185
- };
10186
- },
10187
- setAttributes: setAttributes$g(config),
10188
- validate: function validate(attrs, dataSets) {
10189
- return validateView(attrs, dataSets, config.queryEngineConfig);
10190
- },
10191
- init: function init(dataSetId, overrides) {
10192
- return _extends({
10193
- type: 'barChartV2',
10194
- measure: [],
10195
- dimension: [],
10196
- timeDimension: null,
10197
- displayTitle: '',
10198
- displaySubject: '',
10199
- protectedByOrganisation: undefined,
10200
- viewId: upcastViewId(overrides == null ? void 0 : overrides.viewId),
10201
- filter: [],
10202
- order: [],
10203
- dataSetId: dataSetId,
10204
- limit: 5000,
10205
- xAxisPostfix: '',
10206
- xAxisPrefix: '',
10207
- yAxisPostfix: '',
10208
- yAxisPrefix: '',
10209
- yAxisFormat: null,
10210
- xAxisFormat: null,
10211
- conditionalFormattingRules: [],
10212
- drilldown: [],
10213
- legend: true,
10214
- goalLines: undefined,
10215
- approxXAxisLabelCount: 'auto',
10216
- approxYAxisLabelCount: 'auto',
10217
- parameters: {},
10218
- axisTitles: undefined,
10219
- headline: undefined,
10220
- tags: [],
10221
- drilldownOptions: undefined
10222
- }, overrides);
10223
- },
10224
- createFeedback: createFeedback,
10225
- schema: attributesSchema$i(config),
10226
- removeField: function removeField(attrs, fieldId) {
10227
- return removeField$1(attrs, fieldId, config.queryEngineConfig);
10228
- },
10229
- isRunnable: function isRunnable(hydrated) {
10230
- return hydrated.measure.length > 0 && hydrated.dimension.length > 0;
10231
- },
10232
- autoGenerate: function autoGenerate(dataSet) {
10233
- var _DataSet$buildQueryAt = buildQueryAttributes(dataSet, config.queryEngineConfig, 'barChart'),
10234
- measure = _DataSet$buildQueryAt.measure,
10235
- dimension = _DataSet$buildQueryAt.dimension;
10236
- return this.init(dataSet.id, {
10237
- measure: [measure[0]],
10238
- dimension: dimension
10239
- });
10240
- },
10241
- dataPanelConfig: function dataPanelConfig() {
10242
- return [namespace(CONSTANTS$k, 'data_set'), namespace(CONSTANTS$k, 'views'), _extends({}, namespace(CONSTANTS$k, 'field_y_axis'), {
10243
- fieldFilterOptions: {
10244
- forComponent: 'barChart'
10245
- },
10246
- preSetPartialAttributes: function preSetPartialAttributes(values) {
10247
- return {
10248
- measure: values
10249
- };
10250
- },
10251
- getValues: function getValues(attrs) {
10252
- return attrs.measure;
10253
- },
10254
- testId: 'metric-input'
10255
- }), _extends({}, namespace(CONSTANTS$k, 'field_x_axis'), {
10256
- fieldFilterOptions: {
10257
- forComponent: 'barChart',
10258
- onlyDimensions: true
10259
- },
10260
- preventDuplicates: false,
10261
- // return all values in the dimension array instead of seperating out timeDimension
10262
- preSetPartialAttributes: function preSetPartialAttributes(values) {
10263
- return {
10264
- dimension: [].concat(values)
10265
- };
10266
- },
10267
- // does this need to be updated too?
10268
- getValues: function getValues(attrs) {
10269
- return [].concat(attrs.dimension);
10270
- },
10271
- maxAllowed: 2,
10272
- testId: 'add-dimension'
10273
- }), namespace(CONSTANTS$k, 'sort'), namespace(CONSTANTS$k, 'filter'), _extends({}, namespace(CONSTANTS$k, 'drilldown'), {
10274
- options: {
10275
- property: 'drilldownOptions'
10276
- }
10277
- }), namespace(CONSTANTS$k, 'custom_metrics'), namespace(CONSTANTS$k, 'limit')];
10278
- },
10279
- formatPanelConfig: function formatPanelConfig() {
10280
- var _CONSTANTS$format_pan;
10281
- return [headingConstant(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'chart_styles'), {
10282
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$k.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
10283
- ]
10284
- }), axisLabelsConstants(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'conditional_formatting'), {
10285
- ruleType: 'lineColor'
10286
- }), namespace(CONSTANTS$k, 'goal_line')];
10287
- },
10288
- supportedCustomFields: {
10289
- percentages: true,
10290
- dateCalculations: true,
10291
- simpleMaths: true,
10292
- rules: true,
10293
- aggregateMaths: true,
10294
- roundedNumbers: true,
10295
- conditional: true,
10296
- customBuild: [AcceptedTypes.Maths, AcceptedTypes.IfStatement, AcceptedTypes.Aggregates]
10297
- },
10298
- supportedFeatures: {
10299
- parameters: true,
10300
- colorGradient: false
10301
- },
10302
- setDataAttributesFromPreAggregatedDataSet: function setDataAttributesFromPreAggregatedDataSet$1(attributes, dataSet) {
10303
- return setDataAttributesFromPreAggregatedDataSet(attributes, dataSet, this.setAttributes);
10304
- }
10305
- };
10306
- };
10307
-
10308
- var attributesSchema$j = function attributesSchema(config) {
10309
- return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
10310
- legend: Joi.valid(true, false),
10311
- // labels: Joi.valid(true, false).optional(),
10312
- type: Joi.valid('waterfallChart').required(),
10313
- parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10314
- axisTitles: axisTitleSchema(),
10315
- headline: headlineSchema(),
10316
- tags: tagsSchema(),
10317
- increaseColor: Joi.string().required(),
10318
- decreaseColor: Joi.string().required(),
10319
- comparison: Joi.any()
10320
- }));
10321
- };
10322
-
10323
- var setAttributes$h = (function (config) {
10324
- return function (waterfallChart, partial) {
10325
- var newAttributes = setAttributes(waterfallChart, partial, attributesSchema$j(config));
10326
- newAttributes = removeUnusedOrderFieldsFromTimeSeriesComponent(newAttributes);
10327
- return newAttributes;
10328
- };
10329
- });
10330
-
10331
- var CONSTANTS$l = {
10332
- title: 'Waterfall chart',
10333
- description: "Shows a running total as values are added or subtracted. It's useful for understanding how an initial value is affected by a series of positive and negative values.",
10334
- namespace: 'waterfall_chart',
10335
- data_panel: {
10336
- data_set: {
10337
- type: 'dataSet',
10338
- title: 'Data set',
10339
- description: 'What data do you want to use in this waterfall chart?'
10340
- },
10341
- views: {
10342
- type: 'views',
10343
- title: 'View',
10344
- description: ''
10345
- },
10346
- field_y_axis: {
10347
- type: 'fieldCollector',
10348
- title: 'Metric - Y Axis',
10349
- description: 'What do you want each bar to measure?',
10350
- callToAction: 'Add metric'
10351
- },
10352
- field_x_axis: {
10353
- type: 'fieldCollector',
10354
- title: 'Grouping - X Axis',
10355
- description: 'What do you want each bar to represent? An example would be a a date grouping to show each month as a bar',
10356
- callToAction: 'Add grouping'
10357
- },
10358
- dateComparison: {
10359
- type: 'dateComparison',
10360
- title: 'Comparison',
10361
- description: 'Compare the waterfall chart to a previous period.',
10362
- callToAction: 'Add comparison'
10363
- },
10364
- sort: {
10365
- type: 'sort',
10366
- title: 'Sort',
10367
- description: 'Select the order of categories or time on the x Axis.'
10368
- },
10369
- filter: {
10370
- type: 'filter',
10371
- title: 'Filters',
10372
- description: 'Only include the information you want to use in this waterfall chart.'
10373
- },
10374
- custom_metrics: {
10375
- type: 'customMetrics',
10376
- title: 'Custom metrics',
10377
- description: 'Build your own metrics, such as a percentage.'
10378
- },
10379
- limit: {
10380
- type: 'limit',
10381
- title: 'Limit',
10382
- description: 'Set the maximum number of records to show on this waterfall chart.'
10383
- }
10384
- },
10385
- format_panel: {
10386
- heading: {
10387
- type: 'heading',
10388
- title: 'Heading',
10389
- description: '',
10390
- subSectionDefinition: {
10391
- title: {
10392
- type: 'title',
10393
- title: 'Title',
10394
- description: '',
10395
- namespace: 'title'
10396
- },
10397
- subject: {
10398
- title: 'Subject',
10399
- type: 'subject',
10400
- description: '',
10401
- namespace: 'subject'
10402
- }
10403
- }
10404
- },
10405
- chart_styles: {
10406
- type: 'chartStyles',
10407
- title: 'Chart Settings',
10408
- description: '',
10409
- subSectionDefinition: {
10410
- legend: {
10411
- type: 'legend',
10412
- title: 'Show Legend',
10066
+ labels: {
10067
+ type: 'labels',
10068
+ title: 'Show Labels',
10413
10069
  description: '',
10414
- namespace: 'legend'
10070
+ namespace: 'labels'
10071
+ }
10072
+ }
10073
+ },
10074
+ axis_labels: {
10075
+ type: 'axisLabels',
10076
+ title: 'Axis Preferences',
10077
+ description: '',
10078
+ subSectionDefinition: {
10079
+ x: {
10080
+ title: 'X Axis',
10081
+ description: '',
10082
+ namespace: 'x'
10083
+ },
10084
+ 'x.prefix': {
10085
+ title: 'Prefix',
10086
+ description: '',
10087
+ namespace: 'x.prefix'
10088
+ },
10089
+ 'x.postfix': {
10090
+ title: 'Postfix',
10091
+ description: '',
10092
+ namespace: 'x.postfix'
10093
+ },
10094
+ 'x.format': {
10095
+ title: 'Format',
10096
+ description: '',
10097
+ namespace: 'x.format'
10098
+ },
10099
+ 'x.count': {
10100
+ title: 'Label count',
10101
+ description: '',
10102
+ namespace: 'x.count'
10103
+ },
10104
+ 'x.axis_title': {
10105
+ title: 'Title',
10106
+ description: '',
10107
+ namespace: 'x.axis_title'
10108
+ },
10109
+ y: {
10110
+ title: 'Y Axis',
10111
+ description: '',
10112
+ namespace: 'y'
10113
+ },
10114
+ 'y.prefix': {
10115
+ title: 'Prefix',
10116
+ description: '',
10117
+ namespace: 'y.prefix'
10118
+ },
10119
+ 'y.postfix': {
10120
+ title: 'Postfix',
10121
+ description: '',
10122
+ namespace: 'y.postfix'
10123
+ },
10124
+ 'y.format': {
10125
+ title: 'Format',
10126
+ description: '',
10127
+ namespace: 'y.format'
10128
+ },
10129
+ 'y.count': {
10130
+ title: 'Label count',
10131
+ description: '',
10132
+ namespace: 'y.count'
10133
+ },
10134
+ 'y.axis_title': {
10135
+ title: 'Title',
10136
+ description: '',
10137
+ namespace: 'y.axis_title'
10138
+ }
10139
+ }
10140
+ },
10141
+ conditional_formatting: {
10142
+ type: 'conditionalFormatting',
10143
+ title: 'Conditional Formatting',
10144
+ description: ''
10145
+ },
10146
+ headline: {
10147
+ type: 'headline',
10148
+ title: 'Headline',
10149
+ description: ''
10150
+ },
10151
+ goal_line: {
10152
+ type: 'goalLine',
10153
+ title: 'Goal Lines',
10154
+ description: ''
10155
+ }
10156
+ }
10157
+ };
10158
+
10159
+ var BarChart$1 = function BarChart(config) {
10160
+ return {
10161
+ title: 'Bar chart',
10162
+ description: 'Ideal for illustrating changes and trends over time with bar graphs.',
10163
+ servicesClass: 'BarChart',
10164
+ namespace: 'bar_chart',
10165
+ dump: function dump(hydrated) {
10166
+ return hydrated;
10167
+ },
10168
+ load: function load(dumped) {
10169
+ var _dumped$tags;
10170
+ return {
10171
+ type: dumped.type,
10172
+ measure: upcastMeasure(dumped.measure),
10173
+ order: upcastOrder(dumped.order, dumped.timeDimension),
10174
+ dimension: upcastStringDimensionsToObject(dumped.dimension),
10175
+ // TODO: upcast dumped.timeDimension -> dimension
10176
+ displayTitle: dumped.displayTitle,
10177
+ displaySubject: dumped.displaySubject,
10178
+ protectedByOrganisation: dumped.protectedByOrganisation,
10179
+ viewId: upcastViewId(dumped.viewId),
10180
+ filter: upcastFilter(dumped.filter),
10181
+ dataSetId: dumped.dataSetId,
10182
+ limit: dumped.limit,
10183
+ timeDimension: null,
10184
+ xAxisPostfix: dumped.xAxisPostfix,
10185
+ xAxisPrefix: dumped.xAxisPrefix,
10186
+ yAxisPostfix: dumped.yAxisPostfix,
10187
+ yAxisPrefix: dumped.yAxisPrefix,
10188
+ yAxisFormat: dumped.yAxisFormat,
10189
+ xAxisFormat: dumped.xAxisFormat,
10190
+ conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
10191
+ drilldown: dumped.drilldown,
10192
+ legend: dumped.legend,
10193
+ labels: dumped.labels,
10194
+ goalLines: dumped.goalLines,
10195
+ headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10196
+ parameters: upcastParameters(dumped.parameters),
10197
+ approxXAxisLabelCount: upcastAxisLabel(dumped.approxXAxisLabelCount),
10198
+ approxYAxisLabelCount: upcastAxisLabel(dumped.approxYAxisLabelCount),
10199
+ axisTitles: dumped.axisTitles,
10200
+ tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
10201
+ stacked: dumped.stacked,
10202
+ drilldownOptions: dumped.drilldownOptions
10203
+ };
10204
+ },
10205
+ setAttributes: setAttributes$g(config),
10206
+ validate: function validate(attrs, dataSets) {
10207
+ return validateView(attrs, dataSets, config.queryEngineConfig);
10208
+ },
10209
+ init: function init(dataSetId, overrides) {
10210
+ return _extends({
10211
+ type: 'barChartV2',
10212
+ measure: [],
10213
+ dimension: [],
10214
+ timeDimension: null,
10215
+ displayTitle: '',
10216
+ displaySubject: '',
10217
+ protectedByOrganisation: undefined,
10218
+ viewId: upcastViewId(overrides == null ? void 0 : overrides.viewId),
10219
+ filter: [],
10220
+ order: [],
10221
+ dataSetId: dataSetId,
10222
+ limit: 5000,
10223
+ xAxisPostfix: '',
10224
+ xAxisPrefix: '',
10225
+ yAxisPostfix: '',
10226
+ yAxisPrefix: '',
10227
+ yAxisFormat: null,
10228
+ xAxisFormat: null,
10229
+ conditionalFormattingRules: [],
10230
+ drilldown: [],
10231
+ legend: true,
10232
+ labels: false,
10233
+ goalLines: undefined,
10234
+ approxXAxisLabelCount: 'auto',
10235
+ approxYAxisLabelCount: 'auto',
10236
+ parameters: {},
10237
+ axisTitles: undefined,
10238
+ headline: undefined,
10239
+ tags: [],
10240
+ drilldownOptions: undefined
10241
+ }, overrides);
10242
+ },
10243
+ createFeedback: createFeedback,
10244
+ schema: attributesSchema$i(config),
10245
+ removeField: function removeField(attrs, fieldId) {
10246
+ return removeField$1(attrs, fieldId, config.queryEngineConfig);
10247
+ },
10248
+ isRunnable: function isRunnable(hydrated) {
10249
+ return hydrated.measure.length > 0 && hydrated.dimension.length > 0;
10250
+ },
10251
+ autoGenerate: function autoGenerate(dataSet) {
10252
+ var _DataSet$buildQueryAt = buildQueryAttributes(dataSet, config.queryEngineConfig, 'barChart'),
10253
+ measure = _DataSet$buildQueryAt.measure,
10254
+ dimension = _DataSet$buildQueryAt.dimension;
10255
+ return this.init(dataSet.id, {
10256
+ measure: [measure[0]],
10257
+ dimension: dimension
10258
+ });
10259
+ },
10260
+ dataPanelConfig: function dataPanelConfig() {
10261
+ return [namespace(CONSTANTS$k, 'data_set'), namespace(CONSTANTS$k, 'views'), _extends({}, namespace(CONSTANTS$k, 'field_y_axis'), {
10262
+ fieldFilterOptions: {
10263
+ forComponent: 'barChart'
10264
+ },
10265
+ preSetPartialAttributes: function preSetPartialAttributes(values) {
10266
+ return {
10267
+ measure: values
10268
+ };
10269
+ },
10270
+ getValues: function getValues(attrs) {
10271
+ return attrs.measure;
10272
+ },
10273
+ testId: 'metric-input'
10274
+ }), _extends({}, namespace(CONSTANTS$k, 'field_x_axis'), {
10275
+ fieldFilterOptions: {
10276
+ forComponent: 'barChart',
10277
+ onlyDimensions: true
10278
+ },
10279
+ preventDuplicates: false,
10280
+ // return all values in the dimension array instead of seperating out timeDimension
10281
+ preSetPartialAttributes: function preSetPartialAttributes(values) {
10282
+ return {
10283
+ dimension: [].concat(values)
10284
+ };
10285
+ },
10286
+ // does this need to be updated too?
10287
+ getValues: function getValues(attrs) {
10288
+ return [].concat(attrs.dimension);
10289
+ },
10290
+ maxAllowed: 2,
10291
+ testId: 'add-dimension'
10292
+ }), namespace(CONSTANTS$k, 'sort'), namespace(CONSTANTS$k, 'filter'), _extends({}, namespace(CONSTANTS$k, 'drilldown'), {
10293
+ options: {
10294
+ property: 'drilldownOptions'
10295
+ }
10296
+ }), namespace(CONSTANTS$k, 'custom_metrics'), namespace(CONSTANTS$k, 'limit')];
10297
+ },
10298
+ formatPanelConfig: function formatPanelConfig() {
10299
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
10300
+ return [headingConstant(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'chart_styles'), {
10301
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$k.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$k.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
10302
+ }), axisLabelsConstants(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'conditional_formatting'), {
10303
+ ruleType: 'lineColor'
10304
+ }), namespace(CONSTANTS$k, 'goal_line')];
10305
+ },
10306
+ supportedCustomFields: {
10307
+ percentages: true,
10308
+ dateCalculations: true,
10309
+ simpleMaths: true,
10310
+ rules: true,
10311
+ aggregateMaths: true,
10312
+ roundedNumbers: true,
10313
+ conditional: true,
10314
+ customBuild: [AcceptedTypes.Maths, AcceptedTypes.IfStatement, AcceptedTypes.Aggregates]
10315
+ },
10316
+ supportedFeatures: {
10317
+ parameters: true,
10318
+ colorGradient: false
10319
+ },
10320
+ setDataAttributesFromPreAggregatedDataSet: function setDataAttributesFromPreAggregatedDataSet$1(attributes, dataSet) {
10321
+ return setDataAttributesFromPreAggregatedDataSet(attributes, dataSet, this.setAttributes);
10322
+ }
10323
+ };
10324
+ };
10325
+
10326
+ var attributesSchema$j = function attributesSchema(config) {
10327
+ return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
10328
+ legend: Joi.valid(true, false),
10329
+ labels: Joi.valid(true, false).optional(),
10330
+ type: Joi.valid('waterfallChart').required(),
10331
+ parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10332
+ axisTitles: axisTitleSchema(),
10333
+ headline: headlineSchema(),
10334
+ tags: tagsSchema(),
10335
+ increaseColor: Joi.string().required(),
10336
+ decreaseColor: Joi.string().required(),
10337
+ comparison: Joi.any()
10338
+ }));
10339
+ };
10340
+
10341
+ var setAttributes$h = (function (config) {
10342
+ return function (waterfallChart, partial) {
10343
+ var newAttributes = setAttributes(waterfallChart, partial, attributesSchema$j(config));
10344
+ newAttributes = removeUnusedOrderFieldsFromTimeSeriesComponent(newAttributes);
10345
+ return newAttributes;
10346
+ };
10347
+ });
10348
+
10349
+ var CONSTANTS$l = {
10350
+ title: 'Waterfall chart',
10351
+ description: "Shows a running total as values are added or subtracted. It's useful for understanding how an initial value is affected by a series of positive and negative values.",
10352
+ namespace: 'waterfall_chart',
10353
+ data_panel: {
10354
+ data_set: {
10355
+ type: 'dataSet',
10356
+ title: 'Data set',
10357
+ description: 'What data do you want to use in this waterfall chart?'
10358
+ },
10359
+ views: {
10360
+ type: 'views',
10361
+ title: 'View',
10362
+ description: ''
10363
+ },
10364
+ field_y_axis: {
10365
+ type: 'fieldCollector',
10366
+ title: 'Metric - Y Axis',
10367
+ description: 'What do you want each bar to measure?',
10368
+ callToAction: 'Add metric'
10369
+ },
10370
+ field_x_axis: {
10371
+ type: 'fieldCollector',
10372
+ title: 'Grouping - X Axis',
10373
+ description: 'What do you want each bar to represent? An example would be a a date grouping to show each month as a bar',
10374
+ callToAction: 'Add grouping'
10375
+ },
10376
+ dateComparison: {
10377
+ type: 'dateComparison',
10378
+ title: 'Comparison',
10379
+ description: 'Compare the waterfall chart to a previous period.',
10380
+ callToAction: 'Add comparison'
10381
+ },
10382
+ sort: {
10383
+ type: 'sort',
10384
+ title: 'Sort',
10385
+ description: 'Select the order of categories or time on the x Axis.'
10386
+ },
10387
+ filter: {
10388
+ type: 'filter',
10389
+ title: 'Filters',
10390
+ description: 'Only include the information you want to use in this waterfall chart.'
10391
+ },
10392
+ custom_metrics: {
10393
+ type: 'customMetrics',
10394
+ title: 'Custom metrics',
10395
+ description: 'Build your own metrics, such as a percentage.'
10396
+ },
10397
+ limit: {
10398
+ type: 'limit',
10399
+ title: 'Limit',
10400
+ description: 'Set the maximum number of records to show on this waterfall chart.'
10401
+ }
10402
+ },
10403
+ format_panel: {
10404
+ heading: {
10405
+ type: 'heading',
10406
+ title: 'Heading',
10407
+ description: '',
10408
+ subSectionDefinition: {
10409
+ title: {
10410
+ type: 'title',
10411
+ title: 'Title',
10412
+ description: '',
10413
+ namespace: 'title'
10414
+ },
10415
+ subject: {
10416
+ title: 'Subject',
10417
+ type: 'subject',
10418
+ description: '',
10419
+ namespace: 'subject'
10420
+ }
10421
+ }
10422
+ },
10423
+ chart_styles: {
10424
+ type: 'chartStyles',
10425
+ title: 'Chart Settings',
10426
+ description: '',
10427
+ subSectionDefinition: {
10428
+ legend: {
10429
+ type: 'legend',
10430
+ title: 'Show Legend',
10431
+ description: '',
10432
+ namespace: 'legend'
10433
+ },
10434
+ labels: {
10435
+ type: 'labels',
10436
+ title: 'Show Labels',
10437
+ description: '',
10438
+ namespace: 'labels'
10415
10439
  }
10416
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
10417
10440
  }
10418
10441
  },
10419
10442
  axis_labels: {
@@ -10516,6 +10539,7 @@ var WaterfallChart = function WaterfallChart(config) {
10516
10539
  headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10517
10540
  tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
10518
10541
  legend: dumped.legend,
10542
+ labels: dumped.labels,
10519
10543
  viewId: upcastViewId(dumped.viewId),
10520
10544
  dataSetId: dumped.dataSetId,
10521
10545
  limit: dumped.limit,
@@ -10565,6 +10589,7 @@ var WaterfallChart = function WaterfallChart(config) {
10565
10589
  yAxisFormat: null,
10566
10590
  xAxisFormat: null,
10567
10591
  legend: true,
10592
+ labels: false,
10568
10593
  parameters: {},
10569
10594
  axisTitles: undefined,
10570
10595
  headline: undefined,
@@ -10628,10 +10653,9 @@ var WaterfallChart = function WaterfallChart(config) {
10628
10653
  }), namespace(CONSTANTS$l, 'sort'), namespace(CONSTANTS$l, 'filter'), namespace(CONSTANTS$l, 'custom_metrics'), namespace(CONSTANTS$l, 'limit')];
10629
10654
  },
10630
10655
  formatPanelConfig: function formatPanelConfig() {
10631
- var _CONSTANTS$format_pan;
10656
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
10632
10657
  return [headingConstant(CONSTANTS$l), namespace(CONSTANTS$l, 'waterfall_colors'), _extends({}, namespace(CONSTANTS$l, 'chart_styles'), {
10633
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$l.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
10634
- ]
10658
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$l.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$l.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
10635
10659
  }), axisLabelsConstants(CONSTANTS$l)];
10636
10660
  },
10637
10661
  supportedCustomFields: {
@@ -10658,7 +10682,7 @@ var attributesSchema$k = function attributesSchema(config) {
10658
10682
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
10659
10683
  stacked: Joi.valid(true, false),
10660
10684
  legend: Joi.valid(true, false),
10661
- // labels: Joi.valid(true, false).optional(),
10685
+ labels: Joi.valid(true, false).optional(),
10662
10686
  type: Joi.valid('areaChartV2').required(),
10663
10687
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10664
10688
  lineCurve: areaCurveSchema,
@@ -10774,8 +10798,13 @@ var CONSTANTS$m = {
10774
10798
  title: 'Show Legend',
10775
10799
  description: '',
10776
10800
  namespace: 'legend'
10801
+ },
10802
+ labels: {
10803
+ type: 'labels',
10804
+ title: 'Show Labels',
10805
+ description: '',
10806
+ namespace: 'labels'
10777
10807
  }
10778
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
10779
10808
  }
10780
10809
  },
10781
10810
  axis_labels: {
@@ -10903,6 +10932,7 @@ var AreaChart$1 = function AreaChart(config) {
10903
10932
  conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
10904
10933
  drilldown: dumped.drilldown,
10905
10934
  legend: dumped.legend,
10935
+ labels: dumped.labels,
10906
10936
  goalLines: dumped.goalLines,
10907
10937
  headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10908
10938
  parameters: upcastParameters(dumped.parameters),
@@ -10942,6 +10972,7 @@ var AreaChart$1 = function AreaChart(config) {
10942
10972
  conditionalFormattingRules: [],
10943
10973
  drilldown: [],
10944
10974
  legend: true,
10975
+ labels: false,
10945
10976
  goalLines: undefined,
10946
10977
  approxXAxisLabelCount: 'auto',
10947
10978
  approxYAxisLabelCount: 'auto',
@@ -11005,10 +11036,9 @@ var AreaChart$1 = function AreaChart(config) {
11005
11036
  }), namespace(CONSTANTS$m, 'sort'), namespace(CONSTANTS$m, 'filter'), namespace(CONSTANTS$m, 'custom_metrics'), namespace(CONSTANTS$m, 'limit')];
11006
11037
  },
11007
11038
  formatPanelConfig: function formatPanelConfig() {
11008
- var _CONSTANTS$format_pan;
11039
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
11009
11040
  return [headingConstant(CONSTANTS$m), _extends({}, namespace(CONSTANTS$m, 'chart_styles'), {
11010
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$m.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
11011
- ]
11041
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$m.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$m.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
11012
11042
  }), axisLabelsConstants(CONSTANTS$m), _extends({}, namespace(CONSTANTS$m, 'conditional_formatting'), {
11013
11043
  ruleType: 'lineColor'
11014
11044
  }), namespace(CONSTANTS$m, 'goal_line')];
@@ -11037,7 +11067,7 @@ var attributesSchema$l = function attributesSchema(config) {
11037
11067
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), {
11038
11068
  stacked: Joi.valid(true, false),
11039
11069
  legend: Joi.valid(true, false),
11040
- // labels: Joi.valid(true, false).optional(),
11070
+ labels: Joi.valid(true, false).optional(),
11041
11071
  barMeasure: Joi.array().items(measureSchema(config.queryEngineConfig.supportedAggregates, config.attributesSchemaOptions)),
11042
11072
  lineMeasure: Joi.array().items(measureSchema(config.queryEngineConfig.supportedAggregates, config.attributesSchemaOptions)),
11043
11073
  barDimension: dimensionSchema(config.queryEngineConfig.supportedTimeTruncFunctions, config.attributesSchemaOptions),
@@ -11183,8 +11213,13 @@ var CONSTANTS$n = {
11183
11213
  title: 'Show Legend',
11184
11214
  description: '',
11185
11215
  namespace: 'legend'
11216
+ },
11217
+ labels: {
11218
+ type: 'labels',
11219
+ title: 'Show Labels',
11220
+ description: '',
11221
+ namespace: 'labels'
11186
11222
  }
11187
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
11188
11223
  }
11189
11224
  },
11190
11225
  axis_labels: {
@@ -11316,6 +11351,7 @@ var ComboChartV2 = function ComboChartV2(config) {
11316
11351
  yAxisFormat: null,
11317
11352
  xAxisFormat: null,
11318
11353
  legend: true,
11354
+ labels: false,
11319
11355
  approxXAxisLabelCount: 'auto',
11320
11356
  approxYAxisLabelCount: 'auto',
11321
11357
  goalLines: undefined,
@@ -11356,19 +11392,18 @@ var ComboChartV2 = function ComboChartV2(config) {
11356
11392
  }), namespace(CONSTANTS$n, 'combo_chart_dimension'), namespace(CONSTANTS$n, 'sort'), namespace(CONSTANTS$n, 'filter'), namespace(CONSTANTS$n, 'custom_metrics'), namespace(CONSTANTS$n, 'limit')];
11357
11393
  },
11358
11394
  formatPanelConfig: function formatPanelConfig() {
11359
- var _CONSTANTS$format_pan, _CONSTANTS$format_pan2, _CONSTANTS$format_pan3, _CONSTANTS$format_pan4, _CONSTANTS$format_pan5, _CONSTANTS$format_pan6, _CONSTANTS$format_pan7;
11395
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2, _CONSTANTS$format_pan3, _CONSTANTS$format_pan4, _CONSTANTS$format_pan5, _CONSTANTS$format_pan6, _CONSTANTS$format_pan7, _CONSTANTS$format_pan8;
11360
11396
  return [headingConstant(CONSTANTS$n), _extends({}, namespace(CONSTANTS$n, 'chart_styles'), {
11361
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$n.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
11362
- ]
11397
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$n.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$n.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
11363
11398
  }), axisLabelsConstants(CONSTANTS$n), _extends({}, namespace(CONSTANTS$n, 'conditional_formatting'), {
11364
11399
  ruleType: 'backgroundColor',
11365
11400
  subSection: [{
11366
- title: (_CONSTANTS$format_pan2 = (_CONSTANTS$format_pan3 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan3 = _CONSTANTS$format_pan3.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan3.bar.title) != null ? _CONSTANTS$format_pan2 : '',
11367
- namespace: (_CONSTANTS$format_pan4 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan4 = _CONSTANTS$format_pan4.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan4.bar.namespace,
11401
+ title: (_CONSTANTS$format_pan3 = (_CONSTANTS$format_pan4 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan4 = _CONSTANTS$format_pan4.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan4.bar.title) != null ? _CONSTANTS$format_pan3 : '',
11402
+ namespace: (_CONSTANTS$format_pan5 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan5 = _CONSTANTS$format_pan5.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan5.bar.namespace,
11368
11403
  propKey: 'bar'
11369
11404
  }, {
11370
- title: (_CONSTANTS$format_pan5 = (_CONSTANTS$format_pan6 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan6 = _CONSTANTS$format_pan6.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan6.line.title) != null ? _CONSTANTS$format_pan5 : '',
11371
- namespace: (_CONSTANTS$format_pan7 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan7 = _CONSTANTS$format_pan7.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan7.line.namespace,
11405
+ title: (_CONSTANTS$format_pan6 = (_CONSTANTS$format_pan7 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan7 = _CONSTANTS$format_pan7.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan7.line.title) != null ? _CONSTANTS$format_pan6 : '',
11406
+ namespace: (_CONSTANTS$format_pan8 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan8 = _CONSTANTS$format_pan8.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan8.line.namespace,
11372
11407
  propKey: 'line'
11373
11408
  }]
11374
11409
  }), namespace(CONSTANTS$n, 'goal_line')];
@@ -12509,12 +12544,16 @@ var defaultNumberFormatOptions = function defaultNumberFormatOptions(textOverrid
12509
12544
  description: textOverride('number_format_option.currency_eur', 'Currency €')
12510
12545
  },
12511
12546
  _vizzly_to_percentage: {
12512
- formatter: function formatter(value, noValueReplacement) {
12547
+ formatter: function formatter(value, noValueReplacement, total) {
12513
12548
  if (noValueReplacement === void 0) {
12514
12549
  noValueReplacement = noValue;
12515
12550
  }
12516
12551
  if (value === null || value === undefined) return noValueReplacement;
12517
12552
  if (Number.isNaN(value)) return formattingError;
12553
+ if (total !== undefined && total !== 0 && typeof value === 'number') {
12554
+ var percentage = isPercentageOf(value, total);
12555
+ return toDp(percentage, 2) + "%";
12556
+ }
12518
12557
  return toPercentage(value, 2);
12519
12558
  },
12520
12559
  description: textOverride('number_format_option.percentage', 'Percentage')
@@ -13062,10 +13101,10 @@ var formatSeriesName = function formatSeriesName(result, textOverride, type, id,
13062
13101
  return newTitle != null ? newTitle : defaultLabel;
13063
13102
  };
13064
13103
  };
13065
- var convertValueToFormat = function convertValueToFormat(value, numberFormatOptions, format) {
13104
+ var convertValueToFormat = function convertValueToFormat(value, numberFormatOptions, format, total) {
13066
13105
  var _numberFormatOptions;
13067
13106
  var formatter = numberFormatOptions == null || (_numberFormatOptions = numberFormatOptions[format != null ? format : '']) == null ? void 0 : _numberFormatOptions.formatter;
13068
- return formatter ? formatter(value) : value;
13107
+ return formatter ? formatter(value, undefined, total) : value;
13069
13108
  };
13070
13109
  function getGradientAdjustedColor(rule, matchedHexValue, actualValue) {
13071
13110
  if (rule.boundaries && rule.boundaries.length === 2 && rule.ruleValueEnd) {
@@ -34066,6 +34105,12 @@ var calculateMinMax = function calculateMinMax(values) {
34066
34105
  maxValue: maxValue
34067
34106
  };
34068
34107
  };
34108
+ var normalizeKey = function normalizeKey(value) {
34109
+ if (typeof value === 'number' || !isNaN(Number(value)) && !isNaN(parseFloat(value))) {
34110
+ return Number(value).toString().split('.')[0];
34111
+ }
34112
+ return String(value);
34113
+ };
34069
34114
  var showMinMaxLabel = function showMinMaxLabel(value, totalItems, minValue, maxValue) {
34070
34115
  return totalItems < 11 || value == minValue || value == maxValue;
34071
34116
  };
@@ -34078,6 +34123,40 @@ var getMinMaxChartValueFromNumberArray = function getMinMaxChartValueFromNumberA
34078
34123
  maxValue: maxValue
34079
34124
  };
34080
34125
  };
34126
+ var getLabelDictionary = function getLabelDictionary(formattedData, keys) {
34127
+ var formattedLabelNames = formattedData == null ? void 0 : formattedData.map(function (d) {
34128
+ var convertedArray = keys.map(function (key) {
34129
+ var _ref;
34130
+ if (!d[key].formattedValue) return;
34131
+ var valueKey = normalizeKey(d[key].value);
34132
+ var label = d[key].formattedValue;
34133
+ return _ref = {}, _ref[valueKey] = label, _ref;
34134
+ }).flat();
34135
+ return convertedArray;
34136
+ });
34137
+ if (!formattedLabelNames) return {};
34138
+ var dictionary = {};
34139
+ formattedLabelNames.forEach(function (labelArray) {
34140
+ if (labelArray) {
34141
+ labelArray.forEach(function (labelObj) {
34142
+ if (labelObj) {
34143
+ Object.entries(labelObj).forEach(function (_ref2) {
34144
+ var value = _ref2[0],
34145
+ label = _ref2[1];
34146
+ dictionary[value] = label;
34147
+ });
34148
+ }
34149
+ });
34150
+ }
34151
+ });
34152
+ return dictionary;
34153
+ };
34154
+ var getFormattedValue = function getFormattedValue(value, dictionary) {
34155
+ var _dictionary$normalize;
34156
+ if (!dictionary) return value;
34157
+ var normalizedKey = normalizeKey(value);
34158
+ return (_dictionary$normalize = dictionary[normalizedKey]) != null ? _dictionary$normalize : value;
34159
+ };
34081
34160
  var getAllChartValues = function getAllChartValues(data, keys) {
34082
34161
  var allValues = [];
34083
34162
  data.forEach(function (item) {
@@ -34103,6 +34182,12 @@ var accessors = function accessors(xAxisIsTime, xKey, yKey, horizontal) {
34103
34182
  };
34104
34183
  };
34105
34184
  var DEFAULT_Y_AXIS_LABEL_COUNT = 5;
34185
+ var LABEL_TEXT_STYLE = {
34186
+ textAnchor: 'middle',
34187
+ fontSize: '10px',
34188
+ fill: '#333',
34189
+ fontWeight: 500
34190
+ };
34106
34191
  var VizzlyXYChart = function VizzlyXYChart(props) {
34107
34192
  var _props$height, _theme$axis$stroke, _theme$axis, _ref, _props$lines$data$len, _props$lines, _props$areas, _props$bars, _props$lines$threshol, _props$lines2, _props$areas2, _props$forceXAxisAsTi, _props$bars2, _props$lines3, _theme$grid$stroke, _theme$grid, _props$axisTitles, _props$axisTitles2, _props$axisTitles3, _props$axisTitles4, _props$areas7, _props$bars3, _props$bars7, _props$lines4, _props$lines7, _props$trends2, _props$lines13, _props$bars14, _props$goalLine, _props$bars15, _props$bars16, _props$bars17;
34108
34193
  var height = adjustHeight((_props$height = props == null ? void 0 : props.height) != null ? _props$height : 300, props == null ? void 0 : props.legend);
@@ -34387,57 +34472,49 @@ var VizzlyXYChart = function VizzlyXYChart(props) {
34387
34472
  }), "bar_with_previous_" + props.uniqueId + "_" + keyIndex);
34388
34473
  })
34389
34474
  }), props.bars.data.map(function (dataPoint, dataIndex) {
34390
- return jsx("g", {
34391
- children: props.bars.keys.map(function (key, keyIndex) {
34392
- var value = dataPoint[key];
34393
- if (!value || !props.labels) return null;
34394
- if (props.bars.data.length > 10) {
34395
- var values = props.bars.data.map(function (d) {
34396
- return Number(d[key]);
34397
- }).filter(function (v) {
34398
- return v;
34399
- });
34400
- var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(values),
34401
- _minValue = _getMinMaxChartValueF.minValue,
34402
- _maxValue = _getMinMaxChartValueF.maxValue;
34403
- var currentValue = Number(value);
34404
- if (currentValue !== _minValue && currentValue !== _maxValue) {
34405
- return null;
34406
- }
34407
- }
34408
- var chartWidth = props.width || 400;
34409
- var barWidth = (chartWidth - margin.left - margin.right) / props.bars.data.length;
34410
- var barX = margin.left + dataIndex * barWidth + barWidth / 2;
34411
- var isPositiveModifier = isPositiveModifierKey(key);
34412
- var barHeight, barY;
34413
- if (isPositiveModifier) {
34414
- // Helper function to extract the base name from the key (e.g., "{Revenue, previous}" -> "Revenue")
34415
- var getBaseKeyName = function getBaseKeyName(keyName) {
34416
- return keyName.replace(/[{}]/g, '').split(',')[0].trim();
34417
- };
34418
- var standardKey = props.bars.keys.find(function (k) {
34419
- return !isPositiveModifierKey(k) && getBaseKeyName(k) === getBaseKeyName(key);
34420
- });
34421
- var totalValue = standardKey ? dataPoint[standardKey] : 0;
34422
- var previousValue = Number(value);
34423
- var totalBarValue = Number(totalValue) + previousValue;
34424
- barHeight = (height - margin.top - margin.bottom) * totalBarValue / (maxValue || 1);
34425
- barY = height - margin.bottom - barHeight;
34426
- } else {
34427
- barHeight = (height - margin.top - margin.bottom) * Number(value) / (maxValue || 1);
34428
- barY = height - margin.bottom - barHeight;
34429
- }
34430
- return jsx("text", {
34431
- x: barX,
34432
- y: barY,
34433
- textAnchor: "bottom",
34434
- fontSize: "10px",
34435
- fill: "#333",
34436
- fontWeight: "500",
34437
- children: formatYAxisLabel$1(props)(value)
34438
- }, "funnel_label_" + props.uniqueId + "_" + dataIndex + "_" + keyIndex);
34439
- })
34440
- }, "funnel_labels_" + props.uniqueId + "_" + dataIndex);
34475
+ var mainKey = props.bars.keys[0];
34476
+ var value = dataPoint[mainKey];
34477
+ if (!value || !props.labels) return null;
34478
+ if (props.bars && props.bars.data.length > 30) {
34479
+ var values = props.bars.data.map(function (d) {
34480
+ return Number(d[mainKey]);
34481
+ }).filter(function (v) {
34482
+ return v;
34483
+ });
34484
+ var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(values),
34485
+ _minValue = _getMinMaxChartValueF.minValue,
34486
+ _maxValue = _getMinMaxChartValueF.maxValue;
34487
+ var currentValue = Number(value);
34488
+ if (currentValue !== _minValue && currentValue !== _maxValue) {
34489
+ return null;
34490
+ }
34491
+ }
34492
+ var _accessors = accessors(xAxisIsTime, x, mainKey, horizontal),
34493
+ yAccessor = _accessors.yAccessor;
34494
+ var yValue = yAccessor(dataPoint);
34495
+ var defaultChartWidth = 400;
34496
+ var chartWidth = props.width || defaultChartWidth;
34497
+ var barWidth = (chartWidth - margin.left - margin.right) / props.bars.data.length;
34498
+ var barX = margin.left + dataIndex * barWidth + barWidth / 2;
34499
+ var availableHeight = height - margin.top - margin.bottom;
34500
+ var yScale = scaleLinear({
34501
+ domain: [minValue, maxValue],
34502
+ range: [availableHeight, 0],
34503
+ nice: true
34504
+ });
34505
+ var scaledYValue = yScale(Number(yValue));
34506
+ var barTopY = margin.top + scaledYValue;
34507
+ var yPadding = 5;
34508
+ var labelY = barTopY - yPadding;
34509
+ return jsx("text", {
34510
+ x: barX,
34511
+ y: labelY,
34512
+ textAnchor: LABEL_TEXT_STYLE.textAnchor,
34513
+ fontSize: LABEL_TEXT_STYLE.fontSize,
34514
+ fill: LABEL_TEXT_STYLE.fill,
34515
+ fontWeight: LABEL_TEXT_STYLE.fontWeight,
34516
+ children: formatYAxisLabel$1(props)(value)
34517
+ }, "funnel_label_" + props.uniqueId + "_" + dataIndex);
34441
34518
  })]
34442
34519
  }), (props == null ? void 0 : props.bars) && props.bars.stacked && jsxs(Fragment, {
34443
34520
  children: [props.enableHover && jsx("style", {
@@ -38891,12 +38968,12 @@ var PieChartView = function PieChartView(props) {
38891
38968
  var rS = resultSet$1(props.result, pivotConfig, fakeQuery, false, checkForNullValue(props.dataSetId, props.dimension, props.timeDimension, textOverride, valueAlias));
38892
38969
  var pieSeries = series$1(fakeQuery, props.result, pivotConfig);
38893
38970
 
38894
- /*
38971
+ /*
38895
38972
  NOTES
38896
38973
  - isArray(data[props.dimension[0].field]) check below added so Pie charts can support conditional formatting on string[] dataTypes
38897
38974
  */
38898
38975
 
38899
- /*
38976
+ /*
38900
38977
  TODO
38901
38978
  - Allow string[] dataTypes to be chosen as a grouping in the Pie chart
38902
38979
  - Make sure the formatting of labels is correct when using string[] dataTypes (currently they appear with no spaces or commas within the pie chart tooltip)
@@ -38961,7 +39038,10 @@ var PieChartView = function PieChartView(props) {
38961
39038
  showLabel: (theme == null ? void 0 : theme.detail) === 'verbose' && (props == null ? void 0 : props.labels) !== false || (props == null ? void 0 : props.labels),
38962
39039
  legend: showLegend(props == null ? void 0 : props.legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
38963
39040
  formatValue: function formatValue(value) {
38964
- return convertValueToFormat(toDp(value, 2), props == null ? void 0 : props.numberFormatOptions, props == null ? void 0 : props.labelFormat);
39041
+ var total = data[0].data.reduce(function (sum, item) {
39042
+ return sum + (item[data[0].valueKey] || 0);
39043
+ }, 0);
39044
+ return convertValueToFormat(value, props == null ? void 0 : props.numberFormatOptions, props == null ? void 0 : props.labelFormat, total);
38965
39045
  }
38966
39046
  })
38967
39047
  })]
@@ -43419,373 +43499,6 @@ function buildComboTooltipData(barTooltipData, lineTooltipData, xScaleKey) {
43419
43499
  return barTooltipData && lineTooltipData ? _extends({}, barTooltipData, lineTooltipData) : undefined;
43420
43500
  }
43421
43501
 
43422
- var LegendItemBox = function LegendItemBox(_ref) {
43423
- var color = _ref.color,
43424
- style = _ref.style;
43425
- return jsx("svg", {
43426
- width: 10,
43427
- height: 10,
43428
- style: {
43429
- display: 'block'
43430
- },
43431
- children: style.type === 'line' ? style.strokeDasharray !== null ? jsx("line", {
43432
- x1: "0",
43433
- y1: "5",
43434
- x2: "10",
43435
- y2: "5",
43436
- stroke: color,
43437
- strokeWidth: style.strokeWidth,
43438
- strokeDasharray: 2
43439
- }) : jsx("line", {
43440
- x1: "0",
43441
- y1: "5",
43442
- x2: "10",
43443
- y2: "5",
43444
- stroke: color,
43445
- strokeWidth: style.strokeWidth
43446
- }) : jsx("rect", {
43447
- fill: color,
43448
- width: 10,
43449
- height: 10,
43450
- rx: "2"
43451
- })
43452
- });
43453
- };
43454
- var LegendItemSquare = function LegendItemSquare(_ref2) {
43455
- var color = _ref2.color;
43456
- return jsx("svg", {
43457
- width: 8,
43458
- height: 8,
43459
- style: {
43460
- display: 'block'
43461
- },
43462
- children: jsx("rect", {
43463
- fill: color,
43464
- width: 8,
43465
- height: 8,
43466
- rx: "2"
43467
- })
43468
- });
43469
- };
43470
- var LegendItemTriangle = function LegendItemTriangle(_ref3) {
43471
- var color = _ref3.color;
43472
- return jsx("svg", {
43473
- width: 8,
43474
- height: 8,
43475
- style: {
43476
- display: 'block',
43477
- borderRadius: 1
43478
- },
43479
- children: jsx("polygon", {
43480
- points: "0,0 10,10 0,10",
43481
- fill: color
43482
- })
43483
- });
43484
- };
43485
-
43486
- function _EMOTION_STRINGIFIED_CSS_ERROR__$5() { 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)."; }
43487
- var MIN_TOOLTIP_WIDTH = 180;
43488
- var TOOLTIP_OFFSET = 20;
43489
- var SCROLLBAR_WIDTH = 40;
43490
- var Tooltip$1 = function Tooltip(_ref) {
43491
- var _tooltipData$xKey$for, _tooltipData$xKey;
43492
- var keys = _ref.keys,
43493
- showRoundedTotal = _ref.showRoundedTotal,
43494
- tooltipData = _ref.tooltipData,
43495
- tooltipLeft = _ref.tooltipLeft,
43496
- tooltipTop = _ref.tooltipTop,
43497
- xKey = _ref.xKey,
43498
- yKeys = _ref.yKeys,
43499
- theme = _ref.theme,
43500
- items = _ref.items,
43501
- _ref$shouldShowColorL = _ref.shouldShowColorLegend,
43502
- shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
43503
- var tooltipRef = useRef(null);
43504
- var _useState = useState({
43505
- left: tooltipLeft
43506
- }),
43507
- position = _useState[0],
43508
- setPosition = _useState[1];
43509
- useEffect(function () {
43510
- var adjustTooltipPosition = function adjustTooltipPosition() {
43511
- var tooltipElement = tooltipRef.current;
43512
- if (tooltipElement) {
43513
- var screenWidth = window.innerWidth;
43514
- var rect = tooltipElement.getBoundingClientRect();
43515
- var width = rect.width;
43516
- if (width < MIN_TOOLTIP_WIDTH) {
43517
- width = MIN_TOOLTIP_WIDTH;
43518
- }
43519
- var left = tooltipLeft + TOOLTIP_OFFSET;
43520
- if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {
43521
- left = tooltipLeft - width - TOOLTIP_OFFSET;
43522
- }
43523
- setPosition({
43524
- left: left
43525
- });
43526
- }
43527
- };
43528
- adjustTooltipPosition();
43529
- }, [tooltipLeft]);
43530
- return /*#__PURE__*/createPortal(jsx("div", {
43531
- ref: tooltipRef,
43532
- style: _extends({
43533
- position: 'absolute',
43534
- left: position.left,
43535
- top: tooltipTop,
43536
- zIndex: 2147483647 * 10
43537
- }, theme),
43538
- children: jsxs("div", {
43539
- style: {
43540
- wordBreak: 'break-all'
43541
- },
43542
- children: [jsx("div", {
43543
- className: /*#__PURE__*/css$1({
43544
- fontFamily: 'inherit',
43545
- lineHeight: 'inherit',
43546
- letterSpacing: 'inherit',
43547
- fontWeight: 'bold',
43548
- fontSize: '15px',
43549
- width: '100%',
43550
- minWidth: MIN_TOOLTIP_WIDTH
43551
- }, 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"]} */"),
43552
- children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
43553
- }), jsx("table", {
43554
- cellPadding: 0,
43555
- cellSpacing: 0,
43556
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43557
- name: "x8luwd",
43558
- styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none"
43559
- } : {
43560
- name: "9a1sa-Tooltip",
43561
- styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
43562
- 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"]} */",
43563
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
43564
- }),
43565
- children: jsxs("tbody", {
43566
- children: [items.map(function (item, index) {
43567
- var _item$legendItems;
43568
- return jsx(Fragment, {
43569
- children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
43570
- var _item$visibleYKeys, _item$conditionalForm;
43571
- if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
43572
- // yKey could not be found in tooltipData
43573
- return null;
43574
- }
43575
- return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxs("tr", {
43576
- children: [shouldShowColorLegend && jsx("td", {
43577
- style: {
43578
- verticalAlign: 'middle',
43579
- padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
43580
- width: 'auto'
43581
- },
43582
- children: jsx(LegendItemBox, {
43583
- color: getColor({
43584
- defaultColor: legendItem.color,
43585
- value: tooltipData[legendItem.yKey].value,
43586
- yKey: legendItem.yKey,
43587
- conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
43588
- }),
43589
- style: legendItem.style,
43590
- yKey: legendItem.yKey
43591
- })
43592
- }), jsx("td", {
43593
- style: {
43594
- padding: '8px 0 0 0'
43595
- },
43596
- children: keys[legendItem.yKey].keyFormatted
43597
- }), jsx("td", {
43598
- style: {
43599
- fontWeight: 'bold',
43600
- padding: '8px 0 0 16px'
43601
- },
43602
- children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
43603
- })]
43604
- }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
43605
- })
43606
- }, index);
43607
- }), showRoundedTotal && yKeys && jsxs("tr", {
43608
- children: [jsx("td", {
43609
- colSpan: 2,
43610
- style: {
43611
- padding: '12px 0 0 0'
43612
- },
43613
- children: "Rounded Total"
43614
- }), jsx("td", {
43615
- style: {
43616
- fontWeight: 'bold',
43617
- padding: '12px 0 0 16px'
43618
- },
43619
- children: yKeys.reduce(function (total, key) {
43620
- return total + Math.round(tooltipData[key].value);
43621
- }, 0)
43622
- })]
43623
- })]
43624
- })
43625
- })]
43626
- })
43627
- }), document.body);
43628
- };
43629
-
43630
- function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { 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)."; }
43631
- var LegendItem = function LegendItem(_ref) {
43632
- var yKey = _ref.yKey,
43633
- yKeyFormatted = _ref.yKeyFormatted,
43634
- color = _ref.color,
43635
- style = _ref.style,
43636
- onClick = _ref.onClick,
43637
- visible = _ref.visible,
43638
- conditionalFormattingRules = _ref.conditionalFormattingRules;
43639
- var relevantRules = useMemo(function () {
43640
- return conditionalFormattingRules.filter(function (rule) {
43641
- return rule.yKey === yKey;
43642
- });
43643
- }, [conditionalFormattingRules]);
43644
- return jsxs("button", {
43645
- type: "button",
43646
- style: {
43647
- all: 'unset',
43648
- display: 'flex',
43649
- flexWrap: 'nowrap',
43650
- alignItems: 'center',
43651
- outline: 'revert',
43652
- gap: '4px',
43653
- padding: '4px',
43654
- cursor: 'pointer',
43655
- marginRight: '10px'
43656
- },
43657
- onClick: onClick,
43658
- children: [style.type === 'line' && jsxs("span", {
43659
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43660
- name: "1mfeugk",
43661
- styles: "height:10px;display:flex"
43662
- } : {
43663
- name: "mefz6m-LegendItem",
43664
- styles: "height:10px;display:flex;label:LegendItem;",
43665
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
43666
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
43667
- }),
43668
- children: [jsx(LegendItemBox, {
43669
- color: color,
43670
- style: style,
43671
- yKey: yKey
43672
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
43673
- return jsx(LegendItemBox, {
43674
- color: rule.color,
43675
- style: style,
43676
- yKey: yKey
43677
- }, "rule-" + JSON.stringify(rule));
43678
- })]
43679
- }), style.type === 'bar' && jsxs("span", {
43680
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43681
- name: "6b52m3",
43682
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
43683
- } : {
43684
- name: "pglbco-LegendItem",
43685
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
43686
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
43687
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
43688
- }),
43689
- children: [jsx(LegendItemSquare, {
43690
- color: color
43691
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
43692
- return jsx(LegendItemSquare, {
43693
- color: rule.color
43694
- }, "rule-" + JSON.stringify(rule));
43695
- })]
43696
- }), style.type === 'area' && jsxs("span", {
43697
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43698
- name: "6b52m3",
43699
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
43700
- } : {
43701
- name: "pglbco-LegendItem",
43702
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
43703
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFFeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
43704
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
43705
- }),
43706
- children: [jsx(LegendItemTriangle, {
43707
- color: color
43708
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
43709
- return jsx(LegendItemTriangle, {
43710
- color: rule.color
43711
- }, "rule-" + JSON.stringify(rule));
43712
- })]
43713
- }), jsx("span", {
43714
- style: {
43715
- fontSize: '12px',
43716
- lineHeight: '16px',
43717
- display: 'block',
43718
- textDecoration: visible ? 'none' : 'line-through',
43719
- textWrap: 'nowrap'
43720
- },
43721
- children: yKeyFormatted ? yKeyFormatted : yKey
43722
- })]
43723
- }, "legend-" + yKey);
43724
- };
43725
-
43726
- function _EMOTION_STRINGIFIED_CSS_ERROR__$7() { 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)."; }
43727
- var Legend$1 = function Legend(_ref) {
43728
- var keys = _ref.keys,
43729
- setVisibleYKeys = _ref.setVisibleYKeys,
43730
- marginLeft = _ref.marginLeft,
43731
- items = _ref.items;
43732
- var handleOnClick = function handleOnClick(item, legendItem) {
43733
- setVisibleYKeys && setVisibleYKeys(function (prev) {
43734
- var newVisibleLegendItems = [];
43735
- if (prev.length === item.legendItems.length) {
43736
- newVisibleLegendItems = [legendItem.yKey];
43737
- } else {
43738
- if (prev.includes(legendItem.yKey)) {
43739
- newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
43740
- return prevLegendItemId !== legendItem.yKey;
43741
- });
43742
- } else {
43743
- newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
43744
- }
43745
- }
43746
- return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
43747
- return legendItem.yKey;
43748
- }) : newVisibleLegendItems;
43749
- });
43750
- };
43751
- return jsx("div", {
43752
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43753
- name: "1nbollx",
43754
- styles: "height:40px;padding-top:8px"
43755
- } : {
43756
- name: "qz6h7j-Legend",
43757
- styles: "height:40px;padding-top:8px;label:Legend;",
43758
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */",
43759
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
43760
- }),
43761
- children: jsx(Scrollbar, {
43762
- className: /*#__PURE__*/css$1({
43763
- display: 'flex',
43764
- flexDirection: 'row',
43765
- flexWrap: 'nowrap',
43766
- alignItems: 'center',
43767
- marginLeft: marginLeft ? marginLeft + "px" : undefined
43768
- }, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0RtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */"),
43769
- x: true,
43770
- children: items.map(function (item, index) {
43771
- return jsx(Fragment, {
43772
- children: item.legendItems.map(function (legendItem) {
43773
- return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
43774
- key: "legend-" + legendItem.yKey,
43775
- yKeyFormatted: keys[legendItem.yKey].keyFormatted,
43776
- onClick: function onClick() {
43777
- handleOnClick(item, legendItem);
43778
- },
43779
- visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
43780
- conditionalFormattingRules: item.conditionalFormattingRules
43781
- }));
43782
- })
43783
- }, index);
43784
- })
43785
- })
43786
- });
43787
- };
43788
-
43789
43502
  var ASSUMED_AVERAGE_CHAR_WIDTH = 7.1;
43790
43503
 
43791
43504
  function calculateWordWidth(word, avgCharWidth) {
@@ -43975,108 +43688,6 @@ var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, h
43975
43688
  };
43976
43689
  };
43977
43690
 
43978
- function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
43979
- return useMemo(function () {
43980
- if (xScaleKey && xScaleDataType && yKeys.length > 0) {
43981
- return flattenData({
43982
- data: data,
43983
- xScaleKey: xScaleKey,
43984
- xScaleDataType: xScaleDataType,
43985
- yKeys: yKeys
43986
- });
43987
- } else {
43988
- return [];
43989
- }
43990
- }, [data, xScaleKey, xScaleDataType, yKeys]);
43991
- }
43992
-
43993
- var GoalLine = function GoalLine(_ref) {
43994
- var goalLine = _ref.goalLine,
43995
- innerWidth = _ref.innerWidth,
43996
- y = _ref.y,
43997
- margin = _ref.margin;
43998
- var textRef = useRef(null);
43999
- var _useState = useState(0),
44000
- labelWidth = _useState[0],
44001
- setLabelWidth = _useState[1];
44002
- useEffect(function () {
44003
- if (textRef.current) {
44004
- var bbox = textRef.current.getBBox();
44005
- setLabelWidth(bbox.width + 16);
44006
- }
44007
- }, [goalLine.formattedValue]);
44008
- var height = 16;
44009
- var triangleWidth = 8;
44010
- return jsxs("g", {
44011
- style: {
44012
- position: 'relative'
44013
- },
44014
- children: [jsx(Line$1, {
44015
- from: {
44016
- x: margin.left,
44017
- y: margin.top + y
44018
- },
44019
- to: {
44020
- x: margin.left + innerWidth,
44021
- y: margin.top + y
44022
- },
44023
- stroke: goalLine.color,
44024
- strokeDasharray: goalLine.strokeStyle == 'dashed' ? goalLine.strokeWidth * 2.5 + "," + goalLine.strokeWidth * 2.5 : undefined,
44025
- strokeWidth: goalLine.strokeWidth,
44026
- strokeLinecap: "round",
44027
- shapeRendering: "smooth"
44028
- }), jsxs("g", {
44029
- transform: "translate(" + (margin.left + innerWidth - labelWidth) + "," + (y + margin.top + height / 2) + ")",
44030
- children: [jsx("path", {
44031
- d: "M 0,0\n l " + -triangleWidth + "," + -height / 2 + " \n l " + triangleWidth + "," + -height / 2 + " \n h " + labelWidth + " \n a 3,3 0 0 1 3,3 \n v " + (height - 6) + " \n a 3,3 0 0 1 -3,3 \n h " + -labelWidth + " z",
44032
- fill: goalLine.color
44033
- }), jsx("text", {
44034
- ref: textRef,
44035
- x: labelWidth / 2,
44036
- y: -1,
44037
- dy: -4,
44038
- textAnchor: "middle",
44039
- fontFamily: "Arial, sans-serif",
44040
- fontSize: 9,
44041
- fill: '#fff',
44042
- children: goalLine.formattedValue
44043
- })]
44044
- })]
44045
- });
44046
- };
44047
-
44048
- /*
44049
- const strokeWidth = 2;
44050
- const height = 16;
44051
- const triangleWidth = 8;
44052
-
44053
-
44054
-
44055
-
44056
-
44057
- */
44058
-
44059
- var shouldUpdate$1 = function shouldUpdate(previousProps, nextProps) {
44060
- return JSON.stringify(previousProps) == JSON.stringify(nextProps);
44061
- };
44062
- var GoalLines = function GoalLines(_ref) {
44063
- var goalLines = _ref.goalLines,
44064
- margin = _ref.margin,
44065
- y = _ref.y,
44066
- width = _ref.width;
44067
- return jsx(Fragment, {
44068
- children: goalLines.map(function (goalLine) {
44069
- return jsx(GoalLine, {
44070
- innerWidth: width,
44071
- y: y(goalLine.value),
44072
- goalLine: goalLine,
44073
- margin: margin
44074
- }, goalLine.value);
44075
- })
44076
- });
44077
- };
44078
- var GoalLines$1 = /*#__PURE__*/memo(GoalLines, shouldUpdate$1);
44079
-
44080
43691
  var AXIS_TITLE_STYLES = {
44081
43692
  textShadow: 'rgba(0, 0, 0, 0.01) 0px 0px 1px',
44082
43693
  opacity: '0.75',
@@ -44199,36 +43810,8 @@ var AxisLeft = function AxisLeft(_ref) {
44199
43810
  });
44200
43811
  };
44201
43812
 
44202
- var GRID_STYLES = {
44203
- strokeWidth: 2,
44204
- strokeOpacity: 0.8,
44205
- strokeLinecap: 'round',
44206
- strokeDasharray: '0.5 5'
44207
- };
44208
-
44209
- var GridRows = function GridRows(_ref) {
44210
- var ticks = _ref.ticks,
44211
- yScale = _ref.yScale,
44212
- removeStroke = _ref.removeStroke,
44213
- width = _ref.width,
44214
- height = _ref.height,
44215
- themeCSS = _ref.themeCSS;
44216
- return jsx(GridRows$1, {
44217
- tickValues: ticks.length > 0 ? ticks : undefined,
44218
- scale: yScale,
44219
- width: width,
44220
- height: height,
44221
- pointerEvents: "none",
44222
- strokeDasharray: "0.5 5",
44223
- strokeWidth: removeStroke ? 0 : 2,
44224
- lineStyle: _extends({
44225
- stroke: themeCSS.grid.stroke
44226
- }, GRID_STYLES)
44227
- });
44228
- };
44229
-
44230
43813
  var _excluded$g = ["children", "width", "height", "showLegend", "onMouseMove", "onMouseLeave"];
44231
- 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)."; }
43814
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$5() { 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)."; }
44232
43815
  var ChartWrapper$1 = function ChartWrapper(_ref) {
44233
43816
  var children = _ref.children,
44234
43817
  width = _ref.width,
@@ -44249,75 +43832,169 @@ var ChartWrapper$1 = function ChartWrapper(_ref) {
44249
43832
  name: "fx4tbw-ChartWrapper",
44250
43833
  styles: "display:block;label:ChartWrapper;",
44251
43834
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxudHlwZSBDaGFydFdyYXBwZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHNob3dMZWdlbmQ6IGJvb2xlYW47XG4gIG9uTW91c2VNb3ZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG4gIG9uTW91c2VMZWF2ZT86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyPFNWR1NWR0VsZW1lbnQ+O1xufSAmIFJlYWN0LlNWR1Byb3BzPFNWR1NWR0VsZW1lbnQ+O1xuXG5leHBvcnQgY29uc3QgQ2hhcnRXcmFwcGVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIHNob3dMZWdlbmQsXG4gIG9uTW91c2VNb3ZlLFxuICBvbk1vdXNlTGVhdmUsXG4gIC4uLnN2Z1Byb3BzXG59OiBDaGFydFdyYXBwZXJQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIGhlaWdodD17aGVpZ2h0IC0gKHNob3dMZWdlbmQgPyA0MCA6IDApfVxuICAgICAgb25Nb3VzZU1vdmU9e29uTW91c2VNb3ZlfVxuICAgICAgb25Nb3VzZUxlYXZlPXtvbk1vdXNlTGVhdmV9XG4gICAgICBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdibG9jaycgfSl9XG4gICAgICB7Li4uc3ZnUHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvc3ZnPlxuICApO1xufTtcbiJdfQ== */",
44252
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
43835
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
44253
43836
  })
44254
43837
  }, svgProps, {
44255
43838
  children: children
44256
43839
  }));
44257
43840
  };
44258
43841
 
44259
- var CrosshairCircle = function CrosshairCircle(_ref) {
44260
- var dataType = _ref.dataType,
44261
- yKeys = _ref.yKeys,
44262
- tooltipData = _ref.tooltipData,
44263
- xKey = _ref.xKey,
43842
+ var DataLabel = function DataLabel(_ref) {
43843
+ var x = _ref.x,
43844
+ y = _ref.y,
43845
+ title = _ref.title,
43846
+ dx = _ref.dx,
43847
+ dy = _ref.dy,
43848
+ color = _ref.color,
43849
+ backgroundColor = _ref.backgroundColor;
43850
+ return jsx(Annotation$1, {
43851
+ x: x,
43852
+ y: y,
43853
+ dx: dx,
43854
+ dy: dy,
43855
+ children: jsx(Label$1, {
43856
+ title: title,
43857
+ showAnchorLine: false,
43858
+ showBackground: false,
43859
+ backgroundFill: backgroundColor,
43860
+ fontColor: color,
43861
+ titleFontSize: 10,
43862
+ verticalAnchor: "middle"
43863
+ })
43864
+ });
43865
+ };
43866
+
43867
+ var GoalLine = function GoalLine(_ref) {
43868
+ var goalLine = _ref.goalLine,
43869
+ innerWidth = _ref.innerWidth,
43870
+ y = _ref.y,
43871
+ margin = _ref.margin;
43872
+ var textRef = useRef(null);
43873
+ var _useState = useState(0),
43874
+ labelWidth = _useState[0],
43875
+ setLabelWidth = _useState[1];
43876
+ useEffect(function () {
43877
+ if (textRef.current) {
43878
+ var bbox = textRef.current.getBBox();
43879
+ setLabelWidth(bbox.width + 16);
43880
+ }
43881
+ }, [goalLine.formattedValue]);
43882
+ var height = 16;
43883
+ var triangleWidth = 8;
43884
+ return jsxs("g", {
43885
+ style: {
43886
+ position: 'relative'
43887
+ },
43888
+ children: [jsx(Line$1, {
43889
+ from: {
43890
+ x: margin.left,
43891
+ y: margin.top + y
43892
+ },
43893
+ to: {
43894
+ x: margin.left + innerWidth,
43895
+ y: margin.top + y
43896
+ },
43897
+ stroke: goalLine.color,
43898
+ strokeDasharray: goalLine.strokeStyle == 'dashed' ? goalLine.strokeWidth * 2.5 + "," + goalLine.strokeWidth * 2.5 : undefined,
43899
+ strokeWidth: goalLine.strokeWidth,
43900
+ strokeLinecap: "round",
43901
+ shapeRendering: "smooth"
43902
+ }), jsxs("g", {
43903
+ transform: "translate(" + (margin.left + innerWidth - labelWidth) + "," + (y + margin.top + height / 2) + ")",
43904
+ children: [jsx("path", {
43905
+ d: "M 0,0\n l " + -triangleWidth + "," + -height / 2 + " \n l " + triangleWidth + "," + -height / 2 + " \n h " + labelWidth + " \n a 3,3 0 0 1 3,3 \n v " + (height - 6) + " \n a 3,3 0 0 1 -3,3 \n h " + -labelWidth + " z",
43906
+ fill: goalLine.color
43907
+ }), jsx("text", {
43908
+ ref: textRef,
43909
+ x: labelWidth / 2,
43910
+ y: -1,
43911
+ dy: -4,
43912
+ textAnchor: "middle",
43913
+ fontFamily: "Arial, sans-serif",
43914
+ fontSize: 9,
43915
+ fill: '#fff',
43916
+ children: goalLine.formattedValue
43917
+ })]
43918
+ })]
43919
+ });
43920
+ };
43921
+
43922
+ /*
43923
+ const strokeWidth = 2;
43924
+ const height = 16;
43925
+ const triangleWidth = 8;
43926
+
43927
+
43928
+
43929
+
43930
+
43931
+ */
43932
+
43933
+ var shouldUpdate$1 = function shouldUpdate(previousProps, nextProps) {
43934
+ return JSON.stringify(previousProps) == JSON.stringify(nextProps);
43935
+ };
43936
+ var GoalLines = function GoalLines(_ref) {
43937
+ var goalLines = _ref.goalLines,
44264
43938
  margin = _ref.margin,
44265
- conditionalFormattingRules = _ref.conditionalFormattingRules,
44266
- legendItems = _ref.legendItems,
44267
- visibleYKeys = _ref.visibleYKeys,
44268
- yScale = _ref.yScale,
44269
- xScale = _ref.xScale;
43939
+ y = _ref.y,
43940
+ width = _ref.width;
44270
43941
  return jsx(Fragment, {
44271
- children: yKeys.map(function (yKey) {
44272
- if (!xKey || !tooltipData[yKey] || tooltipData[yKey].value === null) return null;
44273
- if (tooltipData[xKey] && tooltipData[xKey].value && dataType && visibleYKeys.includes(yKey)) {
44274
- var xValue = tooltipData[xKey].value;
44275
- var xValueAdjusted = dataType === 'date_time' ? new Date(xValue) : dataType === 'number' ? Number(xValue) : String(xValue);
44276
- return jsx("circle", {
44277
- cx:
44278
- // @ts-ignore
44279
- xScale(xValueAdjusted) + margin.left,
44280
- cy: yScale(yKey) + margin.top,
44281
- r: 4,
44282
- fill: getColor({
44283
- defaultColor: legendItems.filter(function (legendItem) {
44284
- return legendItem.yKey === yKey;
44285
- })[0].color,
44286
- yKey: yKey,
44287
- value: tooltipData[yKey].value,
44288
- conditionalFormattingRules: conditionalFormattingRules
44289
- }),
44290
- strokeWidth: 2,
44291
- stroke: "#fff",
44292
- pointerEvents: "none"
44293
- }, yKey);
44294
- } else {
44295
- return null;
44296
- }
43942
+ children: goalLines.map(function (goalLine) {
43943
+ return jsx(GoalLine, {
43944
+ innerWidth: width,
43945
+ y: y(goalLine.value),
43946
+ goalLine: goalLine,
43947
+ margin: margin
43948
+ }, goalLine.value);
44297
43949
  })
44298
43950
  });
44299
43951
  };
43952
+ var GoalLines$1 = /*#__PURE__*/memo(GoalLines, shouldUpdate$1);
44300
43953
 
44301
- var Line = function Line(_ref) {
44302
- var margin = _ref.margin,
44303
- x = _ref.x,
44304
- height = _ref.height;
44305
- return jsx(Line$1, {
44306
- from: {
44307
- x: x,
44308
- y: margin.top
44309
- },
44310
- to: {
44311
- x: x,
44312
- y: height + margin.top
44313
- },
44314
- stroke: '#aaa',
44315
- strokeWidth: 2,
43954
+ var LINE_STYLES = {
43955
+ strokeWidth: 2,
43956
+ strokeOpacity: 0.8,
43957
+ strokeLinecap: 'round',
43958
+ strokeDasharray: '0.5 5',
43959
+ stroke: 'rgba(0, 0, 0, 0.1)'
43960
+ };
43961
+
43962
+ var GridRows = function GridRows(_ref) {
43963
+ var ticks = _ref.ticks,
43964
+ yScale = _ref.yScale,
43965
+ removeStroke = _ref.removeStroke,
43966
+ width = _ref.width,
43967
+ height = _ref.height,
43968
+ themeCSS = _ref.themeCSS;
43969
+ return jsx(GridRows$1, {
43970
+ tickValues: ticks.length > 0 ? ticks : undefined,
43971
+ scale: yScale,
43972
+ width: width,
43973
+ height: height,
44316
43974
  pointerEvents: "none",
44317
- opacity: 0.8
43975
+ strokeDasharray: "0.5 5",
43976
+ strokeWidth: removeStroke ? 0 : 2,
43977
+ lineStyle: _extends({
43978
+ stroke: themeCSS.grid.stroke
43979
+ }, LINE_STYLES)
44318
43980
  });
44319
43981
  };
44320
43982
 
43983
+ function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
43984
+ return useMemo(function () {
43985
+ if (xScaleKey && xScaleDataType && yKeys.length > 0) {
43986
+ return flattenData({
43987
+ data: data,
43988
+ xScaleKey: xScaleKey,
43989
+ xScaleDataType: xScaleDataType,
43990
+ yKeys: yKeys
43991
+ });
43992
+ } else {
43993
+ return [];
43994
+ }
43995
+ }, [data, xScaleKey, xScaleDataType, yKeys]);
43996
+ }
43997
+
44321
43998
  var _excluded$h = ["tooltipOpen"];
44322
43999
  function useTooltip$1(initialTooltipState) {
44323
44000
  var _useState = useState(_extends({
@@ -44371,31 +44048,435 @@ function useYScale(innerHeight, scale) {
44371
44048
  }, [innerHeight, scale]);
44372
44049
  }
44373
44050
 
44374
- var DataLabel = function DataLabel(_ref) {
44375
- var x = _ref.x,
44376
- y = _ref.y,
44377
- title = _ref.title,
44378
- dx = _ref.dx,
44379
- dy = _ref.dy,
44051
+ var LegendItemBox = function LegendItemBox(_ref) {
44052
+ var color = _ref.color,
44053
+ style = _ref.style;
44054
+ return jsx("svg", {
44055
+ width: 10,
44056
+ height: 10,
44057
+ style: {
44058
+ display: 'block'
44059
+ },
44060
+ children: style.type === 'line' ? style.strokeDasharray !== null ? jsx("line", {
44061
+ x1: "0",
44062
+ y1: "5",
44063
+ x2: "10",
44064
+ y2: "5",
44065
+ stroke: color,
44066
+ strokeWidth: style.strokeWidth,
44067
+ strokeDasharray: 2
44068
+ }) : jsx("line", {
44069
+ x1: "0",
44070
+ y1: "5",
44071
+ x2: "10",
44072
+ y2: "5",
44073
+ stroke: color,
44074
+ strokeWidth: style.strokeWidth
44075
+ }) : jsx("rect", {
44076
+ fill: color,
44077
+ width: 10,
44078
+ height: 10,
44079
+ rx: "2"
44080
+ })
44081
+ });
44082
+ };
44083
+ var LegendItemSquare = function LegendItemSquare(_ref2) {
44084
+ var color = _ref2.color;
44085
+ return jsx("svg", {
44086
+ width: 8,
44087
+ height: 8,
44088
+ style: {
44089
+ display: 'block'
44090
+ },
44091
+ children: jsx("rect", {
44092
+ fill: color,
44093
+ width: 8,
44094
+ height: 8,
44095
+ rx: "2"
44096
+ })
44097
+ });
44098
+ };
44099
+ var LegendItemTriangle = function LegendItemTriangle(_ref3) {
44100
+ var color = _ref3.color;
44101
+ return jsx("svg", {
44102
+ width: 8,
44103
+ height: 8,
44104
+ style: {
44105
+ display: 'block',
44106
+ borderRadius: 1
44107
+ },
44108
+ children: jsx("polygon", {
44109
+ points: "0,0 10,10 0,10",
44110
+ fill: color
44111
+ })
44112
+ });
44113
+ };
44114
+
44115
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { 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)."; }
44116
+ var LegendItem = function LegendItem(_ref) {
44117
+ var yKey = _ref.yKey,
44118
+ yKeyFormatted = _ref.yKeyFormatted,
44380
44119
  color = _ref.color,
44381
- backgroundColor = _ref.backgroundColor;
44382
- return jsx(Annotation$1, {
44383
- x: x,
44384
- y: y,
44385
- dx: dx,
44386
- dy: dy,
44387
- children: jsx(Label$1, {
44388
- title: title,
44389
- showAnchorLine: false,
44390
- showBackground: false,
44391
- backgroundFill: backgroundColor,
44392
- fontColor: color,
44393
- titleFontSize: 10,
44394
- verticalAnchor: "middle"
44120
+ style = _ref.style,
44121
+ onClick = _ref.onClick,
44122
+ visible = _ref.visible,
44123
+ conditionalFormattingRules = _ref.conditionalFormattingRules;
44124
+ var relevantRules = useMemo(function () {
44125
+ return conditionalFormattingRules.filter(function (rule) {
44126
+ return rule.yKey === yKey;
44127
+ });
44128
+ }, [conditionalFormattingRules]);
44129
+ return jsxs("button", {
44130
+ type: "button",
44131
+ style: {
44132
+ all: 'unset',
44133
+ display: 'flex',
44134
+ flexWrap: 'nowrap',
44135
+ alignItems: 'center',
44136
+ outline: 'revert',
44137
+ gap: '4px',
44138
+ padding: '4px',
44139
+ cursor: 'pointer',
44140
+ marginRight: '10px'
44141
+ },
44142
+ onClick: onClick,
44143
+ children: [style.type === 'line' && jsxs("span", {
44144
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44145
+ name: "1mfeugk",
44146
+ styles: "height:10px;display:flex"
44147
+ } : {
44148
+ name: "mefz6m-LegendItem",
44149
+ styles: "height:10px;display:flex;label:LegendItem;",
44150
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
44151
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44152
+ }),
44153
+ children: [jsx(LegendItemBox, {
44154
+ color: color,
44155
+ style: style,
44156
+ yKey: yKey
44157
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44158
+ return jsx(LegendItemBox, {
44159
+ color: rule.color,
44160
+ style: style,
44161
+ yKey: yKey
44162
+ }, "rule-" + JSON.stringify(rule));
44163
+ })]
44164
+ }), style.type === 'bar' && jsxs("span", {
44165
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44166
+ name: "6b52m3",
44167
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
44168
+ } : {
44169
+ name: "pglbco-LegendItem",
44170
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
44171
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
44172
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44173
+ }),
44174
+ children: [jsx(LegendItemSquare, {
44175
+ color: color
44176
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44177
+ return jsx(LegendItemSquare, {
44178
+ color: rule.color
44179
+ }, "rule-" + JSON.stringify(rule));
44180
+ })]
44181
+ }), style.type === 'area' && jsxs("span", {
44182
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44183
+ name: "6b52m3",
44184
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
44185
+ } : {
44186
+ name: "pglbco-LegendItem",
44187
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
44188
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFFeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
44189
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44190
+ }),
44191
+ children: [jsx(LegendItemTriangle, {
44192
+ color: color
44193
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44194
+ return jsx(LegendItemTriangle, {
44195
+ color: rule.color
44196
+ }, "rule-" + JSON.stringify(rule));
44197
+ })]
44198
+ }), jsx("span", {
44199
+ style: {
44200
+ fontSize: '12px',
44201
+ lineHeight: '16px',
44202
+ display: 'block',
44203
+ textDecoration: visible ? 'none' : 'line-through',
44204
+ textWrap: 'nowrap'
44205
+ },
44206
+ children: yKeyFormatted ? yKeyFormatted : yKey
44207
+ })]
44208
+ }, "legend-" + yKey);
44209
+ };
44210
+
44211
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$7() { 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)."; }
44212
+ var Legend$1 = function Legend(_ref) {
44213
+ var keys = _ref.keys,
44214
+ setVisibleYKeys = _ref.setVisibleYKeys,
44215
+ marginLeft = _ref.marginLeft,
44216
+ items = _ref.items;
44217
+ var handleOnClick = function handleOnClick(item, legendItem) {
44218
+ setVisibleYKeys && setVisibleYKeys(function (prev) {
44219
+ var newVisibleLegendItems = [];
44220
+ if (prev.length === item.legendItems.length) {
44221
+ newVisibleLegendItems = [legendItem.yKey];
44222
+ } else {
44223
+ if (prev.includes(legendItem.yKey)) {
44224
+ newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
44225
+ return prevLegendItemId !== legendItem.yKey;
44226
+ });
44227
+ } else {
44228
+ newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
44229
+ }
44230
+ }
44231
+ return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
44232
+ return legendItem.yKey;
44233
+ }) : newVisibleLegendItems;
44234
+ });
44235
+ };
44236
+ return jsx("div", {
44237
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44238
+ name: "1nbollx",
44239
+ styles: "height:40px;padding-top:8px"
44240
+ } : {
44241
+ name: "qz6h7j-Legend",
44242
+ styles: "height:40px;padding-top:8px;label:Legend;",
44243
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */",
44244
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
44245
+ }),
44246
+ children: jsx(Scrollbar, {
44247
+ className: /*#__PURE__*/css$1({
44248
+ display: 'flex',
44249
+ flexDirection: 'row',
44250
+ flexWrap: 'nowrap',
44251
+ alignItems: 'center',
44252
+ marginLeft: marginLeft ? marginLeft + "px" : undefined
44253
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0RtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */"),
44254
+ x: true,
44255
+ children: items.map(function (item, index) {
44256
+ return jsx(Fragment, {
44257
+ children: item.legendItems.map(function (legendItem) {
44258
+ return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
44259
+ key: "legend-" + legendItem.yKey,
44260
+ yKeyFormatted: keys[legendItem.yKey].keyFormatted,
44261
+ onClick: function onClick() {
44262
+ handleOnClick(item, legendItem);
44263
+ },
44264
+ visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
44265
+ conditionalFormattingRules: item.conditionalFormattingRules
44266
+ }));
44267
+ })
44268
+ }, index);
44269
+ })
44395
44270
  })
44396
44271
  });
44397
44272
  };
44398
44273
 
44274
+ 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)."; }
44275
+ var MIN_TOOLTIP_WIDTH = 180;
44276
+ var TOOLTIP_OFFSET = 20;
44277
+ var SCROLLBAR_WIDTH = 40;
44278
+ var Tooltip$1 = function Tooltip(_ref) {
44279
+ var _tooltipData$xKey$for, _tooltipData$xKey;
44280
+ var keys = _ref.keys,
44281
+ showRoundedTotal = _ref.showRoundedTotal,
44282
+ tooltipData = _ref.tooltipData,
44283
+ tooltipLeft = _ref.tooltipLeft,
44284
+ tooltipTop = _ref.tooltipTop,
44285
+ xKey = _ref.xKey,
44286
+ yKeys = _ref.yKeys,
44287
+ theme = _ref.theme,
44288
+ items = _ref.items,
44289
+ _ref$shouldShowColorL = _ref.shouldShowColorLegend,
44290
+ shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
44291
+ var tooltipRef = useRef(null);
44292
+ var _useState = useState({
44293
+ left: tooltipLeft
44294
+ }),
44295
+ position = _useState[0],
44296
+ setPosition = _useState[1];
44297
+ useEffect(function () {
44298
+ var adjustTooltipPosition = function adjustTooltipPosition() {
44299
+ var tooltipElement = tooltipRef.current;
44300
+ if (tooltipElement) {
44301
+ var screenWidth = window.innerWidth;
44302
+ var rect = tooltipElement.getBoundingClientRect();
44303
+ var width = rect.width;
44304
+ if (width < MIN_TOOLTIP_WIDTH) {
44305
+ width = MIN_TOOLTIP_WIDTH;
44306
+ }
44307
+ var left = tooltipLeft + TOOLTIP_OFFSET;
44308
+ if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {
44309
+ left = tooltipLeft - width - TOOLTIP_OFFSET;
44310
+ }
44311
+ setPosition({
44312
+ left: left
44313
+ });
44314
+ }
44315
+ };
44316
+ adjustTooltipPosition();
44317
+ }, [tooltipLeft]);
44318
+ return /*#__PURE__*/createPortal(jsx("div", {
44319
+ ref: tooltipRef,
44320
+ style: _extends({
44321
+ position: 'absolute',
44322
+ left: position.left,
44323
+ top: tooltipTop,
44324
+ zIndex: 2147483647 * 10
44325
+ }, theme),
44326
+ children: jsxs("div", {
44327
+ style: {
44328
+ wordBreak: 'break-all'
44329
+ },
44330
+ children: [jsx("div", {
44331
+ className: /*#__PURE__*/css$1({
44332
+ fontFamily: 'inherit',
44333
+ lineHeight: 'inherit',
44334
+ letterSpacing: 'inherit',
44335
+ fontWeight: 'bold',
44336
+ fontSize: '15px',
44337
+ width: '100%',
44338
+ minWidth: MIN_TOOLTIP_WIDTH
44339
+ }, 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"]} */"),
44340
+ children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
44341
+ }), jsx("table", {
44342
+ cellPadding: 0,
44343
+ cellSpacing: 0,
44344
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44345
+ name: "x8luwd",
44346
+ styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none"
44347
+ } : {
44348
+ name: "9a1sa-Tooltip",
44349
+ styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
44350
+ 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"]} */",
44351
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
44352
+ }),
44353
+ children: jsxs("tbody", {
44354
+ children: [items.map(function (item, index) {
44355
+ var _item$legendItems;
44356
+ return jsx(Fragment, {
44357
+ children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
44358
+ var _item$visibleYKeys, _item$conditionalForm;
44359
+ if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
44360
+ // yKey could not be found in tooltipData
44361
+ return null;
44362
+ }
44363
+ return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxs("tr", {
44364
+ children: [shouldShowColorLegend && jsx("td", {
44365
+ style: {
44366
+ verticalAlign: 'middle',
44367
+ padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
44368
+ width: 'auto'
44369
+ },
44370
+ children: jsx(LegendItemBox, {
44371
+ color: getColor({
44372
+ defaultColor: legendItem.color,
44373
+ value: tooltipData[legendItem.yKey].value,
44374
+ yKey: legendItem.yKey,
44375
+ conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
44376
+ }),
44377
+ style: legendItem.style,
44378
+ yKey: legendItem.yKey
44379
+ })
44380
+ }), jsx("td", {
44381
+ style: {
44382
+ padding: '8px 0 0 0'
44383
+ },
44384
+ children: keys[legendItem.yKey].keyFormatted
44385
+ }), jsx("td", {
44386
+ style: {
44387
+ fontWeight: 'bold',
44388
+ padding: '8px 0 0 16px'
44389
+ },
44390
+ children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
44391
+ })]
44392
+ }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
44393
+ })
44394
+ }, index);
44395
+ }), showRoundedTotal && yKeys && jsxs("tr", {
44396
+ children: [jsx("td", {
44397
+ colSpan: 2,
44398
+ style: {
44399
+ padding: '12px 0 0 0'
44400
+ },
44401
+ children: "Rounded Total"
44402
+ }), jsx("td", {
44403
+ style: {
44404
+ fontWeight: 'bold',
44405
+ padding: '12px 0 0 16px'
44406
+ },
44407
+ children: yKeys.reduce(function (total, key) {
44408
+ return total + Math.round(tooltipData[key].value);
44409
+ }, 0)
44410
+ })]
44411
+ })]
44412
+ })
44413
+ })]
44414
+ })
44415
+ }), document.body);
44416
+ };
44417
+
44418
+ var CrosshairCircle = function CrosshairCircle(_ref) {
44419
+ var dataType = _ref.dataType,
44420
+ yKeys = _ref.yKeys,
44421
+ tooltipData = _ref.tooltipData,
44422
+ xKey = _ref.xKey,
44423
+ margin = _ref.margin,
44424
+ conditionalFormattingRules = _ref.conditionalFormattingRules,
44425
+ legendItems = _ref.legendItems,
44426
+ visibleYKeys = _ref.visibleYKeys,
44427
+ yScale = _ref.yScale,
44428
+ xScale = _ref.xScale;
44429
+ return jsx(Fragment, {
44430
+ children: yKeys.map(function (yKey) {
44431
+ if (!xKey || !tooltipData[yKey] || tooltipData[yKey].value === null) return null;
44432
+ if (tooltipData[xKey] && tooltipData[xKey].value && dataType && visibleYKeys.includes(yKey)) {
44433
+ var xValue = tooltipData[xKey].value;
44434
+ var xValueAdjusted = dataType === 'date_time' ? new Date(xValue) : dataType === 'number' ? Number(xValue) : String(xValue);
44435
+ return jsx("circle", {
44436
+ cx:
44437
+ // @ts-ignore
44438
+ xScale(xValueAdjusted) + margin.left,
44439
+ cy: yScale(yKey) + margin.top,
44440
+ r: 4,
44441
+ fill: getColor({
44442
+ defaultColor: legendItems.filter(function (legendItem) {
44443
+ return legendItem.yKey === yKey;
44444
+ })[0].color,
44445
+ yKey: yKey,
44446
+ value: tooltipData[yKey].value,
44447
+ conditionalFormattingRules: conditionalFormattingRules
44448
+ }),
44449
+ strokeWidth: 2,
44450
+ stroke: "#fff",
44451
+ pointerEvents: "none"
44452
+ }, yKey);
44453
+ } else {
44454
+ return null;
44455
+ }
44456
+ })
44457
+ });
44458
+ };
44459
+
44460
+ var Line = function Line(_ref) {
44461
+ var margin = _ref.margin,
44462
+ x = _ref.x,
44463
+ height = _ref.height;
44464
+ return jsx(Line$1, {
44465
+ from: {
44466
+ x: x,
44467
+ y: margin.top
44468
+ },
44469
+ to: {
44470
+ x: x,
44471
+ y: height + margin.top
44472
+ },
44473
+ stroke: '#aaa',
44474
+ strokeWidth: 2,
44475
+ pointerEvents: "none",
44476
+ opacity: 0.8
44477
+ });
44478
+ };
44479
+
44399
44480
  var LineChart$5 = function LineChart(_ref) {
44400
44481
  var _theme$axis;
44401
44482
  var chart = _ref.chart,
@@ -44485,6 +44566,26 @@ var LineChart$5 = function LineChart(_ref) {
44485
44566
  var handleMouseLeave = useCallback(function () {
44486
44567
  hideTooltip();
44487
44568
  }, [hideTooltip]);
44569
+ var labelDictionary = useMemo(function () {
44570
+ return getLabelDictionary(chart.data, chart.y.keys);
44571
+ }, [chart.data, chart.y.keys]);
44572
+ var memoizedLines = useMemo(function () {
44573
+ if (xScaleKey === null || xScale === null) return null;
44574
+ return jsx(Lines, {
44575
+ lines: chart.lines,
44576
+ conditionalFormattingRules: chart.conditionalFormattingRules,
44577
+ curve: curve,
44578
+ yKeys: chart.y.keys,
44579
+ visibleYKeys: visibleYKeys,
44580
+ data: dataFlattened,
44581
+ xScaleKey: xScaleKey,
44582
+ xScaleDataType: xScaleDataType,
44583
+ xScale: xScale,
44584
+ yScale: _yScale,
44585
+ showLabels: options.showLabels,
44586
+ labelDictionary: labelDictionary
44587
+ });
44588
+ }, [chart.lines, chart.conditionalFormattingRules, curve, chart.y.keys, visibleYKeys, dataFlattened, xScaleKey, xScaleDataType, xScale, _yScale, options.showLabels, labelDictionary]);
44488
44589
  if (width === 0 || height === 0 || xScale === null) return jsx(React__default.Fragment, {});
44489
44590
  var yTickValues = chart.y.ticks.map(function (tick) {
44490
44591
  return Number(tick.value);
@@ -44529,19 +44630,7 @@ var LineChart$5 = function LineChart(_ref) {
44529
44630
  ticks: yTickValues,
44530
44631
  stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
44531
44632
  }), jsx(Group$2, {
44532
- children: xScaleKey !== null && jsx(Lines, {
44533
- lines: chart.lines,
44534
- conditionalFormattingRules: chart.conditionalFormattingRules,
44535
- curve: curve,
44536
- yKeys: chart.y.keys,
44537
- visibleYKeys: visibleYKeys,
44538
- data: dataFlattened,
44539
- xScaleKey: xScaleKey,
44540
- xScaleDataType: xScaleDataType,
44541
- xScale: xScale,
44542
- yScale: _yScale,
44543
- showLabels: options.showLabels
44544
- })
44633
+ children: memoizedLines
44545
44634
  })]
44546
44635
  }), tooltipData && jsxs("g", {
44547
44636
  children: [jsx(Line, {
@@ -44590,7 +44679,7 @@ var LineChart$5 = function LineChart(_ref) {
44590
44679
  })]
44591
44680
  });
44592
44681
  };
44593
- function Lines(_ref2) {
44682
+ var Lines = /*#__PURE__*/memo(function Lines(_ref2) {
44594
44683
  var yKeys = _ref2.yKeys,
44595
44684
  visibleYKeys = _ref2.visibleYKeys,
44596
44685
  data = _ref2.data,
@@ -44601,7 +44690,8 @@ function Lines(_ref2) {
44601
44690
  lines = _ref2.lines,
44602
44691
  curve = _ref2.curve,
44603
44692
  conditionalFormattingRules = _ref2.conditionalFormattingRules,
44604
- showLabels = _ref2.showLabels;
44693
+ showLabels = _ref2.showLabels,
44694
+ labelDictionary = _ref2.labelDictionary;
44605
44695
  var _useMemo = useMemo(function () {
44606
44696
  var allBarValues = getAllChartValues(data, yKeys);
44607
44697
  var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(allBarValues),
@@ -44667,7 +44757,8 @@ function Lines(_ref2) {
44667
44757
  totalItems: data.length,
44668
44758
  minValue: minValue,
44669
44759
  maxValue: maxValue,
44670
- showLabels: showLabels
44760
+ showLabels: showLabels,
44761
+ labelDictionary: labelDictionary
44671
44762
  });
44672
44763
  })]
44673
44764
  });
@@ -44722,33 +44813,35 @@ function Lines(_ref2) {
44722
44813
  }, clipPathId);
44723
44814
  })]
44724
44815
  });
44725
- function LineLabel(_ref5) {
44726
- var chartData = _ref5.chartData,
44727
- yKey = _ref5.yKey,
44728
- xScaleKey = _ref5.xScaleKey,
44729
- xScale = _ref5.xScale,
44730
- yScale = _ref5.yScale,
44731
- totalItems = _ref5.totalItems,
44732
- minValue = _ref5.minValue,
44733
- maxValue = _ref5.maxValue,
44734
- showLabels = _ref5.showLabels;
44735
- var xValue = chartData[xScaleKey];
44736
- var yValue = chartData[yKey];
44737
- var xPadding = 18;
44738
- var yPadding = 8;
44739
- var xPosition = xScale(xValue);
44740
- var yPosition = yScale(yValue);
44741
- var showMinMax = showMinMaxLabel(Number(yValue), totalItems, minValue, maxValue);
44742
- if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
44743
- return jsx(DataLabel, {
44744
- x: xPosition - xPadding,
44745
- y: yPosition - yPadding,
44746
- dx: 2,
44747
- dy: 0,
44748
- title: yValue
44749
- });
44750
- }
44751
- }
44816
+ });
44817
+ var LineLabel = /*#__PURE__*/memo(function LineLabel(_ref5) {
44818
+ var chartData = _ref5.chartData,
44819
+ yKey = _ref5.yKey,
44820
+ xScaleKey = _ref5.xScaleKey,
44821
+ xScale = _ref5.xScale,
44822
+ yScale = _ref5.yScale,
44823
+ totalItems = _ref5.totalItems,
44824
+ minValue = _ref5.minValue,
44825
+ maxValue = _ref5.maxValue,
44826
+ showLabels = _ref5.showLabels,
44827
+ labelDictionary = _ref5.labelDictionary;
44828
+ var xValue = chartData[xScaleKey];
44829
+ var yValue = chartData[yKey];
44830
+ var xPadding = 18;
44831
+ var yPadding = 8;
44832
+ var xPosition = xScale(xValue);
44833
+ var yPosition = yScale(yValue);
44834
+ var showMinMax = showMinMaxLabel(Number(yValue), totalItems, minValue, maxValue);
44835
+ var displayValue = getFormattedValue(yValue, labelDictionary);
44836
+ if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
44837
+ return jsx(DataLabel, {
44838
+ x: xPosition - xPadding,
44839
+ y: yPosition - yPadding,
44840
+ dx: 2,
44841
+ dy: 0,
44842
+ title: displayValue
44843
+ });
44844
+ });
44752
44845
 
44753
44846
  var BAR_RADIUS = 2;
44754
44847
 
@@ -44794,7 +44887,8 @@ function BarGroup(_ref) {
44794
44887
  yLabelPosition = _ref.yLabelPosition,
44795
44888
  showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
44796
44889
  labelStyle = _ref.labelStyle,
44797
- showLabels = _ref.showLabels;
44890
+ showLabels = _ref.showLabels,
44891
+ formattedData = _ref.formattedData;
44798
44892
  var getGroupPosition = function getGroupPosition(d) {
44799
44893
  var xValue = d[xKey];
44800
44894
  if (xScaleDataType === 'string') return String(xValue);
@@ -44806,6 +44900,9 @@ function BarGroup(_ref) {
44806
44900
  }
44807
44901
  return String(xValue);
44808
44902
  };
44903
+ var formattedLabelsDict = useMemo(function () {
44904
+ return getLabelDictionary(formattedData, keys);
44905
+ }, [formattedData, keys]);
44809
44906
  var _useMemo = useMemo(function () {
44810
44907
  var allBarValues = getAllChartValues(data, keys);
44811
44908
  var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(allBarValues),
@@ -44854,7 +44951,9 @@ function BarGroup(_ref) {
44854
44951
  minValue: minValue,
44855
44952
  maxValue: maxValue,
44856
44953
  totalItems: totalItems,
44857
- showLabels: showLabels
44954
+ showLabels: showLabels,
44955
+ labelDictionary: formattedLabelsDict,
44956
+ yScale: yScale
44858
44957
  }, "bar-" + bar.index + "-" + bar.x);
44859
44958
  })
44860
44959
  }, "bar-group-" + barGroup.index + "-" + barGroup.x0);
@@ -44876,11 +44975,17 @@ var Bar = function Bar(_ref2) {
44876
44975
  minValue = _ref2.minValue,
44877
44976
  maxValue = _ref2.maxValue,
44878
44977
  totalItems = _ref2.totalItems,
44879
- showLabels = _ref2.showLabels;
44978
+ showLabels = _ref2.showLabels,
44979
+ labelDictionary = _ref2.labelDictionary,
44980
+ yScale = _ref2.yScale;
44880
44981
  var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
44881
- var labelX = bar.width < 10 ? bar.x - 14 : bar.x / 2;
44882
- var labelY = bar.y - 4;
44982
+ var xPadding = 14;
44983
+ var yPadding = 8;
44984
+ var labelX = bar.x - xPadding;
44985
+ var barTopY = yScale(bar.value);
44986
+ var labelY = barTopY - yPadding;
44883
44987
  var showMinMax = showMinMaxLabel(bar.value, totalItems, minValue, maxValue);
44988
+ var displayValue = getFormattedValue(bar.value, labelDictionary);
44884
44989
  return jsxs(Fragment, {
44885
44990
  children: [showBar && jsx(BarRect, {
44886
44991
  barRectKey: "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
@@ -44896,7 +45001,7 @@ var Bar = function Bar(_ref2) {
44896
45001
  }), showLabels && showMinMax && jsx(DataLabel, {
44897
45002
  x: labelX,
44898
45003
  y: labelY,
44899
- title: bar.value,
45004
+ title: displayValue,
44900
45005
  dx: 1,
44901
45006
  dy: 0
44902
45007
  }), jsx(BarLabel, {
@@ -44927,7 +45032,7 @@ var BarRect = function BarRect(_ref3) {
44927
45032
  } : {
44928
45033
  name: "1ltmijl-classes",
44929
45034
  styles: "cursor:pointer;label:classes;",
44930
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AAkNgC","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, useMemo } 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';\nimport { DataLabel } from '../../components/DataLabel';\nimport {\n  showMinMaxLabel,\n  getMinMaxChartValueFromNumberArray,\n  getAllChartValues,\n} from 'shared-logic/src/DataLabel/index';\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  showLabels?: boolean;\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  showLabels,\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  const { minValue, maxValue, totalItems } = useMemo(() => {\n    const allBarValues = getAllChartValues(data, keys);\n    const { minValue, maxValue } = getMinMaxChartValueFromNumberArray(allBarValues);\n\n    return {\n      minValue,\n      maxValue,\n      totalItems: allBarValues.length,\n    };\n  }, [data, keys]);\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                minValue={minValue}\n                maxValue={maxValue}\n                totalItems={totalItems}\n                showLabels={showLabels}\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  minValue: number;\n  maxValue: number;\n  totalItems: number;\n  showLabels?: boolean;\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  minValue,\n  maxValue,\n  totalItems,\n  showLabels,\n}: BarProps) => {\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n  const labelX = bar.width < 10 ? bar.x - 14 : bar.x / 2;\n  const labelY = bar.y - 4;\n\n  const showMinMax = showMinMaxLabel(bar.value, totalItems, minValue, maxValue);\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      {showLabels && showMinMax && <DataLabel x={labelX} y={labelY} title={bar.value} dx={1} dy={0} />}\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"]} */",
45035
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AAkOgC","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, useMemo } 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';\nimport { DataLabel } from '../../components/DataLabel';\nimport {\n  showMinMaxLabel,\n  getMinMaxChartValueFromNumberArray,\n  getAllChartValues,\n  getLabelDictionary,\n  getFormattedValue,\n} from 'shared-logic/src/DataLabel/index';\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  showLabels?: boolean;\n  formattedData?: ChartDataDefinition[];\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  showLabels,\n  formattedData,\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  const formattedLabelsDict = useMemo(() => {\n    return getLabelDictionary(formattedData, keys);\n  }, [formattedData, keys]);\n\n  const { minValue, maxValue, totalItems } = useMemo(() => {\n    const allBarValues = getAllChartValues(data, keys);\n    const { minValue, maxValue } = getMinMaxChartValueFromNumberArray(allBarValues);\n\n    return {\n      minValue,\n      maxValue,\n      totalItems: allBarValues.length,\n    };\n  }, [data, keys]);\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                minValue={minValue}\n                maxValue={maxValue}\n                totalItems={totalItems}\n                showLabels={showLabels}\n                labelDictionary={formattedLabelsDict}\n                yScale={yScale}\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  minValue: number;\n  maxValue: number;\n  totalItems: number;\n  showLabels?: boolean;\n  labelDictionary?: { [key: string]: string };\n  yScale: ScaleLinear<number, number, never>;\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  minValue,\n  maxValue,\n  totalItems,\n  showLabels,\n  labelDictionary,\n  yScale,\n}: BarProps) => {\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n  const xPadding = 14;\n  const yPadding = 8;\n  const labelX = bar.x - xPadding;\n  const barTopY = yScale(bar.value);\n  const labelY = barTopY - yPadding;\n\n  const showMinMax = showMinMaxLabel(bar.value, totalItems, minValue, maxValue);\n\n  const displayValue = getFormattedValue(bar.value, labelDictionary);\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      {showLabels && showMinMax && <DataLabel x={labelX} y={labelY} title={displayValue} dx={1} dy={0} />}\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"]} */",
44931
45036
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
44932
45037
  }) : '';
44933
45038
  var handleOnMouseEnter = function handleOnMouseEnter() {
@@ -45264,7 +45369,8 @@ var BarChart$5 = function BarChart(_ref) {
45264
45369
  yAxisLabels: yAxisLabels,
45265
45370
  yLabelPosition: ySubLabelPosition,
45266
45371
  labelStyle: themeCSS.labels,
45267
- showLabels: options.showLabels
45372
+ showLabels: options.showLabels,
45373
+ formattedData: chart.data
45268
45374
  }), options.stacked && xScaleKey !== null && jsx(BarStacked, {
45269
45375
  data: dataFlattened,
45270
45376
  keys: chart.y.keys,
@@ -45519,6 +45625,9 @@ var AreaChart$5 = function AreaChart(_ref) {
45519
45625
  };
45520
45626
  return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'natural'];
45521
45627
  }, [options.curve]);
45628
+ var labelDictionary = useMemo(function () {
45629
+ return getLabelDictionary(chart.data, chart.y.keys);
45630
+ }, [chart.data, chart.y.keys]);
45522
45631
  if (width === 0 || height === 0 || xScale === null) return jsx(React__default.Fragment, {});
45523
45632
  var yTickValues = chart.y.ticks.map(function (tick) {
45524
45633
  return Number(tick.value);
@@ -45659,7 +45768,8 @@ var AreaChart$5 = function AreaChart(_ref) {
45659
45768
  totalItems: dataFlattened.length,
45660
45769
  minValue: minValue,
45661
45770
  maxValue: maxValue,
45662
- showLabels: options.showLabels
45771
+ showLabels: options.showLabels,
45772
+ labelDictionary: labelDictionary
45663
45773
  });
45664
45774
  })]
45665
45775
  }, yKey + "-" + AREA_GRADIENT_ID_PREFIX);
@@ -45721,7 +45831,8 @@ function AreaLabel(_ref3) {
45721
45831
  totalItems = _ref3.totalItems,
45722
45832
  minValue = _ref3.minValue,
45723
45833
  maxValue = _ref3.maxValue,
45724
- showLabels = _ref3.showLabels;
45834
+ showLabels = _ref3.showLabels,
45835
+ labelDictionary = _ref3.labelDictionary;
45725
45836
  var xValue = chartData[xScaleKey];
45726
45837
  var yValue = chartData[yKey];
45727
45838
  var xPadding = 18;
@@ -45730,12 +45841,13 @@ function AreaLabel(_ref3) {
45730
45841
  var yPosition = yScale(yValue);
45731
45842
  var showMinMax = showMinMaxLabel(Number(yValue), totalItems, minValue, maxValue);
45732
45843
  if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
45844
+ var displayValue = getFormattedValue(yValue, labelDictionary);
45733
45845
  return jsx(DataLabel, {
45734
45846
  x: xPosition - xPadding,
45735
45847
  y: yPosition - yPadding,
45736
45848
  dx: 2,
45737
45849
  dy: 0,
45738
- title: yValue
45850
+ title: displayValue
45739
45851
  });
45740
45852
  }
45741
45853
  function Area(_ref4) {
@@ -46024,6 +46136,58 @@ function Bubbles(_ref2) {
46024
46136
  });
46025
46137
  }
46026
46138
 
46139
+ var RadarCrosshairCircle = function RadarCrosshairCircle(_ref) {
46140
+ var tooltipData = _ref.tooltipData,
46141
+ yKeys = _ref.yKeys,
46142
+ legendItems = _ref.legendItems,
46143
+ conditionalFormattingRules = _ref.conditionalFormattingRules,
46144
+ visibleYKeys = _ref.visibleYKeys,
46145
+ radius = _ref.radius,
46146
+ yScale = _ref.yScale,
46147
+ dataPointIndex = _ref.dataPointIndex,
46148
+ totalDataPoints = _ref.totalDataPoints;
46149
+ var radiusScale = scaleLinear({
46150
+ range: [0, radius],
46151
+ domain: [0, yScale.max],
46152
+ nice: true
46153
+ });
46154
+ var step = Math.PI * 2 / totalDataPoints;
46155
+ var yKeysTest = [].concat(yKeys);
46156
+ if (yKeysTest.length > 1) {
46157
+ var lastItem = yKeysTest.pop();
46158
+ yKeysTest.unshift(lastItem);
46159
+ }
46160
+ return jsx(Fragment, {
46161
+ children: yKeysTest.map(function (yKey) {
46162
+ var _legendItems$filter$;
46163
+ if (!tooltipData[yKey] || tooltipData[yKey].value === null || !visibleYKeys.includes(yKey)) {
46164
+ return null;
46165
+ }
46166
+ var value = tooltipData[yKey].value;
46167
+ var scaledRadius = radiusScale(value);
46168
+ var angle = (dataPointIndex + 1) * step;
46169
+ var x = scaledRadius * Math.sin(angle);
46170
+ var y = scaledRadius * Math.cos(angle);
46171
+ return jsx("circle", {
46172
+ cx: x,
46173
+ cy: y,
46174
+ r: 6,
46175
+ fill: getColor({
46176
+ defaultColor: ((_legendItems$filter$ = legendItems.filter(function (legendItem) {
46177
+ return legendItem.yKey === yKey;
46178
+ })[0]) == null ? void 0 : _legendItems$filter$.color) || '#000',
46179
+ yKey: yKey,
46180
+ value: tooltipData[yKey].value,
46181
+ conditionalFormattingRules: conditionalFormattingRules
46182
+ }),
46183
+ strokeWidth: 2,
46184
+ stroke: "#fff",
46185
+ pointerEvents: "none"
46186
+ }, "radar-crosshair-" + yKey);
46187
+ })
46188
+ });
46189
+ };
46190
+
46027
46191
  var getValue = function getValue(d, key) {
46028
46192
  return d[key].value;
46029
46193
  };
@@ -46053,7 +46217,9 @@ var genPolygonPoints = function genPolygonPoints(dataArray, scale, yKey) {
46053
46217
  var Polygons = function Polygons(_ref) {
46054
46218
  var chart = _ref.chart,
46055
46219
  radius = _ref.radius,
46056
- visibleYKeys = _ref.visibleYKeys;
46220
+ visibleYKeys = _ref.visibleYKeys,
46221
+ tooltipData = _ref.tooltipData,
46222
+ hoveredDataPointIndex = _ref.hoveredDataPointIndex;
46057
46223
  var yKeys = chart.y.keys;
46058
46224
  var yScale = scaleLinear({
46059
46225
  range: [0, radius],
@@ -46066,16 +46232,26 @@ var Polygons = function Polygons(_ref) {
46066
46232
  return (_yScale = yScale(d)) != null ? _yScale : 0;
46067
46233
  }, yKey);
46068
46234
  });
46069
- return jsx(Fragment$1, {
46070
- children: polygonsPoints.map(function (polygonPoints) {
46235
+ return jsxs(Fragment$1, {
46236
+ children: [polygonsPoints.map(function (polygonPoints) {
46071
46237
  return jsx(SinglePolygon, {
46072
46238
  isVisible: visibleYKeys.includes(polygonPoints.yKey),
46073
46239
  polygonPoints: polygonPoints,
46074
46240
  colors: chart.lines.filter(function (legendItem) {
46075
46241
  return legendItem.yKey === polygonPoints.yKey;
46076
46242
  })[0].color
46077
- });
46078
- })
46243
+ }, polygonPoints.yKey);
46244
+ }), tooltipData && hoveredDataPointIndex !== undefined && hoveredDataPointIndex >= 0 && jsx(RadarCrosshairCircle, {
46245
+ tooltipData: tooltipData,
46246
+ yKeys: chart.y.keys,
46247
+ legendItems: chart.lines,
46248
+ conditionalFormattingRules: [],
46249
+ visibleYKeys: visibleYKeys,
46250
+ radius: radius,
46251
+ yScale: chart.y.scale,
46252
+ dataPointIndex: hoveredDataPointIndex,
46253
+ totalDataPoints: chart.data.length
46254
+ })]
46079
46255
  });
46080
46256
  };
46081
46257
  var SinglePolygon = function SinglePolygon(_ref2) {
@@ -46102,15 +46278,6 @@ var SinglePolygon = function SinglePolygon(_ref2) {
46102
46278
  });
46103
46279
  };
46104
46280
 
46105
- var genPoints = function genPoints(length, radius) {
46106
- var step = Math.PI * 2 / length;
46107
- return [].concat(new Array(length)).map(function (_, i) {
46108
- return {
46109
- x: radius * Math.sin(i * step),
46110
- y: radius * Math.cos(i * step)
46111
- };
46112
- });
46113
- };
46114
46281
  var MiddleLine = function MiddleLine(_ref) {
46115
46282
  var chart = _ref.chart,
46116
46283
  radius = _ref.radius,
@@ -46120,7 +46287,6 @@ var MiddleLine = function MiddleLine(_ref) {
46120
46287
  var _useState = useState([]),
46121
46288
  textWidths = _useState[0],
46122
46289
  setTextWidths = _useState[1];
46123
- var points = genPoints(chart.x.ticks.length, radius);
46124
46290
  var zeroPoint = new Point({
46125
46291
  x: 0,
46126
46292
  y: 0
@@ -46129,22 +46295,33 @@ var MiddleLine = function MiddleLine(_ref) {
46129
46295
  var _tick$formattedValue;
46130
46296
  return (_tick$formattedValue = tick.formattedValue) != null ? _tick$formattedValue : tick.value;
46131
46297
  });
46298
+ var genPoints = function genPoints(length, radius) {
46299
+ var step = Math.PI * 2 / length;
46300
+ return new Array(length).fill(0).map(function (_, i) {
46301
+ return {
46302
+ x: radius * Math.sin(i * step),
46303
+ y: radius * Math.cos(i * step)
46304
+ };
46305
+ });
46306
+ };
46132
46307
  useEffect(function () {
46133
46308
  var newWidths = textRefs.current.map(function (ref) {
46134
46309
  return ref ? ref.getComputedTextLength() : 0;
46135
46310
  });
46136
46311
  setTextWidths(newWidths);
46137
- }, [categoryValues]);
46312
+ }, []);
46313
+ var points = genPoints(chart.x.ticks.length, radius);
46138
46314
  points.push(points.shift());
46139
46315
  return jsx(Fragment$1, {
46140
- children: [].concat(new Array(chart.x.ticks.length)).map(function (_, i) {
46316
+ children: new Array(chart.x.ticks.length).fill(0).map(function (_, i) {
46141
46317
  var xOffset = points[i].x >= 0 ? textWidths[i] / 2 : -(textWidths[i] / 2);
46142
- return jsxs(Fragment$1, {
46318
+ return jsxs(React__default.Fragment, {
46143
46319
  children: [jsx(Line$1, {
46144
46320
  from: zeroPoint,
46145
46321
  to: points[i],
46146
- stroke: themeCSS.axis.stroke,
46147
- strokeDasharray: "0.5 5"
46322
+ style: _extends({
46323
+ stroke: themeCSS.axis.stroke
46324
+ }, LINE_STYLES)
46148
46325
  }, "radar-line-" + i), show && jsx("text", {
46149
46326
  ref: function ref(el) {
46150
46327
  return textRefs.current[i] = el;
@@ -46155,13 +46332,13 @@ var MiddleLine = function MiddleLine(_ref) {
46155
46332
  textAnchor: "middle",
46156
46333
  children: categoryValues[i]
46157
46334
  })]
46158
- });
46335
+ }, "middle-line-" + i);
46159
46336
  })
46160
46337
  });
46161
46338
  };
46162
46339
 
46163
46340
  var genAngles = function genAngles(length, degrees) {
46164
- return [].concat(new Array(length + 1)).map(function (_, i) {
46341
+ return new Array(length + 1).fill(0).map(function (_, i) {
46165
46342
  return {
46166
46343
  angle: i * (degrees / length) + (length % 2 === 0 ? 0 : degrees / length / 2)
46167
46344
  };
@@ -46193,9 +46370,9 @@ var Grid$1 = function Grid(_ref) {
46193
46370
  }, [chart.y.ticks]);
46194
46371
  var chartValue = (_chart$y$ticks$scaleV = chart.y.ticks[levels - 1].scaleValue) != null ? _chart$y$ticks$scaleV : chart.y.ticks[levels - 1].value;
46195
46372
  return jsx(Fragment$1, {
46196
- children: [].concat(new Array(levels)).map(function (_, i) {
46373
+ children: new Array(levels).fill(0).map(function (_, i) {
46197
46374
  var levelRadius = chart.y.ticks[i].value / chartValue * radius;
46198
- return jsxs(Fragment$1, {
46375
+ return jsxs(React__default.Fragment, {
46199
46376
  children: [jsx(LineRadial, {
46200
46377
  data: webs,
46201
46378
  angle: function angle(d) {
@@ -46206,7 +46383,7 @@ var Grid$1 = function Grid(_ref) {
46206
46383
  fill: "none",
46207
46384
  style: _extends({
46208
46385
  stroke: themeCSS.axis.stroke
46209
- }, GRID_STYLES)
46386
+ }, LINE_STYLES)
46210
46387
  }, "web-" + i), jsx("text", {
46211
46388
  x: 0,
46212
46389
  y: levelRadius,
@@ -46216,11 +46393,40 @@ var Grid$1 = function Grid(_ref) {
46216
46393
  textAnchor: "middle",
46217
46394
  children: tickFormat(chart.y.ticks[i].value)
46218
46395
  })]
46219
- });
46396
+ }, "grid-level-" + i);
46220
46397
  })
46221
46398
  });
46222
46399
  };
46223
46400
 
46401
+ var getRadarTooltipData = function getRadarTooltipData(_ref) {
46402
+ var data = _ref.data,
46403
+ event = _ref.event,
46404
+ totalDataPoints = _ref.totalDataPoints,
46405
+ centerX = _ref.centerX,
46406
+ centerY = _ref.centerY;
46407
+ var point = localPoint(event) || {
46408
+ x: 0,
46409
+ y: 0
46410
+ };
46411
+ if (!point) return;
46412
+ var mouseX = point.x - centerX;
46413
+ var mouseY = point.y - centerY;
46414
+ var mouseAngle = Math.atan2(mouseX, mouseY);
46415
+ if (mouseAngle < 0) {
46416
+ mouseAngle += 2 * Math.PI;
46417
+ }
46418
+ var step = Math.PI * 2 / totalDataPoints;
46419
+ var dataPointIndex = Math.round(mouseAngle / step) % totalDataPoints;
46420
+ dataPointIndex = (dataPointIndex - 1 + totalDataPoints) % totalDataPoints;
46421
+ var tooltipData = data[dataPointIndex] || null;
46422
+ var angle = (dataPointIndex + 1) * step;
46423
+ return {
46424
+ tooltipData: tooltipData,
46425
+ dataPointIndex: dataPointIndex,
46426
+ angle: angle
46427
+ };
46428
+ };
46429
+
46224
46430
  var WIDTH_MULTIPLIER_TO_SCROLL = 1.2;
46225
46431
  var LEGEND_PADDING = 40;
46226
46432
  var RadarChart$2 = function RadarChart(_ref) {
@@ -46229,6 +46435,15 @@ var RadarChart$2 = function RadarChart(_ref) {
46229
46435
  height = _ref.height,
46230
46436
  options = _ref.options,
46231
46437
  theme = _ref.theme;
46438
+ var _useTooltip = useTooltip$1(),
46439
+ tooltipOpen = _useTooltip.tooltipOpen,
46440
+ _useTooltip$tooltipLe = _useTooltip.tooltipLeft,
46441
+ tooltipLeft = _useTooltip$tooltipLe === void 0 ? 0 : _useTooltip$tooltipLe,
46442
+ _useTooltip$tooltipTo = _useTooltip.tooltipTop,
46443
+ tooltipTop = _useTooltip$tooltipTo === void 0 ? 0 : _useTooltip$tooltipTo,
46444
+ tooltipData = _useTooltip.tooltipData,
46445
+ hideTooltip = _useTooltip.hideTooltip,
46446
+ showTooltip = _useTooltip.showTooltip;
46232
46447
  var ref = useRef(null);
46233
46448
  var _useState = useState(0),
46234
46449
  groupWidth = _useState[0],
@@ -46238,13 +46453,17 @@ var RadarChart$2 = function RadarChart(_ref) {
46238
46453
  })),
46239
46454
  visibleYKeys = _useState2[0],
46240
46455
  setVisibleYKeys = _useState2[1];
46456
+ var _useState3 = useState(),
46457
+ hoveredDataPointIndex = _useState3[0],
46458
+ setHoveredDataPointIndex = _useState3[1];
46241
46459
  var themeCSS = useMemo(function () {
46242
- return getChartThemeCSS(theme);
46460
+ var css = getChartThemeCSS(theme);
46461
+ return css;
46243
46462
  }, [theme]);
46244
46463
  var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);
46245
46464
  var innerWidth = width - margin.left - margin.right - (options.showLegend ? LEGEND_PADDING : 0);
46246
46465
  var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? LEGEND_PADDING : 0);
46247
- var radius = Math.min(innerWidth, innerHeight) / 2;
46466
+ var radius = Math.min(innerWidth, innerHeight) / 2 * 0.93;
46248
46467
  useEffect(function () {
46249
46468
  var _ref$current;
46250
46469
  setVisibleYKeys(chart.lines.map(function (legendItem) {
@@ -46255,16 +46474,41 @@ var RadarChart$2 = function RadarChart(_ref) {
46255
46474
  setVisibleYKeys([]);
46256
46475
  };
46257
46476
  }, [chart.lines]);
46477
+ var centerX = (groupWidth > width ? width * WIDTH_MULTIPLIER_TO_SCROLL : width) / 2;
46478
+ var centerY = height / 2 - margin.top * 2;
46479
+ var handleMouseMove = useCallback(function (event) {
46480
+ var radarTooltipData = getRadarTooltipData({
46481
+ data: chart.data,
46482
+ event: event,
46483
+ totalDataPoints: chart.data.length,
46484
+ centerX: centerX,
46485
+ centerY: centerY
46486
+ });
46487
+ if (radarTooltipData) {
46488
+ setHoveredDataPointIndex(radarTooltipData.dataPointIndex);
46489
+ showTooltip({
46490
+ tooltipLeft: event.pageX,
46491
+ tooltipTop: event.pageY,
46492
+ tooltipData: radarTooltipData.tooltipData
46493
+ });
46494
+ }
46495
+ }, [showTooltip, chart.data, centerX, centerY]);
46496
+ var handleMouseLeave = useCallback(function () {
46497
+ hideTooltip();
46498
+ setHoveredDataPointIndex(-1);
46499
+ }, [hideTooltip]);
46258
46500
  if (width < 10) return null;
46259
46501
  return jsxs(Fragment, {
46260
46502
  children: [jsx(ChartWrapper$1, {
46261
46503
  width: groupWidth > width ? width * WIDTH_MULTIPLIER_TO_SCROLL : width,
46262
46504
  height: height,
46263
46505
  showLegend: options.showLegend,
46506
+ onMouseMove: handleMouseMove,
46507
+ onMouseLeave: handleMouseLeave,
46264
46508
  children: jsxs(Group$2, {
46265
46509
  innerRef: ref,
46266
- top: height / 2 - margin.top * 2,
46267
- left: (groupWidth > width ? width * WIDTH_MULTIPLIER_TO_SCROLL : width) / 2,
46510
+ top: centerY,
46511
+ left: centerX,
46268
46512
  children: [jsx(MiddleLine, {
46269
46513
  chart: chart,
46270
46514
  radius: radius,
@@ -46277,7 +46521,9 @@ var RadarChart$2 = function RadarChart(_ref) {
46277
46521
  }), jsx(Polygons, {
46278
46522
  chart: chart,
46279
46523
  radius: radius,
46280
- visibleYKeys: visibleYKeys
46524
+ visibleYKeys: visibleYKeys,
46525
+ tooltipData: tooltipData,
46526
+ hoveredDataPointIndex: hoveredDataPointIndex
46281
46527
  })]
46282
46528
  })
46283
46529
  }), options.showLegend && jsx(Legend$1, {
@@ -46289,6 +46535,21 @@ var RadarChart$2 = function RadarChart(_ref) {
46289
46535
  setVisibleYKeys: setVisibleYKeys,
46290
46536
  keys: chart.keys,
46291
46537
  marginLeft: margin.left - margin.leftTitleOffset
46538
+ }), tooltipOpen && tooltipData && chart.x.key && jsx(Tooltip$1, {
46539
+ items: [{
46540
+ legendItems: chart.lines,
46541
+ visibleYKeys: visibleYKeys,
46542
+ conditionalFormattingRules: []
46543
+ }],
46544
+ tooltipData: tooltipData,
46545
+ tooltipLeft: tooltipLeft,
46546
+ tooltipTop: tooltipTop,
46547
+ xKey: chart.x.key,
46548
+ keys: chart.keys,
46549
+ yKeys: chart.y.keys,
46550
+ showRoundedTotal: options.showRoundedTotal,
46551
+ theme: themeCSS.popoverMenus,
46552
+ shouldShowColorLegend: false
46292
46553
  })]
46293
46554
  });
46294
46555
  };
@@ -47985,6 +48246,7 @@ var LineChartV2View = function LineChartV2View(props) {
47985
48246
  overflowX: 'hidden'
47986
48247
  },
47987
48248
  children: function children(parent) {
48249
+ var _props$attributes$lab;
47988
48250
  if (chartRepresentation.lines.length === 0) return jsx(LoadingComponent, {});
47989
48251
  return jsx(LineChart$5, {
47990
48252
  width: parent.width,
@@ -47995,7 +48257,7 @@ var LineChartV2View = function LineChartV2View(props) {
47995
48257
  removeStroke: false,
47996
48258
  showRoundedTotal: false,
47997
48259
  showLegend: props.attributes.legend,
47998
- showLabels: false,
48260
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
47999
48261
  axis: {
48000
48262
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
48001
48263
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -48355,7 +48617,7 @@ var AreaChartV2View = function AreaChartV2View(props) {
48355
48617
  overflowX: 'hidden'
48356
48618
  },
48357
48619
  children: function children(parent) {
48358
- var _props$attributes$vie2, _props$attributes$sta;
48620
+ var _props$attributes$vie2, _props$attributes$sta, _props$attributes$lab;
48359
48621
  if (chartRepresentation.areas.length === 0) return jsx(LoadingComponent, {});
48360
48622
  return jsx(AreaChart$5, {
48361
48623
  width: parent.width,
@@ -48368,7 +48630,7 @@ var AreaChartV2View = function AreaChartV2View(props) {
48368
48630
  removeStroke: false,
48369
48631
  showRoundedTotal: false,
48370
48632
  showLegend: props.attributes.legend,
48371
- showLabels: false,
48633
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
48372
48634
  axis: {
48373
48635
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
48374
48636
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -48750,6 +49012,7 @@ var BarChartV2View = function BarChartV2View(props) {
48750
49012
  overflowX: 'hidden'
48751
49013
  },
48752
49014
  children: function children(parent) {
49015
+ var _props$attributes$lab;
48753
49016
  if (chartRepresentation.bars.length === 0) return jsx(LoadingComponent, {});
48754
49017
  return jsx(BarChart$5, {
48755
49018
  width: parent.width,
@@ -48760,7 +49023,7 @@ var BarChartV2View = function BarChartV2View(props) {
48760
49023
  removeStroke: false,
48761
49024
  showRoundedTotal: false,
48762
49025
  showLegend: props.attributes.legend,
48763
- showLabels: false,
49026
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
48764
49027
  axis: {
48765
49028
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
48766
49029
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -49099,6 +49362,9 @@ var ComboChart$4 = function ComboChart(_ref) {
49099
49362
  tooltipData: buildComboTooltipData(barTooltip == null ? void 0 : barTooltip.tooltipData, lineTooltip == null ? void 0 : lineTooltip.tooltipData, xScaleKey)
49100
49363
  });
49101
49364
  }, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.bars.data, chart.lines.data]);
49365
+ var labelDictionary = useMemo(function () {
49366
+ return getLabelDictionary(chart.lines.data, chart.y.lineKeys);
49367
+ }, [chart.lines.data, chart.y.lineKeys]);
49102
49368
  var handleMouseLeave = useCallback(function () {
49103
49369
  hideTooltip();
49104
49370
  }, [hideTooltip]);
@@ -49153,7 +49419,8 @@ var ComboChart$4 = function ComboChart(_ref) {
49153
49419
  showDetailedSubGroupingLabels: false,
49154
49420
  yAxisLabels: [],
49155
49421
  yLabelPosition: 0,
49156
- showLabels: options.showLabels
49422
+ showLabels: options.showLabels,
49423
+ formattedData: chart.bars.data
49157
49424
  }), options.stacked && xScaleKey !== null && jsx(BarStacked, {
49158
49425
  data: barDataFlattened,
49159
49426
  keys: yBarKeys,
@@ -49178,7 +49445,8 @@ var ComboChart$4 = function ComboChart(_ref) {
49178
49445
  xScaleDataType: xScaleDataType,
49179
49446
  xScale: xScale,
49180
49447
  yScale: yScale,
49181
- showLabels: options.showLabels
49448
+ showLabels: options.showLabels,
49449
+ labelDictionary: labelDictionary
49182
49450
  })
49183
49451
  })]
49184
49452
  })]
@@ -49438,7 +49706,7 @@ var ComboChartViewV2 = function ComboChartViewV2(props) {
49438
49706
  overflowX: 'hidden'
49439
49707
  },
49440
49708
  children: function children(parent) {
49441
- var _props$attributes$sta2;
49709
+ var _props$attributes$sta2, _props$attributes$lab;
49442
49710
  var numberOfXTicksFittingIntoSpace = howManyTicksFitInWidth(comboChartRepresentation.x.ticks || [], parent.width);
49443
49711
  return jsx(ComboChart$4, {
49444
49712
  width: parent.width,
@@ -49456,7 +49724,7 @@ var ComboChartViewV2 = function ComboChartViewV2(props) {
49456
49724
  removeStroke: false,
49457
49725
  showRoundedTotal: false,
49458
49726
  showLegend: props.attributes.legend,
49459
- showLabels: false,
49727
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
49460
49728
  axis: {
49461
49729
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
49462
49730
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -52010,7 +52278,7 @@ var defaultProps$8 = {
52010
52278
  approxYAxisLabelCount: 'auto'
52011
52279
  };
52012
52280
  var FunnelChartView = function FunnelChartView(props) {
52013
- var _props$library, _props2, _props3, _props4, _props5, _props6, _props7, _props$viewId, _props8, _props$library2, _props9, _props10, _props11, _theme$charts, _props13, _props14, _props$viewId2, _theme$charts2;
52281
+ var _props$library, _props2, _props3, _props4, _props5, _props6, _props7, _props$viewId, _props8, _props$library2, _props9, _props10, _props11, _theme$charts, _props13, _props$labels, _props14, _props15, _props$viewId2, _theme$charts2;
52014
52282
  var _props = props,
52015
52283
  displayTitle = _props.displayTitle,
52016
52284
  displaySubject = _props.displaySubject;
@@ -52101,11 +52369,11 @@ var FunnelChartView = function FunnelChartView(props) {
52101
52369
  colors: themeToColorScale(theme == null ? void 0 : theme.colors, series$1.length),
52102
52370
  data: resultSet$1,
52103
52371
  legend: showLegend((_props13 = props) == null ? void 0 : _props13.legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
52104
- labels: false,
52372
+ labels: (_props$labels = (_props14 = props) == null ? void 0 : _props14.labels) != null ? _props$labels : false,
52105
52373
  removeStroke: false,
52106
52374
  forceXAxisAsTime: !!props.timeDimension,
52107
52375
  theme: theme == null ? void 0 : theme.charts,
52108
- axisTitles: (_props14 = props) == null ? void 0 : _props14.axisTitles,
52376
+ axisTitles: (_props15 = props) == null ? void 0 : _props15.axisTitles,
52109
52377
  formatSeriesName: formatSeriesName(props.result, textOverride, props.type, (_props$viewId2 = props.viewId) != null ? _props$viewId2 : '', labelFormat),
52110
52378
  conditionalFormattingPossibilities: function conditionalFormattingPossibilities(dataKey) {
52111
52379
  return getExplanationsOfConditionFormattingRulesThatApplyToSeries(props.dimension, props.conditionalFormattingRules,
@@ -52624,7 +52892,7 @@ var getScaleAndTicks$2 = function getScaleAndTicks(_ref) {
52624
52892
  var maxY = y.max || 0;
52625
52893
  var minY = Math.min(y.min || 0, 0);
52626
52894
  var yTickInterval = getNiceInterval$2((maxY - minY) / (tickCountYAxis - 1));
52627
- for (var i = 0; i <= tickCountYAxis; i++) {
52895
+ for (var i = 0; i <= Math.ceil(maxY / yTickInterval); i++) {
52628
52896
  var _value = yTickInterval * i;
52629
52897
  var formattedValue = formattingFunctionY(_value, nullValue);
52630
52898
  yTicks.push({
@@ -54334,14 +54602,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
54334
54602
  if (xScaleDataType === 'string') return String(xValue);
54335
54603
  return '';
54336
54604
  }, [xScaleKey, xScaleDataType]);
54337
- var _useMemo = useMemo(function () {
54338
- var stepValues = formattedChartDataForBarChart.steps.map(function (step) {
54339
- return step.y;
54340
- });
54341
- return getMinMaxChartValueFromNumberArray(stepValues);
54342
- }, [formattedChartDataForBarChart.steps]),
54343
- minValue = _useMemo.minValue,
54344
- maxValue = _useMemo.maxValue;
54605
+ var labelDictionary = useMemo(function () {
54606
+ return getLabelDictionary(formattedChartDataForBarChart.data, formattedChartDataForBarChart.y.keys);
54607
+ }, [formattedChartDataForBarChart.data, formattedChartDataForBarChart.y.keys]);
54345
54608
  if (width === 0 || height === 0 || xScale == null) return null;
54346
54609
  return jsxs(Fragment$1, {
54347
54610
  children: [jsxs(ChartWrapper$1, {
@@ -54439,10 +54702,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
54439
54702
  barGroup: barGroup,
54440
54703
  yScale: yScale,
54441
54704
  formattedChartDataForBarChart: formattedChartDataForBarChart,
54442
- maxValue: maxValue,
54443
- minValue: minValue,
54444
54705
  showLabels: options.showLabels,
54445
- totalItems: formattedChartDataForBarChart.steps.length
54706
+ totalItems: formattedChartDataForBarChart.steps.length,
54707
+ labelDictionary: labelDictionary
54446
54708
  }, "bar-" + bar.index);
54447
54709
  })
54448
54710
  }, "bar-group-" + barGroup.index + "-" + barGroup.x0);
@@ -54477,20 +54739,24 @@ var Bar$2 = function Bar(_ref4) {
54477
54739
  var bar = _ref4.bar,
54478
54740
  barColor = _ref4.barColor,
54479
54741
  barGroup = _ref4.barGroup,
54480
- yScale = _ref4.yScale,
54481
54742
  formattedChartDataForBarChart = _ref4.formattedChartDataForBarChart,
54743
+ labelDictionary = _ref4.labelDictionary,
54482
54744
  showLabels = _ref4.showLabels,
54483
54745
  totalItems = _ref4.totalItems,
54484
- minValue = _ref4.minValue,
54485
- maxValue = _ref4.maxValue;
54746
+ yScale = _ref4.yScale;
54486
54747
  var step = formattedChartDataForBarChart.steps[barGroup.index];
54487
54748
  var y = yScale(Math.max(step.start, step.end));
54488
54749
  var barHeight = Math.abs(yScale(step.start) - yScale(step.end));
54489
- var xPadding = 14;
54490
- var labelX = bar.width < 10 ? bar.x - xPadding : bar.x + bar.width / 2;
54750
+ var xPadding = 10;
54751
+ var labelX = bar.x - xPadding;
54491
54752
  var labelY = getStepYPosition(step, barHeight, y);
54492
- var showMinMax = showMinMaxLabel(step.y, totalItems, minValue, maxValue);
54493
- var shouldShowLabel = showLabels && showMinMax && bar.value > 0;
54753
+ var isFirstOrLastStep = barGroup.index === 0 || barGroup.index === totalItems - 1;
54754
+ var keyValue = step.end - step.start;
54755
+ var displayValue = getFormattedValue(keyValue, labelDictionary);
54756
+ var unformattedValue = displayValue.length > 15;
54757
+ if (unformattedValue) displayValue = keyValue;
54758
+ var showMinMax = unformattedValue ? isFirstOrLastStep : totalItems < 20 || isFirstOrLastStep;
54759
+ var shouldShowLabel = showLabels && showMinMax;
54494
54760
  return jsxs(Fragment$1, {
54495
54761
  children: [jsx("rect", {
54496
54762
  x: bar.x,
@@ -54502,7 +54768,7 @@ var Bar$2 = function Bar(_ref4) {
54502
54768
  }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key), shouldShowLabel && jsx(DataLabel, {
54503
54769
  x: labelX,
54504
54770
  y: labelY,
54505
- title: step.y.toString(),
54771
+ title: displayValue,
54506
54772
  dx: 1,
54507
54773
  dy: 0
54508
54774
  })]
@@ -54531,7 +54797,7 @@ var WaterfallChartView = function WaterfallChartView(props) {
54531
54797
  displayTitle = props.displayTitle,
54532
54798
  headline = props.headline,
54533
54799
  id = props.id,
54534
- increaseColor = props.increaseColor,
54800
+ labels = props.labels,
54535
54801
  legend = props.legend,
54536
54802
  library = props.library,
54537
54803
  localFilters = props.localFilters,
@@ -54551,7 +54817,8 @@ var WaterfallChartView = function WaterfallChartView(props) {
54551
54817
  xAxisPrefix = props.xAxisPrefix,
54552
54818
  yAxisFormat = props.yAxisFormat,
54553
54819
  yAxisPostfix = props.yAxisPostfix,
54554
- yAxisPrefix = props.yAxisPrefix;
54820
+ yAxisPrefix = props.yAxisPrefix,
54821
+ increaseColor = props.increaseColor;
54555
54822
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
54556
54823
  textOverride = _useDashboardBehaviou.textOverride,
54557
54824
  valueAlias = _useDashboardBehaviou.valueAlias,
@@ -54639,7 +54906,7 @@ var WaterfallChartView = function WaterfallChartView(props) {
54639
54906
  height: parent.height,
54640
54907
  options: {
54641
54908
  showLegend: showLegend(legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
54642
- showLabels: false,
54909
+ showLabels: labels != null ? labels : false,
54643
54910
  showTooltipRoundedTotal: true,
54644
54911
  removeStroke: false,
54645
54912
  axis: {