@vizzly/dashboard 0.15.0-dev-d949562f7d69a747b6f32349c6a53a2dc3ed06f9 → 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.
@@ -38,9 +38,9 @@ var adapter$1 = require('@atlaskit/pragmatic-drag-and-drop/external/adapter');
38
38
  var box = require('@atlaskit/pragmatic-drag-and-drop-react-drop-indicator/box');
39
39
  var responsive = require('@visx/responsive');
40
40
  var xychart = require('@visx/xychart');
41
+ var scale = require('@visx/scale');
41
42
  var gradient = require('@visx/gradient');
42
43
  var legend = require('@visx/legend');
43
- var scale = require('@visx/scale');
44
44
  var Ordinal = _interopDefault(require('@visx/legend/lib/legends/Ordinal'));
45
45
  var Curves = require('@visx/curve');
46
46
  var shape = require('@visx/shape');
@@ -62,8 +62,8 @@ var event = require('@visx/event');
62
62
  var d3Array = require('@visx/vendor/d3-array');
63
63
  var axis = require('@visx/axis');
64
64
  var text$3 = require('@visx/text');
65
- var grid = require('@visx/grid');
66
65
  var annotation = require('@visx/annotation');
66
+ var grid = require('@visx/grid');
67
67
  var glyph = require('@visx/glyph');
68
68
  var point = require('@visx/point');
69
69
  var d3Interpolate = require('@visx/vendor/d3-interpolate');
@@ -4184,7 +4184,7 @@ var attributesSchema$2 = function attributesSchema(config) {
4184
4184
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
4185
4185
  stacked: Joi.valid(true, false, '100%'),
4186
4186
  legend: Joi.valid(true, false),
4187
- // labels: Joi.valid(true, false).optional(),
4187
+ labels: Joi.valid(true, false).optional(),
4188
4188
  type: Joi.valid('lineChartV2').required(),
4189
4189
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
4190
4190
  lineCurve: lineCurveSchema,
@@ -4294,8 +4294,13 @@ var CONSTANTS$2 = {
4294
4294
  title: 'Show Legend',
4295
4295
  description: '',
4296
4296
  namespace: 'legend'
4297
+ },
4298
+ labels: {
4299
+ type: 'labels',
4300
+ title: 'Show Labels',
4301
+ description: '',
4302
+ namespace: 'labels'
4297
4303
  }
4298
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
4299
4304
  }
4300
4305
  },
4301
4306
  axis_labels: {
@@ -4423,6 +4428,7 @@ var LineChart$1 = function LineChart(config) {
4423
4428
  conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
4424
4429
  drilldown: dumped.drilldown,
4425
4430
  legend: dumped.legend,
4431
+ labels: dumped.labels,
4426
4432
  goalLines: dumped.goalLines,
4427
4433
  headline: upcastHeadline(dumped.headline, dumped.timeDimension),
4428
4434
  parameters: upcastParameters(dumped.parameters),
@@ -4461,6 +4467,7 @@ var LineChart$1 = function LineChart(config) {
4461
4467
  conditionalFormattingRules: [],
4462
4468
  drilldown: [],
4463
4469
  legend: true,
4470
+ labels: false,
4464
4471
  goalLines: undefined,
4465
4472
  approxXAxisLabelCount: 'auto',
4466
4473
  approxYAxisLabelCount: 'auto',
@@ -4523,10 +4530,9 @@ var LineChart$1 = function LineChart(config) {
4523
4530
  }), namespace(CONSTANTS$2, 'sort'), namespace(CONSTANTS$2, 'filter'), namespace(CONSTANTS$2, 'custom_metrics'), namespace(CONSTANTS$2, 'limit')];
4524
4531
  },
4525
4532
  formatPanelConfig: function formatPanelConfig() {
4526
- var _CONSTANTS$format_pan;
4533
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
4527
4534
  return [headingConstant(CONSTANTS$2), _extends({}, namespace(CONSTANTS$2, 'chart_styles'), {
4528
- 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'>,
4529
- ]
4535
+ 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]
4530
4536
  }), axisLabelsConstants(CONSTANTS$2), _extends({}, namespace(CONSTANTS$2, 'conditional_formatting'), {
4531
4537
  ruleType: 'lineColor'
4532
4538
  }), namespace(CONSTANTS$2, 'goal_line')
@@ -8652,8 +8658,13 @@ var CONSTANTS$h = {
8652
8658
  title: 'Show Legend',
8653
8659
  description: '',
8654
8660
  namespace: 'legend'
8661
+ },
8662
+ labels: {
8663
+ type: 'labels',
8664
+ title: 'Show Labels',
8665
+ description: '',
8666
+ namespace: 'labels'
8655
8667
  }
8656
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
8657
8668
  }
8658
8669
  },
8659
8670
  axis_labels: {
@@ -8751,7 +8762,7 @@ var FunnelChart = function FunnelChart(config) {
8751
8762
  return hydrated;
8752
8763
  },
8753
8764
  load: function load(dumped) {
8754
- var _dumped$tags;
8765
+ var _dumped$tags, _dumped$labels;
8755
8766
  return _extends({}, dumped, {
8756
8767
  measure: upcastMeasure(dumped.measure),
8757
8768
  order: upcastOrder(dumped.order, dumped.timeDimension),
@@ -8761,6 +8772,7 @@ var FunnelChart = function FunnelChart(config) {
8761
8772
  approxXAxisLabelCount: upcastAxisLabel(dumped.approxXAxisLabelCount),
8762
8773
  approxYAxisLabelCount: upcastAxisLabel(dumped.approxYAxisLabelCount),
8763
8774
  tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
8775
+ labels: (_dumped$labels = dumped.labels) != null ? _dumped$labels : false,
8764
8776
  parameters: upcastParameters(dumped.parameters)
8765
8777
  });
8766
8778
  },
@@ -8792,6 +8804,7 @@ var FunnelChart = function FunnelChart(config) {
8792
8804
  yAxisFormat: null,
8793
8805
  xAxisFormat: null,
8794
8806
  legend: true,
8807
+ labels: false,
8795
8808
  approxXAxisLabelCount: 'auto',
8796
8809
  approxYAxisLabelCount: 'auto',
8797
8810
  axisTitles: undefined,
@@ -8849,10 +8862,9 @@ var FunnelChart = function FunnelChart(config) {
8849
8862
  }), namespace(CONSTANTS$h, 'sort'), namespace(CONSTANTS$h, 'filter'), namespace(CONSTANTS$h, 'custom_metrics'), namespace(CONSTANTS$h, 'limit')];
8850
8863
  },
8851
8864
  formatPanelConfig: function formatPanelConfig() {
8852
- var _CONSTANTS$format_pan;
8865
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
8853
8866
  return [headingConstant(CONSTANTS$h), _extends({}, namespace(CONSTANTS$h, 'chart_styles'), {
8854
- 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'>,
8855
- ]
8867
+ 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]
8856
8868
  }), axisLabelsConstants(CONSTANTS$h), _extends({}, namespace(CONSTANTS$h, 'conditional_formatting'), {
8857
8869
  ruleType: 'backgroundColor'
8858
8870
  }), namespace(CONSTANTS$h, 'headline')];
@@ -9950,7 +9962,7 @@ var attributesSchema$i = function attributesSchema(config) {
9950
9962
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
9951
9963
  stacked: Joi.valid(true, false),
9952
9964
  legend: Joi.valid(true, false),
9953
- // labels: Joi.valid(true, false).optional(),
9965
+ labels: Joi.valid(true, false).optional(),
9954
9966
  type: Joi.valid('barChartV2').required(),
9955
9967
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
9956
9968
  conditionalFormattingRules: conditionalFormattingRulesSchema(config.queryEngineConfig),
@@ -10059,370 +10071,381 @@ var CONSTANTS$k = {
10059
10071
  title: 'Show Legend',
10060
10072
  description: '',
10061
10073
  namespace: 'legend'
10062
- }
10063
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
10064
- }
10065
- },
10066
- axis_labels: {
10067
- type: 'axisLabels',
10068
- title: 'Axis Preferences',
10069
- description: '',
10070
- subSectionDefinition: {
10071
- x: {
10072
- title: 'X Axis',
10073
- description: '',
10074
- namespace: 'x'
10075
- },
10076
- 'x.prefix': {
10077
- title: 'Prefix',
10078
- description: '',
10079
- namespace: 'x.prefix'
10080
- },
10081
- 'x.postfix': {
10082
- title: 'Postfix',
10083
- description: '',
10084
- namespace: 'x.postfix'
10085
10074
  },
10086
- 'x.format': {
10087
- title: 'Format',
10088
- description: '',
10089
- namespace: 'x.format'
10090
- },
10091
- 'x.count': {
10092
- title: 'Label count',
10093
- description: '',
10094
- namespace: 'x.count'
10095
- },
10096
- 'x.axis_title': {
10097
- title: 'Title',
10098
- description: '',
10099
- namespace: 'x.axis_title'
10100
- },
10101
- y: {
10102
- title: 'Y Axis',
10103
- description: '',
10104
- namespace: 'y'
10105
- },
10106
- 'y.prefix': {
10107
- title: 'Prefix',
10108
- description: '',
10109
- namespace: 'y.prefix'
10110
- },
10111
- 'y.postfix': {
10112
- title: 'Postfix',
10113
- description: '',
10114
- namespace: 'y.postfix'
10115
- },
10116
- 'y.format': {
10117
- title: 'Format',
10118
- description: '',
10119
- namespace: 'y.format'
10120
- },
10121
- 'y.count': {
10122
- title: 'Label count',
10123
- description: '',
10124
- namespace: 'y.count'
10125
- },
10126
- 'y.axis_title': {
10127
- title: 'Title',
10128
- description: '',
10129
- namespace: 'y.axis_title'
10130
- }
10131
- }
10132
- },
10133
- conditional_formatting: {
10134
- type: 'conditionalFormatting',
10135
- title: 'Conditional Formatting',
10136
- description: ''
10137
- },
10138
- headline: {
10139
- type: 'headline',
10140
- title: 'Headline',
10141
- description: ''
10142
- },
10143
- goal_line: {
10144
- type: 'goalLine',
10145
- title: 'Goal Lines',
10146
- description: ''
10147
- }
10148
- }
10149
- };
10150
-
10151
- var BarChart$1 = function BarChart(config) {
10152
- return {
10153
- title: 'Bar chart',
10154
- description: 'Ideal for illustrating changes and trends over time with bar graphs.',
10155
- servicesClass: 'BarChart',
10156
- namespace: 'bar_chart',
10157
- dump: function dump(hydrated) {
10158
- return hydrated;
10159
- },
10160
- load: function load(dumped) {
10161
- var _dumped$tags;
10162
- return {
10163
- type: dumped.type,
10164
- measure: upcastMeasure(dumped.measure),
10165
- order: upcastOrder(dumped.order, dumped.timeDimension),
10166
- dimension: upcastStringDimensionsToObject(dumped.dimension),
10167
- // TODO: upcast dumped.timeDimension -> dimension
10168
- displayTitle: dumped.displayTitle,
10169
- displaySubject: dumped.displaySubject,
10170
- protectedByOrganisation: dumped.protectedByOrganisation,
10171
- viewId: upcastViewId(dumped.viewId),
10172
- filter: upcastFilter(dumped.filter),
10173
- dataSetId: dumped.dataSetId,
10174
- limit: dumped.limit,
10175
- timeDimension: null,
10176
- xAxisPostfix: dumped.xAxisPostfix,
10177
- xAxisPrefix: dumped.xAxisPrefix,
10178
- yAxisPostfix: dumped.yAxisPostfix,
10179
- yAxisPrefix: dumped.yAxisPrefix,
10180
- yAxisFormat: dumped.yAxisFormat,
10181
- xAxisFormat: dumped.xAxisFormat,
10182
- conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
10183
- drilldown: dumped.drilldown,
10184
- legend: dumped.legend,
10185
- goalLines: dumped.goalLines,
10186
- headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10187
- parameters: upcastParameters(dumped.parameters),
10188
- approxXAxisLabelCount: upcastAxisLabel(dumped.approxXAxisLabelCount),
10189
- approxYAxisLabelCount: upcastAxisLabel(dumped.approxYAxisLabelCount),
10190
- axisTitles: dumped.axisTitles,
10191
- tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
10192
- stacked: dumped.stacked,
10193
- drilldownOptions: dumped.drilldownOptions
10194
- };
10195
- },
10196
- setAttributes: setAttributes$g(config),
10197
- validate: function validate(attrs, dataSets) {
10198
- return validateView(attrs, dataSets, config.queryEngineConfig);
10199
- },
10200
- init: function init(dataSetId, overrides) {
10201
- return _extends({
10202
- type: 'barChartV2',
10203
- measure: [],
10204
- dimension: [],
10205
- timeDimension: null,
10206
- displayTitle: '',
10207
- displaySubject: '',
10208
- protectedByOrganisation: undefined,
10209
- viewId: upcastViewId(overrides == null ? void 0 : overrides.viewId),
10210
- filter: [],
10211
- order: [],
10212
- dataSetId: dataSetId,
10213
- limit: 5000,
10214
- xAxisPostfix: '',
10215
- xAxisPrefix: '',
10216
- yAxisPostfix: '',
10217
- yAxisPrefix: '',
10218
- yAxisFormat: null,
10219
- xAxisFormat: null,
10220
- conditionalFormattingRules: [],
10221
- drilldown: [],
10222
- legend: true,
10223
- goalLines: undefined,
10224
- approxXAxisLabelCount: 'auto',
10225
- approxYAxisLabelCount: 'auto',
10226
- parameters: {},
10227
- axisTitles: undefined,
10228
- headline: undefined,
10229
- tags: [],
10230
- drilldownOptions: undefined
10231
- }, overrides);
10232
- },
10233
- createFeedback: createFeedback,
10234
- schema: attributesSchema$i(config),
10235
- removeField: function removeField(attrs, fieldId) {
10236
- return removeField$1(attrs, fieldId, config.queryEngineConfig);
10237
- },
10238
- isRunnable: function isRunnable(hydrated) {
10239
- return hydrated.measure.length > 0 && hydrated.dimension.length > 0;
10240
- },
10241
- autoGenerate: function autoGenerate(dataSet) {
10242
- var _DataSet$buildQueryAt = buildQueryAttributes(dataSet, config.queryEngineConfig, 'barChart'),
10243
- measure = _DataSet$buildQueryAt.measure,
10244
- dimension = _DataSet$buildQueryAt.dimension;
10245
- return this.init(dataSet.id, {
10246
- measure: [measure[0]],
10247
- dimension: dimension
10248
- });
10249
- },
10250
- dataPanelConfig: function dataPanelConfig() {
10251
- return [namespace(CONSTANTS$k, 'data_set'), namespace(CONSTANTS$k, 'views'), _extends({}, namespace(CONSTANTS$k, 'field_y_axis'), {
10252
- fieldFilterOptions: {
10253
- forComponent: 'barChart'
10254
- },
10255
- preSetPartialAttributes: function preSetPartialAttributes(values) {
10256
- return {
10257
- measure: values
10258
- };
10259
- },
10260
- getValues: function getValues(attrs) {
10261
- return attrs.measure;
10262
- },
10263
- testId: 'metric-input'
10264
- }), _extends({}, namespace(CONSTANTS$k, 'field_x_axis'), {
10265
- fieldFilterOptions: {
10266
- forComponent: 'barChart',
10267
- onlyDimensions: true
10268
- },
10269
- preventDuplicates: false,
10270
- // return all values in the dimension array instead of seperating out timeDimension
10271
- preSetPartialAttributes: function preSetPartialAttributes(values) {
10272
- return {
10273
- dimension: [].concat(values)
10274
- };
10275
- },
10276
- // does this need to be updated too?
10277
- getValues: function getValues(attrs) {
10278
- return [].concat(attrs.dimension);
10279
- },
10280
- maxAllowed: 2,
10281
- testId: 'add-dimension'
10282
- }), namespace(CONSTANTS$k, 'sort'), namespace(CONSTANTS$k, 'filter'), _extends({}, namespace(CONSTANTS$k, 'drilldown'), {
10283
- options: {
10284
- property: 'drilldownOptions'
10285
- }
10286
- }), namespace(CONSTANTS$k, 'custom_metrics'), namespace(CONSTANTS$k, 'limit')];
10287
- },
10288
- formatPanelConfig: function formatPanelConfig() {
10289
- var _CONSTANTS$format_pan;
10290
- return [headingConstant(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'chart_styles'), {
10291
- 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'>,
10292
- ]
10293
- }), axisLabelsConstants(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'conditional_formatting'), {
10294
- ruleType: 'lineColor'
10295
- }), namespace(CONSTANTS$k, 'goal_line')];
10296
- },
10297
- supportedCustomFields: {
10298
- percentages: true,
10299
- dateCalculations: true,
10300
- simpleMaths: true,
10301
- rules: true,
10302
- aggregateMaths: true,
10303
- roundedNumbers: true,
10304
- conditional: true,
10305
- customBuild: [AcceptedTypes.Maths, AcceptedTypes.IfStatement, AcceptedTypes.Aggregates]
10306
- },
10307
- supportedFeatures: {
10308
- parameters: true,
10309
- colorGradient: false
10310
- },
10311
- setDataAttributesFromPreAggregatedDataSet: function setDataAttributesFromPreAggregatedDataSet$1(attributes, dataSet) {
10312
- return setDataAttributesFromPreAggregatedDataSet(attributes, dataSet, this.setAttributes);
10313
- }
10314
- };
10315
- };
10316
-
10317
- var attributesSchema$j = function attributesSchema(config) {
10318
- return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
10319
- legend: Joi.valid(true, false),
10320
- // labels: Joi.valid(true, false).optional(),
10321
- type: Joi.valid('waterfallChart').required(),
10322
- parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10323
- axisTitles: axisTitleSchema(),
10324
- headline: headlineSchema(),
10325
- tags: tagsSchema(),
10326
- increaseColor: Joi.string().required(),
10327
- decreaseColor: Joi.string().required(),
10328
- comparison: Joi.any()
10329
- }));
10330
- };
10331
-
10332
- var setAttributes$h = (function (config) {
10333
- return function (waterfallChart, partial) {
10334
- var newAttributes = setAttributes(waterfallChart, partial, attributesSchema$j(config));
10335
- newAttributes = removeUnusedOrderFieldsFromTimeSeriesComponent(newAttributes);
10336
- return newAttributes;
10337
- };
10338
- });
10339
-
10340
- var CONSTANTS$l = {
10341
- title: 'Waterfall chart',
10342
- 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.",
10343
- namespace: 'waterfall_chart',
10344
- data_panel: {
10345
- data_set: {
10346
- type: 'dataSet',
10347
- title: 'Data set',
10348
- description: 'What data do you want to use in this waterfall chart?'
10349
- },
10350
- views: {
10351
- type: 'views',
10352
- title: 'View',
10353
- description: ''
10354
- },
10355
- field_y_axis: {
10356
- type: 'fieldCollector',
10357
- title: 'Metric - Y Axis',
10358
- description: 'What do you want each bar to measure?',
10359
- callToAction: 'Add metric'
10360
- },
10361
- field_x_axis: {
10362
- type: 'fieldCollector',
10363
- title: 'Grouping - X Axis',
10364
- description: 'What do you want each bar to represent? An example would be a a date grouping to show each month as a bar',
10365
- callToAction: 'Add grouping'
10366
- },
10367
- dateComparison: {
10368
- type: 'dateComparison',
10369
- title: 'Comparison',
10370
- description: 'Compare the waterfall chart to a previous period.',
10371
- callToAction: 'Add comparison'
10372
- },
10373
- sort: {
10374
- type: 'sort',
10375
- title: 'Sort',
10376
- description: 'Select the order of categories or time on the x Axis.'
10377
- },
10378
- filter: {
10379
- type: 'filter',
10380
- title: 'Filters',
10381
- description: 'Only include the information you want to use in this waterfall chart.'
10382
- },
10383
- custom_metrics: {
10384
- type: 'customMetrics',
10385
- title: 'Custom metrics',
10386
- description: 'Build your own metrics, such as a percentage.'
10387
- },
10388
- limit: {
10389
- type: 'limit',
10390
- title: 'Limit',
10391
- description: 'Set the maximum number of records to show on this waterfall chart.'
10392
- }
10393
- },
10394
- format_panel: {
10395
- heading: {
10396
- type: 'heading',
10397
- title: 'Heading',
10398
- description: '',
10399
- subSectionDefinition: {
10400
- title: {
10401
- type: 'title',
10402
- title: 'Title',
10403
- description: '',
10404
- namespace: 'title'
10405
- },
10406
- subject: {
10407
- title: 'Subject',
10408
- type: 'subject',
10409
- description: '',
10410
- namespace: 'subject'
10411
- }
10412
- }
10413
- },
10414
- chart_styles: {
10415
- type: 'chartStyles',
10416
- title: 'Chart Settings',
10417
- description: '',
10418
- subSectionDefinition: {
10419
- legend: {
10420
- type: 'legend',
10421
- title: 'Show Legend',
10075
+ labels: {
10076
+ type: 'labels',
10077
+ title: 'Show Labels',
10422
10078
  description: '',
10423
- namespace: 'legend'
10079
+ namespace: 'labels'
10080
+ }
10081
+ }
10082
+ },
10083
+ axis_labels: {
10084
+ type: 'axisLabels',
10085
+ title: 'Axis Preferences',
10086
+ description: '',
10087
+ subSectionDefinition: {
10088
+ x: {
10089
+ title: 'X Axis',
10090
+ description: '',
10091
+ namespace: 'x'
10092
+ },
10093
+ 'x.prefix': {
10094
+ title: 'Prefix',
10095
+ description: '',
10096
+ namespace: 'x.prefix'
10097
+ },
10098
+ 'x.postfix': {
10099
+ title: 'Postfix',
10100
+ description: '',
10101
+ namespace: 'x.postfix'
10102
+ },
10103
+ 'x.format': {
10104
+ title: 'Format',
10105
+ description: '',
10106
+ namespace: 'x.format'
10107
+ },
10108
+ 'x.count': {
10109
+ title: 'Label count',
10110
+ description: '',
10111
+ namespace: 'x.count'
10112
+ },
10113
+ 'x.axis_title': {
10114
+ title: 'Title',
10115
+ description: '',
10116
+ namespace: 'x.axis_title'
10117
+ },
10118
+ y: {
10119
+ title: 'Y Axis',
10120
+ description: '',
10121
+ namespace: 'y'
10122
+ },
10123
+ 'y.prefix': {
10124
+ title: 'Prefix',
10125
+ description: '',
10126
+ namespace: 'y.prefix'
10127
+ },
10128
+ 'y.postfix': {
10129
+ title: 'Postfix',
10130
+ description: '',
10131
+ namespace: 'y.postfix'
10132
+ },
10133
+ 'y.format': {
10134
+ title: 'Format',
10135
+ description: '',
10136
+ namespace: 'y.format'
10137
+ },
10138
+ 'y.count': {
10139
+ title: 'Label count',
10140
+ description: '',
10141
+ namespace: 'y.count'
10142
+ },
10143
+ 'y.axis_title': {
10144
+ title: 'Title',
10145
+ description: '',
10146
+ namespace: 'y.axis_title'
10147
+ }
10148
+ }
10149
+ },
10150
+ conditional_formatting: {
10151
+ type: 'conditionalFormatting',
10152
+ title: 'Conditional Formatting',
10153
+ description: ''
10154
+ },
10155
+ headline: {
10156
+ type: 'headline',
10157
+ title: 'Headline',
10158
+ description: ''
10159
+ },
10160
+ goal_line: {
10161
+ type: 'goalLine',
10162
+ title: 'Goal Lines',
10163
+ description: ''
10164
+ }
10165
+ }
10166
+ };
10167
+
10168
+ var BarChart$1 = function BarChart(config) {
10169
+ return {
10170
+ title: 'Bar chart',
10171
+ description: 'Ideal for illustrating changes and trends over time with bar graphs.',
10172
+ servicesClass: 'BarChart',
10173
+ namespace: 'bar_chart',
10174
+ dump: function dump(hydrated) {
10175
+ return hydrated;
10176
+ },
10177
+ load: function load(dumped) {
10178
+ var _dumped$tags;
10179
+ return {
10180
+ type: dumped.type,
10181
+ measure: upcastMeasure(dumped.measure),
10182
+ order: upcastOrder(dumped.order, dumped.timeDimension),
10183
+ dimension: upcastStringDimensionsToObject(dumped.dimension),
10184
+ // TODO: upcast dumped.timeDimension -> dimension
10185
+ displayTitle: dumped.displayTitle,
10186
+ displaySubject: dumped.displaySubject,
10187
+ protectedByOrganisation: dumped.protectedByOrganisation,
10188
+ viewId: upcastViewId(dumped.viewId),
10189
+ filter: upcastFilter(dumped.filter),
10190
+ dataSetId: dumped.dataSetId,
10191
+ limit: dumped.limit,
10192
+ timeDimension: null,
10193
+ xAxisPostfix: dumped.xAxisPostfix,
10194
+ xAxisPrefix: dumped.xAxisPrefix,
10195
+ yAxisPostfix: dumped.yAxisPostfix,
10196
+ yAxisPrefix: dumped.yAxisPrefix,
10197
+ yAxisFormat: dumped.yAxisFormat,
10198
+ xAxisFormat: dumped.xAxisFormat,
10199
+ conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
10200
+ drilldown: dumped.drilldown,
10201
+ legend: dumped.legend,
10202
+ labels: dumped.labels,
10203
+ goalLines: dumped.goalLines,
10204
+ headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10205
+ parameters: upcastParameters(dumped.parameters),
10206
+ approxXAxisLabelCount: upcastAxisLabel(dumped.approxXAxisLabelCount),
10207
+ approxYAxisLabelCount: upcastAxisLabel(dumped.approxYAxisLabelCount),
10208
+ axisTitles: dumped.axisTitles,
10209
+ tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
10210
+ stacked: dumped.stacked,
10211
+ drilldownOptions: dumped.drilldownOptions
10212
+ };
10213
+ },
10214
+ setAttributes: setAttributes$g(config),
10215
+ validate: function validate(attrs, dataSets) {
10216
+ return validateView(attrs, dataSets, config.queryEngineConfig);
10217
+ },
10218
+ init: function init(dataSetId, overrides) {
10219
+ return _extends({
10220
+ type: 'barChartV2',
10221
+ measure: [],
10222
+ dimension: [],
10223
+ timeDimension: null,
10224
+ displayTitle: '',
10225
+ displaySubject: '',
10226
+ protectedByOrganisation: undefined,
10227
+ viewId: upcastViewId(overrides == null ? void 0 : overrides.viewId),
10228
+ filter: [],
10229
+ order: [],
10230
+ dataSetId: dataSetId,
10231
+ limit: 5000,
10232
+ xAxisPostfix: '',
10233
+ xAxisPrefix: '',
10234
+ yAxisPostfix: '',
10235
+ yAxisPrefix: '',
10236
+ yAxisFormat: null,
10237
+ xAxisFormat: null,
10238
+ conditionalFormattingRules: [],
10239
+ drilldown: [],
10240
+ legend: true,
10241
+ labels: false,
10242
+ goalLines: undefined,
10243
+ approxXAxisLabelCount: 'auto',
10244
+ approxYAxisLabelCount: 'auto',
10245
+ parameters: {},
10246
+ axisTitles: undefined,
10247
+ headline: undefined,
10248
+ tags: [],
10249
+ drilldownOptions: undefined
10250
+ }, overrides);
10251
+ },
10252
+ createFeedback: createFeedback,
10253
+ schema: attributesSchema$i(config),
10254
+ removeField: function removeField(attrs, fieldId) {
10255
+ return removeField$1(attrs, fieldId, config.queryEngineConfig);
10256
+ },
10257
+ isRunnable: function isRunnable(hydrated) {
10258
+ return hydrated.measure.length > 0 && hydrated.dimension.length > 0;
10259
+ },
10260
+ autoGenerate: function autoGenerate(dataSet) {
10261
+ var _DataSet$buildQueryAt = buildQueryAttributes(dataSet, config.queryEngineConfig, 'barChart'),
10262
+ measure = _DataSet$buildQueryAt.measure,
10263
+ dimension = _DataSet$buildQueryAt.dimension;
10264
+ return this.init(dataSet.id, {
10265
+ measure: [measure[0]],
10266
+ dimension: dimension
10267
+ });
10268
+ },
10269
+ dataPanelConfig: function dataPanelConfig() {
10270
+ return [namespace(CONSTANTS$k, 'data_set'), namespace(CONSTANTS$k, 'views'), _extends({}, namespace(CONSTANTS$k, 'field_y_axis'), {
10271
+ fieldFilterOptions: {
10272
+ forComponent: 'barChart'
10273
+ },
10274
+ preSetPartialAttributes: function preSetPartialAttributes(values) {
10275
+ return {
10276
+ measure: values
10277
+ };
10278
+ },
10279
+ getValues: function getValues(attrs) {
10280
+ return attrs.measure;
10281
+ },
10282
+ testId: 'metric-input'
10283
+ }), _extends({}, namespace(CONSTANTS$k, 'field_x_axis'), {
10284
+ fieldFilterOptions: {
10285
+ forComponent: 'barChart',
10286
+ onlyDimensions: true
10287
+ },
10288
+ preventDuplicates: false,
10289
+ // return all values in the dimension array instead of seperating out timeDimension
10290
+ preSetPartialAttributes: function preSetPartialAttributes(values) {
10291
+ return {
10292
+ dimension: [].concat(values)
10293
+ };
10294
+ },
10295
+ // does this need to be updated too?
10296
+ getValues: function getValues(attrs) {
10297
+ return [].concat(attrs.dimension);
10298
+ },
10299
+ maxAllowed: 2,
10300
+ testId: 'add-dimension'
10301
+ }), namespace(CONSTANTS$k, 'sort'), namespace(CONSTANTS$k, 'filter'), _extends({}, namespace(CONSTANTS$k, 'drilldown'), {
10302
+ options: {
10303
+ property: 'drilldownOptions'
10304
+ }
10305
+ }), namespace(CONSTANTS$k, 'custom_metrics'), namespace(CONSTANTS$k, 'limit')];
10306
+ },
10307
+ formatPanelConfig: function formatPanelConfig() {
10308
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
10309
+ return [headingConstant(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'chart_styles'), {
10310
+ 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]
10311
+ }), axisLabelsConstants(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'conditional_formatting'), {
10312
+ ruleType: 'lineColor'
10313
+ }), namespace(CONSTANTS$k, 'goal_line')];
10314
+ },
10315
+ supportedCustomFields: {
10316
+ percentages: true,
10317
+ dateCalculations: true,
10318
+ simpleMaths: true,
10319
+ rules: true,
10320
+ aggregateMaths: true,
10321
+ roundedNumbers: true,
10322
+ conditional: true,
10323
+ customBuild: [AcceptedTypes.Maths, AcceptedTypes.IfStatement, AcceptedTypes.Aggregates]
10324
+ },
10325
+ supportedFeatures: {
10326
+ parameters: true,
10327
+ colorGradient: false
10328
+ },
10329
+ setDataAttributesFromPreAggregatedDataSet: function setDataAttributesFromPreAggregatedDataSet$1(attributes, dataSet) {
10330
+ return setDataAttributesFromPreAggregatedDataSet(attributes, dataSet, this.setAttributes);
10331
+ }
10332
+ };
10333
+ };
10334
+
10335
+ var attributesSchema$j = function attributesSchema(config) {
10336
+ return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
10337
+ legend: Joi.valid(true, false),
10338
+ labels: Joi.valid(true, false).optional(),
10339
+ type: Joi.valid('waterfallChart').required(),
10340
+ parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10341
+ axisTitles: axisTitleSchema(),
10342
+ headline: headlineSchema(),
10343
+ tags: tagsSchema(),
10344
+ increaseColor: Joi.string().required(),
10345
+ decreaseColor: Joi.string().required(),
10346
+ comparison: Joi.any()
10347
+ }));
10348
+ };
10349
+
10350
+ var setAttributes$h = (function (config) {
10351
+ return function (waterfallChart, partial) {
10352
+ var newAttributes = setAttributes(waterfallChart, partial, attributesSchema$j(config));
10353
+ newAttributes = removeUnusedOrderFieldsFromTimeSeriesComponent(newAttributes);
10354
+ return newAttributes;
10355
+ };
10356
+ });
10357
+
10358
+ var CONSTANTS$l = {
10359
+ title: 'Waterfall chart',
10360
+ 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.",
10361
+ namespace: 'waterfall_chart',
10362
+ data_panel: {
10363
+ data_set: {
10364
+ type: 'dataSet',
10365
+ title: 'Data set',
10366
+ description: 'What data do you want to use in this waterfall chart?'
10367
+ },
10368
+ views: {
10369
+ type: 'views',
10370
+ title: 'View',
10371
+ description: ''
10372
+ },
10373
+ field_y_axis: {
10374
+ type: 'fieldCollector',
10375
+ title: 'Metric - Y Axis',
10376
+ description: 'What do you want each bar to measure?',
10377
+ callToAction: 'Add metric'
10378
+ },
10379
+ field_x_axis: {
10380
+ type: 'fieldCollector',
10381
+ title: 'Grouping - X Axis',
10382
+ description: 'What do you want each bar to represent? An example would be a a date grouping to show each month as a bar',
10383
+ callToAction: 'Add grouping'
10384
+ },
10385
+ dateComparison: {
10386
+ type: 'dateComparison',
10387
+ title: 'Comparison',
10388
+ description: 'Compare the waterfall chart to a previous period.',
10389
+ callToAction: 'Add comparison'
10390
+ },
10391
+ sort: {
10392
+ type: 'sort',
10393
+ title: 'Sort',
10394
+ description: 'Select the order of categories or time on the x Axis.'
10395
+ },
10396
+ filter: {
10397
+ type: 'filter',
10398
+ title: 'Filters',
10399
+ description: 'Only include the information you want to use in this waterfall chart.'
10400
+ },
10401
+ custom_metrics: {
10402
+ type: 'customMetrics',
10403
+ title: 'Custom metrics',
10404
+ description: 'Build your own metrics, such as a percentage.'
10405
+ },
10406
+ limit: {
10407
+ type: 'limit',
10408
+ title: 'Limit',
10409
+ description: 'Set the maximum number of records to show on this waterfall chart.'
10410
+ }
10411
+ },
10412
+ format_panel: {
10413
+ heading: {
10414
+ type: 'heading',
10415
+ title: 'Heading',
10416
+ description: '',
10417
+ subSectionDefinition: {
10418
+ title: {
10419
+ type: 'title',
10420
+ title: 'Title',
10421
+ description: '',
10422
+ namespace: 'title'
10423
+ },
10424
+ subject: {
10425
+ title: 'Subject',
10426
+ type: 'subject',
10427
+ description: '',
10428
+ namespace: 'subject'
10429
+ }
10430
+ }
10431
+ },
10432
+ chart_styles: {
10433
+ type: 'chartStyles',
10434
+ title: 'Chart Settings',
10435
+ description: '',
10436
+ subSectionDefinition: {
10437
+ legend: {
10438
+ type: 'legend',
10439
+ title: 'Show Legend',
10440
+ description: '',
10441
+ namespace: 'legend'
10442
+ },
10443
+ labels: {
10444
+ type: 'labels',
10445
+ title: 'Show Labels',
10446
+ description: '',
10447
+ namespace: 'labels'
10424
10448
  }
10425
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
10426
10449
  }
10427
10450
  },
10428
10451
  axis_labels: {
@@ -10525,6 +10548,7 @@ var WaterfallChart = function WaterfallChart(config) {
10525
10548
  headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10526
10549
  tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
10527
10550
  legend: dumped.legend,
10551
+ labels: dumped.labels,
10528
10552
  viewId: upcastViewId(dumped.viewId),
10529
10553
  dataSetId: dumped.dataSetId,
10530
10554
  limit: dumped.limit,
@@ -10574,6 +10598,7 @@ var WaterfallChart = function WaterfallChart(config) {
10574
10598
  yAxisFormat: null,
10575
10599
  xAxisFormat: null,
10576
10600
  legend: true,
10601
+ labels: false,
10577
10602
  parameters: {},
10578
10603
  axisTitles: undefined,
10579
10604
  headline: undefined,
@@ -10637,10 +10662,9 @@ var WaterfallChart = function WaterfallChart(config) {
10637
10662
  }), namespace(CONSTANTS$l, 'sort'), namespace(CONSTANTS$l, 'filter'), namespace(CONSTANTS$l, 'custom_metrics'), namespace(CONSTANTS$l, 'limit')];
10638
10663
  },
10639
10664
  formatPanelConfig: function formatPanelConfig() {
10640
- var _CONSTANTS$format_pan;
10665
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
10641
10666
  return [headingConstant(CONSTANTS$l), namespace(CONSTANTS$l, 'waterfall_colors'), _extends({}, namespace(CONSTANTS$l, 'chart_styles'), {
10642
- 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'>,
10643
- ]
10667
+ 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]
10644
10668
  }), axisLabelsConstants(CONSTANTS$l)];
10645
10669
  },
10646
10670
  supportedCustomFields: {
@@ -10667,7 +10691,7 @@ var attributesSchema$k = function attributesSchema(config) {
10667
10691
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
10668
10692
  stacked: Joi.valid(true, false),
10669
10693
  legend: Joi.valid(true, false),
10670
- // labels: Joi.valid(true, false).optional(),
10694
+ labels: Joi.valid(true, false).optional(),
10671
10695
  type: Joi.valid('areaChartV2').required(),
10672
10696
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10673
10697
  lineCurve: areaCurveSchema,
@@ -10783,8 +10807,13 @@ var CONSTANTS$m = {
10783
10807
  title: 'Show Legend',
10784
10808
  description: '',
10785
10809
  namespace: 'legend'
10810
+ },
10811
+ labels: {
10812
+ type: 'labels',
10813
+ title: 'Show Labels',
10814
+ description: '',
10815
+ namespace: 'labels'
10786
10816
  }
10787
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
10788
10817
  }
10789
10818
  },
10790
10819
  axis_labels: {
@@ -10912,6 +10941,7 @@ var AreaChart$1 = function AreaChart(config) {
10912
10941
  conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
10913
10942
  drilldown: dumped.drilldown,
10914
10943
  legend: dumped.legend,
10944
+ labels: dumped.labels,
10915
10945
  goalLines: dumped.goalLines,
10916
10946
  headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10917
10947
  parameters: upcastParameters(dumped.parameters),
@@ -10951,6 +10981,7 @@ var AreaChart$1 = function AreaChart(config) {
10951
10981
  conditionalFormattingRules: [],
10952
10982
  drilldown: [],
10953
10983
  legend: true,
10984
+ labels: false,
10954
10985
  goalLines: undefined,
10955
10986
  approxXAxisLabelCount: 'auto',
10956
10987
  approxYAxisLabelCount: 'auto',
@@ -11014,10 +11045,9 @@ var AreaChart$1 = function AreaChart(config) {
11014
11045
  }), namespace(CONSTANTS$m, 'sort'), namespace(CONSTANTS$m, 'filter'), namespace(CONSTANTS$m, 'custom_metrics'), namespace(CONSTANTS$m, 'limit')];
11015
11046
  },
11016
11047
  formatPanelConfig: function formatPanelConfig() {
11017
- var _CONSTANTS$format_pan;
11048
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
11018
11049
  return [headingConstant(CONSTANTS$m), _extends({}, namespace(CONSTANTS$m, 'chart_styles'), {
11019
- 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'>,
11020
- ]
11050
+ 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]
11021
11051
  }), axisLabelsConstants(CONSTANTS$m), _extends({}, namespace(CONSTANTS$m, 'conditional_formatting'), {
11022
11052
  ruleType: 'lineColor'
11023
11053
  }), namespace(CONSTANTS$m, 'goal_line')];
@@ -11046,7 +11076,7 @@ var attributesSchema$l = function attributesSchema(config) {
11046
11076
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), {
11047
11077
  stacked: Joi.valid(true, false),
11048
11078
  legend: Joi.valid(true, false),
11049
- // labels: Joi.valid(true, false).optional(),
11079
+ labels: Joi.valid(true, false).optional(),
11050
11080
  barMeasure: Joi.array().items(measureSchema(config.queryEngineConfig.supportedAggregates, config.attributesSchemaOptions)),
11051
11081
  lineMeasure: Joi.array().items(measureSchema(config.queryEngineConfig.supportedAggregates, config.attributesSchemaOptions)),
11052
11082
  barDimension: dimensionSchema(config.queryEngineConfig.supportedTimeTruncFunctions, config.attributesSchemaOptions),
@@ -11192,8 +11222,13 @@ var CONSTANTS$n = {
11192
11222
  title: 'Show Legend',
11193
11223
  description: '',
11194
11224
  namespace: 'legend'
11225
+ },
11226
+ labels: {
11227
+ type: 'labels',
11228
+ title: 'Show Labels',
11229
+ description: '',
11230
+ namespace: 'labels'
11195
11231
  }
11196
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
11197
11232
  }
11198
11233
  },
11199
11234
  axis_labels: {
@@ -11325,6 +11360,7 @@ var ComboChartV2 = function ComboChartV2(config) {
11325
11360
  yAxisFormat: null,
11326
11361
  xAxisFormat: null,
11327
11362
  legend: true,
11363
+ labels: false,
11328
11364
  approxXAxisLabelCount: 'auto',
11329
11365
  approxYAxisLabelCount: 'auto',
11330
11366
  goalLines: undefined,
@@ -11365,19 +11401,18 @@ var ComboChartV2 = function ComboChartV2(config) {
11365
11401
  }), namespace(CONSTANTS$n, 'combo_chart_dimension'), namespace(CONSTANTS$n, 'sort'), namespace(CONSTANTS$n, 'filter'), namespace(CONSTANTS$n, 'custom_metrics'), namespace(CONSTANTS$n, 'limit')];
11366
11402
  },
11367
11403
  formatPanelConfig: function formatPanelConfig() {
11368
- var _CONSTANTS$format_pan, _CONSTANTS$format_pan2, _CONSTANTS$format_pan3, _CONSTANTS$format_pan4, _CONSTANTS$format_pan5, _CONSTANTS$format_pan6, _CONSTANTS$format_pan7;
11404
+ 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;
11369
11405
  return [headingConstant(CONSTANTS$n), _extends({}, namespace(CONSTANTS$n, 'chart_styles'), {
11370
- 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'>,
11371
- ]
11406
+ 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]
11372
11407
  }), axisLabelsConstants(CONSTANTS$n), _extends({}, namespace(CONSTANTS$n, 'conditional_formatting'), {
11373
11408
  ruleType: 'backgroundColor',
11374
11409
  subSection: [{
11375
- 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 : '',
11376
- 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,
11410
+ 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 : '',
11411
+ 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,
11377
11412
  propKey: 'bar'
11378
11413
  }, {
11379
- 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 : '',
11380
- 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,
11414
+ 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 : '',
11415
+ 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,
11381
11416
  propKey: 'line'
11382
11417
  }]
11383
11418
  }), namespace(CONSTANTS$n, 'goal_line')];
@@ -12515,12 +12550,16 @@ var defaultNumberFormatOptions = function defaultNumberFormatOptions(textOverrid
12515
12550
  description: textOverride('number_format_option.currency_eur', 'Currency €')
12516
12551
  },
12517
12552
  _vizzly_to_percentage: {
12518
- formatter: function formatter(value, noValueReplacement) {
12553
+ formatter: function formatter(value, noValueReplacement, total) {
12519
12554
  if (noValueReplacement === void 0) {
12520
12555
  noValueReplacement = noValue;
12521
12556
  }
12522
12557
  if (value === null || value === undefined) return noValueReplacement;
12523
12558
  if (Number.isNaN(value)) return formattingError;
12559
+ if (total !== undefined && total !== 0 && typeof value === 'number') {
12560
+ var percentage = isPercentageOf(value, total);
12561
+ return toDp(percentage, 2) + "%";
12562
+ }
12524
12563
  return toPercentage(value, 2);
12525
12564
  },
12526
12565
  description: textOverride('number_format_option.percentage', 'Percentage')
@@ -13068,10 +13107,10 @@ var formatSeriesName = function formatSeriesName(result, textOverride, type, id,
13068
13107
  return newTitle != null ? newTitle : defaultLabel;
13069
13108
  };
13070
13109
  };
13071
- var convertValueToFormat = function convertValueToFormat(value, numberFormatOptions, format) {
13110
+ var convertValueToFormat = function convertValueToFormat(value, numberFormatOptions, format, total) {
13072
13111
  var _numberFormatOptions;
13073
13112
  var formatter = numberFormatOptions == null || (_numberFormatOptions = numberFormatOptions[format != null ? format : '']) == null ? void 0 : _numberFormatOptions.formatter;
13074
- return formatter ? formatter(value) : value;
13113
+ return formatter ? formatter(value, undefined, total) : value;
13075
13114
  };
13076
13115
  function getGradientAdjustedColor(rule, matchedHexValue, actualValue) {
13077
13116
  if (rule.boundaries && rule.boundaries.length === 2 && rule.ruleValueEnd) {
@@ -34029,6 +34068,12 @@ var calculateMinMax = function calculateMinMax(values) {
34029
34068
  maxValue: maxValue
34030
34069
  };
34031
34070
  };
34071
+ var normalizeKey = function normalizeKey(value) {
34072
+ if (typeof value === 'number' || !isNaN(Number(value)) && !isNaN(parseFloat(value))) {
34073
+ return Number(value).toString().split('.')[0];
34074
+ }
34075
+ return String(value);
34076
+ };
34032
34077
  var showMinMaxLabel = function showMinMaxLabel(value, totalItems, minValue, maxValue) {
34033
34078
  return totalItems < 11 || value == minValue || value == maxValue;
34034
34079
  };
@@ -34041,6 +34086,40 @@ var getMinMaxChartValueFromNumberArray = function getMinMaxChartValueFromNumberA
34041
34086
  maxValue: maxValue
34042
34087
  };
34043
34088
  };
34089
+ var getLabelDictionary = function getLabelDictionary(formattedData, keys) {
34090
+ var formattedLabelNames = formattedData == null ? void 0 : formattedData.map(function (d) {
34091
+ var convertedArray = keys.map(function (key) {
34092
+ var _ref;
34093
+ if (!d[key].formattedValue) return;
34094
+ var valueKey = normalizeKey(d[key].value);
34095
+ var label = d[key].formattedValue;
34096
+ return _ref = {}, _ref[valueKey] = label, _ref;
34097
+ }).flat();
34098
+ return convertedArray;
34099
+ });
34100
+ if (!formattedLabelNames) return {};
34101
+ var dictionary = {};
34102
+ formattedLabelNames.forEach(function (labelArray) {
34103
+ if (labelArray) {
34104
+ labelArray.forEach(function (labelObj) {
34105
+ if (labelObj) {
34106
+ Object.entries(labelObj).forEach(function (_ref2) {
34107
+ var value = _ref2[0],
34108
+ label = _ref2[1];
34109
+ dictionary[value] = label;
34110
+ });
34111
+ }
34112
+ });
34113
+ }
34114
+ });
34115
+ return dictionary;
34116
+ };
34117
+ var getFormattedValue = function getFormattedValue(value, dictionary) {
34118
+ var _dictionary$normalize;
34119
+ if (!dictionary) return value;
34120
+ var normalizedKey = normalizeKey(value);
34121
+ return (_dictionary$normalize = dictionary[normalizedKey]) != null ? _dictionary$normalize : value;
34122
+ };
34044
34123
  var getAllChartValues = function getAllChartValues(data, keys) {
34045
34124
  var allValues = [];
34046
34125
  data.forEach(function (item) {
@@ -34066,6 +34145,12 @@ var accessors = function accessors(xAxisIsTime, xKey, yKey, horizontal) {
34066
34145
  };
34067
34146
  };
34068
34147
  var DEFAULT_Y_AXIS_LABEL_COUNT = 5;
34148
+ var LABEL_TEXT_STYLE = {
34149
+ textAnchor: 'middle',
34150
+ fontSize: '10px',
34151
+ fill: '#333',
34152
+ fontWeight: 500
34153
+ };
34069
34154
  var VizzlyXYChart = function VizzlyXYChart(props) {
34070
34155
  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;
34071
34156
  var height = adjustHeight((_props$height = props == null ? void 0 : props.height) != null ? _props$height : 300, props == null ? void 0 : props.legend);
@@ -34350,57 +34435,49 @@ var VizzlyXYChart = function VizzlyXYChart(props) {
34350
34435
  }), "bar_with_previous_" + props.uniqueId + "_" + keyIndex);
34351
34436
  })
34352
34437
  }), props.bars.data.map(function (dataPoint, dataIndex) {
34353
- return jsxRuntime.jsx("g", {
34354
- children: props.bars.keys.map(function (key, keyIndex) {
34355
- var value = dataPoint[key];
34356
- if (!value || !props.labels) return null;
34357
- if (props.bars.data.length > 10) {
34358
- var values = props.bars.data.map(function (d) {
34359
- return Number(d[key]);
34360
- }).filter(function (v) {
34361
- return v;
34362
- });
34363
- var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(values),
34364
- _minValue = _getMinMaxChartValueF.minValue,
34365
- _maxValue = _getMinMaxChartValueF.maxValue;
34366
- var currentValue = Number(value);
34367
- if (currentValue !== _minValue && currentValue !== _maxValue) {
34368
- return null;
34369
- }
34370
- }
34371
- var chartWidth = props.width || 400;
34372
- var barWidth = (chartWidth - margin.left - margin.right) / props.bars.data.length;
34373
- var barX = margin.left + dataIndex * barWidth + barWidth / 2;
34374
- var isPositiveModifier = isPositiveModifierKey(key);
34375
- var barHeight, barY;
34376
- if (isPositiveModifier) {
34377
- // Helper function to extract the base name from the key (e.g., "{Revenue, previous}" -> "Revenue")
34378
- var getBaseKeyName = function getBaseKeyName(keyName) {
34379
- return keyName.replace(/[{}]/g, '').split(',')[0].trim();
34380
- };
34381
- var standardKey = props.bars.keys.find(function (k) {
34382
- return !isPositiveModifierKey(k) && getBaseKeyName(k) === getBaseKeyName(key);
34383
- });
34384
- var totalValue = standardKey ? dataPoint[standardKey] : 0;
34385
- var previousValue = Number(value);
34386
- var totalBarValue = Number(totalValue) + previousValue;
34387
- barHeight = (height - margin.top - margin.bottom) * totalBarValue / (maxValue || 1);
34388
- barY = height - margin.bottom - barHeight;
34389
- } else {
34390
- barHeight = (height - margin.top - margin.bottom) * Number(value) / (maxValue || 1);
34391
- barY = height - margin.bottom - barHeight;
34392
- }
34393
- return jsxRuntime.jsx("text", {
34394
- x: barX,
34395
- y: barY,
34396
- textAnchor: "bottom",
34397
- fontSize: "10px",
34398
- fill: "#333",
34399
- fontWeight: "500",
34400
- children: formatYAxisLabel$1(props)(value)
34401
- }, "funnel_label_" + props.uniqueId + "_" + dataIndex + "_" + keyIndex);
34402
- })
34403
- }, "funnel_labels_" + props.uniqueId + "_" + dataIndex);
34438
+ var mainKey = props.bars.keys[0];
34439
+ var value = dataPoint[mainKey];
34440
+ if (!value || !props.labels) return null;
34441
+ if (props.bars && props.bars.data.length > 30) {
34442
+ var values = props.bars.data.map(function (d) {
34443
+ return Number(d[mainKey]);
34444
+ }).filter(function (v) {
34445
+ return v;
34446
+ });
34447
+ var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(values),
34448
+ _minValue = _getMinMaxChartValueF.minValue,
34449
+ _maxValue = _getMinMaxChartValueF.maxValue;
34450
+ var currentValue = Number(value);
34451
+ if (currentValue !== _minValue && currentValue !== _maxValue) {
34452
+ return null;
34453
+ }
34454
+ }
34455
+ var _accessors = accessors(xAxisIsTime, x, mainKey, horizontal),
34456
+ yAccessor = _accessors.yAccessor;
34457
+ var yValue = yAccessor(dataPoint);
34458
+ var defaultChartWidth = 400;
34459
+ var chartWidth = props.width || defaultChartWidth;
34460
+ var barWidth = (chartWidth - margin.left - margin.right) / props.bars.data.length;
34461
+ var barX = margin.left + dataIndex * barWidth + barWidth / 2;
34462
+ var availableHeight = height - margin.top - margin.bottom;
34463
+ var yScale = scale.scaleLinear({
34464
+ domain: [minValue, maxValue],
34465
+ range: [availableHeight, 0],
34466
+ nice: true
34467
+ });
34468
+ var scaledYValue = yScale(Number(yValue));
34469
+ var barTopY = margin.top + scaledYValue;
34470
+ var yPadding = 5;
34471
+ var labelY = barTopY - yPadding;
34472
+ return jsxRuntime.jsx("text", {
34473
+ x: barX,
34474
+ y: labelY,
34475
+ textAnchor: LABEL_TEXT_STYLE.textAnchor,
34476
+ fontSize: LABEL_TEXT_STYLE.fontSize,
34477
+ fill: LABEL_TEXT_STYLE.fill,
34478
+ fontWeight: LABEL_TEXT_STYLE.fontWeight,
34479
+ children: formatYAxisLabel$1(props)(value)
34480
+ }, "funnel_label_" + props.uniqueId + "_" + dataIndex);
34404
34481
  })]
34405
34482
  }), (props == null ? void 0 : props.bars) && props.bars.stacked && jsxRuntime.jsxs(React.Fragment, {
34406
34483
  children: [props.enableHover && jsxRuntime.jsx("style", {
@@ -38854,12 +38931,12 @@ var PieChartView = function PieChartView(props) {
38854
38931
  var rS = resultSet$1(props.result, pivotConfig, fakeQuery, false, checkForNullValue(props.dataSetId, props.dimension, props.timeDimension, textOverride, valueAlias));
38855
38932
  var pieSeries = series$1(fakeQuery, props.result, pivotConfig);
38856
38933
 
38857
- /*
38934
+ /*
38858
38935
  NOTES
38859
38936
  - isArray(data[props.dimension[0].field]) check below added so Pie charts can support conditional formatting on string[] dataTypes
38860
38937
  */
38861
38938
 
38862
- /*
38939
+ /*
38863
38940
  TODO
38864
38941
  - Allow string[] dataTypes to be chosen as a grouping in the Pie chart
38865
38942
  - 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)
@@ -38924,7 +39001,10 @@ var PieChartView = function PieChartView(props) {
38924
39001
  showLabel: (theme == null ? void 0 : theme.detail) === 'verbose' && (props == null ? void 0 : props.labels) !== false || (props == null ? void 0 : props.labels),
38925
39002
  legend: showLegend(props == null ? void 0 : props.legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
38926
39003
  formatValue: function formatValue(value) {
38927
- return convertValueToFormat(toDp(value, 2), props == null ? void 0 : props.numberFormatOptions, props == null ? void 0 : props.labelFormat);
39004
+ var total = data[0].data.reduce(function (sum, item) {
39005
+ return sum + (item[data[0].valueKey] || 0);
39006
+ }, 0);
39007
+ return convertValueToFormat(value, props == null ? void 0 : props.numberFormatOptions, props == null ? void 0 : props.labelFormat, total);
38928
39008
  }
38929
39009
  })
38930
39010
  })]
@@ -43382,358 +43462,6 @@ function buildComboTooltipData(barTooltipData, lineTooltipData, xScaleKey) {
43382
43462
  return barTooltipData && lineTooltipData ? _extends({}, barTooltipData, lineTooltipData) : undefined;
43383
43463
  }
43384
43464
 
43385
- var LegendItemBox = function LegendItemBox(_ref) {
43386
- var color = _ref.color,
43387
- style = _ref.style;
43388
- return jsxRuntime.jsx("svg", {
43389
- width: 10,
43390
- height: 10,
43391
- style: {
43392
- display: 'block'
43393
- },
43394
- children: style.type === 'line' ? style.strokeDasharray !== null ? jsxRuntime.jsx("line", {
43395
- x1: "0",
43396
- y1: "5",
43397
- x2: "10",
43398
- y2: "5",
43399
- stroke: color,
43400
- strokeWidth: style.strokeWidth,
43401
- strokeDasharray: 2
43402
- }) : jsxRuntime.jsx("line", {
43403
- x1: "0",
43404
- y1: "5",
43405
- x2: "10",
43406
- y2: "5",
43407
- stroke: color,
43408
- strokeWidth: style.strokeWidth
43409
- }) : jsxRuntime.jsx("rect", {
43410
- fill: color,
43411
- width: 10,
43412
- height: 10,
43413
- rx: "2"
43414
- })
43415
- });
43416
- };
43417
- var LegendItemSquare = function LegendItemSquare(_ref2) {
43418
- var color = _ref2.color;
43419
- return jsxRuntime.jsx("svg", {
43420
- width: 8,
43421
- height: 8,
43422
- style: {
43423
- display: 'block'
43424
- },
43425
- children: jsxRuntime.jsx("rect", {
43426
- fill: color,
43427
- width: 8,
43428
- height: 8,
43429
- rx: "2"
43430
- })
43431
- });
43432
- };
43433
- var LegendItemTriangle = function LegendItemTriangle(_ref3) {
43434
- var color = _ref3.color;
43435
- return jsxRuntime.jsx("svg", {
43436
- width: 8,
43437
- height: 8,
43438
- style: {
43439
- display: 'block',
43440
- borderRadius: 1
43441
- },
43442
- children: jsxRuntime.jsx("polygon", {
43443
- points: "0,0 10,10 0,10",
43444
- fill: color
43445
- })
43446
- });
43447
- };
43448
-
43449
- 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)."; }
43450
- var MIN_TOOLTIP_WIDTH = 180;
43451
- var TOOLTIP_OFFSET = 20;
43452
- var SCROLLBAR_WIDTH = 40;
43453
- var Tooltip$1 = function Tooltip(_ref) {
43454
- var _tooltipData$xKey$for, _tooltipData$xKey;
43455
- var keys = _ref.keys,
43456
- showRoundedTotal = _ref.showRoundedTotal,
43457
- tooltipData = _ref.tooltipData,
43458
- tooltipLeft = _ref.tooltipLeft,
43459
- tooltipTop = _ref.tooltipTop,
43460
- xKey = _ref.xKey,
43461
- yKeys = _ref.yKeys,
43462
- theme = _ref.theme,
43463
- items = _ref.items,
43464
- _ref$shouldShowColorL = _ref.shouldShowColorLegend,
43465
- shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
43466
- var tooltipRef = React.useRef(null);
43467
- var _useState = React.useState({
43468
- left: tooltipLeft
43469
- }),
43470
- position = _useState[0],
43471
- setPosition = _useState[1];
43472
- React.useEffect(function () {
43473
- var adjustTooltipPosition = function adjustTooltipPosition() {
43474
- var tooltipElement = tooltipRef.current;
43475
- if (tooltipElement) {
43476
- var screenWidth = window.innerWidth;
43477
- var rect = tooltipElement.getBoundingClientRect();
43478
- var width = rect.width;
43479
- if (width < MIN_TOOLTIP_WIDTH) {
43480
- width = MIN_TOOLTIP_WIDTH;
43481
- }
43482
- var left = tooltipLeft + TOOLTIP_OFFSET;
43483
- if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {
43484
- left = tooltipLeft - width - TOOLTIP_OFFSET;
43485
- }
43486
- setPosition({
43487
- left: left
43488
- });
43489
- }
43490
- };
43491
- adjustTooltipPosition();
43492
- }, [tooltipLeft]);
43493
- return /*#__PURE__*/ReactDOM.createPortal(jsxRuntime.jsx("div", {
43494
- ref: tooltipRef,
43495
- style: _extends({
43496
- position: 'absolute',
43497
- left: position.left,
43498
- top: tooltipTop,
43499
- zIndex: 2147483647 * 10
43500
- }, theme),
43501
- children: jsxRuntime.jsxs("div", {
43502
- style: {
43503
- wordBreak: 'break-all'
43504
- },
43505
- children: [jsxRuntime.jsx("div", {
43506
- className: /*#__PURE__*/css$1.css({
43507
- fontFamily: 'inherit',
43508
- lineHeight: 'inherit',
43509
- letterSpacing: 'inherit',
43510
- fontWeight: 'bold',
43511
- fontSize: '15px',
43512
- width: '100%',
43513
- minWidth: MIN_TOOLTIP_WIDTH
43514
- }, ";label:Tooltip;", "/*# 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"]} */"),
43515
- children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
43516
- }), jsxRuntime.jsx("table", {
43517
- cellPadding: 0,
43518
- cellSpacing: 0,
43519
- className: /*#__PURE__*/css$1.css( {
43520
- name: "9a1sa-Tooltip",
43521
- styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
43522
- 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"]} */",
43523
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
43524
- }),
43525
- children: jsxRuntime.jsxs("tbody", {
43526
- children: [items.map(function (item, index) {
43527
- var _item$legendItems;
43528
- return jsxRuntime.jsx(React.Fragment, {
43529
- children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
43530
- var _item$visibleYKeys, _item$conditionalForm;
43531
- if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
43532
- // yKey could not be found in tooltipData
43533
- return null;
43534
- }
43535
- return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxRuntime.jsxs("tr", {
43536
- children: [shouldShowColorLegend && jsxRuntime.jsx("td", {
43537
- style: {
43538
- verticalAlign: 'middle',
43539
- padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
43540
- width: 'auto'
43541
- },
43542
- children: jsxRuntime.jsx(LegendItemBox, {
43543
- color: getColor({
43544
- defaultColor: legendItem.color,
43545
- value: tooltipData[legendItem.yKey].value,
43546
- yKey: legendItem.yKey,
43547
- conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
43548
- }),
43549
- style: legendItem.style,
43550
- yKey: legendItem.yKey
43551
- })
43552
- }), jsxRuntime.jsx("td", {
43553
- style: {
43554
- padding: '8px 0 0 0'
43555
- },
43556
- children: keys[legendItem.yKey].keyFormatted
43557
- }), jsxRuntime.jsx("td", {
43558
- style: {
43559
- fontWeight: 'bold',
43560
- padding: '8px 0 0 16px'
43561
- },
43562
- children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
43563
- })]
43564
- }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
43565
- })
43566
- }, index);
43567
- }), showRoundedTotal && yKeys && jsxRuntime.jsxs("tr", {
43568
- children: [jsxRuntime.jsx("td", {
43569
- colSpan: 2,
43570
- style: {
43571
- padding: '12px 0 0 0'
43572
- },
43573
- children: "Rounded Total"
43574
- }), jsxRuntime.jsx("td", {
43575
- style: {
43576
- fontWeight: 'bold',
43577
- padding: '12px 0 0 16px'
43578
- },
43579
- children: yKeys.reduce(function (total, key) {
43580
- return total + Math.round(tooltipData[key].value);
43581
- }, 0)
43582
- })]
43583
- })]
43584
- })
43585
- })]
43586
- })
43587
- }), document.body);
43588
- };
43589
-
43590
- 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)."; }
43591
- var LegendItem = function LegendItem(_ref) {
43592
- var yKey = _ref.yKey,
43593
- yKeyFormatted = _ref.yKeyFormatted,
43594
- color = _ref.color,
43595
- style = _ref.style,
43596
- onClick = _ref.onClick,
43597
- visible = _ref.visible,
43598
- conditionalFormattingRules = _ref.conditionalFormattingRules;
43599
- var relevantRules = React.useMemo(function () {
43600
- return conditionalFormattingRules.filter(function (rule) {
43601
- return rule.yKey === yKey;
43602
- });
43603
- }, [conditionalFormattingRules]);
43604
- return jsxRuntime.jsxs("button", {
43605
- type: "button",
43606
- style: {
43607
- all: 'unset',
43608
- display: 'flex',
43609
- flexWrap: 'nowrap',
43610
- alignItems: 'center',
43611
- outline: 'revert',
43612
- gap: '4px',
43613
- padding: '4px',
43614
- cursor: 'pointer',
43615
- marginRight: '10px'
43616
- },
43617
- onClick: onClick,
43618
- children: [style.type === 'line' && jsxRuntime.jsxs("span", {
43619
- className: /*#__PURE__*/css$1.css( {
43620
- name: "mefz6m-LegendItem",
43621
- styles: "height:10px;display:flex;label:LegendItem;",
43622
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
43623
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
43624
- }),
43625
- children: [jsxRuntime.jsx(LegendItemBox, {
43626
- color: color,
43627
- style: style,
43628
- yKey: yKey
43629
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
43630
- return jsxRuntime.jsx(LegendItemBox, {
43631
- color: rule.color,
43632
- style: style,
43633
- yKey: yKey
43634
- }, "rule-" + JSON.stringify(rule));
43635
- })]
43636
- }), style.type === 'bar' && jsxRuntime.jsxs("span", {
43637
- className: /*#__PURE__*/css$1.css( {
43638
- name: "pglbco-LegendItem",
43639
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
43640
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
43641
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
43642
- }),
43643
- children: [jsxRuntime.jsx(LegendItemSquare, {
43644
- color: color
43645
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
43646
- return jsxRuntime.jsx(LegendItemSquare, {
43647
- color: rule.color
43648
- }, "rule-" + JSON.stringify(rule));
43649
- })]
43650
- }), style.type === 'area' && jsxRuntime.jsxs("span", {
43651
- className: /*#__PURE__*/css$1.css( {
43652
- name: "pglbco-LegendItem",
43653
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
43654
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFFeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
43655
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
43656
- }),
43657
- children: [jsxRuntime.jsx(LegendItemTriangle, {
43658
- color: color
43659
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
43660
- return jsxRuntime.jsx(LegendItemTriangle, {
43661
- color: rule.color
43662
- }, "rule-" + JSON.stringify(rule));
43663
- })]
43664
- }), jsxRuntime.jsx("span", {
43665
- style: {
43666
- fontSize: '12px',
43667
- lineHeight: '16px',
43668
- display: 'block',
43669
- textDecoration: visible ? 'none' : 'line-through',
43670
- textWrap: 'nowrap'
43671
- },
43672
- children: yKeyFormatted ? yKeyFormatted : yKey
43673
- })]
43674
- }, "legend-" + yKey);
43675
- };
43676
-
43677
- 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)."; }
43678
- var Legend$1 = function Legend(_ref) {
43679
- var keys = _ref.keys,
43680
- setVisibleYKeys = _ref.setVisibleYKeys,
43681
- marginLeft = _ref.marginLeft,
43682
- items = _ref.items;
43683
- var handleOnClick = function handleOnClick(item, legendItem) {
43684
- setVisibleYKeys && setVisibleYKeys(function (prev) {
43685
- var newVisibleLegendItems = [];
43686
- if (prev.length === item.legendItems.length) {
43687
- newVisibleLegendItems = [legendItem.yKey];
43688
- } else {
43689
- if (prev.includes(legendItem.yKey)) {
43690
- newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
43691
- return prevLegendItemId !== legendItem.yKey;
43692
- });
43693
- } else {
43694
- newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
43695
- }
43696
- }
43697
- return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
43698
- return legendItem.yKey;
43699
- }) : newVisibleLegendItems;
43700
- });
43701
- };
43702
- return jsxRuntime.jsx("div", {
43703
- className: /*#__PURE__*/css$1.css( {
43704
- name: "qz6h7j-Legend",
43705
- styles: "height:40px;padding-top:8px;label:Legend;",
43706
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */",
43707
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
43708
- }),
43709
- children: jsxRuntime.jsx(Scrollbar, {
43710
- className: /*#__PURE__*/css$1.css({
43711
- display: 'flex',
43712
- flexDirection: 'row',
43713
- flexWrap: 'nowrap',
43714
- alignItems: 'center',
43715
- marginLeft: marginLeft ? marginLeft + "px" : undefined
43716
- }, ";label:Legend;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0RtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */"),
43717
- x: true,
43718
- children: items.map(function (item, index) {
43719
- return jsxRuntime.jsx(React.Fragment, {
43720
- children: item.legendItems.map(function (legendItem) {
43721
- return keys[legendItem.yKey] && react.createElement(LegendItem, _extends({}, legendItem, {
43722
- key: "legend-" + legendItem.yKey,
43723
- yKeyFormatted: keys[legendItem.yKey].keyFormatted,
43724
- onClick: function onClick() {
43725
- handleOnClick(item, legendItem);
43726
- },
43727
- visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
43728
- conditionalFormattingRules: item.conditionalFormattingRules
43729
- }));
43730
- })
43731
- }, index);
43732
- })
43733
- })
43734
- });
43735
- };
43736
-
43737
43465
  var ASSUMED_AVERAGE_CHAR_WIDTH = 7.1;
43738
43466
 
43739
43467
  function calculateWordWidth(word, avgCharWidth) {
@@ -43923,108 +43651,6 @@ var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, h
43923
43651
  };
43924
43652
  };
43925
43653
 
43926
- function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
43927
- return React.useMemo(function () {
43928
- if (xScaleKey && xScaleDataType && yKeys.length > 0) {
43929
- return flattenData({
43930
- data: data,
43931
- xScaleKey: xScaleKey,
43932
- xScaleDataType: xScaleDataType,
43933
- yKeys: yKeys
43934
- });
43935
- } else {
43936
- return [];
43937
- }
43938
- }, [data, xScaleKey, xScaleDataType, yKeys]);
43939
- }
43940
-
43941
- var GoalLine = function GoalLine(_ref) {
43942
- var goalLine = _ref.goalLine,
43943
- innerWidth = _ref.innerWidth,
43944
- y = _ref.y,
43945
- margin = _ref.margin;
43946
- var textRef = React.useRef(null);
43947
- var _useState = React.useState(0),
43948
- labelWidth = _useState[0],
43949
- setLabelWidth = _useState[1];
43950
- React.useEffect(function () {
43951
- if (textRef.current) {
43952
- var bbox = textRef.current.getBBox();
43953
- setLabelWidth(bbox.width + 16);
43954
- }
43955
- }, [goalLine.formattedValue]);
43956
- var height = 16;
43957
- var triangleWidth = 8;
43958
- return jsxRuntime.jsxs("g", {
43959
- style: {
43960
- position: 'relative'
43961
- },
43962
- children: [jsxRuntime.jsx(shape.Line, {
43963
- from: {
43964
- x: margin.left,
43965
- y: margin.top + y
43966
- },
43967
- to: {
43968
- x: margin.left + innerWidth,
43969
- y: margin.top + y
43970
- },
43971
- stroke: goalLine.color,
43972
- strokeDasharray: goalLine.strokeStyle == 'dashed' ? goalLine.strokeWidth * 2.5 + "," + goalLine.strokeWidth * 2.5 : undefined,
43973
- strokeWidth: goalLine.strokeWidth,
43974
- strokeLinecap: "round",
43975
- shapeRendering: "smooth"
43976
- }), jsxRuntime.jsxs("g", {
43977
- transform: "translate(" + (margin.left + innerWidth - labelWidth) + "," + (y + margin.top + height / 2) + ")",
43978
- children: [jsxRuntime.jsx("path", {
43979
- 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",
43980
- fill: goalLine.color
43981
- }), jsxRuntime.jsx("text", {
43982
- ref: textRef,
43983
- x: labelWidth / 2,
43984
- y: -1,
43985
- dy: -4,
43986
- textAnchor: "middle",
43987
- fontFamily: "Arial, sans-serif",
43988
- fontSize: 9,
43989
- fill: '#fff',
43990
- children: goalLine.formattedValue
43991
- })]
43992
- })]
43993
- });
43994
- };
43995
-
43996
- /*
43997
- const strokeWidth = 2;
43998
- const height = 16;
43999
- const triangleWidth = 8;
44000
-
44001
-
44002
-
44003
-
44004
-
44005
- */
44006
-
44007
- var shouldUpdate$1 = function shouldUpdate(previousProps, nextProps) {
44008
- return JSON.stringify(previousProps) == JSON.stringify(nextProps);
44009
- };
44010
- var GoalLines = function GoalLines(_ref) {
44011
- var goalLines = _ref.goalLines,
44012
- margin = _ref.margin,
44013
- y = _ref.y,
44014
- width = _ref.width;
44015
- return jsxRuntime.jsx(React.Fragment, {
44016
- children: goalLines.map(function (goalLine) {
44017
- return jsxRuntime.jsx(GoalLine, {
44018
- innerWidth: width,
44019
- y: y(goalLine.value),
44020
- goalLine: goalLine,
44021
- margin: margin
44022
- }, goalLine.value);
44023
- })
44024
- });
44025
- };
44026
- var GoalLines$1 = /*#__PURE__*/React.memo(GoalLines, shouldUpdate$1);
44027
-
44028
43654
  var AXIS_TITLE_STYLES = {
44029
43655
  textShadow: 'rgba(0, 0, 0, 0.01) 0px 0px 1px',
44030
43656
  opacity: '0.75',
@@ -44147,6 +43773,144 @@ var AxisLeft = function AxisLeft(_ref) {
44147
43773
  });
44148
43774
  };
44149
43775
 
43776
+ var _excluded$g = ["children", "width", "height", "showLegend", "onMouseMove", "onMouseLeave"];
43777
+ 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)."; }
43778
+ var ChartWrapper$1 = function ChartWrapper(_ref) {
43779
+ var children = _ref.children,
43780
+ width = _ref.width,
43781
+ height = _ref.height,
43782
+ showLegend = _ref.showLegend,
43783
+ onMouseMove = _ref.onMouseMove,
43784
+ onMouseLeave = _ref.onMouseLeave,
43785
+ svgProps = _objectWithoutPropertiesLoose(_ref, _excluded$g);
43786
+ return jsxRuntime.jsx("svg", _extends({
43787
+ width: width,
43788
+ height: height - (showLegend ? 40 : 0),
43789
+ onMouseMove: onMouseMove,
43790
+ onMouseLeave: onMouseLeave,
43791
+ className: /*#__PURE__*/css$1.css( {
43792
+ name: "fx4tbw-ChartWrapper",
43793
+ styles: "display:block;label:ChartWrapper;",
43794
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxudHlwZSBDaGFydFdyYXBwZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHNob3dMZWdlbmQ6IGJvb2xlYW47XG4gIG9uTW91c2VNb3ZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG4gIG9uTW91c2VMZWF2ZT86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyPFNWR1NWR0VsZW1lbnQ+O1xufSAmIFJlYWN0LlNWR1Byb3BzPFNWR1NWR0VsZW1lbnQ+O1xuXG5leHBvcnQgY29uc3QgQ2hhcnRXcmFwcGVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIHNob3dMZWdlbmQsXG4gIG9uTW91c2VNb3ZlLFxuICBvbk1vdXNlTGVhdmUsXG4gIC4uLnN2Z1Byb3BzXG59OiBDaGFydFdyYXBwZXJQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIGhlaWdodD17aGVpZ2h0IC0gKHNob3dMZWdlbmQgPyA0MCA6IDApfVxuICAgICAgb25Nb3VzZU1vdmU9e29uTW91c2VNb3ZlfVxuICAgICAgb25Nb3VzZUxlYXZlPXtvbk1vdXNlTGVhdmV9XG4gICAgICBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdibG9jaycgfSl9XG4gICAgICB7Li4uc3ZnUHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvc3ZnPlxuICApO1xufTtcbiJdfQ== */",
43795
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
43796
+ })
43797
+ }, svgProps, {
43798
+ children: children
43799
+ }));
43800
+ };
43801
+
43802
+ var DataLabel = function DataLabel(_ref) {
43803
+ var x = _ref.x,
43804
+ y = _ref.y,
43805
+ title = _ref.title,
43806
+ dx = _ref.dx,
43807
+ dy = _ref.dy,
43808
+ color = _ref.color,
43809
+ backgroundColor = _ref.backgroundColor;
43810
+ return jsxRuntime.jsx(annotation.Annotation, {
43811
+ x: x,
43812
+ y: y,
43813
+ dx: dx,
43814
+ dy: dy,
43815
+ children: jsxRuntime.jsx(annotation.Label, {
43816
+ title: title,
43817
+ showAnchorLine: false,
43818
+ showBackground: false,
43819
+ backgroundFill: backgroundColor,
43820
+ fontColor: color,
43821
+ titleFontSize: 10,
43822
+ verticalAnchor: "middle"
43823
+ })
43824
+ });
43825
+ };
43826
+
43827
+ var GoalLine = function GoalLine(_ref) {
43828
+ var goalLine = _ref.goalLine,
43829
+ innerWidth = _ref.innerWidth,
43830
+ y = _ref.y,
43831
+ margin = _ref.margin;
43832
+ var textRef = React.useRef(null);
43833
+ var _useState = React.useState(0),
43834
+ labelWidth = _useState[0],
43835
+ setLabelWidth = _useState[1];
43836
+ React.useEffect(function () {
43837
+ if (textRef.current) {
43838
+ var bbox = textRef.current.getBBox();
43839
+ setLabelWidth(bbox.width + 16);
43840
+ }
43841
+ }, [goalLine.formattedValue]);
43842
+ var height = 16;
43843
+ var triangleWidth = 8;
43844
+ return jsxRuntime.jsxs("g", {
43845
+ style: {
43846
+ position: 'relative'
43847
+ },
43848
+ children: [jsxRuntime.jsx(shape.Line, {
43849
+ from: {
43850
+ x: margin.left,
43851
+ y: margin.top + y
43852
+ },
43853
+ to: {
43854
+ x: margin.left + innerWidth,
43855
+ y: margin.top + y
43856
+ },
43857
+ stroke: goalLine.color,
43858
+ strokeDasharray: goalLine.strokeStyle == 'dashed' ? goalLine.strokeWidth * 2.5 + "," + goalLine.strokeWidth * 2.5 : undefined,
43859
+ strokeWidth: goalLine.strokeWidth,
43860
+ strokeLinecap: "round",
43861
+ shapeRendering: "smooth"
43862
+ }), jsxRuntime.jsxs("g", {
43863
+ transform: "translate(" + (margin.left + innerWidth - labelWidth) + "," + (y + margin.top + height / 2) + ")",
43864
+ children: [jsxRuntime.jsx("path", {
43865
+ 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",
43866
+ fill: goalLine.color
43867
+ }), jsxRuntime.jsx("text", {
43868
+ ref: textRef,
43869
+ x: labelWidth / 2,
43870
+ y: -1,
43871
+ dy: -4,
43872
+ textAnchor: "middle",
43873
+ fontFamily: "Arial, sans-serif",
43874
+ fontSize: 9,
43875
+ fill: '#fff',
43876
+ children: goalLine.formattedValue
43877
+ })]
43878
+ })]
43879
+ });
43880
+ };
43881
+
43882
+ /*
43883
+ const strokeWidth = 2;
43884
+ const height = 16;
43885
+ const triangleWidth = 8;
43886
+
43887
+
43888
+
43889
+
43890
+
43891
+ */
43892
+
43893
+ var shouldUpdate$1 = function shouldUpdate(previousProps, nextProps) {
43894
+ return JSON.stringify(previousProps) == JSON.stringify(nextProps);
43895
+ };
43896
+ var GoalLines = function GoalLines(_ref) {
43897
+ var goalLines = _ref.goalLines,
43898
+ margin = _ref.margin,
43899
+ y = _ref.y,
43900
+ width = _ref.width;
43901
+ return jsxRuntime.jsx(React.Fragment, {
43902
+ children: goalLines.map(function (goalLine) {
43903
+ return jsxRuntime.jsx(GoalLine, {
43904
+ innerWidth: width,
43905
+ y: y(goalLine.value),
43906
+ goalLine: goalLine,
43907
+ margin: margin
43908
+ }, goalLine.value);
43909
+ })
43910
+ });
43911
+ };
43912
+ var GoalLines$1 = /*#__PURE__*/React.memo(GoalLines, shouldUpdate$1);
43913
+
44150
43914
  var LINE_STYLES = {
44151
43915
  strokeWidth: 2,
44152
43916
  strokeOpacity: 0.8,
@@ -44176,30 +43940,424 @@ var GridRows = function GridRows(_ref) {
44176
43940
  });
44177
43941
  };
44178
43942
 
44179
- var _excluded$g = ["children", "width", "height", "showLegend", "onMouseMove", "onMouseLeave"];
44180
- 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)."; }
44181
- var ChartWrapper$1 = function ChartWrapper(_ref) {
44182
- var children = _ref.children,
44183
- width = _ref.width,
44184
- height = _ref.height,
44185
- showLegend = _ref.showLegend,
44186
- onMouseMove = _ref.onMouseMove,
44187
- onMouseLeave = _ref.onMouseLeave,
44188
- svgProps = _objectWithoutPropertiesLoose(_ref, _excluded$g);
44189
- return jsxRuntime.jsx("svg", _extends({
44190
- width: width,
44191
- height: height - (showLegend ? 40 : 0),
44192
- onMouseMove: onMouseMove,
44193
- onMouseLeave: onMouseLeave,
43943
+ function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
43944
+ return React.useMemo(function () {
43945
+ if (xScaleKey && xScaleDataType && yKeys.length > 0) {
43946
+ return flattenData({
43947
+ data: data,
43948
+ xScaleKey: xScaleKey,
43949
+ xScaleDataType: xScaleDataType,
43950
+ yKeys: yKeys
43951
+ });
43952
+ } else {
43953
+ return [];
43954
+ }
43955
+ }, [data, xScaleKey, xScaleDataType, yKeys]);
43956
+ }
43957
+
43958
+ var _excluded$h = ["tooltipOpen"];
43959
+ function useTooltip$1(initialTooltipState) {
43960
+ var _useState = React.useState(_extends({
43961
+ tooltipOpen: false
43962
+ }, initialTooltipState)),
43963
+ tooltipState = _useState[0],
43964
+ setTooltipState = _useState[1];
43965
+ var showTooltip = React.useCallback(function (showArgs) {
43966
+ return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
43967
+ var show = _objectWithoutPropertiesLoose(_ref, _excluded$h);
43968
+ return _extends({}, showArgs(show), {
43969
+ tooltipOpen: true
43970
+ });
43971
+ } : {
43972
+ tooltipOpen: true,
43973
+ tooltipLeft: showArgs.tooltipLeft,
43974
+ tooltipTop: showArgs.tooltipTop,
43975
+ lineLeft: showArgs.lineLeft,
43976
+ tooltipData: showArgs.tooltipData
43977
+ });
43978
+ }, [setTooltipState]);
43979
+ var hideTooltip = React.useCallback(function () {
43980
+ return setTooltipState({
43981
+ tooltipOpen: false,
43982
+ tooltipLeft: undefined,
43983
+ lineLeft: undefined,
43984
+ tooltipTop: undefined,
43985
+ tooltipData: undefined
43986
+ });
43987
+ }, [setTooltipState]);
43988
+ return {
43989
+ tooltipOpen: tooltipState.tooltipOpen,
43990
+ tooltipLeft: tooltipState.tooltipLeft,
43991
+ tooltipTop: tooltipState.tooltipTop,
43992
+ lineLeft: tooltipState.lineLeft,
43993
+ tooltipData: tooltipState.tooltipData,
43994
+ updateTooltip: setTooltipState,
43995
+ showTooltip: showTooltip,
43996
+ hideTooltip: hideTooltip
43997
+ };
43998
+ }
43999
+
44000
+ function useYScale(innerHeight, scale$1) {
44001
+ return React.useMemo(function () {
44002
+ return scale.scaleLinear({
44003
+ range: [innerHeight, 0],
44004
+ domain: scale$1.ordering === 'asc' ? [scale$1.min, scale$1.max] : [scale$1.max, scale$1.min],
44005
+ nice: true,
44006
+ round: true
44007
+ });
44008
+ }, [innerHeight, scale$1]);
44009
+ }
44010
+
44011
+ var LegendItemBox = function LegendItemBox(_ref) {
44012
+ var color = _ref.color,
44013
+ style = _ref.style;
44014
+ return jsxRuntime.jsx("svg", {
44015
+ width: 10,
44016
+ height: 10,
44017
+ style: {
44018
+ display: 'block'
44019
+ },
44020
+ children: style.type === 'line' ? style.strokeDasharray !== null ? jsxRuntime.jsx("line", {
44021
+ x1: "0",
44022
+ y1: "5",
44023
+ x2: "10",
44024
+ y2: "5",
44025
+ stroke: color,
44026
+ strokeWidth: style.strokeWidth,
44027
+ strokeDasharray: 2
44028
+ }) : jsxRuntime.jsx("line", {
44029
+ x1: "0",
44030
+ y1: "5",
44031
+ x2: "10",
44032
+ y2: "5",
44033
+ stroke: color,
44034
+ strokeWidth: style.strokeWidth
44035
+ }) : jsxRuntime.jsx("rect", {
44036
+ fill: color,
44037
+ width: 10,
44038
+ height: 10,
44039
+ rx: "2"
44040
+ })
44041
+ });
44042
+ };
44043
+ var LegendItemSquare = function LegendItemSquare(_ref2) {
44044
+ var color = _ref2.color;
44045
+ return jsxRuntime.jsx("svg", {
44046
+ width: 8,
44047
+ height: 8,
44048
+ style: {
44049
+ display: 'block'
44050
+ },
44051
+ children: jsxRuntime.jsx("rect", {
44052
+ fill: color,
44053
+ width: 8,
44054
+ height: 8,
44055
+ rx: "2"
44056
+ })
44057
+ });
44058
+ };
44059
+ var LegendItemTriangle = function LegendItemTriangle(_ref3) {
44060
+ var color = _ref3.color;
44061
+ return jsxRuntime.jsx("svg", {
44062
+ width: 8,
44063
+ height: 8,
44064
+ style: {
44065
+ display: 'block',
44066
+ borderRadius: 1
44067
+ },
44068
+ children: jsxRuntime.jsx("polygon", {
44069
+ points: "0,0 10,10 0,10",
44070
+ fill: color
44071
+ })
44072
+ });
44073
+ };
44074
+
44075
+ 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)."; }
44076
+ var LegendItem = function LegendItem(_ref) {
44077
+ var yKey = _ref.yKey,
44078
+ yKeyFormatted = _ref.yKeyFormatted,
44079
+ color = _ref.color,
44080
+ style = _ref.style,
44081
+ onClick = _ref.onClick,
44082
+ visible = _ref.visible,
44083
+ conditionalFormattingRules = _ref.conditionalFormattingRules;
44084
+ var relevantRules = React.useMemo(function () {
44085
+ return conditionalFormattingRules.filter(function (rule) {
44086
+ return rule.yKey === yKey;
44087
+ });
44088
+ }, [conditionalFormattingRules]);
44089
+ return jsxRuntime.jsxs("button", {
44090
+ type: "button",
44091
+ style: {
44092
+ all: 'unset',
44093
+ display: 'flex',
44094
+ flexWrap: 'nowrap',
44095
+ alignItems: 'center',
44096
+ outline: 'revert',
44097
+ gap: '4px',
44098
+ padding: '4px',
44099
+ cursor: 'pointer',
44100
+ marginRight: '10px'
44101
+ },
44102
+ onClick: onClick,
44103
+ children: [style.type === 'line' && jsxRuntime.jsxs("span", {
44104
+ className: /*#__PURE__*/css$1.css( {
44105
+ name: "mefz6m-LegendItem",
44106
+ styles: "height:10px;display:flex;label:LegendItem;",
44107
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
44108
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44109
+ }),
44110
+ children: [jsxRuntime.jsx(LegendItemBox, {
44111
+ color: color,
44112
+ style: style,
44113
+ yKey: yKey
44114
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44115
+ return jsxRuntime.jsx(LegendItemBox, {
44116
+ color: rule.color,
44117
+ style: style,
44118
+ yKey: yKey
44119
+ }, "rule-" + JSON.stringify(rule));
44120
+ })]
44121
+ }), style.type === 'bar' && jsxRuntime.jsxs("span", {
44122
+ className: /*#__PURE__*/css$1.css( {
44123
+ name: "pglbco-LegendItem",
44124
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
44125
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
44126
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44127
+ }),
44128
+ children: [jsxRuntime.jsx(LegendItemSquare, {
44129
+ color: color
44130
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44131
+ return jsxRuntime.jsx(LegendItemSquare, {
44132
+ color: rule.color
44133
+ }, "rule-" + JSON.stringify(rule));
44134
+ })]
44135
+ }), style.type === 'area' && jsxRuntime.jsxs("span", {
44136
+ className: /*#__PURE__*/css$1.css( {
44137
+ name: "pglbco-LegendItem",
44138
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
44139
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFFeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
44140
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44141
+ }),
44142
+ children: [jsxRuntime.jsx(LegendItemTriangle, {
44143
+ color: color
44144
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44145
+ return jsxRuntime.jsx(LegendItemTriangle, {
44146
+ color: rule.color
44147
+ }, "rule-" + JSON.stringify(rule));
44148
+ })]
44149
+ }), jsxRuntime.jsx("span", {
44150
+ style: {
44151
+ fontSize: '12px',
44152
+ lineHeight: '16px',
44153
+ display: 'block',
44154
+ textDecoration: visible ? 'none' : 'line-through',
44155
+ textWrap: 'nowrap'
44156
+ },
44157
+ children: yKeyFormatted ? yKeyFormatted : yKey
44158
+ })]
44159
+ }, "legend-" + yKey);
44160
+ };
44161
+
44162
+ 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)."; }
44163
+ var Legend$1 = function Legend(_ref) {
44164
+ var keys = _ref.keys,
44165
+ setVisibleYKeys = _ref.setVisibleYKeys,
44166
+ marginLeft = _ref.marginLeft,
44167
+ items = _ref.items;
44168
+ var handleOnClick = function handleOnClick(item, legendItem) {
44169
+ setVisibleYKeys && setVisibleYKeys(function (prev) {
44170
+ var newVisibleLegendItems = [];
44171
+ if (prev.length === item.legendItems.length) {
44172
+ newVisibleLegendItems = [legendItem.yKey];
44173
+ } else {
44174
+ if (prev.includes(legendItem.yKey)) {
44175
+ newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
44176
+ return prevLegendItemId !== legendItem.yKey;
44177
+ });
44178
+ } else {
44179
+ newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
44180
+ }
44181
+ }
44182
+ return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
44183
+ return legendItem.yKey;
44184
+ }) : newVisibleLegendItems;
44185
+ });
44186
+ };
44187
+ return jsxRuntime.jsx("div", {
44194
44188
  className: /*#__PURE__*/css$1.css( {
44195
- name: "fx4tbw-ChartWrapper",
44196
- styles: "display:block;label:ChartWrapper;",
44197
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxudHlwZSBDaGFydFdyYXBwZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHNob3dMZWdlbmQ6IGJvb2xlYW47XG4gIG9uTW91c2VNb3ZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG4gIG9uTW91c2VMZWF2ZT86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyPFNWR1NWR0VsZW1lbnQ+O1xufSAmIFJlYWN0LlNWR1Byb3BzPFNWR1NWR0VsZW1lbnQ+O1xuXG5leHBvcnQgY29uc3QgQ2hhcnRXcmFwcGVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIHNob3dMZWdlbmQsXG4gIG9uTW91c2VNb3ZlLFxuICBvbk1vdXNlTGVhdmUsXG4gIC4uLnN2Z1Byb3BzXG59OiBDaGFydFdyYXBwZXJQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIGhlaWdodD17aGVpZ2h0IC0gKHNob3dMZWdlbmQgPyA0MCA6IDApfVxuICAgICAgb25Nb3VzZU1vdmU9e29uTW91c2VNb3ZlfVxuICAgICAgb25Nb3VzZUxlYXZlPXtvbk1vdXNlTGVhdmV9XG4gICAgICBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdibG9jaycgfSl9XG4gICAgICB7Li4uc3ZnUHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvc3ZnPlxuICApO1xufTtcbiJdfQ== */",
44198
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
44189
+ name: "qz6h7j-Legend",
44190
+ styles: "height:40px;padding-top:8px;label:Legend;",
44191
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */",
44192
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
44193
+ }),
44194
+ children: jsxRuntime.jsx(Scrollbar, {
44195
+ className: /*#__PURE__*/css$1.css({
44196
+ display: 'flex',
44197
+ flexDirection: 'row',
44198
+ flexWrap: 'nowrap',
44199
+ alignItems: 'center',
44200
+ marginLeft: marginLeft ? marginLeft + "px" : undefined
44201
+ }, ";label:Legend;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0RtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */"),
44202
+ x: true,
44203
+ children: items.map(function (item, index) {
44204
+ return jsxRuntime.jsx(React.Fragment, {
44205
+ children: item.legendItems.map(function (legendItem) {
44206
+ return keys[legendItem.yKey] && react.createElement(LegendItem, _extends({}, legendItem, {
44207
+ key: "legend-" + legendItem.yKey,
44208
+ yKeyFormatted: keys[legendItem.yKey].keyFormatted,
44209
+ onClick: function onClick() {
44210
+ handleOnClick(item, legendItem);
44211
+ },
44212
+ visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
44213
+ conditionalFormattingRules: item.conditionalFormattingRules
44214
+ }));
44215
+ })
44216
+ }, index);
44217
+ })
44199
44218
  })
44200
- }, svgProps, {
44201
- children: children
44202
- }));
44219
+ });
44220
+ };
44221
+
44222
+ 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)."; }
44223
+ var MIN_TOOLTIP_WIDTH = 180;
44224
+ var TOOLTIP_OFFSET = 20;
44225
+ var SCROLLBAR_WIDTH = 40;
44226
+ var Tooltip$1 = function Tooltip(_ref) {
44227
+ var _tooltipData$xKey$for, _tooltipData$xKey;
44228
+ var keys = _ref.keys,
44229
+ showRoundedTotal = _ref.showRoundedTotal,
44230
+ tooltipData = _ref.tooltipData,
44231
+ tooltipLeft = _ref.tooltipLeft,
44232
+ tooltipTop = _ref.tooltipTop,
44233
+ xKey = _ref.xKey,
44234
+ yKeys = _ref.yKeys,
44235
+ theme = _ref.theme,
44236
+ items = _ref.items,
44237
+ _ref$shouldShowColorL = _ref.shouldShowColorLegend,
44238
+ shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
44239
+ var tooltipRef = React.useRef(null);
44240
+ var _useState = React.useState({
44241
+ left: tooltipLeft
44242
+ }),
44243
+ position = _useState[0],
44244
+ setPosition = _useState[1];
44245
+ React.useEffect(function () {
44246
+ var adjustTooltipPosition = function adjustTooltipPosition() {
44247
+ var tooltipElement = tooltipRef.current;
44248
+ if (tooltipElement) {
44249
+ var screenWidth = window.innerWidth;
44250
+ var rect = tooltipElement.getBoundingClientRect();
44251
+ var width = rect.width;
44252
+ if (width < MIN_TOOLTIP_WIDTH) {
44253
+ width = MIN_TOOLTIP_WIDTH;
44254
+ }
44255
+ var left = tooltipLeft + TOOLTIP_OFFSET;
44256
+ if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {
44257
+ left = tooltipLeft - width - TOOLTIP_OFFSET;
44258
+ }
44259
+ setPosition({
44260
+ left: left
44261
+ });
44262
+ }
44263
+ };
44264
+ adjustTooltipPosition();
44265
+ }, [tooltipLeft]);
44266
+ return /*#__PURE__*/ReactDOM.createPortal(jsxRuntime.jsx("div", {
44267
+ ref: tooltipRef,
44268
+ style: _extends({
44269
+ position: 'absolute',
44270
+ left: position.left,
44271
+ top: tooltipTop,
44272
+ zIndex: 2147483647 * 10
44273
+ }, theme),
44274
+ children: jsxRuntime.jsxs("div", {
44275
+ style: {
44276
+ wordBreak: 'break-all'
44277
+ },
44278
+ children: [jsxRuntime.jsx("div", {
44279
+ className: /*#__PURE__*/css$1.css({
44280
+ fontFamily: 'inherit',
44281
+ lineHeight: 'inherit',
44282
+ letterSpacing: 'inherit',
44283
+ fontWeight: 'bold',
44284
+ fontSize: '15px',
44285
+ width: '100%',
44286
+ minWidth: MIN_TOOLTIP_WIDTH
44287
+ }, ";label:Tooltip;", "/*# 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"]} */"),
44288
+ children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
44289
+ }), jsxRuntime.jsx("table", {
44290
+ cellPadding: 0,
44291
+ cellSpacing: 0,
44292
+ className: /*#__PURE__*/css$1.css( {
44293
+ name: "9a1sa-Tooltip",
44294
+ styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
44295
+ 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"]} */",
44296
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
44297
+ }),
44298
+ children: jsxRuntime.jsxs("tbody", {
44299
+ children: [items.map(function (item, index) {
44300
+ var _item$legendItems;
44301
+ return jsxRuntime.jsx(React.Fragment, {
44302
+ children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
44303
+ var _item$visibleYKeys, _item$conditionalForm;
44304
+ if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
44305
+ // yKey could not be found in tooltipData
44306
+ return null;
44307
+ }
44308
+ return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxRuntime.jsxs("tr", {
44309
+ children: [shouldShowColorLegend && jsxRuntime.jsx("td", {
44310
+ style: {
44311
+ verticalAlign: 'middle',
44312
+ padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
44313
+ width: 'auto'
44314
+ },
44315
+ children: jsxRuntime.jsx(LegendItemBox, {
44316
+ color: getColor({
44317
+ defaultColor: legendItem.color,
44318
+ value: tooltipData[legendItem.yKey].value,
44319
+ yKey: legendItem.yKey,
44320
+ conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
44321
+ }),
44322
+ style: legendItem.style,
44323
+ yKey: legendItem.yKey
44324
+ })
44325
+ }), jsxRuntime.jsx("td", {
44326
+ style: {
44327
+ padding: '8px 0 0 0'
44328
+ },
44329
+ children: keys[legendItem.yKey].keyFormatted
44330
+ }), jsxRuntime.jsx("td", {
44331
+ style: {
44332
+ fontWeight: 'bold',
44333
+ padding: '8px 0 0 16px'
44334
+ },
44335
+ children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
44336
+ })]
44337
+ }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
44338
+ })
44339
+ }, index);
44340
+ }), showRoundedTotal && yKeys && jsxRuntime.jsxs("tr", {
44341
+ children: [jsxRuntime.jsx("td", {
44342
+ colSpan: 2,
44343
+ style: {
44344
+ padding: '12px 0 0 0'
44345
+ },
44346
+ children: "Rounded Total"
44347
+ }), jsxRuntime.jsx("td", {
44348
+ style: {
44349
+ fontWeight: 'bold',
44350
+ padding: '12px 0 0 16px'
44351
+ },
44352
+ children: yKeys.reduce(function (total, key) {
44353
+ return total + Math.round(tooltipData[key].value);
44354
+ }, 0)
44355
+ })]
44356
+ })]
44357
+ })
44358
+ })]
44359
+ })
44360
+ }), document.body);
44203
44361
  };
44204
44362
 
44205
44363
  var CrosshairCircle = function CrosshairCircle(_ref) {
@@ -44264,84 +44422,6 @@ var Line = function Line(_ref) {
44264
44422
  });
44265
44423
  };
44266
44424
 
44267
- var _excluded$h = ["tooltipOpen"];
44268
- function useTooltip$1(initialTooltipState) {
44269
- var _useState = React.useState(_extends({
44270
- tooltipOpen: false
44271
- }, initialTooltipState)),
44272
- tooltipState = _useState[0],
44273
- setTooltipState = _useState[1];
44274
- var showTooltip = React.useCallback(function (showArgs) {
44275
- return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
44276
- var show = _objectWithoutPropertiesLoose(_ref, _excluded$h);
44277
- return _extends({}, showArgs(show), {
44278
- tooltipOpen: true
44279
- });
44280
- } : {
44281
- tooltipOpen: true,
44282
- tooltipLeft: showArgs.tooltipLeft,
44283
- tooltipTop: showArgs.tooltipTop,
44284
- lineLeft: showArgs.lineLeft,
44285
- tooltipData: showArgs.tooltipData
44286
- });
44287
- }, [setTooltipState]);
44288
- var hideTooltip = React.useCallback(function () {
44289
- return setTooltipState({
44290
- tooltipOpen: false,
44291
- tooltipLeft: undefined,
44292
- lineLeft: undefined,
44293
- tooltipTop: undefined,
44294
- tooltipData: undefined
44295
- });
44296
- }, [setTooltipState]);
44297
- return {
44298
- tooltipOpen: tooltipState.tooltipOpen,
44299
- tooltipLeft: tooltipState.tooltipLeft,
44300
- tooltipTop: tooltipState.tooltipTop,
44301
- lineLeft: tooltipState.lineLeft,
44302
- tooltipData: tooltipState.tooltipData,
44303
- updateTooltip: setTooltipState,
44304
- showTooltip: showTooltip,
44305
- hideTooltip: hideTooltip
44306
- };
44307
- }
44308
-
44309
- function useYScale(innerHeight, scale$1) {
44310
- return React.useMemo(function () {
44311
- return scale.scaleLinear({
44312
- range: [innerHeight, 0],
44313
- domain: scale$1.ordering === 'asc' ? [scale$1.min, scale$1.max] : [scale$1.max, scale$1.min],
44314
- nice: true,
44315
- round: true
44316
- });
44317
- }, [innerHeight, scale$1]);
44318
- }
44319
-
44320
- var DataLabel = function DataLabel(_ref) {
44321
- var x = _ref.x,
44322
- y = _ref.y,
44323
- title = _ref.title,
44324
- dx = _ref.dx,
44325
- dy = _ref.dy,
44326
- color = _ref.color,
44327
- backgroundColor = _ref.backgroundColor;
44328
- return jsxRuntime.jsx(annotation.Annotation, {
44329
- x: x,
44330
- y: y,
44331
- dx: dx,
44332
- dy: dy,
44333
- children: jsxRuntime.jsx(annotation.Label, {
44334
- title: title,
44335
- showAnchorLine: false,
44336
- showBackground: false,
44337
- backgroundFill: backgroundColor,
44338
- fontColor: color,
44339
- titleFontSize: 10,
44340
- verticalAnchor: "middle"
44341
- })
44342
- });
44343
- };
44344
-
44345
44425
  var LineChart$5 = function LineChart(_ref) {
44346
44426
  var _theme$axis;
44347
44427
  var chart = _ref.chart,
@@ -44431,6 +44511,26 @@ var LineChart$5 = function LineChart(_ref) {
44431
44511
  var handleMouseLeave = React.useCallback(function () {
44432
44512
  hideTooltip();
44433
44513
  }, [hideTooltip]);
44514
+ var labelDictionary = React.useMemo(function () {
44515
+ return getLabelDictionary(chart.data, chart.y.keys);
44516
+ }, [chart.data, chart.y.keys]);
44517
+ var memoizedLines = React.useMemo(function () {
44518
+ if (xScaleKey === null || xScale === null) return null;
44519
+ return jsxRuntime.jsx(Lines, {
44520
+ lines: chart.lines,
44521
+ conditionalFormattingRules: chart.conditionalFormattingRules,
44522
+ curve: curve,
44523
+ yKeys: chart.y.keys,
44524
+ visibleYKeys: visibleYKeys,
44525
+ data: dataFlattened,
44526
+ xScaleKey: xScaleKey,
44527
+ xScaleDataType: xScaleDataType,
44528
+ xScale: xScale,
44529
+ yScale: _yScale,
44530
+ showLabels: options.showLabels,
44531
+ labelDictionary: labelDictionary
44532
+ });
44533
+ }, [chart.lines, chart.conditionalFormattingRules, curve, chart.y.keys, visibleYKeys, dataFlattened, xScaleKey, xScaleDataType, xScale, _yScale, options.showLabels, labelDictionary]);
44434
44534
  if (width === 0 || height === 0 || xScale === null) return jsxRuntime.jsx(React__default.Fragment, {});
44435
44535
  var yTickValues = chart.y.ticks.map(function (tick) {
44436
44536
  return Number(tick.value);
@@ -44475,19 +44575,7 @@ var LineChart$5 = function LineChart(_ref) {
44475
44575
  ticks: yTickValues,
44476
44576
  stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
44477
44577
  }), jsxRuntime.jsx(group.Group, {
44478
- children: xScaleKey !== null && jsxRuntime.jsx(Lines, {
44479
- lines: chart.lines,
44480
- conditionalFormattingRules: chart.conditionalFormattingRules,
44481
- curve: curve,
44482
- yKeys: chart.y.keys,
44483
- visibleYKeys: visibleYKeys,
44484
- data: dataFlattened,
44485
- xScaleKey: xScaleKey,
44486
- xScaleDataType: xScaleDataType,
44487
- xScale: xScale,
44488
- yScale: _yScale,
44489
- showLabels: options.showLabels
44490
- })
44578
+ children: memoizedLines
44491
44579
  })]
44492
44580
  }), tooltipData && jsxRuntime.jsxs("g", {
44493
44581
  children: [jsxRuntime.jsx(Line, {
@@ -44536,7 +44624,7 @@ var LineChart$5 = function LineChart(_ref) {
44536
44624
  })]
44537
44625
  });
44538
44626
  };
44539
- function Lines(_ref2) {
44627
+ var Lines = /*#__PURE__*/React.memo(function Lines(_ref2) {
44540
44628
  var yKeys = _ref2.yKeys,
44541
44629
  visibleYKeys = _ref2.visibleYKeys,
44542
44630
  data = _ref2.data,
@@ -44547,7 +44635,8 @@ function Lines(_ref2) {
44547
44635
  lines = _ref2.lines,
44548
44636
  curve = _ref2.curve,
44549
44637
  conditionalFormattingRules = _ref2.conditionalFormattingRules,
44550
- showLabels = _ref2.showLabels;
44638
+ showLabels = _ref2.showLabels,
44639
+ labelDictionary = _ref2.labelDictionary;
44551
44640
  var _useMemo = React.useMemo(function () {
44552
44641
  var allBarValues = getAllChartValues(data, yKeys);
44553
44642
  var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(allBarValues),
@@ -44613,7 +44702,8 @@ function Lines(_ref2) {
44613
44702
  totalItems: data.length,
44614
44703
  minValue: minValue,
44615
44704
  maxValue: maxValue,
44616
- showLabels: showLabels
44705
+ showLabels: showLabels,
44706
+ labelDictionary: labelDictionary
44617
44707
  });
44618
44708
  })]
44619
44709
  });
@@ -44668,33 +44758,35 @@ function Lines(_ref2) {
44668
44758
  }, clipPathId);
44669
44759
  })]
44670
44760
  });
44671
- function LineLabel(_ref5) {
44672
- var chartData = _ref5.chartData,
44673
- yKey = _ref5.yKey,
44674
- xScaleKey = _ref5.xScaleKey,
44675
- xScale = _ref5.xScale,
44676
- yScale = _ref5.yScale,
44677
- totalItems = _ref5.totalItems,
44678
- minValue = _ref5.minValue,
44679
- maxValue = _ref5.maxValue,
44680
- showLabels = _ref5.showLabels;
44681
- var xValue = chartData[xScaleKey];
44682
- var yValue = chartData[yKey];
44683
- var xPadding = 18;
44684
- var yPadding = 8;
44685
- var xPosition = xScale(xValue);
44686
- var yPosition = yScale(yValue);
44687
- var showMinMax = showMinMaxLabel(Number(yValue), totalItems, minValue, maxValue);
44688
- if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
44689
- return jsxRuntime.jsx(DataLabel, {
44690
- x: xPosition - xPadding,
44691
- y: yPosition - yPadding,
44692
- dx: 2,
44693
- dy: 0,
44694
- title: yValue
44695
- });
44696
- }
44697
- }
44761
+ });
44762
+ var LineLabel = /*#__PURE__*/React.memo(function LineLabel(_ref5) {
44763
+ var chartData = _ref5.chartData,
44764
+ yKey = _ref5.yKey,
44765
+ xScaleKey = _ref5.xScaleKey,
44766
+ xScale = _ref5.xScale,
44767
+ yScale = _ref5.yScale,
44768
+ totalItems = _ref5.totalItems,
44769
+ minValue = _ref5.minValue,
44770
+ maxValue = _ref5.maxValue,
44771
+ showLabels = _ref5.showLabels,
44772
+ labelDictionary = _ref5.labelDictionary;
44773
+ var xValue = chartData[xScaleKey];
44774
+ var yValue = chartData[yKey];
44775
+ var xPadding = 18;
44776
+ var yPadding = 8;
44777
+ var xPosition = xScale(xValue);
44778
+ var yPosition = yScale(yValue);
44779
+ var showMinMax = showMinMaxLabel(Number(yValue), totalItems, minValue, maxValue);
44780
+ var displayValue = getFormattedValue(yValue, labelDictionary);
44781
+ if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
44782
+ return jsxRuntime.jsx(DataLabel, {
44783
+ x: xPosition - xPadding,
44784
+ y: yPosition - yPadding,
44785
+ dx: 2,
44786
+ dy: 0,
44787
+ title: displayValue
44788
+ });
44789
+ });
44698
44790
 
44699
44791
  var BAR_RADIUS = 2;
44700
44792
 
@@ -44740,7 +44832,8 @@ function BarGroup(_ref) {
44740
44832
  yLabelPosition = _ref.yLabelPosition,
44741
44833
  showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
44742
44834
  labelStyle = _ref.labelStyle,
44743
- showLabels = _ref.showLabels;
44835
+ showLabels = _ref.showLabels,
44836
+ formattedData = _ref.formattedData;
44744
44837
  var getGroupPosition = function getGroupPosition(d) {
44745
44838
  var xValue = d[xKey];
44746
44839
  if (xScaleDataType === 'string') return String(xValue);
@@ -44752,6 +44845,9 @@ function BarGroup(_ref) {
44752
44845
  }
44753
44846
  return String(xValue);
44754
44847
  };
44848
+ var formattedLabelsDict = React.useMemo(function () {
44849
+ return getLabelDictionary(formattedData, keys);
44850
+ }, [formattedData, keys]);
44755
44851
  var _useMemo = React.useMemo(function () {
44756
44852
  var allBarValues = getAllChartValues(data, keys);
44757
44853
  var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(allBarValues),
@@ -44800,7 +44896,9 @@ function BarGroup(_ref) {
44800
44896
  minValue: minValue,
44801
44897
  maxValue: maxValue,
44802
44898
  totalItems: totalItems,
44803
- showLabels: showLabels
44899
+ showLabels: showLabels,
44900
+ labelDictionary: formattedLabelsDict,
44901
+ yScale: yScale
44804
44902
  }, "bar-" + bar.index + "-" + bar.x);
44805
44903
  })
44806
44904
  }, "bar-group-" + barGroup.index + "-" + barGroup.x0);
@@ -44822,11 +44920,17 @@ var Bar = function Bar(_ref2) {
44822
44920
  minValue = _ref2.minValue,
44823
44921
  maxValue = _ref2.maxValue,
44824
44922
  totalItems = _ref2.totalItems,
44825
- showLabels = _ref2.showLabels;
44923
+ showLabels = _ref2.showLabels,
44924
+ labelDictionary = _ref2.labelDictionary,
44925
+ yScale = _ref2.yScale;
44826
44926
  var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
44827
- var labelX = bar.width < 10 ? bar.x - 14 : bar.x / 2;
44828
- var labelY = bar.y - 4;
44927
+ var xPadding = 14;
44928
+ var yPadding = 8;
44929
+ var labelX = bar.x - xPadding;
44930
+ var barTopY = yScale(bar.value);
44931
+ var labelY = barTopY - yPadding;
44829
44932
  var showMinMax = showMinMaxLabel(bar.value, totalItems, minValue, maxValue);
44933
+ var displayValue = getFormattedValue(bar.value, labelDictionary);
44830
44934
  return jsxRuntime.jsxs(React.Fragment, {
44831
44935
  children: [showBar && jsxRuntime.jsx(BarRect, {
44832
44936
  barRectKey: "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
@@ -44842,7 +44946,7 @@ var Bar = function Bar(_ref2) {
44842
44946
  }), showLabels && showMinMax && jsxRuntime.jsx(DataLabel, {
44843
44947
  x: labelX,
44844
44948
  y: labelY,
44845
- title: bar.value,
44949
+ title: displayValue,
44846
44950
  dx: 1,
44847
44951
  dy: 0
44848
44952
  }), jsxRuntime.jsx(BarLabel, {
@@ -44870,7 +44974,7 @@ var BarRect = function BarRect(_ref3) {
44870
44974
  var classes = enableHover ? /*#__PURE__*/css$1.css( {
44871
44975
  name: "1ltmijl-classes",
44872
44976
  styles: "cursor:pointer;label:classes;",
44873
- 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"]} */",
44977
+ 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"]} */",
44874
44978
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
44875
44979
  }) : '';
44876
44980
  var handleOnMouseEnter = function handleOnMouseEnter() {
@@ -45207,7 +45311,8 @@ var BarChart$5 = function BarChart(_ref) {
45207
45311
  yAxisLabels: yAxisLabels,
45208
45312
  yLabelPosition: ySubLabelPosition,
45209
45313
  labelStyle: themeCSS.labels,
45210
- showLabels: options.showLabels
45314
+ showLabels: options.showLabels,
45315
+ formattedData: chart.data
45211
45316
  }), options.stacked && xScaleKey !== null && jsxRuntime.jsx(BarStacked, {
45212
45317
  data: dataFlattened,
45213
45318
  keys: chart.y.keys,
@@ -45462,6 +45567,9 @@ var AreaChart$5 = function AreaChart(_ref) {
45462
45567
  };
45463
45568
  return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'natural'];
45464
45569
  }, [options.curve]);
45570
+ var labelDictionary = React.useMemo(function () {
45571
+ return getLabelDictionary(chart.data, chart.y.keys);
45572
+ }, [chart.data, chart.y.keys]);
45465
45573
  if (width === 0 || height === 0 || xScale === null) return jsxRuntime.jsx(React__default.Fragment, {});
45466
45574
  var yTickValues = chart.y.ticks.map(function (tick) {
45467
45575
  return Number(tick.value);
@@ -45602,7 +45710,8 @@ var AreaChart$5 = function AreaChart(_ref) {
45602
45710
  totalItems: dataFlattened.length,
45603
45711
  minValue: minValue,
45604
45712
  maxValue: maxValue,
45605
- showLabels: options.showLabels
45713
+ showLabels: options.showLabels,
45714
+ labelDictionary: labelDictionary
45606
45715
  });
45607
45716
  })]
45608
45717
  }, yKey + "-" + AREA_GRADIENT_ID_PREFIX);
@@ -45664,7 +45773,8 @@ function AreaLabel(_ref3) {
45664
45773
  totalItems = _ref3.totalItems,
45665
45774
  minValue = _ref3.minValue,
45666
45775
  maxValue = _ref3.maxValue,
45667
- showLabels = _ref3.showLabels;
45776
+ showLabels = _ref3.showLabels,
45777
+ labelDictionary = _ref3.labelDictionary;
45668
45778
  var xValue = chartData[xScaleKey];
45669
45779
  var yValue = chartData[yKey];
45670
45780
  var xPadding = 18;
@@ -45673,12 +45783,13 @@ function AreaLabel(_ref3) {
45673
45783
  var yPosition = yScale(yValue);
45674
45784
  var showMinMax = showMinMaxLabel(Number(yValue), totalItems, minValue, maxValue);
45675
45785
  if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
45786
+ var displayValue = getFormattedValue(yValue, labelDictionary);
45676
45787
  return jsxRuntime.jsx(DataLabel, {
45677
45788
  x: xPosition - xPadding,
45678
45789
  y: yPosition - yPadding,
45679
45790
  dx: 2,
45680
45791
  dy: 0,
45681
- title: yValue
45792
+ title: displayValue
45682
45793
  });
45683
45794
  }
45684
45795
  function Area(_ref4) {
@@ -48077,6 +48188,7 @@ var LineChartV2View = function LineChartV2View(props) {
48077
48188
  overflowX: 'hidden'
48078
48189
  },
48079
48190
  children: function children(parent) {
48191
+ var _props$attributes$lab;
48080
48192
  if (chartRepresentation.lines.length === 0) return jsxRuntime.jsx(LoadingComponent, {});
48081
48193
  return jsxRuntime.jsx(LineChart$5, {
48082
48194
  width: parent.width,
@@ -48087,7 +48199,7 @@ var LineChartV2View = function LineChartV2View(props) {
48087
48199
  removeStroke: false,
48088
48200
  showRoundedTotal: false,
48089
48201
  showLegend: props.attributes.legend,
48090
- showLabels: false,
48202
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
48091
48203
  axis: {
48092
48204
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
48093
48205
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -48447,7 +48559,7 @@ var AreaChartV2View = function AreaChartV2View(props) {
48447
48559
  overflowX: 'hidden'
48448
48560
  },
48449
48561
  children: function children(parent) {
48450
- var _props$attributes$vie2, _props$attributes$sta;
48562
+ var _props$attributes$vie2, _props$attributes$sta, _props$attributes$lab;
48451
48563
  if (chartRepresentation.areas.length === 0) return jsxRuntime.jsx(LoadingComponent, {});
48452
48564
  return jsxRuntime.jsx(AreaChart$5, {
48453
48565
  width: parent.width,
@@ -48460,7 +48572,7 @@ var AreaChartV2View = function AreaChartV2View(props) {
48460
48572
  removeStroke: false,
48461
48573
  showRoundedTotal: false,
48462
48574
  showLegend: props.attributes.legend,
48463
- showLabels: false,
48575
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
48464
48576
  axis: {
48465
48577
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
48466
48578
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -48842,6 +48954,7 @@ var BarChartV2View = function BarChartV2View(props) {
48842
48954
  overflowX: 'hidden'
48843
48955
  },
48844
48956
  children: function children(parent) {
48957
+ var _props$attributes$lab;
48845
48958
  if (chartRepresentation.bars.length === 0) return jsxRuntime.jsx(LoadingComponent, {});
48846
48959
  return jsxRuntime.jsx(BarChart$5, {
48847
48960
  width: parent.width,
@@ -48852,7 +48965,7 @@ var BarChartV2View = function BarChartV2View(props) {
48852
48965
  removeStroke: false,
48853
48966
  showRoundedTotal: false,
48854
48967
  showLegend: props.attributes.legend,
48855
- showLabels: false,
48968
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
48856
48969
  axis: {
48857
48970
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
48858
48971
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -49191,6 +49304,9 @@ var ComboChart$4 = function ComboChart(_ref) {
49191
49304
  tooltipData: buildComboTooltipData(barTooltip == null ? void 0 : barTooltip.tooltipData, lineTooltip == null ? void 0 : lineTooltip.tooltipData, xScaleKey)
49192
49305
  });
49193
49306
  }, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.bars.data, chart.lines.data]);
49307
+ var labelDictionary = React.useMemo(function () {
49308
+ return getLabelDictionary(chart.lines.data, chart.y.lineKeys);
49309
+ }, [chart.lines.data, chart.y.lineKeys]);
49194
49310
  var handleMouseLeave = React.useCallback(function () {
49195
49311
  hideTooltip();
49196
49312
  }, [hideTooltip]);
@@ -49245,7 +49361,8 @@ var ComboChart$4 = function ComboChart(_ref) {
49245
49361
  showDetailedSubGroupingLabels: false,
49246
49362
  yAxisLabels: [],
49247
49363
  yLabelPosition: 0,
49248
- showLabels: options.showLabels
49364
+ showLabels: options.showLabels,
49365
+ formattedData: chart.bars.data
49249
49366
  }), options.stacked && xScaleKey !== null && jsxRuntime.jsx(BarStacked, {
49250
49367
  data: barDataFlattened,
49251
49368
  keys: yBarKeys,
@@ -49270,7 +49387,8 @@ var ComboChart$4 = function ComboChart(_ref) {
49270
49387
  xScaleDataType: xScaleDataType,
49271
49388
  xScale: xScale,
49272
49389
  yScale: yScale,
49273
- showLabels: options.showLabels
49390
+ showLabels: options.showLabels,
49391
+ labelDictionary: labelDictionary
49274
49392
  })
49275
49393
  })]
49276
49394
  })]
@@ -49530,7 +49648,7 @@ var ComboChartViewV2 = function ComboChartViewV2(props) {
49530
49648
  overflowX: 'hidden'
49531
49649
  },
49532
49650
  children: function children(parent) {
49533
- var _props$attributes$sta2;
49651
+ var _props$attributes$sta2, _props$attributes$lab;
49534
49652
  var numberOfXTicksFittingIntoSpace = howManyTicksFitInWidth(comboChartRepresentation.x.ticks || [], parent.width);
49535
49653
  return jsxRuntime.jsx(ComboChart$4, {
49536
49654
  width: parent.width,
@@ -49548,7 +49666,7 @@ var ComboChartViewV2 = function ComboChartViewV2(props) {
49548
49666
  removeStroke: false,
49549
49667
  showRoundedTotal: false,
49550
49668
  showLegend: props.attributes.legend,
49551
- showLabels: false,
49669
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
49552
49670
  axis: {
49553
49671
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
49554
49672
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -52102,7 +52220,7 @@ var defaultProps$8 = {
52102
52220
  approxYAxisLabelCount: 'auto'
52103
52221
  };
52104
52222
  var FunnelChartView = function FunnelChartView(props) {
52105
- 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;
52223
+ 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;
52106
52224
  var _props = props,
52107
52225
  displayTitle = _props.displayTitle,
52108
52226
  displaySubject = _props.displaySubject;
@@ -52193,11 +52311,11 @@ var FunnelChartView = function FunnelChartView(props) {
52193
52311
  colors: themeToColorScale(theme == null ? void 0 : theme.colors, series$1.length),
52194
52312
  data: resultSet$1,
52195
52313
  legend: showLegend((_props13 = props) == null ? void 0 : _props13.legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
52196
- labels: false,
52314
+ labels: (_props$labels = (_props14 = props) == null ? void 0 : _props14.labels) != null ? _props$labels : false,
52197
52315
  removeStroke: false,
52198
52316
  forceXAxisAsTime: !!props.timeDimension,
52199
52317
  theme: theme == null ? void 0 : theme.charts,
52200
- axisTitles: (_props14 = props) == null ? void 0 : _props14.axisTitles,
52318
+ axisTitles: (_props15 = props) == null ? void 0 : _props15.axisTitles,
52201
52319
  formatSeriesName: formatSeriesName(props.result, textOverride, props.type, (_props$viewId2 = props.viewId) != null ? _props$viewId2 : '', labelFormat),
52202
52320
  conditionalFormattingPossibilities: function conditionalFormattingPossibilities(dataKey) {
52203
52321
  return getExplanationsOfConditionFormattingRulesThatApplyToSeries(props.dimension, props.conditionalFormattingRules,
@@ -54426,14 +54544,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
54426
54544
  if (xScaleDataType === 'string') return String(xValue);
54427
54545
  return '';
54428
54546
  }, [xScaleKey, xScaleDataType]);
54429
- var _useMemo = React.useMemo(function () {
54430
- var stepValues = formattedChartDataForBarChart.steps.map(function (step) {
54431
- return step.y;
54432
- });
54433
- return getMinMaxChartValueFromNumberArray(stepValues);
54434
- }, [formattedChartDataForBarChart.steps]),
54435
- minValue = _useMemo.minValue,
54436
- maxValue = _useMemo.maxValue;
54547
+ var labelDictionary = React.useMemo(function () {
54548
+ return getLabelDictionary(formattedChartDataForBarChart.data, formattedChartDataForBarChart.y.keys);
54549
+ }, [formattedChartDataForBarChart.data, formattedChartDataForBarChart.y.keys]);
54437
54550
  if (width === 0 || height === 0 || xScale == null) return null;
54438
54551
  return jsxRuntime.jsxs(jsxRuntime.Fragment, {
54439
54552
  children: [jsxRuntime.jsxs(ChartWrapper$1, {
@@ -54531,10 +54644,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
54531
54644
  barGroup: barGroup,
54532
54645
  yScale: yScale,
54533
54646
  formattedChartDataForBarChart: formattedChartDataForBarChart,
54534
- maxValue: maxValue,
54535
- minValue: minValue,
54536
54647
  showLabels: options.showLabels,
54537
- totalItems: formattedChartDataForBarChart.steps.length
54648
+ totalItems: formattedChartDataForBarChart.steps.length,
54649
+ labelDictionary: labelDictionary
54538
54650
  }, "bar-" + bar.index);
54539
54651
  })
54540
54652
  }, "bar-group-" + barGroup.index + "-" + barGroup.x0);
@@ -54569,20 +54681,24 @@ var Bar$2 = function Bar(_ref4) {
54569
54681
  var bar = _ref4.bar,
54570
54682
  barColor = _ref4.barColor,
54571
54683
  barGroup = _ref4.barGroup,
54572
- yScale = _ref4.yScale,
54573
54684
  formattedChartDataForBarChart = _ref4.formattedChartDataForBarChart,
54685
+ labelDictionary = _ref4.labelDictionary,
54574
54686
  showLabels = _ref4.showLabels,
54575
54687
  totalItems = _ref4.totalItems,
54576
- minValue = _ref4.minValue,
54577
- maxValue = _ref4.maxValue;
54688
+ yScale = _ref4.yScale;
54578
54689
  var step = formattedChartDataForBarChart.steps[barGroup.index];
54579
54690
  var y = yScale(Math.max(step.start, step.end));
54580
54691
  var barHeight = Math.abs(yScale(step.start) - yScale(step.end));
54581
- var xPadding = 14;
54582
- var labelX = bar.width < 10 ? bar.x - xPadding : bar.x + bar.width / 2;
54692
+ var xPadding = 10;
54693
+ var labelX = bar.x - xPadding;
54583
54694
  var labelY = getStepYPosition(step, barHeight, y);
54584
- var showMinMax = showMinMaxLabel(step.y, totalItems, minValue, maxValue);
54585
- var shouldShowLabel = showLabels && showMinMax && bar.value > 0;
54695
+ var isFirstOrLastStep = barGroup.index === 0 || barGroup.index === totalItems - 1;
54696
+ var keyValue = step.end - step.start;
54697
+ var displayValue = getFormattedValue(keyValue, labelDictionary);
54698
+ var unformattedValue = displayValue.length > 15;
54699
+ if (unformattedValue) displayValue = keyValue;
54700
+ var showMinMax = unformattedValue ? isFirstOrLastStep : totalItems < 20 || isFirstOrLastStep;
54701
+ var shouldShowLabel = showLabels && showMinMax;
54586
54702
  return jsxRuntime.jsxs(jsxRuntime.Fragment, {
54587
54703
  children: [jsxRuntime.jsx("rect", {
54588
54704
  x: bar.x,
@@ -54594,7 +54710,7 @@ var Bar$2 = function Bar(_ref4) {
54594
54710
  }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key), shouldShowLabel && jsxRuntime.jsx(DataLabel, {
54595
54711
  x: labelX,
54596
54712
  y: labelY,
54597
- title: step.y.toString(),
54713
+ title: displayValue,
54598
54714
  dx: 1,
54599
54715
  dy: 0
54600
54716
  })]
@@ -54623,7 +54739,7 @@ var WaterfallChartView = function WaterfallChartView(props) {
54623
54739
  displayTitle = props.displayTitle,
54624
54740
  headline = props.headline,
54625
54741
  id = props.id,
54626
- increaseColor = props.increaseColor,
54742
+ labels = props.labels,
54627
54743
  legend = props.legend,
54628
54744
  library = props.library,
54629
54745
  localFilters = props.localFilters,
@@ -54643,7 +54759,8 @@ var WaterfallChartView = function WaterfallChartView(props) {
54643
54759
  xAxisPrefix = props.xAxisPrefix,
54644
54760
  yAxisFormat = props.yAxisFormat,
54645
54761
  yAxisPostfix = props.yAxisPostfix,
54646
- yAxisPrefix = props.yAxisPrefix;
54762
+ yAxisPrefix = props.yAxisPrefix,
54763
+ increaseColor = props.increaseColor;
54647
54764
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
54648
54765
  textOverride = _useDashboardBehaviou.textOverride,
54649
54766
  valueAlias = _useDashboardBehaviou.valueAlias,
@@ -54731,7 +54848,7 @@ var WaterfallChartView = function WaterfallChartView(props) {
54731
54848
  height: parent.height,
54732
54849
  options: {
54733
54850
  showLegend: showLegend(legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
54734
- showLabels: false,
54851
+ showLabels: labels != null ? labels : false,
54735
54852
  showTooltipRoundedTotal: true,
54736
54853
  removeStroke: false,
54737
54854
  axis: {