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