@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.
@@ -29,9 +29,9 @@ import { dropTargetForExternal } from '@atlaskit/pragmatic-drag-and-drop/externa
29
29
  import { DropIndicator } from '@atlaskit/pragmatic-drag-and-drop-react-drop-indicator/box';
30
30
  import { ParentSize } from '@visx/responsive';
31
31
  import { Annotation, AnnotationConnector, AnnotationLabel, DataContext, buildChartTheme, lightTheme, XYChart, Grid as Grid$2, Axis, AreaSeries, AreaStack, BarGroup as BarGroup$1, BarSeries, BarStack, GlyphSeries, LineSeries, Tooltip as Tooltip$3 } from '@visx/xychart';
32
+ import { scaleOrdinal, scaleLinear, scaleQuantize, scalePoint, scaleTime, scaleBand } from '@visx/scale';
32
33
  import { LinearGradient } from '@visx/gradient';
33
34
  import { LegendItem as LegendItem$1, LegendLabel } from '@visx/legend';
34
- import { scaleOrdinal, scaleQuantize, scaleLinear, scalePoint, scaleTime, scaleBand } from '@visx/scale';
35
35
  import Ordinal from '@visx/legend/lib/legends/Ordinal';
36
36
  import { curveNatural, curveMonotoneX, curveMonotoneY, curveLinear, curveStep, curveStepBefore, curveStepAfter } from '@visx/curve';
37
37
  import { Line as Line$1, LinePath, BarGroup as BarGroup$2, BarStack as BarStack$1, AreaStack as AreaStack$1, AreaClosed, LineRadial } from '@visx/shape';
@@ -53,8 +53,8 @@ import { localPoint } from '@visx/event';
53
53
  import { bisector } from '@visx/vendor/d3-array';
54
54
  import { AxisBottom as AxisBottom$1, AxisLeft as AxisLeft$1 } from '@visx/axis';
55
55
  import { Text } from '@visx/text';
56
- import { GridRows as GridRows$1 } from '@visx/grid';
57
56
  import { Annotation as Annotation$1, Label as Label$1 } from '@visx/annotation';
57
+ import { GridRows as GridRows$1 } from '@visx/grid';
58
58
  import { GlyphDot } from '@visx/glyph';
59
59
  import { Point } from '@visx/point';
60
60
  import { interpolate as interpolate$1 } from '@visx/vendor/d3-interpolate';
@@ -4175,7 +4175,7 @@ var attributesSchema$2 = function attributesSchema(config) {
4175
4175
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
4176
4176
  stacked: Joi.valid(true, false, '100%'),
4177
4177
  legend: Joi.valid(true, false),
4178
- // labels: Joi.valid(true, false).optional(),
4178
+ labels: Joi.valid(true, false).optional(),
4179
4179
  type: Joi.valid('lineChartV2').required(),
4180
4180
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
4181
4181
  lineCurve: lineCurveSchema,
@@ -4285,8 +4285,13 @@ var CONSTANTS$2 = {
4285
4285
  title: 'Show Legend',
4286
4286
  description: '',
4287
4287
  namespace: 'legend'
4288
+ },
4289
+ labels: {
4290
+ type: 'labels',
4291
+ title: 'Show Labels',
4292
+ description: '',
4293
+ namespace: 'labels'
4288
4294
  }
4289
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
4290
4295
  }
4291
4296
  },
4292
4297
  axis_labels: {
@@ -4414,6 +4419,7 @@ var LineChart$1 = function LineChart(config) {
4414
4419
  conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
4415
4420
  drilldown: dumped.drilldown,
4416
4421
  legend: dumped.legend,
4422
+ labels: dumped.labels,
4417
4423
  goalLines: dumped.goalLines,
4418
4424
  headline: upcastHeadline(dumped.headline, dumped.timeDimension),
4419
4425
  parameters: upcastParameters(dumped.parameters),
@@ -4452,6 +4458,7 @@ var LineChart$1 = function LineChart(config) {
4452
4458
  conditionalFormattingRules: [],
4453
4459
  drilldown: [],
4454
4460
  legend: true,
4461
+ labels: false,
4455
4462
  goalLines: undefined,
4456
4463
  approxXAxisLabelCount: 'auto',
4457
4464
  approxYAxisLabelCount: 'auto',
@@ -4514,10 +4521,9 @@ var LineChart$1 = function LineChart(config) {
4514
4521
  }), namespace(CONSTANTS$2, 'sort'), namespace(CONSTANTS$2, 'filter'), namespace(CONSTANTS$2, 'custom_metrics'), namespace(CONSTANTS$2, 'limit')];
4515
4522
  },
4516
4523
  formatPanelConfig: function formatPanelConfig() {
4517
- var _CONSTANTS$format_pan;
4524
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
4518
4525
  return [headingConstant(CONSTANTS$2), _extends({}, namespace(CONSTANTS$2, 'chart_styles'), {
4519
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$2.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
4520
- ]
4526
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$2.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$2.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
4521
4527
  }), axisLabelsConstants(CONSTANTS$2), _extends({}, namespace(CONSTANTS$2, 'conditional_formatting'), {
4522
4528
  ruleType: 'lineColor'
4523
4529
  }), namespace(CONSTANTS$2, 'goal_line')
@@ -8643,8 +8649,13 @@ var CONSTANTS$h = {
8643
8649
  title: 'Show Legend',
8644
8650
  description: '',
8645
8651
  namespace: 'legend'
8652
+ },
8653
+ labels: {
8654
+ type: 'labels',
8655
+ title: 'Show Labels',
8656
+ description: '',
8657
+ namespace: 'labels'
8646
8658
  }
8647
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
8648
8659
  }
8649
8660
  },
8650
8661
  axis_labels: {
@@ -8742,7 +8753,7 @@ var FunnelChart = function FunnelChart(config) {
8742
8753
  return hydrated;
8743
8754
  },
8744
8755
  load: function load(dumped) {
8745
- var _dumped$tags;
8756
+ var _dumped$tags, _dumped$labels;
8746
8757
  return _extends({}, dumped, {
8747
8758
  measure: upcastMeasure(dumped.measure),
8748
8759
  order: upcastOrder(dumped.order, dumped.timeDimension),
@@ -8752,6 +8763,7 @@ var FunnelChart = function FunnelChart(config) {
8752
8763
  approxXAxisLabelCount: upcastAxisLabel(dumped.approxXAxisLabelCount),
8753
8764
  approxYAxisLabelCount: upcastAxisLabel(dumped.approxYAxisLabelCount),
8754
8765
  tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
8766
+ labels: (_dumped$labels = dumped.labels) != null ? _dumped$labels : false,
8755
8767
  parameters: upcastParameters(dumped.parameters)
8756
8768
  });
8757
8769
  },
@@ -8783,6 +8795,7 @@ var FunnelChart = function FunnelChart(config) {
8783
8795
  yAxisFormat: null,
8784
8796
  xAxisFormat: null,
8785
8797
  legend: true,
8798
+ labels: false,
8786
8799
  approxXAxisLabelCount: 'auto',
8787
8800
  approxYAxisLabelCount: 'auto',
8788
8801
  axisTitles: undefined,
@@ -8840,10 +8853,9 @@ var FunnelChart = function FunnelChart(config) {
8840
8853
  }), namespace(CONSTANTS$h, 'sort'), namespace(CONSTANTS$h, 'filter'), namespace(CONSTANTS$h, 'custom_metrics'), namespace(CONSTANTS$h, 'limit')];
8841
8854
  },
8842
8855
  formatPanelConfig: function formatPanelConfig() {
8843
- var _CONSTANTS$format_pan;
8856
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
8844
8857
  return [headingConstant(CONSTANTS$h), _extends({}, namespace(CONSTANTS$h, 'chart_styles'), {
8845
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$h.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
8846
- ]
8858
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$h.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$h.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
8847
8859
  }), axisLabelsConstants(CONSTANTS$h), _extends({}, namespace(CONSTANTS$h, 'conditional_formatting'), {
8848
8860
  ruleType: 'backgroundColor'
8849
8861
  }), namespace(CONSTANTS$h, 'headline')];
@@ -9941,7 +9953,7 @@ var attributesSchema$i = function attributesSchema(config) {
9941
9953
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
9942
9954
  stacked: Joi.valid(true, false),
9943
9955
  legend: Joi.valid(true, false),
9944
- // labels: Joi.valid(true, false).optional(),
9956
+ labels: Joi.valid(true, false).optional(),
9945
9957
  type: Joi.valid('barChartV2').required(),
9946
9958
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
9947
9959
  conditionalFormattingRules: conditionalFormattingRulesSchema(config.queryEngineConfig),
@@ -10050,370 +10062,381 @@ var CONSTANTS$k = {
10050
10062
  title: 'Show Legend',
10051
10063
  description: '',
10052
10064
  namespace: 'legend'
10053
- }
10054
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
10055
- }
10056
- },
10057
- axis_labels: {
10058
- type: 'axisLabels',
10059
- title: 'Axis Preferences',
10060
- description: '',
10061
- subSectionDefinition: {
10062
- x: {
10063
- title: 'X Axis',
10064
- description: '',
10065
- namespace: 'x'
10066
10065
  },
10067
- 'x.prefix': {
10068
- title: 'Prefix',
10069
- description: '',
10070
- namespace: 'x.prefix'
10071
- },
10072
- 'x.postfix': {
10073
- title: 'Postfix',
10074
- description: '',
10075
- namespace: 'x.postfix'
10076
- },
10077
- 'x.format': {
10078
- title: 'Format',
10079
- description: '',
10080
- namespace: 'x.format'
10081
- },
10082
- 'x.count': {
10083
- title: 'Label count',
10084
- description: '',
10085
- namespace: 'x.count'
10086
- },
10087
- 'x.axis_title': {
10088
- title: 'Title',
10089
- description: '',
10090
- namespace: 'x.axis_title'
10091
- },
10092
- y: {
10093
- title: 'Y Axis',
10094
- description: '',
10095
- namespace: 'y'
10096
- },
10097
- 'y.prefix': {
10098
- title: 'Prefix',
10099
- description: '',
10100
- namespace: 'y.prefix'
10101
- },
10102
- 'y.postfix': {
10103
- title: 'Postfix',
10104
- description: '',
10105
- namespace: 'y.postfix'
10106
- },
10107
- 'y.format': {
10108
- title: 'Format',
10109
- description: '',
10110
- namespace: 'y.format'
10111
- },
10112
- 'y.count': {
10113
- title: 'Label count',
10114
- description: '',
10115
- namespace: 'y.count'
10116
- },
10117
- 'y.axis_title': {
10118
- title: 'Title',
10119
- description: '',
10120
- namespace: 'y.axis_title'
10121
- }
10122
- }
10123
- },
10124
- conditional_formatting: {
10125
- type: 'conditionalFormatting',
10126
- title: 'Conditional Formatting',
10127
- description: ''
10128
- },
10129
- headline: {
10130
- type: 'headline',
10131
- title: 'Headline',
10132
- description: ''
10133
- },
10134
- goal_line: {
10135
- type: 'goalLine',
10136
- title: 'Goal Lines',
10137
- description: ''
10138
- }
10139
- }
10140
- };
10141
-
10142
- var BarChart$1 = function BarChart(config) {
10143
- return {
10144
- title: 'Bar chart',
10145
- description: 'Ideal for illustrating changes and trends over time with bar graphs.',
10146
- servicesClass: 'BarChart',
10147
- namespace: 'bar_chart',
10148
- dump: function dump(hydrated) {
10149
- return hydrated;
10150
- },
10151
- load: function load(dumped) {
10152
- var _dumped$tags;
10153
- return {
10154
- type: dumped.type,
10155
- measure: upcastMeasure(dumped.measure),
10156
- order: upcastOrder(dumped.order, dumped.timeDimension),
10157
- dimension: upcastStringDimensionsToObject(dumped.dimension),
10158
- // TODO: upcast dumped.timeDimension -> dimension
10159
- displayTitle: dumped.displayTitle,
10160
- displaySubject: dumped.displaySubject,
10161
- protectedByOrganisation: dumped.protectedByOrganisation,
10162
- viewId: upcastViewId(dumped.viewId),
10163
- filter: upcastFilter(dumped.filter),
10164
- dataSetId: dumped.dataSetId,
10165
- limit: dumped.limit,
10166
- timeDimension: null,
10167
- xAxisPostfix: dumped.xAxisPostfix,
10168
- xAxisPrefix: dumped.xAxisPrefix,
10169
- yAxisPostfix: dumped.yAxisPostfix,
10170
- yAxisPrefix: dumped.yAxisPrefix,
10171
- yAxisFormat: dumped.yAxisFormat,
10172
- xAxisFormat: dumped.xAxisFormat,
10173
- conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
10174
- drilldown: dumped.drilldown,
10175
- legend: dumped.legend,
10176
- goalLines: dumped.goalLines,
10177
- headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10178
- parameters: upcastParameters(dumped.parameters),
10179
- approxXAxisLabelCount: upcastAxisLabel(dumped.approxXAxisLabelCount),
10180
- approxYAxisLabelCount: upcastAxisLabel(dumped.approxYAxisLabelCount),
10181
- axisTitles: dumped.axisTitles,
10182
- tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
10183
- stacked: dumped.stacked,
10184
- drilldownOptions: dumped.drilldownOptions
10185
- };
10186
- },
10187
- setAttributes: setAttributes$g(config),
10188
- validate: function validate(attrs, dataSets) {
10189
- return validateView(attrs, dataSets, config.queryEngineConfig);
10190
- },
10191
- init: function init(dataSetId, overrides) {
10192
- return _extends({
10193
- type: 'barChartV2',
10194
- measure: [],
10195
- dimension: [],
10196
- timeDimension: null,
10197
- displayTitle: '',
10198
- displaySubject: '',
10199
- protectedByOrganisation: undefined,
10200
- viewId: upcastViewId(overrides == null ? void 0 : overrides.viewId),
10201
- filter: [],
10202
- order: [],
10203
- dataSetId: dataSetId,
10204
- limit: 5000,
10205
- xAxisPostfix: '',
10206
- xAxisPrefix: '',
10207
- yAxisPostfix: '',
10208
- yAxisPrefix: '',
10209
- yAxisFormat: null,
10210
- xAxisFormat: null,
10211
- conditionalFormattingRules: [],
10212
- drilldown: [],
10213
- legend: true,
10214
- goalLines: undefined,
10215
- approxXAxisLabelCount: 'auto',
10216
- approxYAxisLabelCount: 'auto',
10217
- parameters: {},
10218
- axisTitles: undefined,
10219
- headline: undefined,
10220
- tags: [],
10221
- drilldownOptions: undefined
10222
- }, overrides);
10223
- },
10224
- createFeedback: createFeedback,
10225
- schema: attributesSchema$i(config),
10226
- removeField: function removeField(attrs, fieldId) {
10227
- return removeField$1(attrs, fieldId, config.queryEngineConfig);
10228
- },
10229
- isRunnable: function isRunnable(hydrated) {
10230
- return hydrated.measure.length > 0 && hydrated.dimension.length > 0;
10231
- },
10232
- autoGenerate: function autoGenerate(dataSet) {
10233
- var _DataSet$buildQueryAt = buildQueryAttributes(dataSet, config.queryEngineConfig, 'barChart'),
10234
- measure = _DataSet$buildQueryAt.measure,
10235
- dimension = _DataSet$buildQueryAt.dimension;
10236
- return this.init(dataSet.id, {
10237
- measure: [measure[0]],
10238
- dimension: dimension
10239
- });
10240
- },
10241
- dataPanelConfig: function dataPanelConfig() {
10242
- return [namespace(CONSTANTS$k, 'data_set'), namespace(CONSTANTS$k, 'views'), _extends({}, namespace(CONSTANTS$k, 'field_y_axis'), {
10243
- fieldFilterOptions: {
10244
- forComponent: 'barChart'
10245
- },
10246
- preSetPartialAttributes: function preSetPartialAttributes(values) {
10247
- return {
10248
- measure: values
10249
- };
10250
- },
10251
- getValues: function getValues(attrs) {
10252
- return attrs.measure;
10253
- },
10254
- testId: 'metric-input'
10255
- }), _extends({}, namespace(CONSTANTS$k, 'field_x_axis'), {
10256
- fieldFilterOptions: {
10257
- forComponent: 'barChart',
10258
- onlyDimensions: true
10259
- },
10260
- preventDuplicates: false,
10261
- // return all values in the dimension array instead of seperating out timeDimension
10262
- preSetPartialAttributes: function preSetPartialAttributes(values) {
10263
- return {
10264
- dimension: [].concat(values)
10265
- };
10266
- },
10267
- // does this need to be updated too?
10268
- getValues: function getValues(attrs) {
10269
- return [].concat(attrs.dimension);
10270
- },
10271
- maxAllowed: 2,
10272
- testId: 'add-dimension'
10273
- }), namespace(CONSTANTS$k, 'sort'), namespace(CONSTANTS$k, 'filter'), _extends({}, namespace(CONSTANTS$k, 'drilldown'), {
10274
- options: {
10275
- property: 'drilldownOptions'
10276
- }
10277
- }), namespace(CONSTANTS$k, 'custom_metrics'), namespace(CONSTANTS$k, 'limit')];
10278
- },
10279
- formatPanelConfig: function formatPanelConfig() {
10280
- var _CONSTANTS$format_pan;
10281
- return [headingConstant(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'chart_styles'), {
10282
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$k.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
10283
- ]
10284
- }), axisLabelsConstants(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'conditional_formatting'), {
10285
- ruleType: 'lineColor'
10286
- }), namespace(CONSTANTS$k, 'goal_line')];
10287
- },
10288
- supportedCustomFields: {
10289
- percentages: true,
10290
- dateCalculations: true,
10291
- simpleMaths: true,
10292
- rules: true,
10293
- aggregateMaths: true,
10294
- roundedNumbers: true,
10295
- conditional: true,
10296
- customBuild: [AcceptedTypes.Maths, AcceptedTypes.IfStatement, AcceptedTypes.Aggregates]
10297
- },
10298
- supportedFeatures: {
10299
- parameters: true,
10300
- colorGradient: false
10301
- },
10302
- setDataAttributesFromPreAggregatedDataSet: function setDataAttributesFromPreAggregatedDataSet$1(attributes, dataSet) {
10303
- return setDataAttributesFromPreAggregatedDataSet(attributes, dataSet, this.setAttributes);
10304
- }
10305
- };
10306
- };
10307
-
10308
- var attributesSchema$j = function attributesSchema(config) {
10309
- return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
10310
- legend: Joi.valid(true, false),
10311
- // labels: Joi.valid(true, false).optional(),
10312
- type: Joi.valid('waterfallChart').required(),
10313
- parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10314
- axisTitles: axisTitleSchema(),
10315
- headline: headlineSchema(),
10316
- tags: tagsSchema(),
10317
- increaseColor: Joi.string().required(),
10318
- decreaseColor: Joi.string().required(),
10319
- comparison: Joi.any()
10320
- }));
10321
- };
10322
-
10323
- var setAttributes$h = (function (config) {
10324
- return function (waterfallChart, partial) {
10325
- var newAttributes = setAttributes(waterfallChart, partial, attributesSchema$j(config));
10326
- newAttributes = removeUnusedOrderFieldsFromTimeSeriesComponent(newAttributes);
10327
- return newAttributes;
10328
- };
10329
- });
10330
-
10331
- var CONSTANTS$l = {
10332
- title: 'Waterfall chart',
10333
- description: "Shows a running total as values are added or subtracted. It's useful for understanding how an initial value is affected by a series of positive and negative values.",
10334
- namespace: 'waterfall_chart',
10335
- data_panel: {
10336
- data_set: {
10337
- type: 'dataSet',
10338
- title: 'Data set',
10339
- description: 'What data do you want to use in this waterfall chart?'
10340
- },
10341
- views: {
10342
- type: 'views',
10343
- title: 'View',
10344
- description: ''
10345
- },
10346
- field_y_axis: {
10347
- type: 'fieldCollector',
10348
- title: 'Metric - Y Axis',
10349
- description: 'What do you want each bar to measure?',
10350
- callToAction: 'Add metric'
10351
- },
10352
- field_x_axis: {
10353
- type: 'fieldCollector',
10354
- title: 'Grouping - X Axis',
10355
- description: 'What do you want each bar to represent? An example would be a a date grouping to show each month as a bar',
10356
- callToAction: 'Add grouping'
10357
- },
10358
- dateComparison: {
10359
- type: 'dateComparison',
10360
- title: 'Comparison',
10361
- description: 'Compare the waterfall chart to a previous period.',
10362
- callToAction: 'Add comparison'
10363
- },
10364
- sort: {
10365
- type: 'sort',
10366
- title: 'Sort',
10367
- description: 'Select the order of categories or time on the x Axis.'
10368
- },
10369
- filter: {
10370
- type: 'filter',
10371
- title: 'Filters',
10372
- description: 'Only include the information you want to use in this waterfall chart.'
10373
- },
10374
- custom_metrics: {
10375
- type: 'customMetrics',
10376
- title: 'Custom metrics',
10377
- description: 'Build your own metrics, such as a percentage.'
10378
- },
10379
- limit: {
10380
- type: 'limit',
10381
- title: 'Limit',
10382
- description: 'Set the maximum number of records to show on this waterfall chart.'
10383
- }
10384
- },
10385
- format_panel: {
10386
- heading: {
10387
- type: 'heading',
10388
- title: 'Heading',
10389
- description: '',
10390
- subSectionDefinition: {
10391
- title: {
10392
- type: 'title',
10393
- title: 'Title',
10394
- description: '',
10395
- namespace: 'title'
10396
- },
10397
- subject: {
10398
- title: 'Subject',
10399
- type: 'subject',
10400
- description: '',
10401
- namespace: 'subject'
10402
- }
10403
- }
10404
- },
10405
- chart_styles: {
10406
- type: 'chartStyles',
10407
- title: 'Chart Settings',
10408
- description: '',
10409
- subSectionDefinition: {
10410
- legend: {
10411
- type: 'legend',
10412
- title: 'Show Legend',
10066
+ labels: {
10067
+ type: 'labels',
10068
+ title: 'Show Labels',
10413
10069
  description: '',
10414
- namespace: 'legend'
10070
+ namespace: 'labels'
10071
+ }
10072
+ }
10073
+ },
10074
+ axis_labels: {
10075
+ type: 'axisLabels',
10076
+ title: 'Axis Preferences',
10077
+ description: '',
10078
+ subSectionDefinition: {
10079
+ x: {
10080
+ title: 'X Axis',
10081
+ description: '',
10082
+ namespace: 'x'
10083
+ },
10084
+ 'x.prefix': {
10085
+ title: 'Prefix',
10086
+ description: '',
10087
+ namespace: 'x.prefix'
10088
+ },
10089
+ 'x.postfix': {
10090
+ title: 'Postfix',
10091
+ description: '',
10092
+ namespace: 'x.postfix'
10093
+ },
10094
+ 'x.format': {
10095
+ title: 'Format',
10096
+ description: '',
10097
+ namespace: 'x.format'
10098
+ },
10099
+ 'x.count': {
10100
+ title: 'Label count',
10101
+ description: '',
10102
+ namespace: 'x.count'
10103
+ },
10104
+ 'x.axis_title': {
10105
+ title: 'Title',
10106
+ description: '',
10107
+ namespace: 'x.axis_title'
10108
+ },
10109
+ y: {
10110
+ title: 'Y Axis',
10111
+ description: '',
10112
+ namespace: 'y'
10113
+ },
10114
+ 'y.prefix': {
10115
+ title: 'Prefix',
10116
+ description: '',
10117
+ namespace: 'y.prefix'
10118
+ },
10119
+ 'y.postfix': {
10120
+ title: 'Postfix',
10121
+ description: '',
10122
+ namespace: 'y.postfix'
10123
+ },
10124
+ 'y.format': {
10125
+ title: 'Format',
10126
+ description: '',
10127
+ namespace: 'y.format'
10128
+ },
10129
+ 'y.count': {
10130
+ title: 'Label count',
10131
+ description: '',
10132
+ namespace: 'y.count'
10133
+ },
10134
+ 'y.axis_title': {
10135
+ title: 'Title',
10136
+ description: '',
10137
+ namespace: 'y.axis_title'
10138
+ }
10139
+ }
10140
+ },
10141
+ conditional_formatting: {
10142
+ type: 'conditionalFormatting',
10143
+ title: 'Conditional Formatting',
10144
+ description: ''
10145
+ },
10146
+ headline: {
10147
+ type: 'headline',
10148
+ title: 'Headline',
10149
+ description: ''
10150
+ },
10151
+ goal_line: {
10152
+ type: 'goalLine',
10153
+ title: 'Goal Lines',
10154
+ description: ''
10155
+ }
10156
+ }
10157
+ };
10158
+
10159
+ var BarChart$1 = function BarChart(config) {
10160
+ return {
10161
+ title: 'Bar chart',
10162
+ description: 'Ideal for illustrating changes and trends over time with bar graphs.',
10163
+ servicesClass: 'BarChart',
10164
+ namespace: 'bar_chart',
10165
+ dump: function dump(hydrated) {
10166
+ return hydrated;
10167
+ },
10168
+ load: function load(dumped) {
10169
+ var _dumped$tags;
10170
+ return {
10171
+ type: dumped.type,
10172
+ measure: upcastMeasure(dumped.measure),
10173
+ order: upcastOrder(dumped.order, dumped.timeDimension),
10174
+ dimension: upcastStringDimensionsToObject(dumped.dimension),
10175
+ // TODO: upcast dumped.timeDimension -> dimension
10176
+ displayTitle: dumped.displayTitle,
10177
+ displaySubject: dumped.displaySubject,
10178
+ protectedByOrganisation: dumped.protectedByOrganisation,
10179
+ viewId: upcastViewId(dumped.viewId),
10180
+ filter: upcastFilter(dumped.filter),
10181
+ dataSetId: dumped.dataSetId,
10182
+ limit: dumped.limit,
10183
+ timeDimension: null,
10184
+ xAxisPostfix: dumped.xAxisPostfix,
10185
+ xAxisPrefix: dumped.xAxisPrefix,
10186
+ yAxisPostfix: dumped.yAxisPostfix,
10187
+ yAxisPrefix: dumped.yAxisPrefix,
10188
+ yAxisFormat: dumped.yAxisFormat,
10189
+ xAxisFormat: dumped.xAxisFormat,
10190
+ conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
10191
+ drilldown: dumped.drilldown,
10192
+ legend: dumped.legend,
10193
+ labels: dumped.labels,
10194
+ goalLines: dumped.goalLines,
10195
+ headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10196
+ parameters: upcastParameters(dumped.parameters),
10197
+ approxXAxisLabelCount: upcastAxisLabel(dumped.approxXAxisLabelCount),
10198
+ approxYAxisLabelCount: upcastAxisLabel(dumped.approxYAxisLabelCount),
10199
+ axisTitles: dumped.axisTitles,
10200
+ tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
10201
+ stacked: dumped.stacked,
10202
+ drilldownOptions: dumped.drilldownOptions
10203
+ };
10204
+ },
10205
+ setAttributes: setAttributes$g(config),
10206
+ validate: function validate(attrs, dataSets) {
10207
+ return validateView(attrs, dataSets, config.queryEngineConfig);
10208
+ },
10209
+ init: function init(dataSetId, overrides) {
10210
+ return _extends({
10211
+ type: 'barChartV2',
10212
+ measure: [],
10213
+ dimension: [],
10214
+ timeDimension: null,
10215
+ displayTitle: '',
10216
+ displaySubject: '',
10217
+ protectedByOrganisation: undefined,
10218
+ viewId: upcastViewId(overrides == null ? void 0 : overrides.viewId),
10219
+ filter: [],
10220
+ order: [],
10221
+ dataSetId: dataSetId,
10222
+ limit: 5000,
10223
+ xAxisPostfix: '',
10224
+ xAxisPrefix: '',
10225
+ yAxisPostfix: '',
10226
+ yAxisPrefix: '',
10227
+ yAxisFormat: null,
10228
+ xAxisFormat: null,
10229
+ conditionalFormattingRules: [],
10230
+ drilldown: [],
10231
+ legend: true,
10232
+ labels: false,
10233
+ goalLines: undefined,
10234
+ approxXAxisLabelCount: 'auto',
10235
+ approxYAxisLabelCount: 'auto',
10236
+ parameters: {},
10237
+ axisTitles: undefined,
10238
+ headline: undefined,
10239
+ tags: [],
10240
+ drilldownOptions: undefined
10241
+ }, overrides);
10242
+ },
10243
+ createFeedback: createFeedback,
10244
+ schema: attributesSchema$i(config),
10245
+ removeField: function removeField(attrs, fieldId) {
10246
+ return removeField$1(attrs, fieldId, config.queryEngineConfig);
10247
+ },
10248
+ isRunnable: function isRunnable(hydrated) {
10249
+ return hydrated.measure.length > 0 && hydrated.dimension.length > 0;
10250
+ },
10251
+ autoGenerate: function autoGenerate(dataSet) {
10252
+ var _DataSet$buildQueryAt = buildQueryAttributes(dataSet, config.queryEngineConfig, 'barChart'),
10253
+ measure = _DataSet$buildQueryAt.measure,
10254
+ dimension = _DataSet$buildQueryAt.dimension;
10255
+ return this.init(dataSet.id, {
10256
+ measure: [measure[0]],
10257
+ dimension: dimension
10258
+ });
10259
+ },
10260
+ dataPanelConfig: function dataPanelConfig() {
10261
+ return [namespace(CONSTANTS$k, 'data_set'), namespace(CONSTANTS$k, 'views'), _extends({}, namespace(CONSTANTS$k, 'field_y_axis'), {
10262
+ fieldFilterOptions: {
10263
+ forComponent: 'barChart'
10264
+ },
10265
+ preSetPartialAttributes: function preSetPartialAttributes(values) {
10266
+ return {
10267
+ measure: values
10268
+ };
10269
+ },
10270
+ getValues: function getValues(attrs) {
10271
+ return attrs.measure;
10272
+ },
10273
+ testId: 'metric-input'
10274
+ }), _extends({}, namespace(CONSTANTS$k, 'field_x_axis'), {
10275
+ fieldFilterOptions: {
10276
+ forComponent: 'barChart',
10277
+ onlyDimensions: true
10278
+ },
10279
+ preventDuplicates: false,
10280
+ // return all values in the dimension array instead of seperating out timeDimension
10281
+ preSetPartialAttributes: function preSetPartialAttributes(values) {
10282
+ return {
10283
+ dimension: [].concat(values)
10284
+ };
10285
+ },
10286
+ // does this need to be updated too?
10287
+ getValues: function getValues(attrs) {
10288
+ return [].concat(attrs.dimension);
10289
+ },
10290
+ maxAllowed: 2,
10291
+ testId: 'add-dimension'
10292
+ }), namespace(CONSTANTS$k, 'sort'), namespace(CONSTANTS$k, 'filter'), _extends({}, namespace(CONSTANTS$k, 'drilldown'), {
10293
+ options: {
10294
+ property: 'drilldownOptions'
10295
+ }
10296
+ }), namespace(CONSTANTS$k, 'custom_metrics'), namespace(CONSTANTS$k, 'limit')];
10297
+ },
10298
+ formatPanelConfig: function formatPanelConfig() {
10299
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
10300
+ return [headingConstant(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'chart_styles'), {
10301
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$k.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$k.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
10302
+ }), axisLabelsConstants(CONSTANTS$k), _extends({}, namespace(CONSTANTS$k, 'conditional_formatting'), {
10303
+ ruleType: 'lineColor'
10304
+ }), namespace(CONSTANTS$k, 'goal_line')];
10305
+ },
10306
+ supportedCustomFields: {
10307
+ percentages: true,
10308
+ dateCalculations: true,
10309
+ simpleMaths: true,
10310
+ rules: true,
10311
+ aggregateMaths: true,
10312
+ roundedNumbers: true,
10313
+ conditional: true,
10314
+ customBuild: [AcceptedTypes.Maths, AcceptedTypes.IfStatement, AcceptedTypes.Aggregates]
10315
+ },
10316
+ supportedFeatures: {
10317
+ parameters: true,
10318
+ colorGradient: false
10319
+ },
10320
+ setDataAttributesFromPreAggregatedDataSet: function setDataAttributesFromPreAggregatedDataSet$1(attributes, dataSet) {
10321
+ return setDataAttributesFromPreAggregatedDataSet(attributes, dataSet, this.setAttributes);
10322
+ }
10323
+ };
10324
+ };
10325
+
10326
+ var attributesSchema$j = function attributesSchema(config) {
10327
+ return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
10328
+ legend: Joi.valid(true, false),
10329
+ labels: Joi.valid(true, false).optional(),
10330
+ type: Joi.valid('waterfallChart').required(),
10331
+ parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10332
+ axisTitles: axisTitleSchema(),
10333
+ headline: headlineSchema(),
10334
+ tags: tagsSchema(),
10335
+ increaseColor: Joi.string().required(),
10336
+ decreaseColor: Joi.string().required(),
10337
+ comparison: Joi.any()
10338
+ }));
10339
+ };
10340
+
10341
+ var setAttributes$h = (function (config) {
10342
+ return function (waterfallChart, partial) {
10343
+ var newAttributes = setAttributes(waterfallChart, partial, attributesSchema$j(config));
10344
+ newAttributes = removeUnusedOrderFieldsFromTimeSeriesComponent(newAttributes);
10345
+ return newAttributes;
10346
+ };
10347
+ });
10348
+
10349
+ var CONSTANTS$l = {
10350
+ title: 'Waterfall chart',
10351
+ description: "Shows a running total as values are added or subtracted. It's useful for understanding how an initial value is affected by a series of positive and negative values.",
10352
+ namespace: 'waterfall_chart',
10353
+ data_panel: {
10354
+ data_set: {
10355
+ type: 'dataSet',
10356
+ title: 'Data set',
10357
+ description: 'What data do you want to use in this waterfall chart?'
10358
+ },
10359
+ views: {
10360
+ type: 'views',
10361
+ title: 'View',
10362
+ description: ''
10363
+ },
10364
+ field_y_axis: {
10365
+ type: 'fieldCollector',
10366
+ title: 'Metric - Y Axis',
10367
+ description: 'What do you want each bar to measure?',
10368
+ callToAction: 'Add metric'
10369
+ },
10370
+ field_x_axis: {
10371
+ type: 'fieldCollector',
10372
+ title: 'Grouping - X Axis',
10373
+ description: 'What do you want each bar to represent? An example would be a a date grouping to show each month as a bar',
10374
+ callToAction: 'Add grouping'
10375
+ },
10376
+ dateComparison: {
10377
+ type: 'dateComparison',
10378
+ title: 'Comparison',
10379
+ description: 'Compare the waterfall chart to a previous period.',
10380
+ callToAction: 'Add comparison'
10381
+ },
10382
+ sort: {
10383
+ type: 'sort',
10384
+ title: 'Sort',
10385
+ description: 'Select the order of categories or time on the x Axis.'
10386
+ },
10387
+ filter: {
10388
+ type: 'filter',
10389
+ title: 'Filters',
10390
+ description: 'Only include the information you want to use in this waterfall chart.'
10391
+ },
10392
+ custom_metrics: {
10393
+ type: 'customMetrics',
10394
+ title: 'Custom metrics',
10395
+ description: 'Build your own metrics, such as a percentage.'
10396
+ },
10397
+ limit: {
10398
+ type: 'limit',
10399
+ title: 'Limit',
10400
+ description: 'Set the maximum number of records to show on this waterfall chart.'
10401
+ }
10402
+ },
10403
+ format_panel: {
10404
+ heading: {
10405
+ type: 'heading',
10406
+ title: 'Heading',
10407
+ description: '',
10408
+ subSectionDefinition: {
10409
+ title: {
10410
+ type: 'title',
10411
+ title: 'Title',
10412
+ description: '',
10413
+ namespace: 'title'
10414
+ },
10415
+ subject: {
10416
+ title: 'Subject',
10417
+ type: 'subject',
10418
+ description: '',
10419
+ namespace: 'subject'
10420
+ }
10421
+ }
10422
+ },
10423
+ chart_styles: {
10424
+ type: 'chartStyles',
10425
+ title: 'Chart Settings',
10426
+ description: '',
10427
+ subSectionDefinition: {
10428
+ legend: {
10429
+ type: 'legend',
10430
+ title: 'Show Legend',
10431
+ description: '',
10432
+ namespace: 'legend'
10433
+ },
10434
+ labels: {
10435
+ type: 'labels',
10436
+ title: 'Show Labels',
10437
+ description: '',
10438
+ namespace: 'labels'
10415
10439
  }
10416
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
10417
10440
  }
10418
10441
  },
10419
10442
  axis_labels: {
@@ -10516,6 +10539,7 @@ var WaterfallChart = function WaterfallChart(config) {
10516
10539
  headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10517
10540
  tags: (_dumped$tags = dumped.tags) != null ? _dumped$tags : [],
10518
10541
  legend: dumped.legend,
10542
+ labels: dumped.labels,
10519
10543
  viewId: upcastViewId(dumped.viewId),
10520
10544
  dataSetId: dumped.dataSetId,
10521
10545
  limit: dumped.limit,
@@ -10565,6 +10589,7 @@ var WaterfallChart = function WaterfallChart(config) {
10565
10589
  yAxisFormat: null,
10566
10590
  xAxisFormat: null,
10567
10591
  legend: true,
10592
+ labels: false,
10568
10593
  parameters: {},
10569
10594
  axisTitles: undefined,
10570
10595
  headline: undefined,
@@ -10628,10 +10653,9 @@ var WaterfallChart = function WaterfallChart(config) {
10628
10653
  }), namespace(CONSTANTS$l, 'sort'), namespace(CONSTANTS$l, 'filter'), namespace(CONSTANTS$l, 'custom_metrics'), namespace(CONSTANTS$l, 'limit')];
10629
10654
  },
10630
10655
  formatPanelConfig: function formatPanelConfig() {
10631
- var _CONSTANTS$format_pan;
10656
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
10632
10657
  return [headingConstant(CONSTANTS$l), namespace(CONSTANTS$l, 'waterfall_colors'), _extends({}, namespace(CONSTANTS$l, 'chart_styles'), {
10633
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$l.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
10634
- ]
10658
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$l.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$l.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
10635
10659
  }), axisLabelsConstants(CONSTANTS$l)];
10636
10660
  },
10637
10661
  supportedCustomFields: {
@@ -10658,7 +10682,7 @@ var attributesSchema$k = function attributesSchema(config) {
10658
10682
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), timeDimensionQuerySchema(config.queryEngineConfig, config.attributesSchemaOptions), {
10659
10683
  stacked: Joi.valid(true, false),
10660
10684
  legend: Joi.valid(true, false),
10661
- // labels: Joi.valid(true, false).optional(),
10685
+ labels: Joi.valid(true, false).optional(),
10662
10686
  type: Joi.valid('areaChartV2').required(),
10663
10687
  parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
10664
10688
  lineCurve: areaCurveSchema,
@@ -10774,8 +10798,13 @@ var CONSTANTS$m = {
10774
10798
  title: 'Show Legend',
10775
10799
  description: '',
10776
10800
  namespace: 'legend'
10801
+ },
10802
+ labels: {
10803
+ type: 'labels',
10804
+ title: 'Show Labels',
10805
+ description: '',
10806
+ namespace: 'labels'
10777
10807
  }
10778
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
10779
10808
  }
10780
10809
  },
10781
10810
  axis_labels: {
@@ -10903,6 +10932,7 @@ var AreaChart$1 = function AreaChart(config) {
10903
10932
  conditionalFormattingRules: upcast$1(config.queryEngineConfig, dumped.conditionalFormattingRules),
10904
10933
  drilldown: dumped.drilldown,
10905
10934
  legend: dumped.legend,
10935
+ labels: dumped.labels,
10906
10936
  goalLines: dumped.goalLines,
10907
10937
  headline: upcastHeadline(dumped.headline, dumped.timeDimension),
10908
10938
  parameters: upcastParameters(dumped.parameters),
@@ -10942,6 +10972,7 @@ var AreaChart$1 = function AreaChart(config) {
10942
10972
  conditionalFormattingRules: [],
10943
10973
  drilldown: [],
10944
10974
  legend: true,
10975
+ labels: false,
10945
10976
  goalLines: undefined,
10946
10977
  approxXAxisLabelCount: 'auto',
10947
10978
  approxYAxisLabelCount: 'auto',
@@ -11005,10 +11036,9 @@ var AreaChart$1 = function AreaChart(config) {
11005
11036
  }), namespace(CONSTANTS$m, 'sort'), namespace(CONSTANTS$m, 'filter'), namespace(CONSTANTS$m, 'custom_metrics'), namespace(CONSTANTS$m, 'limit')];
11006
11037
  },
11007
11038
  formatPanelConfig: function formatPanelConfig() {
11008
- var _CONSTANTS$format_pan;
11039
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2;
11009
11040
  return [headingConstant(CONSTANTS$m), _extends({}, namespace(CONSTANTS$m, 'chart_styles'), {
11010
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$m.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
11011
- ]
11041
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$m.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$m.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
11012
11042
  }), axisLabelsConstants(CONSTANTS$m), _extends({}, namespace(CONSTANTS$m, 'conditional_formatting'), {
11013
11043
  ruleType: 'lineColor'
11014
11044
  }), namespace(CONSTANTS$m, 'goal_line')];
@@ -11037,7 +11067,7 @@ var attributesSchema$l = function attributesSchema(config) {
11037
11067
  return Joi.object(_extends({}, baseAttributesSchema(config.attributesSchemaOptions), {
11038
11068
  stacked: Joi.valid(true, false),
11039
11069
  legend: Joi.valid(true, false),
11040
- // labels: Joi.valid(true, false).optional(),
11070
+ labels: Joi.valid(true, false).optional(),
11041
11071
  barMeasure: Joi.array().items(measureSchema(config.queryEngineConfig.supportedAggregates, config.attributesSchemaOptions)),
11042
11072
  lineMeasure: Joi.array().items(measureSchema(config.queryEngineConfig.supportedAggregates, config.attributesSchemaOptions)),
11043
11073
  barDimension: dimensionSchema(config.queryEngineConfig.supportedTimeTruncFunctions, config.attributesSchemaOptions),
@@ -11183,8 +11213,13 @@ var CONSTANTS$n = {
11183
11213
  title: 'Show Legend',
11184
11214
  description: '',
11185
11215
  namespace: 'legend'
11216
+ },
11217
+ labels: {
11218
+ type: 'labels',
11219
+ title: 'Show Labels',
11220
+ description: '',
11221
+ namespace: 'labels'
11186
11222
  }
11187
- // labels: { type: 'labels', title: 'Show Labels', description: '', namespace: 'labels' },
11188
11223
  }
11189
11224
  },
11190
11225
  axis_labels: {
@@ -11316,6 +11351,7 @@ var ComboChartV2 = function ComboChartV2(config) {
11316
11351
  yAxisFormat: null,
11317
11352
  xAxisFormat: null,
11318
11353
  legend: true,
11354
+ labels: false,
11319
11355
  approxXAxisLabelCount: 'auto',
11320
11356
  approxYAxisLabelCount: 'auto',
11321
11357
  goalLines: undefined,
@@ -11356,19 +11392,18 @@ var ComboChartV2 = function ComboChartV2(config) {
11356
11392
  }), namespace(CONSTANTS$n, 'combo_chart_dimension'), namespace(CONSTANTS$n, 'sort'), namespace(CONSTANTS$n, 'filter'), namespace(CONSTANTS$n, 'custom_metrics'), namespace(CONSTANTS$n, 'limit')];
11357
11393
  },
11358
11394
  formatPanelConfig: function formatPanelConfig() {
11359
- var _CONSTANTS$format_pan, _CONSTANTS$format_pan2, _CONSTANTS$format_pan3, _CONSTANTS$format_pan4, _CONSTANTS$format_pan5, _CONSTANTS$format_pan6, _CONSTANTS$format_pan7;
11395
+ var _CONSTANTS$format_pan, _CONSTANTS$format_pan2, _CONSTANTS$format_pan3, _CONSTANTS$format_pan4, _CONSTANTS$format_pan5, _CONSTANTS$format_pan6, _CONSTANTS$format_pan7, _CONSTANTS$format_pan8;
11360
11396
  return [headingConstant(CONSTANTS$n), _extends({}, namespace(CONSTANTS$n, 'chart_styles'), {
11361
- subSection: [(_CONSTANTS$format_pan = CONSTANTS$n.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend // CONSTANTS.format_panel.chart_styles?.subSectionDefinition.labels as Section<'labels'>,
11362
- ]
11397
+ subSection: [(_CONSTANTS$format_pan = CONSTANTS$n.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan.subSectionDefinition.legend, (_CONSTANTS$format_pan2 = CONSTANTS$n.format_panel.chart_styles) == null ? void 0 : _CONSTANTS$format_pan2.subSectionDefinition.labels]
11363
11398
  }), axisLabelsConstants(CONSTANTS$n), _extends({}, namespace(CONSTANTS$n, 'conditional_formatting'), {
11364
11399
  ruleType: 'backgroundColor',
11365
11400
  subSection: [{
11366
- title: (_CONSTANTS$format_pan2 = (_CONSTANTS$format_pan3 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan3 = _CONSTANTS$format_pan3.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan3.bar.title) != null ? _CONSTANTS$format_pan2 : '',
11367
- namespace: (_CONSTANTS$format_pan4 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan4 = _CONSTANTS$format_pan4.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan4.bar.namespace,
11401
+ title: (_CONSTANTS$format_pan3 = (_CONSTANTS$format_pan4 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan4 = _CONSTANTS$format_pan4.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan4.bar.title) != null ? _CONSTANTS$format_pan3 : '',
11402
+ namespace: (_CONSTANTS$format_pan5 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan5 = _CONSTANTS$format_pan5.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan5.bar.namespace,
11368
11403
  propKey: 'bar'
11369
11404
  }, {
11370
- title: (_CONSTANTS$format_pan5 = (_CONSTANTS$format_pan6 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan6 = _CONSTANTS$format_pan6.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan6.line.title) != null ? _CONSTANTS$format_pan5 : '',
11371
- namespace: (_CONSTANTS$format_pan7 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan7 = _CONSTANTS$format_pan7.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan7.line.namespace,
11405
+ title: (_CONSTANTS$format_pan6 = (_CONSTANTS$format_pan7 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan7 = _CONSTANTS$format_pan7.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan7.line.title) != null ? _CONSTANTS$format_pan6 : '',
11406
+ namespace: (_CONSTANTS$format_pan8 = CONSTANTS$n.format_panel.conditional_formatting) == null || (_CONSTANTS$format_pan8 = _CONSTANTS$format_pan8.subSectionDefinition) == null ? void 0 : _CONSTANTS$format_pan8.line.namespace,
11372
11407
  propKey: 'line'
11373
11408
  }]
11374
11409
  }), namespace(CONSTANTS$n, 'goal_line')];
@@ -12509,12 +12544,16 @@ var defaultNumberFormatOptions = function defaultNumberFormatOptions(textOverrid
12509
12544
  description: textOverride('number_format_option.currency_eur', 'Currency €')
12510
12545
  },
12511
12546
  _vizzly_to_percentage: {
12512
- formatter: function formatter(value, noValueReplacement) {
12547
+ formatter: function formatter(value, noValueReplacement, total) {
12513
12548
  if (noValueReplacement === void 0) {
12514
12549
  noValueReplacement = noValue;
12515
12550
  }
12516
12551
  if (value === null || value === undefined) return noValueReplacement;
12517
12552
  if (Number.isNaN(value)) return formattingError;
12553
+ if (total !== undefined && total !== 0 && typeof value === 'number') {
12554
+ var percentage = isPercentageOf(value, total);
12555
+ return toDp(percentage, 2) + "%";
12556
+ }
12518
12557
  return toPercentage(value, 2);
12519
12558
  },
12520
12559
  description: textOverride('number_format_option.percentage', 'Percentage')
@@ -13062,10 +13101,10 @@ var formatSeriesName = function formatSeriesName(result, textOverride, type, id,
13062
13101
  return newTitle != null ? newTitle : defaultLabel;
13063
13102
  };
13064
13103
  };
13065
- var convertValueToFormat = function convertValueToFormat(value, numberFormatOptions, format) {
13104
+ var convertValueToFormat = function convertValueToFormat(value, numberFormatOptions, format, total) {
13066
13105
  var _numberFormatOptions;
13067
13106
  var formatter = numberFormatOptions == null || (_numberFormatOptions = numberFormatOptions[format != null ? format : '']) == null ? void 0 : _numberFormatOptions.formatter;
13068
- return formatter ? formatter(value) : value;
13107
+ return formatter ? formatter(value, undefined, total) : value;
13069
13108
  };
13070
13109
  function getGradientAdjustedColor(rule, matchedHexValue, actualValue) {
13071
13110
  if (rule.boundaries && rule.boundaries.length === 2 && rule.ruleValueEnd) {
@@ -34066,6 +34105,12 @@ var calculateMinMax = function calculateMinMax(values) {
34066
34105
  maxValue: maxValue
34067
34106
  };
34068
34107
  };
34108
+ var normalizeKey = function normalizeKey(value) {
34109
+ if (typeof value === 'number' || !isNaN(Number(value)) && !isNaN(parseFloat(value))) {
34110
+ return Number(value).toString().split('.')[0];
34111
+ }
34112
+ return String(value);
34113
+ };
34069
34114
  var showMinMaxLabel = function showMinMaxLabel(value, totalItems, minValue, maxValue) {
34070
34115
  return totalItems < 11 || value == minValue || value == maxValue;
34071
34116
  };
@@ -34078,6 +34123,40 @@ var getMinMaxChartValueFromNumberArray = function getMinMaxChartValueFromNumberA
34078
34123
  maxValue: maxValue
34079
34124
  };
34080
34125
  };
34126
+ var getLabelDictionary = function getLabelDictionary(formattedData, keys) {
34127
+ var formattedLabelNames = formattedData == null ? void 0 : formattedData.map(function (d) {
34128
+ var convertedArray = keys.map(function (key) {
34129
+ var _ref;
34130
+ if (!d[key].formattedValue) return;
34131
+ var valueKey = normalizeKey(d[key].value);
34132
+ var label = d[key].formattedValue;
34133
+ return _ref = {}, _ref[valueKey] = label, _ref;
34134
+ }).flat();
34135
+ return convertedArray;
34136
+ });
34137
+ if (!formattedLabelNames) return {};
34138
+ var dictionary = {};
34139
+ formattedLabelNames.forEach(function (labelArray) {
34140
+ if (labelArray) {
34141
+ labelArray.forEach(function (labelObj) {
34142
+ if (labelObj) {
34143
+ Object.entries(labelObj).forEach(function (_ref2) {
34144
+ var value = _ref2[0],
34145
+ label = _ref2[1];
34146
+ dictionary[value] = label;
34147
+ });
34148
+ }
34149
+ });
34150
+ }
34151
+ });
34152
+ return dictionary;
34153
+ };
34154
+ var getFormattedValue = function getFormattedValue(value, dictionary) {
34155
+ var _dictionary$normalize;
34156
+ if (!dictionary) return value;
34157
+ var normalizedKey = normalizeKey(value);
34158
+ return (_dictionary$normalize = dictionary[normalizedKey]) != null ? _dictionary$normalize : value;
34159
+ };
34081
34160
  var getAllChartValues = function getAllChartValues(data, keys) {
34082
34161
  var allValues = [];
34083
34162
  data.forEach(function (item) {
@@ -34103,6 +34182,12 @@ var accessors = function accessors(xAxisIsTime, xKey, yKey, horizontal) {
34103
34182
  };
34104
34183
  };
34105
34184
  var DEFAULT_Y_AXIS_LABEL_COUNT = 5;
34185
+ var LABEL_TEXT_STYLE = {
34186
+ textAnchor: 'middle',
34187
+ fontSize: '10px',
34188
+ fill: '#333',
34189
+ fontWeight: 500
34190
+ };
34106
34191
  var VizzlyXYChart = function VizzlyXYChart(props) {
34107
34192
  var _props$height, _theme$axis$stroke, _theme$axis, _ref, _props$lines$data$len, _props$lines, _props$areas, _props$bars, _props$lines$threshol, _props$lines2, _props$areas2, _props$forceXAxisAsTi, _props$bars2, _props$lines3, _theme$grid$stroke, _theme$grid, _props$axisTitles, _props$axisTitles2, _props$axisTitles3, _props$axisTitles4, _props$areas7, _props$bars3, _props$bars7, _props$lines4, _props$lines7, _props$trends2, _props$lines13, _props$bars14, _props$goalLine, _props$bars15, _props$bars16, _props$bars17;
34108
34193
  var height = adjustHeight((_props$height = props == null ? void 0 : props.height) != null ? _props$height : 300, props == null ? void 0 : props.legend);
@@ -34387,57 +34472,49 @@ var VizzlyXYChart = function VizzlyXYChart(props) {
34387
34472
  }), "bar_with_previous_" + props.uniqueId + "_" + keyIndex);
34388
34473
  })
34389
34474
  }), props.bars.data.map(function (dataPoint, dataIndex) {
34390
- return jsx("g", {
34391
- children: props.bars.keys.map(function (key, keyIndex) {
34392
- var value = dataPoint[key];
34393
- if (!value || !props.labels) return null;
34394
- if (props.bars.data.length > 10) {
34395
- var values = props.bars.data.map(function (d) {
34396
- return Number(d[key]);
34397
- }).filter(function (v) {
34398
- return v;
34399
- });
34400
- var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(values),
34401
- _minValue = _getMinMaxChartValueF.minValue,
34402
- _maxValue = _getMinMaxChartValueF.maxValue;
34403
- var currentValue = Number(value);
34404
- if (currentValue !== _minValue && currentValue !== _maxValue) {
34405
- return null;
34406
- }
34407
- }
34408
- var chartWidth = props.width || 400;
34409
- var barWidth = (chartWidth - margin.left - margin.right) / props.bars.data.length;
34410
- var barX = margin.left + dataIndex * barWidth + barWidth / 2;
34411
- var isPositiveModifier = isPositiveModifierKey(key);
34412
- var barHeight, barY;
34413
- if (isPositiveModifier) {
34414
- // Helper function to extract the base name from the key (e.g., "{Revenue, previous}" -> "Revenue")
34415
- var getBaseKeyName = function getBaseKeyName(keyName) {
34416
- return keyName.replace(/[{}]/g, '').split(',')[0].trim();
34417
- };
34418
- var standardKey = props.bars.keys.find(function (k) {
34419
- return !isPositiveModifierKey(k) && getBaseKeyName(k) === getBaseKeyName(key);
34420
- });
34421
- var totalValue = standardKey ? dataPoint[standardKey] : 0;
34422
- var previousValue = Number(value);
34423
- var totalBarValue = Number(totalValue) + previousValue;
34424
- barHeight = (height - margin.top - margin.bottom) * totalBarValue / (maxValue || 1);
34425
- barY = height - margin.bottom - barHeight;
34426
- } else {
34427
- barHeight = (height - margin.top - margin.bottom) * Number(value) / (maxValue || 1);
34428
- barY = height - margin.bottom - barHeight;
34429
- }
34430
- return jsx("text", {
34431
- x: barX,
34432
- y: barY,
34433
- textAnchor: "bottom",
34434
- fontSize: "10px",
34435
- fill: "#333",
34436
- fontWeight: "500",
34437
- children: formatYAxisLabel$1(props)(value)
34438
- }, "funnel_label_" + props.uniqueId + "_" + dataIndex + "_" + keyIndex);
34439
- })
34440
- }, "funnel_labels_" + props.uniqueId + "_" + dataIndex);
34475
+ var mainKey = props.bars.keys[0];
34476
+ var value = dataPoint[mainKey];
34477
+ if (!value || !props.labels) return null;
34478
+ if (props.bars && props.bars.data.length > 30) {
34479
+ var values = props.bars.data.map(function (d) {
34480
+ return Number(d[mainKey]);
34481
+ }).filter(function (v) {
34482
+ return v;
34483
+ });
34484
+ var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(values),
34485
+ _minValue = _getMinMaxChartValueF.minValue,
34486
+ _maxValue = _getMinMaxChartValueF.maxValue;
34487
+ var currentValue = Number(value);
34488
+ if (currentValue !== _minValue && currentValue !== _maxValue) {
34489
+ return null;
34490
+ }
34491
+ }
34492
+ var _accessors = accessors(xAxisIsTime, x, mainKey, horizontal),
34493
+ yAccessor = _accessors.yAccessor;
34494
+ var yValue = yAccessor(dataPoint);
34495
+ var defaultChartWidth = 400;
34496
+ var chartWidth = props.width || defaultChartWidth;
34497
+ var barWidth = (chartWidth - margin.left - margin.right) / props.bars.data.length;
34498
+ var barX = margin.left + dataIndex * barWidth + barWidth / 2;
34499
+ var availableHeight = height - margin.top - margin.bottom;
34500
+ var yScale = scaleLinear({
34501
+ domain: [minValue, maxValue],
34502
+ range: [availableHeight, 0],
34503
+ nice: true
34504
+ });
34505
+ var scaledYValue = yScale(Number(yValue));
34506
+ var barTopY = margin.top + scaledYValue;
34507
+ var yPadding = 5;
34508
+ var labelY = barTopY - yPadding;
34509
+ return jsx("text", {
34510
+ x: barX,
34511
+ y: labelY,
34512
+ textAnchor: LABEL_TEXT_STYLE.textAnchor,
34513
+ fontSize: LABEL_TEXT_STYLE.fontSize,
34514
+ fill: LABEL_TEXT_STYLE.fill,
34515
+ fontWeight: LABEL_TEXT_STYLE.fontWeight,
34516
+ children: formatYAxisLabel$1(props)(value)
34517
+ }, "funnel_label_" + props.uniqueId + "_" + dataIndex);
34441
34518
  })]
34442
34519
  }), (props == null ? void 0 : props.bars) && props.bars.stacked && jsxs(Fragment, {
34443
34520
  children: [props.enableHover && jsx("style", {
@@ -38891,12 +38968,12 @@ var PieChartView = function PieChartView(props) {
38891
38968
  var rS = resultSet$1(props.result, pivotConfig, fakeQuery, false, checkForNullValue(props.dataSetId, props.dimension, props.timeDimension, textOverride, valueAlias));
38892
38969
  var pieSeries = series$1(fakeQuery, props.result, pivotConfig);
38893
38970
 
38894
- /*
38971
+ /*
38895
38972
  NOTES
38896
38973
  - isArray(data[props.dimension[0].field]) check below added so Pie charts can support conditional formatting on string[] dataTypes
38897
38974
  */
38898
38975
 
38899
- /*
38976
+ /*
38900
38977
  TODO
38901
38978
  - Allow string[] dataTypes to be chosen as a grouping in the Pie chart
38902
38979
  - Make sure the formatting of labels is correct when using string[] dataTypes (currently they appear with no spaces or commas within the pie chart tooltip)
@@ -38961,7 +39038,10 @@ var PieChartView = function PieChartView(props) {
38961
39038
  showLabel: (theme == null ? void 0 : theme.detail) === 'verbose' && (props == null ? void 0 : props.labels) !== false || (props == null ? void 0 : props.labels),
38962
39039
  legend: showLegend(props == null ? void 0 : props.legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
38963
39040
  formatValue: function formatValue(value) {
38964
- return convertValueToFormat(toDp(value, 2), props == null ? void 0 : props.numberFormatOptions, props == null ? void 0 : props.labelFormat);
39041
+ var total = data[0].data.reduce(function (sum, item) {
39042
+ return sum + (item[data[0].valueKey] || 0);
39043
+ }, 0);
39044
+ return convertValueToFormat(value, props == null ? void 0 : props.numberFormatOptions, props == null ? void 0 : props.labelFormat, total);
38965
39045
  }
38966
39046
  })
38967
39047
  })]
@@ -43419,373 +43499,6 @@ function buildComboTooltipData(barTooltipData, lineTooltipData, xScaleKey) {
43419
43499
  return barTooltipData && lineTooltipData ? _extends({}, barTooltipData, lineTooltipData) : undefined;
43420
43500
  }
43421
43501
 
43422
- var LegendItemBox = function LegendItemBox(_ref) {
43423
- var color = _ref.color,
43424
- style = _ref.style;
43425
- return jsx("svg", {
43426
- width: 10,
43427
- height: 10,
43428
- style: {
43429
- display: 'block'
43430
- },
43431
- children: style.type === 'line' ? style.strokeDasharray !== null ? jsx("line", {
43432
- x1: "0",
43433
- y1: "5",
43434
- x2: "10",
43435
- y2: "5",
43436
- stroke: color,
43437
- strokeWidth: style.strokeWidth,
43438
- strokeDasharray: 2
43439
- }) : jsx("line", {
43440
- x1: "0",
43441
- y1: "5",
43442
- x2: "10",
43443
- y2: "5",
43444
- stroke: color,
43445
- strokeWidth: style.strokeWidth
43446
- }) : jsx("rect", {
43447
- fill: color,
43448
- width: 10,
43449
- height: 10,
43450
- rx: "2"
43451
- })
43452
- });
43453
- };
43454
- var LegendItemSquare = function LegendItemSquare(_ref2) {
43455
- var color = _ref2.color;
43456
- return jsx("svg", {
43457
- width: 8,
43458
- height: 8,
43459
- style: {
43460
- display: 'block'
43461
- },
43462
- children: jsx("rect", {
43463
- fill: color,
43464
- width: 8,
43465
- height: 8,
43466
- rx: "2"
43467
- })
43468
- });
43469
- };
43470
- var LegendItemTriangle = function LegendItemTriangle(_ref3) {
43471
- var color = _ref3.color;
43472
- return jsx("svg", {
43473
- width: 8,
43474
- height: 8,
43475
- style: {
43476
- display: 'block',
43477
- borderRadius: 1
43478
- },
43479
- children: jsx("polygon", {
43480
- points: "0,0 10,10 0,10",
43481
- fill: color
43482
- })
43483
- });
43484
- };
43485
-
43486
- function _EMOTION_STRINGIFIED_CSS_ERROR__$5() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
43487
- var MIN_TOOLTIP_WIDTH = 180;
43488
- var TOOLTIP_OFFSET = 20;
43489
- var SCROLLBAR_WIDTH = 40;
43490
- var Tooltip$1 = function Tooltip(_ref) {
43491
- var _tooltipData$xKey$for, _tooltipData$xKey;
43492
- var keys = _ref.keys,
43493
- showRoundedTotal = _ref.showRoundedTotal,
43494
- tooltipData = _ref.tooltipData,
43495
- tooltipLeft = _ref.tooltipLeft,
43496
- tooltipTop = _ref.tooltipTop,
43497
- xKey = _ref.xKey,
43498
- yKeys = _ref.yKeys,
43499
- theme = _ref.theme,
43500
- items = _ref.items,
43501
- _ref$shouldShowColorL = _ref.shouldShowColorLegend,
43502
- shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
43503
- var tooltipRef = useRef(null);
43504
- var _useState = useState({
43505
- left: tooltipLeft
43506
- }),
43507
- position = _useState[0],
43508
- setPosition = _useState[1];
43509
- useEffect(function () {
43510
- var adjustTooltipPosition = function adjustTooltipPosition() {
43511
- var tooltipElement = tooltipRef.current;
43512
- if (tooltipElement) {
43513
- var screenWidth = window.innerWidth;
43514
- var rect = tooltipElement.getBoundingClientRect();
43515
- var width = rect.width;
43516
- if (width < MIN_TOOLTIP_WIDTH) {
43517
- width = MIN_TOOLTIP_WIDTH;
43518
- }
43519
- var left = tooltipLeft + TOOLTIP_OFFSET;
43520
- if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {
43521
- left = tooltipLeft - width - TOOLTIP_OFFSET;
43522
- }
43523
- setPosition({
43524
- left: left
43525
- });
43526
- }
43527
- };
43528
- adjustTooltipPosition();
43529
- }, [tooltipLeft]);
43530
- return /*#__PURE__*/createPortal(jsx("div", {
43531
- ref: tooltipRef,
43532
- style: _extends({
43533
- position: 'absolute',
43534
- left: position.left,
43535
- top: tooltipTop,
43536
- zIndex: 2147483647 * 10
43537
- }, theme),
43538
- children: jsxs("div", {
43539
- style: {
43540
- wordBreak: 'break-all'
43541
- },
43542
- children: [jsx("div", {
43543
- className: /*#__PURE__*/css$1({
43544
- fontFamily: 'inherit',
43545
- lineHeight: 'inherit',
43546
- letterSpacing: 'inherit',
43547
- fontWeight: 'bold',
43548
- fontSize: '15px',
43549
- width: '100%',
43550
- minWidth: MIN_TOOLTIP_WIDTH
43551
- }, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA6FqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {tooltipData[legendItem.yKey].formattedValue\n                              ? tooltipData[legendItem.yKey].formattedValue\n                              : tooltipData[legendItem.yKey].value}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */"),
43552
- children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
43553
- }), jsx("table", {
43554
- cellPadding: 0,
43555
- cellSpacing: 0,
43556
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43557
- name: "x8luwd",
43558
- styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none"
43559
- } : {
43560
- name: "9a1sa-Tooltip",
43561
- styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
43562
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA4GqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {tooltipData[legendItem.yKey].formattedValue\n                              ? tooltipData[legendItem.yKey].formattedValue\n                              : tooltipData[legendItem.yKey].value}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */",
43563
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
43564
- }),
43565
- children: jsxs("tbody", {
43566
- children: [items.map(function (item, index) {
43567
- var _item$legendItems;
43568
- return jsx(Fragment, {
43569
- children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
43570
- var _item$visibleYKeys, _item$conditionalForm;
43571
- if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
43572
- // yKey could not be found in tooltipData
43573
- return null;
43574
- }
43575
- return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxs("tr", {
43576
- children: [shouldShowColorLegend && jsx("td", {
43577
- style: {
43578
- verticalAlign: 'middle',
43579
- padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
43580
- width: 'auto'
43581
- },
43582
- children: jsx(LegendItemBox, {
43583
- color: getColor({
43584
- defaultColor: legendItem.color,
43585
- value: tooltipData[legendItem.yKey].value,
43586
- yKey: legendItem.yKey,
43587
- conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
43588
- }),
43589
- style: legendItem.style,
43590
- yKey: legendItem.yKey
43591
- })
43592
- }), jsx("td", {
43593
- style: {
43594
- padding: '8px 0 0 0'
43595
- },
43596
- children: keys[legendItem.yKey].keyFormatted
43597
- }), jsx("td", {
43598
- style: {
43599
- fontWeight: 'bold',
43600
- padding: '8px 0 0 16px'
43601
- },
43602
- children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
43603
- })]
43604
- }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
43605
- })
43606
- }, index);
43607
- }), showRoundedTotal && yKeys && jsxs("tr", {
43608
- children: [jsx("td", {
43609
- colSpan: 2,
43610
- style: {
43611
- padding: '12px 0 0 0'
43612
- },
43613
- children: "Rounded Total"
43614
- }), jsx("td", {
43615
- style: {
43616
- fontWeight: 'bold',
43617
- padding: '12px 0 0 16px'
43618
- },
43619
- children: yKeys.reduce(function (total, key) {
43620
- return total + Math.round(tooltipData[key].value);
43621
- }, 0)
43622
- })]
43623
- })]
43624
- })
43625
- })]
43626
- })
43627
- }), document.body);
43628
- };
43629
-
43630
- function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
43631
- var LegendItem = function LegendItem(_ref) {
43632
- var yKey = _ref.yKey,
43633
- yKeyFormatted = _ref.yKeyFormatted,
43634
- color = _ref.color,
43635
- style = _ref.style,
43636
- onClick = _ref.onClick,
43637
- visible = _ref.visible,
43638
- conditionalFormattingRules = _ref.conditionalFormattingRules;
43639
- var relevantRules = useMemo(function () {
43640
- return conditionalFormattingRules.filter(function (rule) {
43641
- return rule.yKey === yKey;
43642
- });
43643
- }, [conditionalFormattingRules]);
43644
- return jsxs("button", {
43645
- type: "button",
43646
- style: {
43647
- all: 'unset',
43648
- display: 'flex',
43649
- flexWrap: 'nowrap',
43650
- alignItems: 'center',
43651
- outline: 'revert',
43652
- gap: '4px',
43653
- padding: '4px',
43654
- cursor: 'pointer',
43655
- marginRight: '10px'
43656
- },
43657
- onClick: onClick,
43658
- children: [style.type === 'line' && jsxs("span", {
43659
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43660
- name: "1mfeugk",
43661
- styles: "height:10px;display:flex"
43662
- } : {
43663
- name: "mefz6m-LegendItem",
43664
- styles: "height:10px;display:flex;label:LegendItem;",
43665
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
43666
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
43667
- }),
43668
- children: [jsx(LegendItemBox, {
43669
- color: color,
43670
- style: style,
43671
- yKey: yKey
43672
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
43673
- return jsx(LegendItemBox, {
43674
- color: rule.color,
43675
- style: style,
43676
- yKey: yKey
43677
- }, "rule-" + JSON.stringify(rule));
43678
- })]
43679
- }), style.type === 'bar' && jsxs("span", {
43680
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43681
- name: "6b52m3",
43682
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
43683
- } : {
43684
- name: "pglbco-LegendItem",
43685
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
43686
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
43687
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
43688
- }),
43689
- children: [jsx(LegendItemSquare, {
43690
- color: color
43691
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
43692
- return jsx(LegendItemSquare, {
43693
- color: rule.color
43694
- }, "rule-" + JSON.stringify(rule));
43695
- })]
43696
- }), style.type === 'area' && jsxs("span", {
43697
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43698
- name: "6b52m3",
43699
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
43700
- } : {
43701
- name: "pglbco-LegendItem",
43702
- styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
43703
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFFeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
43704
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
43705
- }),
43706
- children: [jsx(LegendItemTriangle, {
43707
- color: color
43708
- }), relevantRules.length > 0 && relevantRules.map(function (rule) {
43709
- return jsx(LegendItemTriangle, {
43710
- color: rule.color
43711
- }, "rule-" + JSON.stringify(rule));
43712
- })]
43713
- }), jsx("span", {
43714
- style: {
43715
- fontSize: '12px',
43716
- lineHeight: '16px',
43717
- display: 'block',
43718
- textDecoration: visible ? 'none' : 'line-through',
43719
- textWrap: 'nowrap'
43720
- },
43721
- children: yKeyFormatted ? yKeyFormatted : yKey
43722
- })]
43723
- }, "legend-" + yKey);
43724
- };
43725
-
43726
- function _EMOTION_STRINGIFIED_CSS_ERROR__$7() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
43727
- var Legend$1 = function Legend(_ref) {
43728
- var keys = _ref.keys,
43729
- setVisibleYKeys = _ref.setVisibleYKeys,
43730
- marginLeft = _ref.marginLeft,
43731
- items = _ref.items;
43732
- var handleOnClick = function handleOnClick(item, legendItem) {
43733
- setVisibleYKeys && setVisibleYKeys(function (prev) {
43734
- var newVisibleLegendItems = [];
43735
- if (prev.length === item.legendItems.length) {
43736
- newVisibleLegendItems = [legendItem.yKey];
43737
- } else {
43738
- if (prev.includes(legendItem.yKey)) {
43739
- newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
43740
- return prevLegendItemId !== legendItem.yKey;
43741
- });
43742
- } else {
43743
- newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
43744
- }
43745
- }
43746
- return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
43747
- return legendItem.yKey;
43748
- }) : newVisibleLegendItems;
43749
- });
43750
- };
43751
- return jsx("div", {
43752
- className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43753
- name: "1nbollx",
43754
- styles: "height:40px;padding-top:8px"
43755
- } : {
43756
- name: "qz6h7j-Legend",
43757
- styles: "height:40px;padding-top:8px;label:Legend;",
43758
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */",
43759
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
43760
- }),
43761
- children: jsx(Scrollbar, {
43762
- className: /*#__PURE__*/css$1({
43763
- display: 'flex',
43764
- flexDirection: 'row',
43765
- flexWrap: 'nowrap',
43766
- alignItems: 'center',
43767
- marginLeft: marginLeft ? marginLeft + "px" : undefined
43768
- }, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0RtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */"),
43769
- x: true,
43770
- children: items.map(function (item, index) {
43771
- return jsx(Fragment, {
43772
- children: item.legendItems.map(function (legendItem) {
43773
- return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
43774
- key: "legend-" + legendItem.yKey,
43775
- yKeyFormatted: keys[legendItem.yKey].keyFormatted,
43776
- onClick: function onClick() {
43777
- handleOnClick(item, legendItem);
43778
- },
43779
- visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
43780
- conditionalFormattingRules: item.conditionalFormattingRules
43781
- }));
43782
- })
43783
- }, index);
43784
- })
43785
- })
43786
- });
43787
- };
43788
-
43789
43502
  var ASSUMED_AVERAGE_CHAR_WIDTH = 7.1;
43790
43503
 
43791
43504
  function calculateWordWidth(word, avgCharWidth) {
@@ -43975,108 +43688,6 @@ var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, h
43975
43688
  };
43976
43689
  };
43977
43690
 
43978
- function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
43979
- return useMemo(function () {
43980
- if (xScaleKey && xScaleDataType && yKeys.length > 0) {
43981
- return flattenData({
43982
- data: data,
43983
- xScaleKey: xScaleKey,
43984
- xScaleDataType: xScaleDataType,
43985
- yKeys: yKeys
43986
- });
43987
- } else {
43988
- return [];
43989
- }
43990
- }, [data, xScaleKey, xScaleDataType, yKeys]);
43991
- }
43992
-
43993
- var GoalLine = function GoalLine(_ref) {
43994
- var goalLine = _ref.goalLine,
43995
- innerWidth = _ref.innerWidth,
43996
- y = _ref.y,
43997
- margin = _ref.margin;
43998
- var textRef = useRef(null);
43999
- var _useState = useState(0),
44000
- labelWidth = _useState[0],
44001
- setLabelWidth = _useState[1];
44002
- useEffect(function () {
44003
- if (textRef.current) {
44004
- var bbox = textRef.current.getBBox();
44005
- setLabelWidth(bbox.width + 16);
44006
- }
44007
- }, [goalLine.formattedValue]);
44008
- var height = 16;
44009
- var triangleWidth = 8;
44010
- return jsxs("g", {
44011
- style: {
44012
- position: 'relative'
44013
- },
44014
- children: [jsx(Line$1, {
44015
- from: {
44016
- x: margin.left,
44017
- y: margin.top + y
44018
- },
44019
- to: {
44020
- x: margin.left + innerWidth,
44021
- y: margin.top + y
44022
- },
44023
- stroke: goalLine.color,
44024
- strokeDasharray: goalLine.strokeStyle == 'dashed' ? goalLine.strokeWidth * 2.5 + "," + goalLine.strokeWidth * 2.5 : undefined,
44025
- strokeWidth: goalLine.strokeWidth,
44026
- strokeLinecap: "round",
44027
- shapeRendering: "smooth"
44028
- }), jsxs("g", {
44029
- transform: "translate(" + (margin.left + innerWidth - labelWidth) + "," + (y + margin.top + height / 2) + ")",
44030
- children: [jsx("path", {
44031
- d: "M 0,0\n l " + -triangleWidth + "," + -height / 2 + " \n l " + triangleWidth + "," + -height / 2 + " \n h " + labelWidth + " \n a 3,3 0 0 1 3,3 \n v " + (height - 6) + " \n a 3,3 0 0 1 -3,3 \n h " + -labelWidth + " z",
44032
- fill: goalLine.color
44033
- }), jsx("text", {
44034
- ref: textRef,
44035
- x: labelWidth / 2,
44036
- y: -1,
44037
- dy: -4,
44038
- textAnchor: "middle",
44039
- fontFamily: "Arial, sans-serif",
44040
- fontSize: 9,
44041
- fill: '#fff',
44042
- children: goalLine.formattedValue
44043
- })]
44044
- })]
44045
- });
44046
- };
44047
-
44048
- /*
44049
- const strokeWidth = 2;
44050
- const height = 16;
44051
- const triangleWidth = 8;
44052
-
44053
-
44054
-
44055
-
44056
-
44057
- */
44058
-
44059
- var shouldUpdate$1 = function shouldUpdate(previousProps, nextProps) {
44060
- return JSON.stringify(previousProps) == JSON.stringify(nextProps);
44061
- };
44062
- var GoalLines = function GoalLines(_ref) {
44063
- var goalLines = _ref.goalLines,
44064
- margin = _ref.margin,
44065
- y = _ref.y,
44066
- width = _ref.width;
44067
- return jsx(Fragment, {
44068
- children: goalLines.map(function (goalLine) {
44069
- return jsx(GoalLine, {
44070
- innerWidth: width,
44071
- y: y(goalLine.value),
44072
- goalLine: goalLine,
44073
- margin: margin
44074
- }, goalLine.value);
44075
- })
44076
- });
44077
- };
44078
- var GoalLines$1 = /*#__PURE__*/memo(GoalLines, shouldUpdate$1);
44079
-
44080
43691
  var AXIS_TITLE_STYLES = {
44081
43692
  textShadow: 'rgba(0, 0, 0, 0.01) 0px 0px 1px',
44082
43693
  opacity: '0.75',
@@ -44199,6 +43810,147 @@ var AxisLeft = function AxisLeft(_ref) {
44199
43810
  });
44200
43811
  };
44201
43812
 
43813
+ var _excluded$g = ["children", "width", "height", "showLegend", "onMouseMove", "onMouseLeave"];
43814
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$5() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
43815
+ var ChartWrapper$1 = function ChartWrapper(_ref) {
43816
+ var children = _ref.children,
43817
+ width = _ref.width,
43818
+ height = _ref.height,
43819
+ showLegend = _ref.showLegend,
43820
+ onMouseMove = _ref.onMouseMove,
43821
+ onMouseLeave = _ref.onMouseLeave,
43822
+ svgProps = _objectWithoutPropertiesLoose(_ref, _excluded$g);
43823
+ return jsx("svg", _extends({
43824
+ width: width,
43825
+ height: height - (showLegend ? 40 : 0),
43826
+ onMouseMove: onMouseMove,
43827
+ onMouseLeave: onMouseLeave,
43828
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
43829
+ name: "4zleql",
43830
+ styles: "display:block"
43831
+ } : {
43832
+ name: "fx4tbw-ChartWrapper",
43833
+ styles: "display:block;label:ChartWrapper;",
43834
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxudHlwZSBDaGFydFdyYXBwZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHNob3dMZWdlbmQ6IGJvb2xlYW47XG4gIG9uTW91c2VNb3ZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG4gIG9uTW91c2VMZWF2ZT86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyPFNWR1NWR0VsZW1lbnQ+O1xufSAmIFJlYWN0LlNWR1Byb3BzPFNWR1NWR0VsZW1lbnQ+O1xuXG5leHBvcnQgY29uc3QgQ2hhcnRXcmFwcGVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIHNob3dMZWdlbmQsXG4gIG9uTW91c2VNb3ZlLFxuICBvbk1vdXNlTGVhdmUsXG4gIC4uLnN2Z1Byb3BzXG59OiBDaGFydFdyYXBwZXJQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIGhlaWdodD17aGVpZ2h0IC0gKHNob3dMZWdlbmQgPyA0MCA6IDApfVxuICAgICAgb25Nb3VzZU1vdmU9e29uTW91c2VNb3ZlfVxuICAgICAgb25Nb3VzZUxlYXZlPXtvbk1vdXNlTGVhdmV9XG4gICAgICBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdibG9jaycgfSl9XG4gICAgICB7Li4uc3ZnUHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvc3ZnPlxuICApO1xufTtcbiJdfQ== */",
43835
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
43836
+ })
43837
+ }, svgProps, {
43838
+ children: children
43839
+ }));
43840
+ };
43841
+
43842
+ var DataLabel = function DataLabel(_ref) {
43843
+ var x = _ref.x,
43844
+ y = _ref.y,
43845
+ title = _ref.title,
43846
+ dx = _ref.dx,
43847
+ dy = _ref.dy,
43848
+ color = _ref.color,
43849
+ backgroundColor = _ref.backgroundColor;
43850
+ return jsx(Annotation$1, {
43851
+ x: x,
43852
+ y: y,
43853
+ dx: dx,
43854
+ dy: dy,
43855
+ children: jsx(Label$1, {
43856
+ title: title,
43857
+ showAnchorLine: false,
43858
+ showBackground: false,
43859
+ backgroundFill: backgroundColor,
43860
+ fontColor: color,
43861
+ titleFontSize: 10,
43862
+ verticalAnchor: "middle"
43863
+ })
43864
+ });
43865
+ };
43866
+
43867
+ var GoalLine = function GoalLine(_ref) {
43868
+ var goalLine = _ref.goalLine,
43869
+ innerWidth = _ref.innerWidth,
43870
+ y = _ref.y,
43871
+ margin = _ref.margin;
43872
+ var textRef = useRef(null);
43873
+ var _useState = useState(0),
43874
+ labelWidth = _useState[0],
43875
+ setLabelWidth = _useState[1];
43876
+ useEffect(function () {
43877
+ if (textRef.current) {
43878
+ var bbox = textRef.current.getBBox();
43879
+ setLabelWidth(bbox.width + 16);
43880
+ }
43881
+ }, [goalLine.formattedValue]);
43882
+ var height = 16;
43883
+ var triangleWidth = 8;
43884
+ return jsxs("g", {
43885
+ style: {
43886
+ position: 'relative'
43887
+ },
43888
+ children: [jsx(Line$1, {
43889
+ from: {
43890
+ x: margin.left,
43891
+ y: margin.top + y
43892
+ },
43893
+ to: {
43894
+ x: margin.left + innerWidth,
43895
+ y: margin.top + y
43896
+ },
43897
+ stroke: goalLine.color,
43898
+ strokeDasharray: goalLine.strokeStyle == 'dashed' ? goalLine.strokeWidth * 2.5 + "," + goalLine.strokeWidth * 2.5 : undefined,
43899
+ strokeWidth: goalLine.strokeWidth,
43900
+ strokeLinecap: "round",
43901
+ shapeRendering: "smooth"
43902
+ }), jsxs("g", {
43903
+ transform: "translate(" + (margin.left + innerWidth - labelWidth) + "," + (y + margin.top + height / 2) + ")",
43904
+ children: [jsx("path", {
43905
+ d: "M 0,0\n l " + -triangleWidth + "," + -height / 2 + " \n l " + triangleWidth + "," + -height / 2 + " \n h " + labelWidth + " \n a 3,3 0 0 1 3,3 \n v " + (height - 6) + " \n a 3,3 0 0 1 -3,3 \n h " + -labelWidth + " z",
43906
+ fill: goalLine.color
43907
+ }), jsx("text", {
43908
+ ref: textRef,
43909
+ x: labelWidth / 2,
43910
+ y: -1,
43911
+ dy: -4,
43912
+ textAnchor: "middle",
43913
+ fontFamily: "Arial, sans-serif",
43914
+ fontSize: 9,
43915
+ fill: '#fff',
43916
+ children: goalLine.formattedValue
43917
+ })]
43918
+ })]
43919
+ });
43920
+ };
43921
+
43922
+ /*
43923
+ const strokeWidth = 2;
43924
+ const height = 16;
43925
+ const triangleWidth = 8;
43926
+
43927
+
43928
+
43929
+
43930
+
43931
+ */
43932
+
43933
+ var shouldUpdate$1 = function shouldUpdate(previousProps, nextProps) {
43934
+ return JSON.stringify(previousProps) == JSON.stringify(nextProps);
43935
+ };
43936
+ var GoalLines = function GoalLines(_ref) {
43937
+ var goalLines = _ref.goalLines,
43938
+ margin = _ref.margin,
43939
+ y = _ref.y,
43940
+ width = _ref.width;
43941
+ return jsx(Fragment, {
43942
+ children: goalLines.map(function (goalLine) {
43943
+ return jsx(GoalLine, {
43944
+ innerWidth: width,
43945
+ y: y(goalLine.value),
43946
+ goalLine: goalLine,
43947
+ margin: margin
43948
+ }, goalLine.value);
43949
+ })
43950
+ });
43951
+ };
43952
+ var GoalLines$1 = /*#__PURE__*/memo(GoalLines, shouldUpdate$1);
43953
+
44202
43954
  var LINE_STYLES = {
44203
43955
  strokeWidth: 2,
44204
43956
  strokeOpacity: 0.8,
@@ -44228,33 +43980,439 @@ var GridRows = function GridRows(_ref) {
44228
43980
  });
44229
43981
  };
44230
43982
 
44231
- var _excluded$g = ["children", "width", "height", "showLegend", "onMouseMove", "onMouseLeave"];
44232
- 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)."; }
44233
- var ChartWrapper$1 = function ChartWrapper(_ref) {
44234
- var children = _ref.children,
44235
- width = _ref.width,
44236
- height = _ref.height,
44237
- showLegend = _ref.showLegend,
44238
- onMouseMove = _ref.onMouseMove,
44239
- onMouseLeave = _ref.onMouseLeave,
44240
- svgProps = _objectWithoutPropertiesLoose(_ref, _excluded$g);
44241
- return jsx("svg", _extends({
44242
- width: width,
44243
- height: height - (showLegend ? 40 : 0),
44244
- onMouseMove: onMouseMove,
44245
- onMouseLeave: onMouseLeave,
43983
+ function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
43984
+ return useMemo(function () {
43985
+ if (xScaleKey && xScaleDataType && yKeys.length > 0) {
43986
+ return flattenData({
43987
+ data: data,
43988
+ xScaleKey: xScaleKey,
43989
+ xScaleDataType: xScaleDataType,
43990
+ yKeys: yKeys
43991
+ });
43992
+ } else {
43993
+ return [];
43994
+ }
43995
+ }, [data, xScaleKey, xScaleDataType, yKeys]);
43996
+ }
43997
+
43998
+ var _excluded$h = ["tooltipOpen"];
43999
+ function useTooltip$1(initialTooltipState) {
44000
+ var _useState = useState(_extends({
44001
+ tooltipOpen: false
44002
+ }, initialTooltipState)),
44003
+ tooltipState = _useState[0],
44004
+ setTooltipState = _useState[1];
44005
+ var showTooltip = useCallback(function (showArgs) {
44006
+ return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
44007
+ var show = _objectWithoutPropertiesLoose(_ref, _excluded$h);
44008
+ return _extends({}, showArgs(show), {
44009
+ tooltipOpen: true
44010
+ });
44011
+ } : {
44012
+ tooltipOpen: true,
44013
+ tooltipLeft: showArgs.tooltipLeft,
44014
+ tooltipTop: showArgs.tooltipTop,
44015
+ lineLeft: showArgs.lineLeft,
44016
+ tooltipData: showArgs.tooltipData
44017
+ });
44018
+ }, [setTooltipState]);
44019
+ var hideTooltip = useCallback(function () {
44020
+ return setTooltipState({
44021
+ tooltipOpen: false,
44022
+ tooltipLeft: undefined,
44023
+ lineLeft: undefined,
44024
+ tooltipTop: undefined,
44025
+ tooltipData: undefined
44026
+ });
44027
+ }, [setTooltipState]);
44028
+ return {
44029
+ tooltipOpen: tooltipState.tooltipOpen,
44030
+ tooltipLeft: tooltipState.tooltipLeft,
44031
+ tooltipTop: tooltipState.tooltipTop,
44032
+ lineLeft: tooltipState.lineLeft,
44033
+ tooltipData: tooltipState.tooltipData,
44034
+ updateTooltip: setTooltipState,
44035
+ showTooltip: showTooltip,
44036
+ hideTooltip: hideTooltip
44037
+ };
44038
+ }
44039
+
44040
+ function useYScale(innerHeight, scale) {
44041
+ return useMemo(function () {
44042
+ return scaleLinear({
44043
+ range: [innerHeight, 0],
44044
+ domain: scale.ordering === 'asc' ? [scale.min, scale.max] : [scale.max, scale.min],
44045
+ nice: true,
44046
+ round: true
44047
+ });
44048
+ }, [innerHeight, scale]);
44049
+ }
44050
+
44051
+ var LegendItemBox = function LegendItemBox(_ref) {
44052
+ var color = _ref.color,
44053
+ style = _ref.style;
44054
+ return jsx("svg", {
44055
+ width: 10,
44056
+ height: 10,
44057
+ style: {
44058
+ display: 'block'
44059
+ },
44060
+ children: style.type === 'line' ? style.strokeDasharray !== null ? jsx("line", {
44061
+ x1: "0",
44062
+ y1: "5",
44063
+ x2: "10",
44064
+ y2: "5",
44065
+ stroke: color,
44066
+ strokeWidth: style.strokeWidth,
44067
+ strokeDasharray: 2
44068
+ }) : jsx("line", {
44069
+ x1: "0",
44070
+ y1: "5",
44071
+ x2: "10",
44072
+ y2: "5",
44073
+ stroke: color,
44074
+ strokeWidth: style.strokeWidth
44075
+ }) : jsx("rect", {
44076
+ fill: color,
44077
+ width: 10,
44078
+ height: 10,
44079
+ rx: "2"
44080
+ })
44081
+ });
44082
+ };
44083
+ var LegendItemSquare = function LegendItemSquare(_ref2) {
44084
+ var color = _ref2.color;
44085
+ return jsx("svg", {
44086
+ width: 8,
44087
+ height: 8,
44088
+ style: {
44089
+ display: 'block'
44090
+ },
44091
+ children: jsx("rect", {
44092
+ fill: color,
44093
+ width: 8,
44094
+ height: 8,
44095
+ rx: "2"
44096
+ })
44097
+ });
44098
+ };
44099
+ var LegendItemTriangle = function LegendItemTriangle(_ref3) {
44100
+ var color = _ref3.color;
44101
+ return jsx("svg", {
44102
+ width: 8,
44103
+ height: 8,
44104
+ style: {
44105
+ display: 'block',
44106
+ borderRadius: 1
44107
+ },
44108
+ children: jsx("polygon", {
44109
+ points: "0,0 10,10 0,10",
44110
+ fill: color
44111
+ })
44112
+ });
44113
+ };
44114
+
44115
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
44116
+ var LegendItem = function LegendItem(_ref) {
44117
+ var yKey = _ref.yKey,
44118
+ yKeyFormatted = _ref.yKeyFormatted,
44119
+ color = _ref.color,
44120
+ style = _ref.style,
44121
+ onClick = _ref.onClick,
44122
+ visible = _ref.visible,
44123
+ conditionalFormattingRules = _ref.conditionalFormattingRules;
44124
+ var relevantRules = useMemo(function () {
44125
+ return conditionalFormattingRules.filter(function (rule) {
44126
+ return rule.yKey === yKey;
44127
+ });
44128
+ }, [conditionalFormattingRules]);
44129
+ return jsxs("button", {
44130
+ type: "button",
44131
+ style: {
44132
+ all: 'unset',
44133
+ display: 'flex',
44134
+ flexWrap: 'nowrap',
44135
+ alignItems: 'center',
44136
+ outline: 'revert',
44137
+ gap: '4px',
44138
+ padding: '4px',
44139
+ cursor: 'pointer',
44140
+ marginRight: '10px'
44141
+ },
44142
+ onClick: onClick,
44143
+ children: [style.type === 'line' && jsxs("span", {
44144
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44145
+ name: "1mfeugk",
44146
+ styles: "height:10px;display:flex"
44147
+ } : {
44148
+ name: "mefz6m-LegendItem",
44149
+ styles: "height:10px;display:flex;label:LegendItem;",
44150
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
44151
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44152
+ }),
44153
+ children: [jsx(LegendItemBox, {
44154
+ color: color,
44155
+ style: style,
44156
+ yKey: yKey
44157
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44158
+ return jsx(LegendItemBox, {
44159
+ color: rule.color,
44160
+ style: style,
44161
+ yKey: yKey
44162
+ }, "rule-" + JSON.stringify(rule));
44163
+ })]
44164
+ }), style.type === 'bar' && jsxs("span", {
44165
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44166
+ name: "6b52m3",
44167
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
44168
+ } : {
44169
+ name: "pglbco-LegendItem",
44170
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
44171
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
44172
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44173
+ }),
44174
+ children: [jsx(LegendItemSquare, {
44175
+ color: color
44176
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44177
+ return jsx(LegendItemSquare, {
44178
+ color: rule.color
44179
+ }, "rule-" + JSON.stringify(rule));
44180
+ })]
44181
+ }), style.type === 'area' && jsxs("span", {
44182
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44183
+ name: "6b52m3",
44184
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px"
44185
+ } : {
44186
+ name: "pglbco-LegendItem",
44187
+ styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
44188
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFFeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZEl0ZW1Qcm9wczxUPiBleHRlbmRzIFNoYXBlRGVmaW5pdGlvbjxUPiB7XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIHZpc2libGU6IGJvb2xlYW47XG4gIHlLZXlGb3JtYXR0ZWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM6IEFycmF5PENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGU+O1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kSXRlbSA9ICh7XG4gIHlLZXksXG4gIHlLZXlGb3JtYXR0ZWQsXG4gIGNvbG9yLFxuICBzdHlsZSxcbiAgb25DbGljayxcbiAgdmlzaWJsZSxcbiAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMsXG59OiBMZWdlbmRJdGVtUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+KSA9PiB7XG4gIGNvbnN0IHJlbGV2YW50UnVsZXMgPSB1c2VNZW1vKCgpID0+IGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLmZpbHRlcihydWxlID0+IHJ1bGUueUtleSA9PT0geUtleSksIFtcbiAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8YnV0dG9uXG4gICAgICBrZXk9e2BsZWdlbmQtJHt5S2V5fWB9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGFsbDogJ3Vuc2V0JyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBvdXRsaW5lOiAncmV2ZXJ0JyxcbiAgICAgICAgZ2FwOiAnNHB4JyxcbiAgICAgICAgcGFkZGluZzogJzRweCcsXG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgICAgICBtYXJnaW5SaWdodDogJzEwcHgnLFxuICAgICAgfX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge3N0eWxlLnR5cGUgPT09ICdsaW5lJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiAxMCwgZGlzcGxheTogJ2ZsZXgnIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbUJveCBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfSB5S2V5PXt5S2V5fSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgIGNvbG9yPXtydWxlLmNvbG9yfVxuICAgICAgICAgICAgICAgIGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfVxuICAgICAgICAgICAgICAgIHN0eWxlPXtzdHlsZSBhcyBMaW5lU3R5bGVzfVxuICAgICAgICAgICAgICAgIHlLZXk9e3lLZXl9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYmFyJyAmJiAoXG4gICAgICAgIDxzcGFuIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2ZsZXgnLCBmbGV4RGlyZWN0aW9uOiAncm93JywgYWxpZ25JdGVtczogJ2NlbnRlcicsIGdhcDogMiB9KX0+XG4gICAgICAgICAgPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1TcXVhcmUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2FyZWEnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVRyaWFuZ2xlIGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICB7cmVsZXZhbnRSdWxlcy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICByZWxldmFudFJ1bGVzLm1hcChydWxlID0+IDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e3J1bGUuY29sb3J9IGtleT17YHJ1bGUtJHtKU09OLnN0cmluZ2lmeShydWxlKX1gfSAvPil9XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICl9XG4gICAgICA8c3BhblxuICAgICAgICBzdHlsZT17e1xuICAgICAgICAgIGZvbnRTaXplOiAnMTJweCcsXG4gICAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdibG9jaycsXG4gICAgICAgICAgdGV4dERlY29yYXRpb246IHZpc2libGUgPyAnbm9uZScgOiAnbGluZS10aHJvdWdoJyxcbiAgICAgICAgICB0ZXh0V3JhcDogJ25vd3JhcCcsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHt5S2V5Rm9ybWF0dGVkID8geUtleUZvcm1hdHRlZCA6IHlLZXl9XG4gICAgICA8L3NwYW4+XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuIl19 */",
44189
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
44190
+ }),
44191
+ children: [jsx(LegendItemTriangle, {
44192
+ color: color
44193
+ }), relevantRules.length > 0 && relevantRules.map(function (rule) {
44194
+ return jsx(LegendItemTriangle, {
44195
+ color: rule.color
44196
+ }, "rule-" + JSON.stringify(rule));
44197
+ })]
44198
+ }), jsx("span", {
44199
+ style: {
44200
+ fontSize: '12px',
44201
+ lineHeight: '16px',
44202
+ display: 'block',
44203
+ textDecoration: visible ? 'none' : 'line-through',
44204
+ textWrap: 'nowrap'
44205
+ },
44206
+ children: yKeyFormatted ? yKeyFormatted : yKey
44207
+ })]
44208
+ }, "legend-" + yKey);
44209
+ };
44210
+
44211
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$7() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
44212
+ var Legend$1 = function Legend(_ref) {
44213
+ var keys = _ref.keys,
44214
+ setVisibleYKeys = _ref.setVisibleYKeys,
44215
+ marginLeft = _ref.marginLeft,
44216
+ items = _ref.items;
44217
+ var handleOnClick = function handleOnClick(item, legendItem) {
44218
+ setVisibleYKeys && setVisibleYKeys(function (prev) {
44219
+ var newVisibleLegendItems = [];
44220
+ if (prev.length === item.legendItems.length) {
44221
+ newVisibleLegendItems = [legendItem.yKey];
44222
+ } else {
44223
+ if (prev.includes(legendItem.yKey)) {
44224
+ newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
44225
+ return prevLegendItemId !== legendItem.yKey;
44226
+ });
44227
+ } else {
44228
+ newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
44229
+ }
44230
+ }
44231
+ return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
44232
+ return legendItem.yKey;
44233
+ }) : newVisibleLegendItems;
44234
+ });
44235
+ };
44236
+ return jsx("div", {
44246
44237
  className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44247
- name: "4zleql",
44248
- styles: "display:block"
44238
+ name: "1nbollx",
44239
+ styles: "height:40px;padding-top:8px"
44249
44240
  } : {
44250
- name: "fx4tbw-ChartWrapper",
44251
- styles: "display:block;label:ChartWrapper;",
44252
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxudHlwZSBDaGFydFdyYXBwZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHNob3dMZWdlbmQ6IGJvb2xlYW47XG4gIG9uTW91c2VNb3ZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG4gIG9uTW91c2VMZWF2ZT86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyPFNWR1NWR0VsZW1lbnQ+O1xufSAmIFJlYWN0LlNWR1Byb3BzPFNWR1NWR0VsZW1lbnQ+O1xuXG5leHBvcnQgY29uc3QgQ2hhcnRXcmFwcGVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIHNob3dMZWdlbmQsXG4gIG9uTW91c2VNb3ZlLFxuICBvbk1vdXNlTGVhdmUsXG4gIC4uLnN2Z1Byb3BzXG59OiBDaGFydFdyYXBwZXJQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIGhlaWdodD17aGVpZ2h0IC0gKHNob3dMZWdlbmQgPyA0MCA6IDApfVxuICAgICAgb25Nb3VzZU1vdmU9e29uTW91c2VNb3ZlfVxuICAgICAgb25Nb3VzZUxlYXZlPXtvbk1vdXNlTGVhdmV9XG4gICAgICBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdibG9jaycgfSl9XG4gICAgICB7Li4uc3ZnUHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvc3ZnPlxuICApO1xufTtcbiJdfQ== */",
44253
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
44241
+ name: "qz6h7j-Legend",
44242
+ styles: "height:40px;padding-top:8px;label:Legend;",
44243
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */",
44244
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
44245
+ }),
44246
+ children: jsx(Scrollbar, {
44247
+ className: /*#__PURE__*/css$1({
44248
+ display: 'flex',
44249
+ flexDirection: 'row',
44250
+ flexWrap: 'nowrap',
44251
+ alignItems: 'center',
44252
+ marginLeft: marginLeft ? marginLeft + "px" : undefined
44253
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0RtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQnViYmxlU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CdWJibGVDaGFydFYyL3R5cGVzJztcblxudHlwZSBJdGVtPFQ+ID0ge1xuICBsZWdlbmRJdGVtczogQXJyYXk8U2hhcGVEZWZpbml0aW9uPFQ+PjtcbiAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59O1xuZXhwb3J0IHR5cGUgTGVnZW5kUHJvcHM8VD4gPSB7XG4gIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xuICBpdGVtczogSXRlbTxUPltdO1xufTtcblxuZXhwb3J0IGNvbnN0IExlZ2VuZCA9ICh7XG4gIGtleXMsXG4gIHNldFZpc2libGVZS2V5cyxcbiAgbWFyZ2luTGVmdCxcbiAgaXRlbXMsXG59OiBMZWdlbmRQcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcyB8IEJ1YmJsZVN0eWxlcz4pID0+IHtcbiAgY29uc3QgaGFuZGxlT25DbGljayA9IChcbiAgICBpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzIHwgQnViYmxlU3R5bGVzPixcbiAgICBsZWdlbmRJdGVtOiBTaGFwZURlZmluaXRpb248QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXMgfCBCdWJibGVTdHlsZXM+XG4gICkgPT4ge1xuICAgIHNldFZpc2libGVZS2V5cyAmJlxuICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgaWYgKHByZXYubGVuZ3RoID09PSBpdGVtLmxlZ2VuZEl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG5ld1Zpc2libGVMZWdlbmRJdGVtcy5sZW5ndGggPT09IDBcbiAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y3NzKHsgaGVpZ2h0OiA0MCwgcGFkZGluZ1RvcDogOCB9KX0+XG4gICAgICA8U2Nyb2xsYmFyXG4gICAgICAgIGNsYXNzTmFtZT17Y3NzKHtcbiAgICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgZmxleFdyYXA6ICdub3dyYXAnLFxuICAgICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSl9XG4gICAgICAgIHg9e3RydWV9XG4gICAgICA+XG4gICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXMubWFwKFxuICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAga2V5c1tsZWdlbmRJdGVtLnlLZXldICYmIChcbiAgICAgICAgICAgICAgICAgIDxMZWdlbmRJdGVtXG4gICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICBrZXk9e2BsZWdlbmQtJHtsZWdlbmRJdGVtLnlLZXl9YH1cbiAgICAgICAgICAgICAgICAgICAgeUtleUZvcm1hdHRlZD17a2V5c1tsZWdlbmRJdGVtLnlLZXldLmtleUZvcm1hdHRlZH1cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZU9uQ2xpY2soaXRlbSwgbGVnZW5kSXRlbSk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHZpc2libGU9e3NldFZpc2libGVZS2V5cyA/IGl0ZW0udmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgOiB0cnVlfVxuICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcz17aXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlc31cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICApKX1cbiAgICAgIDwvU2Nyb2xsYmFyPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ== */"),
44254
+ x: true,
44255
+ children: items.map(function (item, index) {
44256
+ return jsx(Fragment, {
44257
+ children: item.legendItems.map(function (legendItem) {
44258
+ return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
44259
+ key: "legend-" + legendItem.yKey,
44260
+ yKeyFormatted: keys[legendItem.yKey].keyFormatted,
44261
+ onClick: function onClick() {
44262
+ handleOnClick(item, legendItem);
44263
+ },
44264
+ visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
44265
+ conditionalFormattingRules: item.conditionalFormattingRules
44266
+ }));
44267
+ })
44268
+ }, index);
44269
+ })
44254
44270
  })
44255
- }, svgProps, {
44256
- children: children
44257
- }));
44271
+ });
44272
+ };
44273
+
44274
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$8() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
44275
+ var MIN_TOOLTIP_WIDTH = 180;
44276
+ var TOOLTIP_OFFSET = 20;
44277
+ var SCROLLBAR_WIDTH = 40;
44278
+ var Tooltip$1 = function Tooltip(_ref) {
44279
+ var _tooltipData$xKey$for, _tooltipData$xKey;
44280
+ var keys = _ref.keys,
44281
+ showRoundedTotal = _ref.showRoundedTotal,
44282
+ tooltipData = _ref.tooltipData,
44283
+ tooltipLeft = _ref.tooltipLeft,
44284
+ tooltipTop = _ref.tooltipTop,
44285
+ xKey = _ref.xKey,
44286
+ yKeys = _ref.yKeys,
44287
+ theme = _ref.theme,
44288
+ items = _ref.items,
44289
+ _ref$shouldShowColorL = _ref.shouldShowColorLegend,
44290
+ shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
44291
+ var tooltipRef = useRef(null);
44292
+ var _useState = useState({
44293
+ left: tooltipLeft
44294
+ }),
44295
+ position = _useState[0],
44296
+ setPosition = _useState[1];
44297
+ useEffect(function () {
44298
+ var adjustTooltipPosition = function adjustTooltipPosition() {
44299
+ var tooltipElement = tooltipRef.current;
44300
+ if (tooltipElement) {
44301
+ var screenWidth = window.innerWidth;
44302
+ var rect = tooltipElement.getBoundingClientRect();
44303
+ var width = rect.width;
44304
+ if (width < MIN_TOOLTIP_WIDTH) {
44305
+ width = MIN_TOOLTIP_WIDTH;
44306
+ }
44307
+ var left = tooltipLeft + TOOLTIP_OFFSET;
44308
+ if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {
44309
+ left = tooltipLeft - width - TOOLTIP_OFFSET;
44310
+ }
44311
+ setPosition({
44312
+ left: left
44313
+ });
44314
+ }
44315
+ };
44316
+ adjustTooltipPosition();
44317
+ }, [tooltipLeft]);
44318
+ return /*#__PURE__*/createPortal(jsx("div", {
44319
+ ref: tooltipRef,
44320
+ style: _extends({
44321
+ position: 'absolute',
44322
+ left: position.left,
44323
+ top: tooltipTop,
44324
+ zIndex: 2147483647 * 10
44325
+ }, theme),
44326
+ children: jsxs("div", {
44327
+ style: {
44328
+ wordBreak: 'break-all'
44329
+ },
44330
+ children: [jsx("div", {
44331
+ className: /*#__PURE__*/css$1({
44332
+ fontFamily: 'inherit',
44333
+ lineHeight: 'inherit',
44334
+ letterSpacing: 'inherit',
44335
+ fontWeight: 'bold',
44336
+ fontSize: '15px',
44337
+ width: '100%',
44338
+ minWidth: MIN_TOOLTIP_WIDTH
44339
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA6FqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {tooltipData[legendItem.yKey].formattedValue\n                              ? tooltipData[legendItem.yKey].formattedValue\n                              : tooltipData[legendItem.yKey].value}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */"),
44340
+ children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
44341
+ }), jsx("table", {
44342
+ cellPadding: 0,
44343
+ cellSpacing: 0,
44344
+ className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
44345
+ name: "x8luwd",
44346
+ styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none"
44347
+ } : {
44348
+ name: "9a1sa-Tooltip",
44349
+ styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
44350
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA4GqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {tooltipData[legendItem.yKey].formattedValue\n                              ? tooltipData[legendItem.yKey].formattedValue\n                              : tooltipData[legendItem.yKey].value}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */",
44351
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
44352
+ }),
44353
+ children: jsxs("tbody", {
44354
+ children: [items.map(function (item, index) {
44355
+ var _item$legendItems;
44356
+ return jsx(Fragment, {
44357
+ children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
44358
+ var _item$visibleYKeys, _item$conditionalForm;
44359
+ if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
44360
+ // yKey could not be found in tooltipData
44361
+ return null;
44362
+ }
44363
+ return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxs("tr", {
44364
+ children: [shouldShowColorLegend && jsx("td", {
44365
+ style: {
44366
+ verticalAlign: 'middle',
44367
+ padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
44368
+ width: 'auto'
44369
+ },
44370
+ children: jsx(LegendItemBox, {
44371
+ color: getColor({
44372
+ defaultColor: legendItem.color,
44373
+ value: tooltipData[legendItem.yKey].value,
44374
+ yKey: legendItem.yKey,
44375
+ conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
44376
+ }),
44377
+ style: legendItem.style,
44378
+ yKey: legendItem.yKey
44379
+ })
44380
+ }), jsx("td", {
44381
+ style: {
44382
+ padding: '8px 0 0 0'
44383
+ },
44384
+ children: keys[legendItem.yKey].keyFormatted
44385
+ }), jsx("td", {
44386
+ style: {
44387
+ fontWeight: 'bold',
44388
+ padding: '8px 0 0 16px'
44389
+ },
44390
+ children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
44391
+ })]
44392
+ }, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
44393
+ })
44394
+ }, index);
44395
+ }), showRoundedTotal && yKeys && jsxs("tr", {
44396
+ children: [jsx("td", {
44397
+ colSpan: 2,
44398
+ style: {
44399
+ padding: '12px 0 0 0'
44400
+ },
44401
+ children: "Rounded Total"
44402
+ }), jsx("td", {
44403
+ style: {
44404
+ fontWeight: 'bold',
44405
+ padding: '12px 0 0 16px'
44406
+ },
44407
+ children: yKeys.reduce(function (total, key) {
44408
+ return total + Math.round(tooltipData[key].value);
44409
+ }, 0)
44410
+ })]
44411
+ })]
44412
+ })
44413
+ })]
44414
+ })
44415
+ }), document.body);
44258
44416
  };
44259
44417
 
44260
44418
  var CrosshairCircle = function CrosshairCircle(_ref) {
@@ -44319,84 +44477,6 @@ var Line = function Line(_ref) {
44319
44477
  });
44320
44478
  };
44321
44479
 
44322
- var _excluded$h = ["tooltipOpen"];
44323
- function useTooltip$1(initialTooltipState) {
44324
- var _useState = useState(_extends({
44325
- tooltipOpen: false
44326
- }, initialTooltipState)),
44327
- tooltipState = _useState[0],
44328
- setTooltipState = _useState[1];
44329
- var showTooltip = useCallback(function (showArgs) {
44330
- return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
44331
- var show = _objectWithoutPropertiesLoose(_ref, _excluded$h);
44332
- return _extends({}, showArgs(show), {
44333
- tooltipOpen: true
44334
- });
44335
- } : {
44336
- tooltipOpen: true,
44337
- tooltipLeft: showArgs.tooltipLeft,
44338
- tooltipTop: showArgs.tooltipTop,
44339
- lineLeft: showArgs.lineLeft,
44340
- tooltipData: showArgs.tooltipData
44341
- });
44342
- }, [setTooltipState]);
44343
- var hideTooltip = useCallback(function () {
44344
- return setTooltipState({
44345
- tooltipOpen: false,
44346
- tooltipLeft: undefined,
44347
- lineLeft: undefined,
44348
- tooltipTop: undefined,
44349
- tooltipData: undefined
44350
- });
44351
- }, [setTooltipState]);
44352
- return {
44353
- tooltipOpen: tooltipState.tooltipOpen,
44354
- tooltipLeft: tooltipState.tooltipLeft,
44355
- tooltipTop: tooltipState.tooltipTop,
44356
- lineLeft: tooltipState.lineLeft,
44357
- tooltipData: tooltipState.tooltipData,
44358
- updateTooltip: setTooltipState,
44359
- showTooltip: showTooltip,
44360
- hideTooltip: hideTooltip
44361
- };
44362
- }
44363
-
44364
- function useYScale(innerHeight, scale) {
44365
- return useMemo(function () {
44366
- return scaleLinear({
44367
- range: [innerHeight, 0],
44368
- domain: scale.ordering === 'asc' ? [scale.min, scale.max] : [scale.max, scale.min],
44369
- nice: true,
44370
- round: true
44371
- });
44372
- }, [innerHeight, scale]);
44373
- }
44374
-
44375
- var DataLabel = function DataLabel(_ref) {
44376
- var x = _ref.x,
44377
- y = _ref.y,
44378
- title = _ref.title,
44379
- dx = _ref.dx,
44380
- dy = _ref.dy,
44381
- color = _ref.color,
44382
- backgroundColor = _ref.backgroundColor;
44383
- return jsx(Annotation$1, {
44384
- x: x,
44385
- y: y,
44386
- dx: dx,
44387
- dy: dy,
44388
- children: jsx(Label$1, {
44389
- title: title,
44390
- showAnchorLine: false,
44391
- showBackground: false,
44392
- backgroundFill: backgroundColor,
44393
- fontColor: color,
44394
- titleFontSize: 10,
44395
- verticalAnchor: "middle"
44396
- })
44397
- });
44398
- };
44399
-
44400
44480
  var LineChart$5 = function LineChart(_ref) {
44401
44481
  var _theme$axis;
44402
44482
  var chart = _ref.chart,
@@ -44486,6 +44566,26 @@ var LineChart$5 = function LineChart(_ref) {
44486
44566
  var handleMouseLeave = useCallback(function () {
44487
44567
  hideTooltip();
44488
44568
  }, [hideTooltip]);
44569
+ var labelDictionary = useMemo(function () {
44570
+ return getLabelDictionary(chart.data, chart.y.keys);
44571
+ }, [chart.data, chart.y.keys]);
44572
+ var memoizedLines = useMemo(function () {
44573
+ if (xScaleKey === null || xScale === null) return null;
44574
+ return jsx(Lines, {
44575
+ lines: chart.lines,
44576
+ conditionalFormattingRules: chart.conditionalFormattingRules,
44577
+ curve: curve,
44578
+ yKeys: chart.y.keys,
44579
+ visibleYKeys: visibleYKeys,
44580
+ data: dataFlattened,
44581
+ xScaleKey: xScaleKey,
44582
+ xScaleDataType: xScaleDataType,
44583
+ xScale: xScale,
44584
+ yScale: _yScale,
44585
+ showLabels: options.showLabels,
44586
+ labelDictionary: labelDictionary
44587
+ });
44588
+ }, [chart.lines, chart.conditionalFormattingRules, curve, chart.y.keys, visibleYKeys, dataFlattened, xScaleKey, xScaleDataType, xScale, _yScale, options.showLabels, labelDictionary]);
44489
44589
  if (width === 0 || height === 0 || xScale === null) return jsx(React__default.Fragment, {});
44490
44590
  var yTickValues = chart.y.ticks.map(function (tick) {
44491
44591
  return Number(tick.value);
@@ -44530,19 +44630,7 @@ var LineChart$5 = function LineChart(_ref) {
44530
44630
  ticks: yTickValues,
44531
44631
  stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
44532
44632
  }), jsx(Group$2, {
44533
- children: xScaleKey !== null && jsx(Lines, {
44534
- lines: chart.lines,
44535
- conditionalFormattingRules: chart.conditionalFormattingRules,
44536
- curve: curve,
44537
- yKeys: chart.y.keys,
44538
- visibleYKeys: visibleYKeys,
44539
- data: dataFlattened,
44540
- xScaleKey: xScaleKey,
44541
- xScaleDataType: xScaleDataType,
44542
- xScale: xScale,
44543
- yScale: _yScale,
44544
- showLabels: options.showLabels
44545
- })
44633
+ children: memoizedLines
44546
44634
  })]
44547
44635
  }), tooltipData && jsxs("g", {
44548
44636
  children: [jsx(Line, {
@@ -44591,7 +44679,7 @@ var LineChart$5 = function LineChart(_ref) {
44591
44679
  })]
44592
44680
  });
44593
44681
  };
44594
- function Lines(_ref2) {
44682
+ var Lines = /*#__PURE__*/memo(function Lines(_ref2) {
44595
44683
  var yKeys = _ref2.yKeys,
44596
44684
  visibleYKeys = _ref2.visibleYKeys,
44597
44685
  data = _ref2.data,
@@ -44602,7 +44690,8 @@ function Lines(_ref2) {
44602
44690
  lines = _ref2.lines,
44603
44691
  curve = _ref2.curve,
44604
44692
  conditionalFormattingRules = _ref2.conditionalFormattingRules,
44605
- showLabels = _ref2.showLabels;
44693
+ showLabels = _ref2.showLabels,
44694
+ labelDictionary = _ref2.labelDictionary;
44606
44695
  var _useMemo = useMemo(function () {
44607
44696
  var allBarValues = getAllChartValues(data, yKeys);
44608
44697
  var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(allBarValues),
@@ -44668,7 +44757,8 @@ function Lines(_ref2) {
44668
44757
  totalItems: data.length,
44669
44758
  minValue: minValue,
44670
44759
  maxValue: maxValue,
44671
- showLabels: showLabels
44760
+ showLabels: showLabels,
44761
+ labelDictionary: labelDictionary
44672
44762
  });
44673
44763
  })]
44674
44764
  });
@@ -44723,33 +44813,35 @@ function Lines(_ref2) {
44723
44813
  }, clipPathId);
44724
44814
  })]
44725
44815
  });
44726
- function LineLabel(_ref5) {
44727
- var chartData = _ref5.chartData,
44728
- yKey = _ref5.yKey,
44729
- xScaleKey = _ref5.xScaleKey,
44730
- xScale = _ref5.xScale,
44731
- yScale = _ref5.yScale,
44732
- totalItems = _ref5.totalItems,
44733
- minValue = _ref5.minValue,
44734
- maxValue = _ref5.maxValue,
44735
- showLabels = _ref5.showLabels;
44736
- var xValue = chartData[xScaleKey];
44737
- var yValue = chartData[yKey];
44738
- var xPadding = 18;
44739
- var yPadding = 8;
44740
- var xPosition = xScale(xValue);
44741
- var yPosition = yScale(yValue);
44742
- var showMinMax = showMinMaxLabel(Number(yValue), totalItems, minValue, maxValue);
44743
- if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
44744
- return jsx(DataLabel, {
44745
- x: xPosition - xPadding,
44746
- y: yPosition - yPadding,
44747
- dx: 2,
44748
- dy: 0,
44749
- title: yValue
44750
- });
44751
- }
44752
- }
44816
+ });
44817
+ var LineLabel = /*#__PURE__*/memo(function LineLabel(_ref5) {
44818
+ var chartData = _ref5.chartData,
44819
+ yKey = _ref5.yKey,
44820
+ xScaleKey = _ref5.xScaleKey,
44821
+ xScale = _ref5.xScale,
44822
+ yScale = _ref5.yScale,
44823
+ totalItems = _ref5.totalItems,
44824
+ minValue = _ref5.minValue,
44825
+ maxValue = _ref5.maxValue,
44826
+ showLabels = _ref5.showLabels,
44827
+ labelDictionary = _ref5.labelDictionary;
44828
+ var xValue = chartData[xScaleKey];
44829
+ var yValue = chartData[yKey];
44830
+ var xPadding = 18;
44831
+ var yPadding = 8;
44832
+ var xPosition = xScale(xValue);
44833
+ var yPosition = yScale(yValue);
44834
+ var showMinMax = showMinMaxLabel(Number(yValue), totalItems, minValue, maxValue);
44835
+ var displayValue = getFormattedValue(yValue, labelDictionary);
44836
+ if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
44837
+ return jsx(DataLabel, {
44838
+ x: xPosition - xPadding,
44839
+ y: yPosition - yPadding,
44840
+ dx: 2,
44841
+ dy: 0,
44842
+ title: displayValue
44843
+ });
44844
+ });
44753
44845
 
44754
44846
  var BAR_RADIUS = 2;
44755
44847
 
@@ -44795,7 +44887,8 @@ function BarGroup(_ref) {
44795
44887
  yLabelPosition = _ref.yLabelPosition,
44796
44888
  showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
44797
44889
  labelStyle = _ref.labelStyle,
44798
- showLabels = _ref.showLabels;
44890
+ showLabels = _ref.showLabels,
44891
+ formattedData = _ref.formattedData;
44799
44892
  var getGroupPosition = function getGroupPosition(d) {
44800
44893
  var xValue = d[xKey];
44801
44894
  if (xScaleDataType === 'string') return String(xValue);
@@ -44807,6 +44900,9 @@ function BarGroup(_ref) {
44807
44900
  }
44808
44901
  return String(xValue);
44809
44902
  };
44903
+ var formattedLabelsDict = useMemo(function () {
44904
+ return getLabelDictionary(formattedData, keys);
44905
+ }, [formattedData, keys]);
44810
44906
  var _useMemo = useMemo(function () {
44811
44907
  var allBarValues = getAllChartValues(data, keys);
44812
44908
  var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(allBarValues),
@@ -44855,7 +44951,9 @@ function BarGroup(_ref) {
44855
44951
  minValue: minValue,
44856
44952
  maxValue: maxValue,
44857
44953
  totalItems: totalItems,
44858
- showLabels: showLabels
44954
+ showLabels: showLabels,
44955
+ labelDictionary: formattedLabelsDict,
44956
+ yScale: yScale
44859
44957
  }, "bar-" + bar.index + "-" + bar.x);
44860
44958
  })
44861
44959
  }, "bar-group-" + barGroup.index + "-" + barGroup.x0);
@@ -44877,11 +44975,17 @@ var Bar = function Bar(_ref2) {
44877
44975
  minValue = _ref2.minValue,
44878
44976
  maxValue = _ref2.maxValue,
44879
44977
  totalItems = _ref2.totalItems,
44880
- showLabels = _ref2.showLabels;
44978
+ showLabels = _ref2.showLabels,
44979
+ labelDictionary = _ref2.labelDictionary,
44980
+ yScale = _ref2.yScale;
44881
44981
  var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
44882
- var labelX = bar.width < 10 ? bar.x - 14 : bar.x / 2;
44883
- var labelY = bar.y - 4;
44982
+ var xPadding = 14;
44983
+ var yPadding = 8;
44984
+ var labelX = bar.x - xPadding;
44985
+ var barTopY = yScale(bar.value);
44986
+ var labelY = barTopY - yPadding;
44884
44987
  var showMinMax = showMinMaxLabel(bar.value, totalItems, minValue, maxValue);
44988
+ var displayValue = getFormattedValue(bar.value, labelDictionary);
44885
44989
  return jsxs(Fragment, {
44886
44990
  children: [showBar && jsx(BarRect, {
44887
44991
  barRectKey: "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
@@ -44897,7 +45001,7 @@ var Bar = function Bar(_ref2) {
44897
45001
  }), showLabels && showMinMax && jsx(DataLabel, {
44898
45002
  x: labelX,
44899
45003
  y: labelY,
44900
- title: bar.value,
45004
+ title: displayValue,
44901
45005
  dx: 1,
44902
45006
  dy: 0
44903
45007
  }), jsx(BarLabel, {
@@ -44928,7 +45032,7 @@ var BarRect = function BarRect(_ref3) {
44928
45032
  } : {
44929
45033
  name: "1ltmijl-classes",
44930
45034
  styles: "cursor:pointer;label:classes;",
44931
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AAkNgC","file":"BarGroup.tsx","sourcesContent":["import { css } from '@emotion/css';\nimport { Group } from '@visx/group';\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';\nimport { Fragment, useState, useMemo } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS';\nimport { getBarFill } from '../getBarFill';\nimport { DataLabel } from '../../components/DataLabel';\nimport {\n  showMinMaxLabel,\n  getMinMaxChartValueFromNumberArray,\n  getAllChartValues,\n} from 'shared-logic/src/DataLabel/index';\n\nexport type BarGroupProps = {\n  data: ChartDataDefinition[];\n  keys: string[];\n  height: number;\n  xKey: string;\n  xScaleDataType: DataType;\n  xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n  innerXScale: ScaleBand<string> | undefined;\n  yScale: ScaleLinear<number, number, never>;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  bars: ShapeDefinition<BarStyles>[];\n  enableHover?: boolean;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  showLabels?: boolean;\n};\n\nexport function BarGroup({\n  data,\n  keys,\n  height,\n  xKey,\n  xScaleDataType,\n  xScale,\n  innerXScale,\n  yScale,\n  onClick,\n  conditionalFormattingRules,\n  bars,\n  enableHover,\n  yAxisLabels,\n  yLabelPosition,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n  showLabels,\n}: BarGroupProps) {\n  const getGroupPosition = (d: DatumObject) => {\n    const xValue = d[xKey as keyof typeof d];\n\n    if (xScaleDataType === 'string') return String(xValue);\n\n    if (xScaleDataType === 'date_time') {\n      return new Date(String(xValue));\n    }\n\n    if (xScaleDataType === 'number') {\n      return Number(xValue);\n    }\n\n    return String(xValue);\n  };\n\n  const { minValue, maxValue, totalItems } = useMemo(() => {\n    const allBarValues = getAllChartValues(data, keys);\n    const { minValue, maxValue } = getMinMaxChartValueFromNumberArray(allBarValues);\n\n    return {\n      minValue,\n      maxValue,\n      totalItems: allBarValues.length,\n    };\n  }, [data, keys]);\n\n  return (\n    <VisxBarGroup<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      height={height}\n      x0={getGroupPosition}\n      // @ts-ignore\n      x0Scale={xScale}\n      // @ts-ignore\n      x1Scale={innerXScale}\n      yScale={yScale}\n      color={() => ''}\n    >\n      {(barGroups) => {\n        return barGroups.map((barGroup) => (\n          <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n            {barGroup.bars.map((bar) => (\n              <Bar\n                key={`bar-${bar.index}-${bar.x}`}\n                bar={bar}\n                barGroup={barGroup}\n                bars={bars}\n                conditionalFormattingRules={conditionalFormattingRules}\n                enableHover={enableHover}\n                labelStyle={labelStyle}\n                onClick={onClick}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                yAxisLabels={yAxisLabels}\n                yLabelPosition={yLabelPosition}\n                minValue={minValue}\n                maxValue={maxValue}\n                totalItems={totalItems}\n                showLabels={showLabels}\n              />\n            ))}\n          </Group>\n        ));\n      }}\n    </VisxBarGroup>\n  );\n}\n\ntype BarProps = {\n  bar: any;\n  barGroup: any;\n  bars: ShapeDefinition<BarStyles>[];\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  enableHover?: boolean;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n  minValue: number;\n  maxValue: number;\n  totalItems: number;\n  showLabels?: boolean;\n};\n\nconst Bar = ({\n  bar,\n  barGroup,\n  bars,\n  conditionalFormattingRules,\n  enableHover,\n  labelStyle,\n  onClick,\n  showDetailedSubGroupingLabels,\n  yAxisLabels,\n  yLabelPosition,\n  minValue,\n  maxValue,\n  totalItems,\n  showLabels,\n}: BarProps) => {\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n  const labelX = bar.width < 10 ? bar.x - 14 : bar.x / 2;\n  const labelY = bar.y - 4;\n\n  const showMinMax = showMinMaxLabel(bar.value, totalItems, minValue, maxValue);\n\n  return (\n    <Fragment>\n      {showBar && (\n        <BarRect\n          barRectKey={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n          x={bar.x}\n          y={bar.y}\n          width={bar.width}\n          height={bar.height}\n          fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n          onClick={(e) => onClick(e, barGroup, bar)}\n          enableHover={enableHover}\n        />\n      )}\n\n      {showLabels && showMinMax && <DataLabel x={labelX} y={labelY} title={bar.value} dx={1} dy={0} />}\n\n      <BarLabel\n        bar={bar}\n        barGroup={barGroup}\n        yLabelPosition={yLabelPosition}\n        yAxisLabels={yAxisLabels}\n        showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n        labelStyle={labelStyle}\n      />\n    </Fragment>\n  );\n};\n\ntype BarRectProps = {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  barRectKey: string;\n  enableHover?: boolean;\n};\n\nconst BarRect = ({ onClick, fill, x, y, width, height, barRectKey, enableHover }: BarRectProps) => {\n  const [fillColor, setFillColor] = useState(fill);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setFillColor(lightenColor(fill, 0.8));\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setFillColor(fill);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={onClick}\n      onMouseEnter={handleOnMouseEnter}\n      onMouseLeave={handleOnMouseLeave}\n      className={classes}\n    />\n  );\n};\n\ntype BarLabelProps = {\n  bar: any;\n  barGroup: any;\n  yLabelPosition?: number;\n  yAxisLabels?: string[];\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n  bar,\n  barGroup,\n  yLabelPosition,\n  yAxisLabels,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: BarLabelProps) => {\n  if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n  const label = yAxisLabels[bar.index];\n  const columnLabel = label.split('•')[0];\n\n  let formattedColumnLabel: string;\n  if (columnLabel.length >= 13) {\n    formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n  } else {\n    formattedColumnLabel = columnLabel.slice(0, 13);\n  }\n\n  const labelXGap = 4;\n  const labelXPosition = bar.x + bar.width / 2 + labelXGap;\n\n  const labelYGap = 15;\n  const labelYPosition = yLabelPosition + labelYGap;\n\n  const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n  return (\n    <text\n      key={labelKey}\n      x={labelXPosition}\n      y={labelYPosition}\n      style={labelStyle}\n      transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n      textAnchor=\"end\"\n    >\n      {formattedColumnLabel}\n    </text>\n  );\n};\n"]} */",
45035
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AAkOgC","file":"BarGroup.tsx","sourcesContent":["import { css } from '@emotion/css';\nimport { Group } from '@visx/group';\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';\nimport { Fragment, useState, useMemo } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS';\nimport { getBarFill } from '../getBarFill';\nimport { DataLabel } from '../../components/DataLabel';\nimport {\n  showMinMaxLabel,\n  getMinMaxChartValueFromNumberArray,\n  getAllChartValues,\n  getLabelDictionary,\n  getFormattedValue,\n} from 'shared-logic/src/DataLabel/index';\n\nexport type BarGroupProps = {\n  data: ChartDataDefinition[];\n  keys: string[];\n  height: number;\n  xKey: string;\n  xScaleDataType: DataType;\n  xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n  innerXScale: ScaleBand<string> | undefined;\n  yScale: ScaleLinear<number, number, never>;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  bars: ShapeDefinition<BarStyles>[];\n  enableHover?: boolean;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  showLabels?: boolean;\n  formattedData?: ChartDataDefinition[];\n};\n\nexport function BarGroup({\n  data,\n  keys,\n  height,\n  xKey,\n  xScaleDataType,\n  xScale,\n  innerXScale,\n  yScale,\n  onClick,\n  conditionalFormattingRules,\n  bars,\n  enableHover,\n  yAxisLabels,\n  yLabelPosition,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n  showLabels,\n  formattedData,\n}: BarGroupProps) {\n  const getGroupPosition = (d: DatumObject) => {\n    const xValue = d[xKey as keyof typeof d];\n\n    if (xScaleDataType === 'string') return String(xValue);\n\n    if (xScaleDataType === 'date_time') {\n      return new Date(String(xValue));\n    }\n\n    if (xScaleDataType === 'number') {\n      return Number(xValue);\n    }\n\n    return String(xValue);\n  };\n\n  const formattedLabelsDict = useMemo(() => {\n    return getLabelDictionary(formattedData, keys);\n  }, [formattedData, keys]);\n\n  const { minValue, maxValue, totalItems } = useMemo(() => {\n    const allBarValues = getAllChartValues(data, keys);\n    const { minValue, maxValue } = getMinMaxChartValueFromNumberArray(allBarValues);\n\n    return {\n      minValue,\n      maxValue,\n      totalItems: allBarValues.length,\n    };\n  }, [data, keys]);\n  return (\n    <VisxBarGroup<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      height={height}\n      x0={getGroupPosition}\n      // @ts-ignore\n      x0Scale={xScale}\n      // @ts-ignore\n      x1Scale={innerXScale}\n      yScale={yScale}\n      color={() => ''}\n    >\n      {(barGroups) => {\n        return barGroups.map((barGroup) => (\n          <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n            {barGroup.bars.map((bar) => (\n              <Bar\n                key={`bar-${bar.index}-${bar.x}`}\n                bar={bar}\n                barGroup={barGroup}\n                bars={bars}\n                conditionalFormattingRules={conditionalFormattingRules}\n                enableHover={enableHover}\n                labelStyle={labelStyle}\n                onClick={onClick}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                yAxisLabels={yAxisLabels}\n                yLabelPosition={yLabelPosition}\n                minValue={minValue}\n                maxValue={maxValue}\n                totalItems={totalItems}\n                showLabels={showLabels}\n                labelDictionary={formattedLabelsDict}\n                yScale={yScale}\n              />\n            ))}\n          </Group>\n        ));\n      }}\n    </VisxBarGroup>\n  );\n}\n\ntype BarProps = {\n  bar: any;\n  barGroup: any;\n  bars: ShapeDefinition<BarStyles>[];\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  enableHover?: boolean;\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n  yAxisLabels?: string[];\n  yLabelPosition?: number;\n  minValue: number;\n  maxValue: number;\n  totalItems: number;\n  showLabels?: boolean;\n  labelDictionary?: { [key: string]: string };\n  yScale: ScaleLinear<number, number, never>;\n};\n\nconst Bar = ({\n  bar,\n  barGroup,\n  bars,\n  conditionalFormattingRules,\n  enableHover,\n  labelStyle,\n  onClick,\n  showDetailedSubGroupingLabels,\n  yAxisLabels,\n  yLabelPosition,\n  minValue,\n  maxValue,\n  totalItems,\n  showLabels,\n  labelDictionary,\n  yScale,\n}: BarProps) => {\n  const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n  const xPadding = 14;\n  const yPadding = 8;\n  const labelX = bar.x - xPadding;\n  const barTopY = yScale(bar.value);\n  const labelY = barTopY - yPadding;\n\n  const showMinMax = showMinMaxLabel(bar.value, totalItems, minValue, maxValue);\n\n  const displayValue = getFormattedValue(bar.value, labelDictionary);\n  return (\n    <Fragment>\n      {showBar && (\n        <BarRect\n          barRectKey={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${String(bar.key)}`}\n          x={bar.x}\n          y={bar.y}\n          width={bar.width}\n          height={bar.height}\n          fill={getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value)}\n          onClick={(e) => onClick(e, barGroup, bar)}\n          enableHover={enableHover}\n        />\n      )}\n\n      {showLabels && showMinMax && <DataLabel x={labelX} y={labelY} title={displayValue} dx={1} dy={0} />}\n\n      <BarLabel\n        bar={bar}\n        barGroup={barGroup}\n        yLabelPosition={yLabelPosition}\n        yAxisLabels={yAxisLabels}\n        showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n        labelStyle={labelStyle}\n      />\n    </Fragment>\n  );\n};\n\ntype BarRectProps = {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  barRectKey: string;\n  enableHover?: boolean;\n};\n\nconst BarRect = ({ onClick, fill, x, y, width, height, barRectKey, enableHover }: BarRectProps) => {\n  const [fillColor, setFillColor] = useState(fill);\n\n  const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n  const handleOnMouseEnter = () => {\n    if (enableHover) {\n      setFillColor(lightenColor(fill, 0.8));\n    }\n  };\n\n  const handleOnMouseLeave = () => {\n    if (enableHover) {\n      setFillColor(fill);\n    }\n  };\n\n  return (\n    <rect\n      key={barRectKey}\n      x={x}\n      y={y}\n      width={width}\n      height={height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={onClick}\n      onMouseEnter={handleOnMouseEnter}\n      onMouseLeave={handleOnMouseLeave}\n      className={classes}\n    />\n  );\n};\n\ntype BarLabelProps = {\n  bar: any;\n  barGroup: any;\n  yLabelPosition?: number;\n  yAxisLabels?: string[];\n  showDetailedSubGroupingLabels: boolean;\n  labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n  bar,\n  barGroup,\n  yLabelPosition,\n  yAxisLabels,\n  showDetailedSubGroupingLabels,\n  labelStyle,\n}: BarLabelProps) => {\n  if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n  const label = yAxisLabels[bar.index];\n  const columnLabel = label.split('•')[0];\n\n  let formattedColumnLabel: string;\n  if (columnLabel.length >= 13) {\n    formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n  } else {\n    formattedColumnLabel = columnLabel.slice(0, 13);\n  }\n\n  const labelXGap = 4;\n  const labelXPosition = bar.x + bar.width / 2 + labelXGap;\n\n  const labelYGap = 15;\n  const labelYPosition = yLabelPosition + labelYGap;\n\n  const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n  return (\n    <text\n      key={labelKey}\n      x={labelXPosition}\n      y={labelYPosition}\n      style={labelStyle}\n      transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n      textAnchor=\"end\"\n    >\n      {formattedColumnLabel}\n    </text>\n  );\n};\n"]} */",
44932
45036
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
44933
45037
  }) : '';
44934
45038
  var handleOnMouseEnter = function handleOnMouseEnter() {
@@ -45265,7 +45369,8 @@ var BarChart$5 = function BarChart(_ref) {
45265
45369
  yAxisLabels: yAxisLabels,
45266
45370
  yLabelPosition: ySubLabelPosition,
45267
45371
  labelStyle: themeCSS.labels,
45268
- showLabels: options.showLabels
45372
+ showLabels: options.showLabels,
45373
+ formattedData: chart.data
45269
45374
  }), options.stacked && xScaleKey !== null && jsx(BarStacked, {
45270
45375
  data: dataFlattened,
45271
45376
  keys: chart.y.keys,
@@ -45520,6 +45625,9 @@ var AreaChart$5 = function AreaChart(_ref) {
45520
45625
  };
45521
45626
  return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'natural'];
45522
45627
  }, [options.curve]);
45628
+ var labelDictionary = useMemo(function () {
45629
+ return getLabelDictionary(chart.data, chart.y.keys);
45630
+ }, [chart.data, chart.y.keys]);
45523
45631
  if (width === 0 || height === 0 || xScale === null) return jsx(React__default.Fragment, {});
45524
45632
  var yTickValues = chart.y.ticks.map(function (tick) {
45525
45633
  return Number(tick.value);
@@ -45660,7 +45768,8 @@ var AreaChart$5 = function AreaChart(_ref) {
45660
45768
  totalItems: dataFlattened.length,
45661
45769
  minValue: minValue,
45662
45770
  maxValue: maxValue,
45663
- showLabels: options.showLabels
45771
+ showLabels: options.showLabels,
45772
+ labelDictionary: labelDictionary
45664
45773
  });
45665
45774
  })]
45666
45775
  }, yKey + "-" + AREA_GRADIENT_ID_PREFIX);
@@ -45722,7 +45831,8 @@ function AreaLabel(_ref3) {
45722
45831
  totalItems = _ref3.totalItems,
45723
45832
  minValue = _ref3.minValue,
45724
45833
  maxValue = _ref3.maxValue,
45725
- showLabels = _ref3.showLabels;
45834
+ showLabels = _ref3.showLabels,
45835
+ labelDictionary = _ref3.labelDictionary;
45726
45836
  var xValue = chartData[xScaleKey];
45727
45837
  var yValue = chartData[yKey];
45728
45838
  var xPadding = 18;
@@ -45731,12 +45841,13 @@ function AreaLabel(_ref3) {
45731
45841
  var yPosition = yScale(yValue);
45732
45842
  var showMinMax = showMinMaxLabel(Number(yValue), totalItems, minValue, maxValue);
45733
45843
  if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
45844
+ var displayValue = getFormattedValue(yValue, labelDictionary);
45734
45845
  return jsx(DataLabel, {
45735
45846
  x: xPosition - xPadding,
45736
45847
  y: yPosition - yPadding,
45737
45848
  dx: 2,
45738
45849
  dy: 0,
45739
- title: yValue
45850
+ title: displayValue
45740
45851
  });
45741
45852
  }
45742
45853
  function Area(_ref4) {
@@ -48135,6 +48246,7 @@ var LineChartV2View = function LineChartV2View(props) {
48135
48246
  overflowX: 'hidden'
48136
48247
  },
48137
48248
  children: function children(parent) {
48249
+ var _props$attributes$lab;
48138
48250
  if (chartRepresentation.lines.length === 0) return jsx(LoadingComponent, {});
48139
48251
  return jsx(LineChart$5, {
48140
48252
  width: parent.width,
@@ -48145,7 +48257,7 @@ var LineChartV2View = function LineChartV2View(props) {
48145
48257
  removeStroke: false,
48146
48258
  showRoundedTotal: false,
48147
48259
  showLegend: props.attributes.legend,
48148
- showLabels: false,
48260
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
48149
48261
  axis: {
48150
48262
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
48151
48263
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -48505,7 +48617,7 @@ var AreaChartV2View = function AreaChartV2View(props) {
48505
48617
  overflowX: 'hidden'
48506
48618
  },
48507
48619
  children: function children(parent) {
48508
- var _props$attributes$vie2, _props$attributes$sta;
48620
+ var _props$attributes$vie2, _props$attributes$sta, _props$attributes$lab;
48509
48621
  if (chartRepresentation.areas.length === 0) return jsx(LoadingComponent, {});
48510
48622
  return jsx(AreaChart$5, {
48511
48623
  width: parent.width,
@@ -48518,7 +48630,7 @@ var AreaChartV2View = function AreaChartV2View(props) {
48518
48630
  removeStroke: false,
48519
48631
  showRoundedTotal: false,
48520
48632
  showLegend: props.attributes.legend,
48521
- showLabels: false,
48633
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
48522
48634
  axis: {
48523
48635
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
48524
48636
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -48900,6 +49012,7 @@ var BarChartV2View = function BarChartV2View(props) {
48900
49012
  overflowX: 'hidden'
48901
49013
  },
48902
49014
  children: function children(parent) {
49015
+ var _props$attributes$lab;
48903
49016
  if (chartRepresentation.bars.length === 0) return jsx(LoadingComponent, {});
48904
49017
  return jsx(BarChart$5, {
48905
49018
  width: parent.width,
@@ -48910,7 +49023,7 @@ var BarChartV2View = function BarChartV2View(props) {
48910
49023
  removeStroke: false,
48911
49024
  showRoundedTotal: false,
48912
49025
  showLegend: props.attributes.legend,
48913
- showLabels: false,
49026
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
48914
49027
  axis: {
48915
49028
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
48916
49029
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -49249,6 +49362,9 @@ var ComboChart$4 = function ComboChart(_ref) {
49249
49362
  tooltipData: buildComboTooltipData(barTooltip == null ? void 0 : barTooltip.tooltipData, lineTooltip == null ? void 0 : lineTooltip.tooltipData, xScaleKey)
49250
49363
  });
49251
49364
  }, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.bars.data, chart.lines.data]);
49365
+ var labelDictionary = useMemo(function () {
49366
+ return getLabelDictionary(chart.lines.data, chart.y.lineKeys);
49367
+ }, [chart.lines.data, chart.y.lineKeys]);
49252
49368
  var handleMouseLeave = useCallback(function () {
49253
49369
  hideTooltip();
49254
49370
  }, [hideTooltip]);
@@ -49303,7 +49419,8 @@ var ComboChart$4 = function ComboChart(_ref) {
49303
49419
  showDetailedSubGroupingLabels: false,
49304
49420
  yAxisLabels: [],
49305
49421
  yLabelPosition: 0,
49306
- showLabels: options.showLabels
49422
+ showLabels: options.showLabels,
49423
+ formattedData: chart.bars.data
49307
49424
  }), options.stacked && xScaleKey !== null && jsx(BarStacked, {
49308
49425
  data: barDataFlattened,
49309
49426
  keys: yBarKeys,
@@ -49328,7 +49445,8 @@ var ComboChart$4 = function ComboChart(_ref) {
49328
49445
  xScaleDataType: xScaleDataType,
49329
49446
  xScale: xScale,
49330
49447
  yScale: yScale,
49331
- showLabels: options.showLabels
49448
+ showLabels: options.showLabels,
49449
+ labelDictionary: labelDictionary
49332
49450
  })
49333
49451
  })]
49334
49452
  })]
@@ -49588,7 +49706,7 @@ var ComboChartViewV2 = function ComboChartViewV2(props) {
49588
49706
  overflowX: 'hidden'
49589
49707
  },
49590
49708
  children: function children(parent) {
49591
- var _props$attributes$sta2;
49709
+ var _props$attributes$sta2, _props$attributes$lab;
49592
49710
  var numberOfXTicksFittingIntoSpace = howManyTicksFitInWidth(comboChartRepresentation.x.ticks || [], parent.width);
49593
49711
  return jsx(ComboChart$4, {
49594
49712
  width: parent.width,
@@ -49606,7 +49724,7 @@ var ComboChartViewV2 = function ComboChartViewV2(props) {
49606
49724
  removeStroke: false,
49607
49725
  showRoundedTotal: false,
49608
49726
  showLegend: props.attributes.legend,
49609
- showLabels: false,
49727
+ showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
49610
49728
  axis: {
49611
49729
  showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
49612
49730
  showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
@@ -52160,7 +52278,7 @@ var defaultProps$8 = {
52160
52278
  approxYAxisLabelCount: 'auto'
52161
52279
  };
52162
52280
  var FunnelChartView = function FunnelChartView(props) {
52163
- var _props$library, _props2, _props3, _props4, _props5, _props6, _props7, _props$viewId, _props8, _props$library2, _props9, _props10, _props11, _theme$charts, _props13, _props14, _props$viewId2, _theme$charts2;
52281
+ var _props$library, _props2, _props3, _props4, _props5, _props6, _props7, _props$viewId, _props8, _props$library2, _props9, _props10, _props11, _theme$charts, _props13, _props$labels, _props14, _props15, _props$viewId2, _theme$charts2;
52164
52282
  var _props = props,
52165
52283
  displayTitle = _props.displayTitle,
52166
52284
  displaySubject = _props.displaySubject;
@@ -52251,11 +52369,11 @@ var FunnelChartView = function FunnelChartView(props) {
52251
52369
  colors: themeToColorScale(theme == null ? void 0 : theme.colors, series$1.length),
52252
52370
  data: resultSet$1,
52253
52371
  legend: showLegend((_props13 = props) == null ? void 0 : _props13.legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
52254
- labels: false,
52372
+ labels: (_props$labels = (_props14 = props) == null ? void 0 : _props14.labels) != null ? _props$labels : false,
52255
52373
  removeStroke: false,
52256
52374
  forceXAxisAsTime: !!props.timeDimension,
52257
52375
  theme: theme == null ? void 0 : theme.charts,
52258
- axisTitles: (_props14 = props) == null ? void 0 : _props14.axisTitles,
52376
+ axisTitles: (_props15 = props) == null ? void 0 : _props15.axisTitles,
52259
52377
  formatSeriesName: formatSeriesName(props.result, textOverride, props.type, (_props$viewId2 = props.viewId) != null ? _props$viewId2 : '', labelFormat),
52260
52378
  conditionalFormattingPossibilities: function conditionalFormattingPossibilities(dataKey) {
52261
52379
  return getExplanationsOfConditionFormattingRulesThatApplyToSeries(props.dimension, props.conditionalFormattingRules,
@@ -54484,14 +54602,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
54484
54602
  if (xScaleDataType === 'string') return String(xValue);
54485
54603
  return '';
54486
54604
  }, [xScaleKey, xScaleDataType]);
54487
- var _useMemo = useMemo(function () {
54488
- var stepValues = formattedChartDataForBarChart.steps.map(function (step) {
54489
- return step.y;
54490
- });
54491
- return getMinMaxChartValueFromNumberArray(stepValues);
54492
- }, [formattedChartDataForBarChart.steps]),
54493
- minValue = _useMemo.minValue,
54494
- maxValue = _useMemo.maxValue;
54605
+ var labelDictionary = useMemo(function () {
54606
+ return getLabelDictionary(formattedChartDataForBarChart.data, formattedChartDataForBarChart.y.keys);
54607
+ }, [formattedChartDataForBarChart.data, formattedChartDataForBarChart.y.keys]);
54495
54608
  if (width === 0 || height === 0 || xScale == null) return null;
54496
54609
  return jsxs(Fragment$1, {
54497
54610
  children: [jsxs(ChartWrapper$1, {
@@ -54589,10 +54702,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
54589
54702
  barGroup: barGroup,
54590
54703
  yScale: yScale,
54591
54704
  formattedChartDataForBarChart: formattedChartDataForBarChart,
54592
- maxValue: maxValue,
54593
- minValue: minValue,
54594
54705
  showLabels: options.showLabels,
54595
- totalItems: formattedChartDataForBarChart.steps.length
54706
+ totalItems: formattedChartDataForBarChart.steps.length,
54707
+ labelDictionary: labelDictionary
54596
54708
  }, "bar-" + bar.index);
54597
54709
  })
54598
54710
  }, "bar-group-" + barGroup.index + "-" + barGroup.x0);
@@ -54627,20 +54739,24 @@ var Bar$2 = function Bar(_ref4) {
54627
54739
  var bar = _ref4.bar,
54628
54740
  barColor = _ref4.barColor,
54629
54741
  barGroup = _ref4.barGroup,
54630
- yScale = _ref4.yScale,
54631
54742
  formattedChartDataForBarChart = _ref4.formattedChartDataForBarChart,
54743
+ labelDictionary = _ref4.labelDictionary,
54632
54744
  showLabels = _ref4.showLabels,
54633
54745
  totalItems = _ref4.totalItems,
54634
- minValue = _ref4.minValue,
54635
- maxValue = _ref4.maxValue;
54746
+ yScale = _ref4.yScale;
54636
54747
  var step = formattedChartDataForBarChart.steps[barGroup.index];
54637
54748
  var y = yScale(Math.max(step.start, step.end));
54638
54749
  var barHeight = Math.abs(yScale(step.start) - yScale(step.end));
54639
- var xPadding = 14;
54640
- var labelX = bar.width < 10 ? bar.x - xPadding : bar.x + bar.width / 2;
54750
+ var xPadding = 10;
54751
+ var labelX = bar.x - xPadding;
54641
54752
  var labelY = getStepYPosition(step, barHeight, y);
54642
- var showMinMax = showMinMaxLabel(step.y, totalItems, minValue, maxValue);
54643
- var shouldShowLabel = showLabels && showMinMax && bar.value > 0;
54753
+ var isFirstOrLastStep = barGroup.index === 0 || barGroup.index === totalItems - 1;
54754
+ var keyValue = step.end - step.start;
54755
+ var displayValue = getFormattedValue(keyValue, labelDictionary);
54756
+ var unformattedValue = displayValue.length > 15;
54757
+ if (unformattedValue) displayValue = keyValue;
54758
+ var showMinMax = unformattedValue ? isFirstOrLastStep : totalItems < 20 || isFirstOrLastStep;
54759
+ var shouldShowLabel = showLabels && showMinMax;
54644
54760
  return jsxs(Fragment$1, {
54645
54761
  children: [jsx("rect", {
54646
54762
  x: bar.x,
@@ -54652,7 +54768,7 @@ var Bar$2 = function Bar(_ref4) {
54652
54768
  }, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key), shouldShowLabel && jsx(DataLabel, {
54653
54769
  x: labelX,
54654
54770
  y: labelY,
54655
- title: step.y.toString(),
54771
+ title: displayValue,
54656
54772
  dx: 1,
54657
54773
  dy: 0
54658
54774
  })]
@@ -54681,7 +54797,7 @@ var WaterfallChartView = function WaterfallChartView(props) {
54681
54797
  displayTitle = props.displayTitle,
54682
54798
  headline = props.headline,
54683
54799
  id = props.id,
54684
- increaseColor = props.increaseColor,
54800
+ labels = props.labels,
54685
54801
  legend = props.legend,
54686
54802
  library = props.library,
54687
54803
  localFilters = props.localFilters,
@@ -54701,7 +54817,8 @@ var WaterfallChartView = function WaterfallChartView(props) {
54701
54817
  xAxisPrefix = props.xAxisPrefix,
54702
54818
  yAxisFormat = props.yAxisFormat,
54703
54819
  yAxisPostfix = props.yAxisPostfix,
54704
- yAxisPrefix = props.yAxisPrefix;
54820
+ yAxisPrefix = props.yAxisPrefix,
54821
+ increaseColor = props.increaseColor;
54705
54822
  var _useDashboardBehaviou = useDashboardBehaviourContext(),
54706
54823
  textOverride = _useDashboardBehaviou.textOverride,
54707
54824
  valueAlias = _useDashboardBehaviou.valueAlias,
@@ -54789,7 +54906,7 @@ var WaterfallChartView = function WaterfallChartView(props) {
54789
54906
  height: parent.height,
54790
54907
  options: {
54791
54908
  showLegend: showLegend(legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
54792
- showLabels: false,
54909
+ showLabels: labels != null ? labels : false,
54793
54910
  showTooltipRoundedTotal: true,
54794
54911
  removeStroke: false,
54795
54912
  axis: {