@vizzly/dashboard 0.15.0-dev-307a9830cb4e82f036693ccfe2634f74381a2b72 → 0.15.0-dev-927f480c64f078c9b01edc81be29e4e33f862c8d
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/charts/src/v2/components/LineChart/LineChart.d.ts +10 -7
- package/dist/charts/src/v2/components/RadarChart/Polygons.d.ts +1 -1
- package/dist/charts/src/v2/components/RadarChart/RadarCrosshairCircle.d.ts +19 -0
- package/dist/charts/src/v2/components/RadarChart/shared.d.ts +2 -0
- package/dist/charts/src/v2/components/RadarChart/types.d.ts +4 -0
- package/dist/charts/src/v2/components/Tooltip/CrosshairCircle.d.ts +1 -1
- package/dist/charts/src/v2/utils/components/BarGroup.d.ts +2 -1
- package/dist/charts/src/v2/utils/getRadarTooltipData.d.ts +21 -0
- package/dist/dashboard.cjs.development.js +1390 -1123
- package/dist/dashboard.cjs.production.min.js +1 -1
- package/dist/dashboard.esm.js +1405 -1138
- 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
- package/dist/charts/src/v2/components/GridRows/shared.d.ts +0 -2
|
@@ -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,36 +43773,8 @@ var AxisLeft = function AxisLeft(_ref) {
|
|
|
44147
43773
|
});
|
|
44148
43774
|
};
|
|
44149
43775
|
|
|
44150
|
-
var GRID_STYLES = {
|
|
44151
|
-
strokeWidth: 2,
|
|
44152
|
-
strokeOpacity: 0.8,
|
|
44153
|
-
strokeLinecap: 'round',
|
|
44154
|
-
strokeDasharray: '0.5 5'
|
|
44155
|
-
};
|
|
44156
|
-
|
|
44157
|
-
var GridRows = function GridRows(_ref) {
|
|
44158
|
-
var ticks = _ref.ticks,
|
|
44159
|
-
yScale = _ref.yScale,
|
|
44160
|
-
removeStroke = _ref.removeStroke,
|
|
44161
|
-
width = _ref.width,
|
|
44162
|
-
height = _ref.height,
|
|
44163
|
-
themeCSS = _ref.themeCSS;
|
|
44164
|
-
return jsxRuntime.jsx(grid.GridRows, {
|
|
44165
|
-
tickValues: ticks.length > 0 ? ticks : undefined,
|
|
44166
|
-
scale: yScale,
|
|
44167
|
-
width: width,
|
|
44168
|
-
height: height,
|
|
44169
|
-
pointerEvents: "none",
|
|
44170
|
-
strokeDasharray: "0.5 5",
|
|
44171
|
-
strokeWidth: removeStroke ? 0 : 2,
|
|
44172
|
-
lineStyle: _extends({
|
|
44173
|
-
stroke: themeCSS.grid.stroke
|
|
44174
|
-
}, GRID_STYLES)
|
|
44175
|
-
});
|
|
44176
|
-
};
|
|
44177
|
-
|
|
44178
43776
|
var _excluded$g = ["children", "width", "height", "showLegend", "onMouseMove", "onMouseLeave"];
|
|
44179
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
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)."; }
|
|
44180
43778
|
var ChartWrapper$1 = function ChartWrapper(_ref) {
|
|
44181
43779
|
var children = _ref.children,
|
|
44182
43780
|
width = _ref.width,
|
|
@@ -44194,75 +43792,169 @@ var ChartWrapper$1 = function ChartWrapper(_ref) {
|
|
|
44194
43792
|
name: "fx4tbw-ChartWrapper",
|
|
44195
43793
|
styles: "display:block;label:ChartWrapper;",
|
|
44196
43794
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxudHlwZSBDaGFydFdyYXBwZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHNob3dMZWdlbmQ6IGJvb2xlYW47XG4gIG9uTW91c2VNb3ZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG4gIG9uTW91c2VMZWF2ZT86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyPFNWR1NWR0VsZW1lbnQ+O1xufSAmIFJlYWN0LlNWR1Byb3BzPFNWR1NWR0VsZW1lbnQ+O1xuXG5leHBvcnQgY29uc3QgQ2hhcnRXcmFwcGVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIHNob3dMZWdlbmQsXG4gIG9uTW91c2VNb3ZlLFxuICBvbk1vdXNlTGVhdmUsXG4gIC4uLnN2Z1Byb3BzXG59OiBDaGFydFdyYXBwZXJQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIGhlaWdodD17aGVpZ2h0IC0gKHNob3dMZWdlbmQgPyA0MCA6IDApfVxuICAgICAgb25Nb3VzZU1vdmU9e29uTW91c2VNb3ZlfVxuICAgICAgb25Nb3VzZUxlYXZlPXtvbk1vdXNlTGVhdmV9XG4gICAgICBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdibG9jaycgfSl9XG4gICAgICB7Li4uc3ZnUHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvc3ZnPlxuICApO1xufTtcbiJdfQ== */",
|
|
44197
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
43795
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
44198
43796
|
})
|
|
44199
43797
|
}, svgProps, {
|
|
44200
43798
|
children: children
|
|
44201
43799
|
}));
|
|
44202
43800
|
};
|
|
44203
43801
|
|
|
44204
|
-
var
|
|
44205
|
-
var
|
|
44206
|
-
|
|
44207
|
-
|
|
44208
|
-
|
|
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,
|
|
44209
43898
|
margin = _ref.margin,
|
|
44210
|
-
|
|
44211
|
-
|
|
44212
|
-
visibleYKeys = _ref.visibleYKeys,
|
|
44213
|
-
yScale = _ref.yScale,
|
|
44214
|
-
xScale = _ref.xScale;
|
|
43899
|
+
y = _ref.y,
|
|
43900
|
+
width = _ref.width;
|
|
44215
43901
|
return jsxRuntime.jsx(React.Fragment, {
|
|
44216
|
-
children:
|
|
44217
|
-
|
|
44218
|
-
|
|
44219
|
-
|
|
44220
|
-
|
|
44221
|
-
|
|
44222
|
-
|
|
44223
|
-
// @ts-ignore
|
|
44224
|
-
xScale(xValueAdjusted) + margin.left,
|
|
44225
|
-
cy: yScale(yKey) + margin.top,
|
|
44226
|
-
r: 4,
|
|
44227
|
-
fill: getColor({
|
|
44228
|
-
defaultColor: legendItems.filter(function (legendItem) {
|
|
44229
|
-
return legendItem.yKey === yKey;
|
|
44230
|
-
})[0].color,
|
|
44231
|
-
yKey: yKey,
|
|
44232
|
-
value: tooltipData[yKey].value,
|
|
44233
|
-
conditionalFormattingRules: conditionalFormattingRules
|
|
44234
|
-
}),
|
|
44235
|
-
strokeWidth: 2,
|
|
44236
|
-
stroke: "#fff",
|
|
44237
|
-
pointerEvents: "none"
|
|
44238
|
-
}, yKey);
|
|
44239
|
-
} else {
|
|
44240
|
-
return null;
|
|
44241
|
-
}
|
|
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);
|
|
44242
43909
|
})
|
|
44243
43910
|
});
|
|
44244
43911
|
};
|
|
43912
|
+
var GoalLines$1 = /*#__PURE__*/React.memo(GoalLines, shouldUpdate$1);
|
|
44245
43913
|
|
|
44246
|
-
var
|
|
44247
|
-
|
|
44248
|
-
|
|
44249
|
-
|
|
44250
|
-
|
|
44251
|
-
|
|
44252
|
-
|
|
44253
|
-
|
|
44254
|
-
|
|
44255
|
-
|
|
44256
|
-
|
|
44257
|
-
|
|
44258
|
-
|
|
44259
|
-
|
|
44260
|
-
|
|
43914
|
+
var LINE_STYLES = {
|
|
43915
|
+
strokeWidth: 2,
|
|
43916
|
+
strokeOpacity: 0.8,
|
|
43917
|
+
strokeLinecap: 'round',
|
|
43918
|
+
strokeDasharray: '0.5 5',
|
|
43919
|
+
stroke: 'rgba(0, 0, 0, 0.1)'
|
|
43920
|
+
};
|
|
43921
|
+
|
|
43922
|
+
var GridRows = function GridRows(_ref) {
|
|
43923
|
+
var ticks = _ref.ticks,
|
|
43924
|
+
yScale = _ref.yScale,
|
|
43925
|
+
removeStroke = _ref.removeStroke,
|
|
43926
|
+
width = _ref.width,
|
|
43927
|
+
height = _ref.height,
|
|
43928
|
+
themeCSS = _ref.themeCSS;
|
|
43929
|
+
return jsxRuntime.jsx(grid.GridRows, {
|
|
43930
|
+
tickValues: ticks.length > 0 ? ticks : undefined,
|
|
43931
|
+
scale: yScale,
|
|
43932
|
+
width: width,
|
|
43933
|
+
height: height,
|
|
44261
43934
|
pointerEvents: "none",
|
|
44262
|
-
|
|
43935
|
+
strokeDasharray: "0.5 5",
|
|
43936
|
+
strokeWidth: removeStroke ? 0 : 2,
|
|
43937
|
+
lineStyle: _extends({
|
|
43938
|
+
stroke: themeCSS.grid.stroke
|
|
43939
|
+
}, LINE_STYLES)
|
|
44263
43940
|
});
|
|
44264
43941
|
};
|
|
44265
43942
|
|
|
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
|
+
|
|
44266
43958
|
var _excluded$h = ["tooltipOpen"];
|
|
44267
43959
|
function useTooltip$1(initialTooltipState) {
|
|
44268
43960
|
var _useState = React.useState(_extends({
|
|
@@ -44316,31 +44008,420 @@ function useYScale(innerHeight, scale$1) {
|
|
|
44316
44008
|
}, [innerHeight, scale$1]);
|
|
44317
44009
|
}
|
|
44318
44010
|
|
|
44319
|
-
var
|
|
44320
|
-
var
|
|
44321
|
-
|
|
44322
|
-
|
|
44323
|
-
|
|
44324
|
-
|
|
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,
|
|
44325
44079
|
color = _ref.color,
|
|
44326
|
-
|
|
44327
|
-
|
|
44328
|
-
|
|
44329
|
-
|
|
44330
|
-
|
|
44331
|
-
|
|
44332
|
-
|
|
44333
|
-
|
|
44334
|
-
|
|
44335
|
-
|
|
44336
|
-
|
|
44337
|
-
|
|
44338
|
-
|
|
44339
|
-
|
|
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", {
|
|
44188
|
+
className: /*#__PURE__*/css$1.css( {
|
|
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
|
+
})
|
|
44218
|
+
})
|
|
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);
|
|
44361
|
+
};
|
|
44362
|
+
|
|
44363
|
+
var CrosshairCircle = function CrosshairCircle(_ref) {
|
|
44364
|
+
var dataType = _ref.dataType,
|
|
44365
|
+
yKeys = _ref.yKeys,
|
|
44366
|
+
tooltipData = _ref.tooltipData,
|
|
44367
|
+
xKey = _ref.xKey,
|
|
44368
|
+
margin = _ref.margin,
|
|
44369
|
+
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
44370
|
+
legendItems = _ref.legendItems,
|
|
44371
|
+
visibleYKeys = _ref.visibleYKeys,
|
|
44372
|
+
yScale = _ref.yScale,
|
|
44373
|
+
xScale = _ref.xScale;
|
|
44374
|
+
return jsxRuntime.jsx(React.Fragment, {
|
|
44375
|
+
children: yKeys.map(function (yKey) {
|
|
44376
|
+
if (!xKey || !tooltipData[yKey] || tooltipData[yKey].value === null) return null;
|
|
44377
|
+
if (tooltipData[xKey] && tooltipData[xKey].value && dataType && visibleYKeys.includes(yKey)) {
|
|
44378
|
+
var xValue = tooltipData[xKey].value;
|
|
44379
|
+
var xValueAdjusted = dataType === 'date_time' ? new Date(xValue) : dataType === 'number' ? Number(xValue) : String(xValue);
|
|
44380
|
+
return jsxRuntime.jsx("circle", {
|
|
44381
|
+
cx:
|
|
44382
|
+
// @ts-ignore
|
|
44383
|
+
xScale(xValueAdjusted) + margin.left,
|
|
44384
|
+
cy: yScale(yKey) + margin.top,
|
|
44385
|
+
r: 4,
|
|
44386
|
+
fill: getColor({
|
|
44387
|
+
defaultColor: legendItems.filter(function (legendItem) {
|
|
44388
|
+
return legendItem.yKey === yKey;
|
|
44389
|
+
})[0].color,
|
|
44390
|
+
yKey: yKey,
|
|
44391
|
+
value: tooltipData[yKey].value,
|
|
44392
|
+
conditionalFormattingRules: conditionalFormattingRules
|
|
44393
|
+
}),
|
|
44394
|
+
strokeWidth: 2,
|
|
44395
|
+
stroke: "#fff",
|
|
44396
|
+
pointerEvents: "none"
|
|
44397
|
+
}, yKey);
|
|
44398
|
+
} else {
|
|
44399
|
+
return null;
|
|
44400
|
+
}
|
|
44340
44401
|
})
|
|
44341
44402
|
});
|
|
44342
44403
|
};
|
|
44343
44404
|
|
|
44405
|
+
var Line = function Line(_ref) {
|
|
44406
|
+
var margin = _ref.margin,
|
|
44407
|
+
x = _ref.x,
|
|
44408
|
+
height = _ref.height;
|
|
44409
|
+
return jsxRuntime.jsx(shape.Line, {
|
|
44410
|
+
from: {
|
|
44411
|
+
x: x,
|
|
44412
|
+
y: margin.top
|
|
44413
|
+
},
|
|
44414
|
+
to: {
|
|
44415
|
+
x: x,
|
|
44416
|
+
y: height + margin.top
|
|
44417
|
+
},
|
|
44418
|
+
stroke: '#aaa',
|
|
44419
|
+
strokeWidth: 2,
|
|
44420
|
+
pointerEvents: "none",
|
|
44421
|
+
opacity: 0.8
|
|
44422
|
+
});
|
|
44423
|
+
};
|
|
44424
|
+
|
|
44344
44425
|
var LineChart$5 = function LineChart(_ref) {
|
|
44345
44426
|
var _theme$axis;
|
|
44346
44427
|
var chart = _ref.chart,
|
|
@@ -44430,6 +44511,26 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
44430
44511
|
var handleMouseLeave = React.useCallback(function () {
|
|
44431
44512
|
hideTooltip();
|
|
44432
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]);
|
|
44433
44534
|
if (width === 0 || height === 0 || xScale === null) return jsxRuntime.jsx(React__default.Fragment, {});
|
|
44434
44535
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
44435
44536
|
return Number(tick.value);
|
|
@@ -44474,19 +44575,7 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
44474
44575
|
ticks: yTickValues,
|
|
44475
44576
|
stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
|
|
44476
44577
|
}), jsxRuntime.jsx(group.Group, {
|
|
44477
|
-
children:
|
|
44478
|
-
lines: chart.lines,
|
|
44479
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
44480
|
-
curve: curve,
|
|
44481
|
-
yKeys: chart.y.keys,
|
|
44482
|
-
visibleYKeys: visibleYKeys,
|
|
44483
|
-
data: dataFlattened,
|
|
44484
|
-
xScaleKey: xScaleKey,
|
|
44485
|
-
xScaleDataType: xScaleDataType,
|
|
44486
|
-
xScale: xScale,
|
|
44487
|
-
yScale: _yScale,
|
|
44488
|
-
showLabels: options.showLabels
|
|
44489
|
-
})
|
|
44578
|
+
children: memoizedLines
|
|
44490
44579
|
})]
|
|
44491
44580
|
}), tooltipData && jsxRuntime.jsxs("g", {
|
|
44492
44581
|
children: [jsxRuntime.jsx(Line, {
|
|
@@ -44535,7 +44624,7 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
44535
44624
|
})]
|
|
44536
44625
|
});
|
|
44537
44626
|
};
|
|
44538
|
-
function Lines(_ref2) {
|
|
44627
|
+
var Lines = /*#__PURE__*/React.memo(function Lines(_ref2) {
|
|
44539
44628
|
var yKeys = _ref2.yKeys,
|
|
44540
44629
|
visibleYKeys = _ref2.visibleYKeys,
|
|
44541
44630
|
data = _ref2.data,
|
|
@@ -44546,7 +44635,8 @@ function Lines(_ref2) {
|
|
|
44546
44635
|
lines = _ref2.lines,
|
|
44547
44636
|
curve = _ref2.curve,
|
|
44548
44637
|
conditionalFormattingRules = _ref2.conditionalFormattingRules,
|
|
44549
|
-
showLabels = _ref2.showLabels
|
|
44638
|
+
showLabels = _ref2.showLabels,
|
|
44639
|
+
labelDictionary = _ref2.labelDictionary;
|
|
44550
44640
|
var _useMemo = React.useMemo(function () {
|
|
44551
44641
|
var allBarValues = getAllChartValues(data, yKeys);
|
|
44552
44642
|
var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(allBarValues),
|
|
@@ -44612,7 +44702,8 @@ function Lines(_ref2) {
|
|
|
44612
44702
|
totalItems: data.length,
|
|
44613
44703
|
minValue: minValue,
|
|
44614
44704
|
maxValue: maxValue,
|
|
44615
|
-
showLabels: showLabels
|
|
44705
|
+
showLabels: showLabels,
|
|
44706
|
+
labelDictionary: labelDictionary
|
|
44616
44707
|
});
|
|
44617
44708
|
})]
|
|
44618
44709
|
});
|
|
@@ -44667,33 +44758,35 @@ function Lines(_ref2) {
|
|
|
44667
44758
|
}, clipPathId);
|
|
44668
44759
|
})]
|
|
44669
44760
|
});
|
|
44670
|
-
|
|
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
|
-
|
|
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
|
+
});
|
|
44697
44790
|
|
|
44698
44791
|
var BAR_RADIUS = 2;
|
|
44699
44792
|
|
|
@@ -44739,7 +44832,8 @@ function BarGroup(_ref) {
|
|
|
44739
44832
|
yLabelPosition = _ref.yLabelPosition,
|
|
44740
44833
|
showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
|
|
44741
44834
|
labelStyle = _ref.labelStyle,
|
|
44742
|
-
showLabels = _ref.showLabels
|
|
44835
|
+
showLabels = _ref.showLabels,
|
|
44836
|
+
formattedData = _ref.formattedData;
|
|
44743
44837
|
var getGroupPosition = function getGroupPosition(d) {
|
|
44744
44838
|
var xValue = d[xKey];
|
|
44745
44839
|
if (xScaleDataType === 'string') return String(xValue);
|
|
@@ -44751,6 +44845,9 @@ function BarGroup(_ref) {
|
|
|
44751
44845
|
}
|
|
44752
44846
|
return String(xValue);
|
|
44753
44847
|
};
|
|
44848
|
+
var formattedLabelsDict = React.useMemo(function () {
|
|
44849
|
+
return getLabelDictionary(formattedData, keys);
|
|
44850
|
+
}, [formattedData, keys]);
|
|
44754
44851
|
var _useMemo = React.useMemo(function () {
|
|
44755
44852
|
var allBarValues = getAllChartValues(data, keys);
|
|
44756
44853
|
var _getMinMaxChartValueF = getMinMaxChartValueFromNumberArray(allBarValues),
|
|
@@ -44799,7 +44896,9 @@ function BarGroup(_ref) {
|
|
|
44799
44896
|
minValue: minValue,
|
|
44800
44897
|
maxValue: maxValue,
|
|
44801
44898
|
totalItems: totalItems,
|
|
44802
|
-
showLabels: showLabels
|
|
44899
|
+
showLabels: showLabels,
|
|
44900
|
+
labelDictionary: formattedLabelsDict,
|
|
44901
|
+
yScale: yScale
|
|
44803
44902
|
}, "bar-" + bar.index + "-" + bar.x);
|
|
44804
44903
|
})
|
|
44805
44904
|
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
@@ -44821,11 +44920,17 @@ var Bar = function Bar(_ref2) {
|
|
|
44821
44920
|
minValue = _ref2.minValue,
|
|
44822
44921
|
maxValue = _ref2.maxValue,
|
|
44823
44922
|
totalItems = _ref2.totalItems,
|
|
44824
|
-
showLabels = _ref2.showLabels
|
|
44923
|
+
showLabels = _ref2.showLabels,
|
|
44924
|
+
labelDictionary = _ref2.labelDictionary,
|
|
44925
|
+
yScale = _ref2.yScale;
|
|
44825
44926
|
var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
|
|
44826
|
-
var
|
|
44827
|
-
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;
|
|
44828
44932
|
var showMinMax = showMinMaxLabel(bar.value, totalItems, minValue, maxValue);
|
|
44933
|
+
var displayValue = getFormattedValue(bar.value, labelDictionary);
|
|
44829
44934
|
return jsxRuntime.jsxs(React.Fragment, {
|
|
44830
44935
|
children: [showBar && jsxRuntime.jsx(BarRect, {
|
|
44831
44936
|
barRectKey: "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
|
|
@@ -44841,7 +44946,7 @@ var Bar = function Bar(_ref2) {
|
|
|
44841
44946
|
}), showLabels && showMinMax && jsxRuntime.jsx(DataLabel, {
|
|
44842
44947
|
x: labelX,
|
|
44843
44948
|
y: labelY,
|
|
44844
|
-
title:
|
|
44949
|
+
title: displayValue,
|
|
44845
44950
|
dx: 1,
|
|
44846
44951
|
dy: 0
|
|
44847
44952
|
}), jsxRuntime.jsx(BarLabel, {
|
|
@@ -44869,7 +44974,7 @@ var BarRect = function BarRect(_ref3) {
|
|
|
44869
44974
|
var classes = enableHover ? /*#__PURE__*/css$1.css( {
|
|
44870
44975
|
name: "1ltmijl-classes",
|
|
44871
44976
|
styles: "cursor:pointer;label:classes;",
|
|
44872
|
-
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"]} */",
|
|
44873
44978
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
44874
44979
|
}) : '';
|
|
44875
44980
|
var handleOnMouseEnter = function handleOnMouseEnter() {
|
|
@@ -45206,7 +45311,8 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
45206
45311
|
yAxisLabels: yAxisLabels,
|
|
45207
45312
|
yLabelPosition: ySubLabelPosition,
|
|
45208
45313
|
labelStyle: themeCSS.labels,
|
|
45209
|
-
showLabels: options.showLabels
|
|
45314
|
+
showLabels: options.showLabels,
|
|
45315
|
+
formattedData: chart.data
|
|
45210
45316
|
}), options.stacked && xScaleKey !== null && jsxRuntime.jsx(BarStacked, {
|
|
45211
45317
|
data: dataFlattened,
|
|
45212
45318
|
keys: chart.y.keys,
|
|
@@ -45461,6 +45567,9 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
45461
45567
|
};
|
|
45462
45568
|
return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'natural'];
|
|
45463
45569
|
}, [options.curve]);
|
|
45570
|
+
var labelDictionary = React.useMemo(function () {
|
|
45571
|
+
return getLabelDictionary(chart.data, chart.y.keys);
|
|
45572
|
+
}, [chart.data, chart.y.keys]);
|
|
45464
45573
|
if (width === 0 || height === 0 || xScale === null) return jsxRuntime.jsx(React__default.Fragment, {});
|
|
45465
45574
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
45466
45575
|
return Number(tick.value);
|
|
@@ -45601,7 +45710,8 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
45601
45710
|
totalItems: dataFlattened.length,
|
|
45602
45711
|
minValue: minValue,
|
|
45603
45712
|
maxValue: maxValue,
|
|
45604
|
-
showLabels: options.showLabels
|
|
45713
|
+
showLabels: options.showLabels,
|
|
45714
|
+
labelDictionary: labelDictionary
|
|
45605
45715
|
});
|
|
45606
45716
|
})]
|
|
45607
45717
|
}, yKey + "-" + AREA_GRADIENT_ID_PREFIX);
|
|
@@ -45663,7 +45773,8 @@ function AreaLabel(_ref3) {
|
|
|
45663
45773
|
totalItems = _ref3.totalItems,
|
|
45664
45774
|
minValue = _ref3.minValue,
|
|
45665
45775
|
maxValue = _ref3.maxValue,
|
|
45666
|
-
showLabels = _ref3.showLabels
|
|
45776
|
+
showLabels = _ref3.showLabels,
|
|
45777
|
+
labelDictionary = _ref3.labelDictionary;
|
|
45667
45778
|
var xValue = chartData[xScaleKey];
|
|
45668
45779
|
var yValue = chartData[yKey];
|
|
45669
45780
|
var xPadding = 18;
|
|
@@ -45672,12 +45783,13 @@ function AreaLabel(_ref3) {
|
|
|
45672
45783
|
var yPosition = yScale(yValue);
|
|
45673
45784
|
var showMinMax = showMinMaxLabel(Number(yValue), totalItems, minValue, maxValue);
|
|
45674
45785
|
if (xPosition == null || yPosition == null || !showMinMax || !showLabels) return null;
|
|
45786
|
+
var displayValue = getFormattedValue(yValue, labelDictionary);
|
|
45675
45787
|
return jsxRuntime.jsx(DataLabel, {
|
|
45676
45788
|
x: xPosition - xPadding,
|
|
45677
45789
|
y: yPosition - yPadding,
|
|
45678
45790
|
dx: 2,
|
|
45679
45791
|
dy: 0,
|
|
45680
|
-
title:
|
|
45792
|
+
title: displayValue
|
|
45681
45793
|
});
|
|
45682
45794
|
}
|
|
45683
45795
|
function Area(_ref4) {
|
|
@@ -45966,6 +46078,58 @@ function Bubbles(_ref2) {
|
|
|
45966
46078
|
});
|
|
45967
46079
|
}
|
|
45968
46080
|
|
|
46081
|
+
var RadarCrosshairCircle = function RadarCrosshairCircle(_ref) {
|
|
46082
|
+
var tooltipData = _ref.tooltipData,
|
|
46083
|
+
yKeys = _ref.yKeys,
|
|
46084
|
+
legendItems = _ref.legendItems,
|
|
46085
|
+
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
46086
|
+
visibleYKeys = _ref.visibleYKeys,
|
|
46087
|
+
radius = _ref.radius,
|
|
46088
|
+
yScale = _ref.yScale,
|
|
46089
|
+
dataPointIndex = _ref.dataPointIndex,
|
|
46090
|
+
totalDataPoints = _ref.totalDataPoints;
|
|
46091
|
+
var radiusScale = scale.scaleLinear({
|
|
46092
|
+
range: [0, radius],
|
|
46093
|
+
domain: [0, yScale.max],
|
|
46094
|
+
nice: true
|
|
46095
|
+
});
|
|
46096
|
+
var step = Math.PI * 2 / totalDataPoints;
|
|
46097
|
+
var yKeysTest = [].concat(yKeys);
|
|
46098
|
+
if (yKeysTest.length > 1) {
|
|
46099
|
+
var lastItem = yKeysTest.pop();
|
|
46100
|
+
yKeysTest.unshift(lastItem);
|
|
46101
|
+
}
|
|
46102
|
+
return jsxRuntime.jsx(React.Fragment, {
|
|
46103
|
+
children: yKeysTest.map(function (yKey) {
|
|
46104
|
+
var _legendItems$filter$;
|
|
46105
|
+
if (!tooltipData[yKey] || tooltipData[yKey].value === null || !visibleYKeys.includes(yKey)) {
|
|
46106
|
+
return null;
|
|
46107
|
+
}
|
|
46108
|
+
var value = tooltipData[yKey].value;
|
|
46109
|
+
var scaledRadius = radiusScale(value);
|
|
46110
|
+
var angle = (dataPointIndex + 1) * step;
|
|
46111
|
+
var x = scaledRadius * Math.sin(angle);
|
|
46112
|
+
var y = scaledRadius * Math.cos(angle);
|
|
46113
|
+
return jsxRuntime.jsx("circle", {
|
|
46114
|
+
cx: x,
|
|
46115
|
+
cy: y,
|
|
46116
|
+
r: 6,
|
|
46117
|
+
fill: getColor({
|
|
46118
|
+
defaultColor: ((_legendItems$filter$ = legendItems.filter(function (legendItem) {
|
|
46119
|
+
return legendItem.yKey === yKey;
|
|
46120
|
+
})[0]) == null ? void 0 : _legendItems$filter$.color) || '#000',
|
|
46121
|
+
yKey: yKey,
|
|
46122
|
+
value: tooltipData[yKey].value,
|
|
46123
|
+
conditionalFormattingRules: conditionalFormattingRules
|
|
46124
|
+
}),
|
|
46125
|
+
strokeWidth: 2,
|
|
46126
|
+
stroke: "#fff",
|
|
46127
|
+
pointerEvents: "none"
|
|
46128
|
+
}, "radar-crosshair-" + yKey);
|
|
46129
|
+
})
|
|
46130
|
+
});
|
|
46131
|
+
};
|
|
46132
|
+
|
|
45969
46133
|
var getValue = function getValue(d, key) {
|
|
45970
46134
|
return d[key].value;
|
|
45971
46135
|
};
|
|
@@ -45995,7 +46159,9 @@ var genPolygonPoints = function genPolygonPoints(dataArray, scale, yKey) {
|
|
|
45995
46159
|
var Polygons = function Polygons(_ref) {
|
|
45996
46160
|
var chart = _ref.chart,
|
|
45997
46161
|
radius = _ref.radius,
|
|
45998
|
-
visibleYKeys = _ref.visibleYKeys
|
|
46162
|
+
visibleYKeys = _ref.visibleYKeys,
|
|
46163
|
+
tooltipData = _ref.tooltipData,
|
|
46164
|
+
hoveredDataPointIndex = _ref.hoveredDataPointIndex;
|
|
45999
46165
|
var yKeys = chart.y.keys;
|
|
46000
46166
|
var yScale = scale.scaleLinear({
|
|
46001
46167
|
range: [0, radius],
|
|
@@ -46008,16 +46174,26 @@ var Polygons = function Polygons(_ref) {
|
|
|
46008
46174
|
return (_yScale = yScale(d)) != null ? _yScale : 0;
|
|
46009
46175
|
}, yKey);
|
|
46010
46176
|
});
|
|
46011
|
-
return jsxRuntime.
|
|
46012
|
-
children: polygonsPoints.map(function (polygonPoints) {
|
|
46177
|
+
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
46178
|
+
children: [polygonsPoints.map(function (polygonPoints) {
|
|
46013
46179
|
return jsxRuntime.jsx(SinglePolygon, {
|
|
46014
46180
|
isVisible: visibleYKeys.includes(polygonPoints.yKey),
|
|
46015
46181
|
polygonPoints: polygonPoints,
|
|
46016
46182
|
colors: chart.lines.filter(function (legendItem) {
|
|
46017
46183
|
return legendItem.yKey === polygonPoints.yKey;
|
|
46018
46184
|
})[0].color
|
|
46019
|
-
});
|
|
46020
|
-
})
|
|
46185
|
+
}, polygonPoints.yKey);
|
|
46186
|
+
}), tooltipData && hoveredDataPointIndex !== undefined && hoveredDataPointIndex >= 0 && jsxRuntime.jsx(RadarCrosshairCircle, {
|
|
46187
|
+
tooltipData: tooltipData,
|
|
46188
|
+
yKeys: chart.y.keys,
|
|
46189
|
+
legendItems: chart.lines,
|
|
46190
|
+
conditionalFormattingRules: [],
|
|
46191
|
+
visibleYKeys: visibleYKeys,
|
|
46192
|
+
radius: radius,
|
|
46193
|
+
yScale: chart.y.scale,
|
|
46194
|
+
dataPointIndex: hoveredDataPointIndex,
|
|
46195
|
+
totalDataPoints: chart.data.length
|
|
46196
|
+
})]
|
|
46021
46197
|
});
|
|
46022
46198
|
};
|
|
46023
46199
|
var SinglePolygon = function SinglePolygon(_ref2) {
|
|
@@ -46044,15 +46220,6 @@ var SinglePolygon = function SinglePolygon(_ref2) {
|
|
|
46044
46220
|
});
|
|
46045
46221
|
};
|
|
46046
46222
|
|
|
46047
|
-
var genPoints = function genPoints(length, radius) {
|
|
46048
|
-
var step = Math.PI * 2 / length;
|
|
46049
|
-
return [].concat(new Array(length)).map(function (_, i) {
|
|
46050
|
-
return {
|
|
46051
|
-
x: radius * Math.sin(i * step),
|
|
46052
|
-
y: radius * Math.cos(i * step)
|
|
46053
|
-
};
|
|
46054
|
-
});
|
|
46055
|
-
};
|
|
46056
46223
|
var MiddleLine = function MiddleLine(_ref) {
|
|
46057
46224
|
var chart = _ref.chart,
|
|
46058
46225
|
radius = _ref.radius,
|
|
@@ -46062,7 +46229,6 @@ var MiddleLine = function MiddleLine(_ref) {
|
|
|
46062
46229
|
var _useState = React.useState([]),
|
|
46063
46230
|
textWidths = _useState[0],
|
|
46064
46231
|
setTextWidths = _useState[1];
|
|
46065
|
-
var points = genPoints(chart.x.ticks.length, radius);
|
|
46066
46232
|
var zeroPoint = new point.Point({
|
|
46067
46233
|
x: 0,
|
|
46068
46234
|
y: 0
|
|
@@ -46071,22 +46237,33 @@ var MiddleLine = function MiddleLine(_ref) {
|
|
|
46071
46237
|
var _tick$formattedValue;
|
|
46072
46238
|
return (_tick$formattedValue = tick.formattedValue) != null ? _tick$formattedValue : tick.value;
|
|
46073
46239
|
});
|
|
46240
|
+
var genPoints = function genPoints(length, radius) {
|
|
46241
|
+
var step = Math.PI * 2 / length;
|
|
46242
|
+
return new Array(length).fill(0).map(function (_, i) {
|
|
46243
|
+
return {
|
|
46244
|
+
x: radius * Math.sin(i * step),
|
|
46245
|
+
y: radius * Math.cos(i * step)
|
|
46246
|
+
};
|
|
46247
|
+
});
|
|
46248
|
+
};
|
|
46074
46249
|
React.useEffect(function () {
|
|
46075
46250
|
var newWidths = textRefs.current.map(function (ref) {
|
|
46076
46251
|
return ref ? ref.getComputedTextLength() : 0;
|
|
46077
46252
|
});
|
|
46078
46253
|
setTextWidths(newWidths);
|
|
46079
|
-
}, [
|
|
46254
|
+
}, []);
|
|
46255
|
+
var points = genPoints(chart.x.ticks.length, radius);
|
|
46080
46256
|
points.push(points.shift());
|
|
46081
46257
|
return jsxRuntime.jsx(jsxRuntime.Fragment, {
|
|
46082
|
-
children:
|
|
46258
|
+
children: new Array(chart.x.ticks.length).fill(0).map(function (_, i) {
|
|
46083
46259
|
var xOffset = points[i].x >= 0 ? textWidths[i] / 2 : -(textWidths[i] / 2);
|
|
46084
|
-
return jsxRuntime.jsxs(
|
|
46260
|
+
return jsxRuntime.jsxs(React__default.Fragment, {
|
|
46085
46261
|
children: [jsxRuntime.jsx(shape.Line, {
|
|
46086
46262
|
from: zeroPoint,
|
|
46087
46263
|
to: points[i],
|
|
46088
|
-
|
|
46089
|
-
|
|
46264
|
+
style: _extends({
|
|
46265
|
+
stroke: themeCSS.axis.stroke
|
|
46266
|
+
}, LINE_STYLES)
|
|
46090
46267
|
}, "radar-line-" + i), show && jsxRuntime.jsx("text", {
|
|
46091
46268
|
ref: function ref(el) {
|
|
46092
46269
|
return textRefs.current[i] = el;
|
|
@@ -46097,13 +46274,13 @@ var MiddleLine = function MiddleLine(_ref) {
|
|
|
46097
46274
|
textAnchor: "middle",
|
|
46098
46275
|
children: categoryValues[i]
|
|
46099
46276
|
})]
|
|
46100
|
-
});
|
|
46277
|
+
}, "middle-line-" + i);
|
|
46101
46278
|
})
|
|
46102
46279
|
});
|
|
46103
46280
|
};
|
|
46104
46281
|
|
|
46105
46282
|
var genAngles = function genAngles(length, degrees) {
|
|
46106
|
-
return
|
|
46283
|
+
return new Array(length + 1).fill(0).map(function (_, i) {
|
|
46107
46284
|
return {
|
|
46108
46285
|
angle: i * (degrees / length) + (length % 2 === 0 ? 0 : degrees / length / 2)
|
|
46109
46286
|
};
|
|
@@ -46135,9 +46312,9 @@ var Grid$1 = function Grid(_ref) {
|
|
|
46135
46312
|
}, [chart.y.ticks]);
|
|
46136
46313
|
var chartValue = (_chart$y$ticks$scaleV = chart.y.ticks[levels - 1].scaleValue) != null ? _chart$y$ticks$scaleV : chart.y.ticks[levels - 1].value;
|
|
46137
46314
|
return jsxRuntime.jsx(jsxRuntime.Fragment, {
|
|
46138
|
-
children:
|
|
46315
|
+
children: new Array(levels).fill(0).map(function (_, i) {
|
|
46139
46316
|
var levelRadius = chart.y.ticks[i].value / chartValue * radius;
|
|
46140
|
-
return jsxRuntime.jsxs(
|
|
46317
|
+
return jsxRuntime.jsxs(React__default.Fragment, {
|
|
46141
46318
|
children: [jsxRuntime.jsx(shape.LineRadial, {
|
|
46142
46319
|
data: webs,
|
|
46143
46320
|
angle: function angle(d) {
|
|
@@ -46148,7 +46325,7 @@ var Grid$1 = function Grid(_ref) {
|
|
|
46148
46325
|
fill: "none",
|
|
46149
46326
|
style: _extends({
|
|
46150
46327
|
stroke: themeCSS.axis.stroke
|
|
46151
|
-
},
|
|
46328
|
+
}, LINE_STYLES)
|
|
46152
46329
|
}, "web-" + i), jsxRuntime.jsx("text", {
|
|
46153
46330
|
x: 0,
|
|
46154
46331
|
y: levelRadius,
|
|
@@ -46158,11 +46335,40 @@ var Grid$1 = function Grid(_ref) {
|
|
|
46158
46335
|
textAnchor: "middle",
|
|
46159
46336
|
children: tickFormat(chart.y.ticks[i].value)
|
|
46160
46337
|
})]
|
|
46161
|
-
});
|
|
46338
|
+
}, "grid-level-" + i);
|
|
46162
46339
|
})
|
|
46163
46340
|
});
|
|
46164
46341
|
};
|
|
46165
46342
|
|
|
46343
|
+
var getRadarTooltipData = function getRadarTooltipData(_ref) {
|
|
46344
|
+
var data = _ref.data,
|
|
46345
|
+
event$1 = _ref.event,
|
|
46346
|
+
totalDataPoints = _ref.totalDataPoints,
|
|
46347
|
+
centerX = _ref.centerX,
|
|
46348
|
+
centerY = _ref.centerY;
|
|
46349
|
+
var point = event.localPoint(event$1) || {
|
|
46350
|
+
x: 0,
|
|
46351
|
+
y: 0
|
|
46352
|
+
};
|
|
46353
|
+
if (!point) return;
|
|
46354
|
+
var mouseX = point.x - centerX;
|
|
46355
|
+
var mouseY = point.y - centerY;
|
|
46356
|
+
var mouseAngle = Math.atan2(mouseX, mouseY);
|
|
46357
|
+
if (mouseAngle < 0) {
|
|
46358
|
+
mouseAngle += 2 * Math.PI;
|
|
46359
|
+
}
|
|
46360
|
+
var step = Math.PI * 2 / totalDataPoints;
|
|
46361
|
+
var dataPointIndex = Math.round(mouseAngle / step) % totalDataPoints;
|
|
46362
|
+
dataPointIndex = (dataPointIndex - 1 + totalDataPoints) % totalDataPoints;
|
|
46363
|
+
var tooltipData = data[dataPointIndex] || null;
|
|
46364
|
+
var angle = (dataPointIndex + 1) * step;
|
|
46365
|
+
return {
|
|
46366
|
+
tooltipData: tooltipData,
|
|
46367
|
+
dataPointIndex: dataPointIndex,
|
|
46368
|
+
angle: angle
|
|
46369
|
+
};
|
|
46370
|
+
};
|
|
46371
|
+
|
|
46166
46372
|
var WIDTH_MULTIPLIER_TO_SCROLL = 1.2;
|
|
46167
46373
|
var LEGEND_PADDING = 40;
|
|
46168
46374
|
var RadarChart$2 = function RadarChart(_ref) {
|
|
@@ -46171,6 +46377,15 @@ var RadarChart$2 = function RadarChart(_ref) {
|
|
|
46171
46377
|
height = _ref.height,
|
|
46172
46378
|
options = _ref.options,
|
|
46173
46379
|
theme = _ref.theme;
|
|
46380
|
+
var _useTooltip = useTooltip$1(),
|
|
46381
|
+
tooltipOpen = _useTooltip.tooltipOpen,
|
|
46382
|
+
_useTooltip$tooltipLe = _useTooltip.tooltipLeft,
|
|
46383
|
+
tooltipLeft = _useTooltip$tooltipLe === void 0 ? 0 : _useTooltip$tooltipLe,
|
|
46384
|
+
_useTooltip$tooltipTo = _useTooltip.tooltipTop,
|
|
46385
|
+
tooltipTop = _useTooltip$tooltipTo === void 0 ? 0 : _useTooltip$tooltipTo,
|
|
46386
|
+
tooltipData = _useTooltip.tooltipData,
|
|
46387
|
+
hideTooltip = _useTooltip.hideTooltip,
|
|
46388
|
+
showTooltip = _useTooltip.showTooltip;
|
|
46174
46389
|
var ref = React.useRef(null);
|
|
46175
46390
|
var _useState = React.useState(0),
|
|
46176
46391
|
groupWidth = _useState[0],
|
|
@@ -46180,13 +46395,17 @@ var RadarChart$2 = function RadarChart(_ref) {
|
|
|
46180
46395
|
})),
|
|
46181
46396
|
visibleYKeys = _useState2[0],
|
|
46182
46397
|
setVisibleYKeys = _useState2[1];
|
|
46398
|
+
var _useState3 = React.useState(),
|
|
46399
|
+
hoveredDataPointIndex = _useState3[0],
|
|
46400
|
+
setHoveredDataPointIndex = _useState3[1];
|
|
46183
46401
|
var themeCSS = React.useMemo(function () {
|
|
46184
|
-
|
|
46402
|
+
var css = getChartThemeCSS(theme);
|
|
46403
|
+
return css;
|
|
46185
46404
|
}, [theme]);
|
|
46186
46405
|
var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);
|
|
46187
46406
|
var innerWidth = width - margin.left - margin.right - (options.showLegend ? LEGEND_PADDING : 0);
|
|
46188
46407
|
var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? LEGEND_PADDING : 0);
|
|
46189
|
-
var radius = Math.min(innerWidth, innerHeight) / 2;
|
|
46408
|
+
var radius = Math.min(innerWidth, innerHeight) / 2 * 0.93;
|
|
46190
46409
|
React.useEffect(function () {
|
|
46191
46410
|
var _ref$current;
|
|
46192
46411
|
setVisibleYKeys(chart.lines.map(function (legendItem) {
|
|
@@ -46197,16 +46416,41 @@ var RadarChart$2 = function RadarChart(_ref) {
|
|
|
46197
46416
|
setVisibleYKeys([]);
|
|
46198
46417
|
};
|
|
46199
46418
|
}, [chart.lines]);
|
|
46419
|
+
var centerX = (groupWidth > width ? width * WIDTH_MULTIPLIER_TO_SCROLL : width) / 2;
|
|
46420
|
+
var centerY = height / 2 - margin.top * 2;
|
|
46421
|
+
var handleMouseMove = React.useCallback(function (event) {
|
|
46422
|
+
var radarTooltipData = getRadarTooltipData({
|
|
46423
|
+
data: chart.data,
|
|
46424
|
+
event: event,
|
|
46425
|
+
totalDataPoints: chart.data.length,
|
|
46426
|
+
centerX: centerX,
|
|
46427
|
+
centerY: centerY
|
|
46428
|
+
});
|
|
46429
|
+
if (radarTooltipData) {
|
|
46430
|
+
setHoveredDataPointIndex(radarTooltipData.dataPointIndex);
|
|
46431
|
+
showTooltip({
|
|
46432
|
+
tooltipLeft: event.pageX,
|
|
46433
|
+
tooltipTop: event.pageY,
|
|
46434
|
+
tooltipData: radarTooltipData.tooltipData
|
|
46435
|
+
});
|
|
46436
|
+
}
|
|
46437
|
+
}, [showTooltip, chart.data, centerX, centerY]);
|
|
46438
|
+
var handleMouseLeave = React.useCallback(function () {
|
|
46439
|
+
hideTooltip();
|
|
46440
|
+
setHoveredDataPointIndex(-1);
|
|
46441
|
+
}, [hideTooltip]);
|
|
46200
46442
|
if (width < 10) return null;
|
|
46201
46443
|
return jsxRuntime.jsxs(React.Fragment, {
|
|
46202
46444
|
children: [jsxRuntime.jsx(ChartWrapper$1, {
|
|
46203
46445
|
width: groupWidth > width ? width * WIDTH_MULTIPLIER_TO_SCROLL : width,
|
|
46204
46446
|
height: height,
|
|
46205
46447
|
showLegend: options.showLegend,
|
|
46448
|
+
onMouseMove: handleMouseMove,
|
|
46449
|
+
onMouseLeave: handleMouseLeave,
|
|
46206
46450
|
children: jsxRuntime.jsxs(group.Group, {
|
|
46207
46451
|
innerRef: ref,
|
|
46208
|
-
top:
|
|
46209
|
-
left:
|
|
46452
|
+
top: centerY,
|
|
46453
|
+
left: centerX,
|
|
46210
46454
|
children: [jsxRuntime.jsx(MiddleLine, {
|
|
46211
46455
|
chart: chart,
|
|
46212
46456
|
radius: radius,
|
|
@@ -46219,7 +46463,9 @@ var RadarChart$2 = function RadarChart(_ref) {
|
|
|
46219
46463
|
}), jsxRuntime.jsx(Polygons, {
|
|
46220
46464
|
chart: chart,
|
|
46221
46465
|
radius: radius,
|
|
46222
|
-
visibleYKeys: visibleYKeys
|
|
46466
|
+
visibleYKeys: visibleYKeys,
|
|
46467
|
+
tooltipData: tooltipData,
|
|
46468
|
+
hoveredDataPointIndex: hoveredDataPointIndex
|
|
46223
46469
|
})]
|
|
46224
46470
|
})
|
|
46225
46471
|
}), options.showLegend && jsxRuntime.jsx(Legend$1, {
|
|
@@ -46231,6 +46477,21 @@ var RadarChart$2 = function RadarChart(_ref) {
|
|
|
46231
46477
|
setVisibleYKeys: setVisibleYKeys,
|
|
46232
46478
|
keys: chart.keys,
|
|
46233
46479
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
46480
|
+
}), tooltipOpen && tooltipData && chart.x.key && jsxRuntime.jsx(Tooltip$1, {
|
|
46481
|
+
items: [{
|
|
46482
|
+
legendItems: chart.lines,
|
|
46483
|
+
visibleYKeys: visibleYKeys,
|
|
46484
|
+
conditionalFormattingRules: []
|
|
46485
|
+
}],
|
|
46486
|
+
tooltipData: tooltipData,
|
|
46487
|
+
tooltipLeft: tooltipLeft,
|
|
46488
|
+
tooltipTop: tooltipTop,
|
|
46489
|
+
xKey: chart.x.key,
|
|
46490
|
+
keys: chart.keys,
|
|
46491
|
+
yKeys: chart.y.keys,
|
|
46492
|
+
showRoundedTotal: options.showRoundedTotal,
|
|
46493
|
+
theme: themeCSS.popoverMenus,
|
|
46494
|
+
shouldShowColorLegend: false
|
|
46234
46495
|
})]
|
|
46235
46496
|
});
|
|
46236
46497
|
};
|
|
@@ -47927,6 +48188,7 @@ var LineChartV2View = function LineChartV2View(props) {
|
|
|
47927
48188
|
overflowX: 'hidden'
|
|
47928
48189
|
},
|
|
47929
48190
|
children: function children(parent) {
|
|
48191
|
+
var _props$attributes$lab;
|
|
47930
48192
|
if (chartRepresentation.lines.length === 0) return jsxRuntime.jsx(LoadingComponent, {});
|
|
47931
48193
|
return jsxRuntime.jsx(LineChart$5, {
|
|
47932
48194
|
width: parent.width,
|
|
@@ -47937,7 +48199,7 @@ var LineChartV2View = function LineChartV2View(props) {
|
|
|
47937
48199
|
removeStroke: false,
|
|
47938
48200
|
showRoundedTotal: false,
|
|
47939
48201
|
showLegend: props.attributes.legend,
|
|
47940
|
-
showLabels: false,
|
|
48202
|
+
showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
|
|
47941
48203
|
axis: {
|
|
47942
48204
|
showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
|
|
47943
48205
|
showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
|
|
@@ -48297,7 +48559,7 @@ var AreaChartV2View = function AreaChartV2View(props) {
|
|
|
48297
48559
|
overflowX: 'hidden'
|
|
48298
48560
|
},
|
|
48299
48561
|
children: function children(parent) {
|
|
48300
|
-
var _props$attributes$vie2, _props$attributes$sta;
|
|
48562
|
+
var _props$attributes$vie2, _props$attributes$sta, _props$attributes$lab;
|
|
48301
48563
|
if (chartRepresentation.areas.length === 0) return jsxRuntime.jsx(LoadingComponent, {});
|
|
48302
48564
|
return jsxRuntime.jsx(AreaChart$5, {
|
|
48303
48565
|
width: parent.width,
|
|
@@ -48310,7 +48572,7 @@ var AreaChartV2View = function AreaChartV2View(props) {
|
|
|
48310
48572
|
removeStroke: false,
|
|
48311
48573
|
showRoundedTotal: false,
|
|
48312
48574
|
showLegend: props.attributes.legend,
|
|
48313
|
-
showLabels: false,
|
|
48575
|
+
showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
|
|
48314
48576
|
axis: {
|
|
48315
48577
|
showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
|
|
48316
48578
|
showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
|
|
@@ -48692,6 +48954,7 @@ var BarChartV2View = function BarChartV2View(props) {
|
|
|
48692
48954
|
overflowX: 'hidden'
|
|
48693
48955
|
},
|
|
48694
48956
|
children: function children(parent) {
|
|
48957
|
+
var _props$attributes$lab;
|
|
48695
48958
|
if (chartRepresentation.bars.length === 0) return jsxRuntime.jsx(LoadingComponent, {});
|
|
48696
48959
|
return jsxRuntime.jsx(BarChart$5, {
|
|
48697
48960
|
width: parent.width,
|
|
@@ -48702,7 +48965,7 @@ var BarChartV2View = function BarChartV2View(props) {
|
|
|
48702
48965
|
removeStroke: false,
|
|
48703
48966
|
showRoundedTotal: false,
|
|
48704
48967
|
showLegend: props.attributes.legend,
|
|
48705
|
-
showLabels: false,
|
|
48968
|
+
showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
|
|
48706
48969
|
axis: {
|
|
48707
48970
|
showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
|
|
48708
48971
|
showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
|
|
@@ -49041,6 +49304,9 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
49041
49304
|
tooltipData: buildComboTooltipData(barTooltip == null ? void 0 : barTooltip.tooltipData, lineTooltip == null ? void 0 : lineTooltip.tooltipData, xScaleKey)
|
|
49042
49305
|
});
|
|
49043
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]);
|
|
49044
49310
|
var handleMouseLeave = React.useCallback(function () {
|
|
49045
49311
|
hideTooltip();
|
|
49046
49312
|
}, [hideTooltip]);
|
|
@@ -49095,7 +49361,8 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
49095
49361
|
showDetailedSubGroupingLabels: false,
|
|
49096
49362
|
yAxisLabels: [],
|
|
49097
49363
|
yLabelPosition: 0,
|
|
49098
|
-
showLabels: options.showLabels
|
|
49364
|
+
showLabels: options.showLabels,
|
|
49365
|
+
formattedData: chart.bars.data
|
|
49099
49366
|
}), options.stacked && xScaleKey !== null && jsxRuntime.jsx(BarStacked, {
|
|
49100
49367
|
data: barDataFlattened,
|
|
49101
49368
|
keys: yBarKeys,
|
|
@@ -49120,7 +49387,8 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
49120
49387
|
xScaleDataType: xScaleDataType,
|
|
49121
49388
|
xScale: xScale,
|
|
49122
49389
|
yScale: yScale,
|
|
49123
|
-
showLabels: options.showLabels
|
|
49390
|
+
showLabels: options.showLabels,
|
|
49391
|
+
labelDictionary: labelDictionary
|
|
49124
49392
|
})
|
|
49125
49393
|
})]
|
|
49126
49394
|
})]
|
|
@@ -49380,7 +49648,7 @@ var ComboChartViewV2 = function ComboChartViewV2(props) {
|
|
|
49380
49648
|
overflowX: 'hidden'
|
|
49381
49649
|
},
|
|
49382
49650
|
children: function children(parent) {
|
|
49383
|
-
var _props$attributes$sta2;
|
|
49651
|
+
var _props$attributes$sta2, _props$attributes$lab;
|
|
49384
49652
|
var numberOfXTicksFittingIntoSpace = howManyTicksFitInWidth(comboChartRepresentation.x.ticks || [], parent.width);
|
|
49385
49653
|
return jsxRuntime.jsx(ComboChart$4, {
|
|
49386
49654
|
width: parent.width,
|
|
@@ -49398,7 +49666,7 @@ var ComboChartViewV2 = function ComboChartViewV2(props) {
|
|
|
49398
49666
|
removeStroke: false,
|
|
49399
49667
|
showRoundedTotal: false,
|
|
49400
49668
|
showLegend: props.attributes.legend,
|
|
49401
|
-
showLabels: false,
|
|
49669
|
+
showLabels: (_props$attributes$lab = props.attributes.labels) != null ? _props$attributes$lab : false,
|
|
49402
49670
|
axis: {
|
|
49403
49671
|
showXAxisLabels: props.attributes.approxXAxisLabelCount !== 0,
|
|
49404
49672
|
showYAxisLabels: props.attributes.approxYAxisLabelCount !== 0
|
|
@@ -51952,7 +52220,7 @@ var defaultProps$8 = {
|
|
|
51952
52220
|
approxYAxisLabelCount: 'auto'
|
|
51953
52221
|
};
|
|
51954
52222
|
var FunnelChartView = function FunnelChartView(props) {
|
|
51955
|
-
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;
|
|
51956
52224
|
var _props = props,
|
|
51957
52225
|
displayTitle = _props.displayTitle,
|
|
51958
52226
|
displaySubject = _props.displaySubject;
|
|
@@ -52043,11 +52311,11 @@ var FunnelChartView = function FunnelChartView(props) {
|
|
|
52043
52311
|
colors: themeToColorScale(theme == null ? void 0 : theme.colors, series$1.length),
|
|
52044
52312
|
data: resultSet$1,
|
|
52045
52313
|
legend: showLegend((_props13 = props) == null ? void 0 : _props13.legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
|
|
52046
|
-
labels: false,
|
|
52314
|
+
labels: (_props$labels = (_props14 = props) == null ? void 0 : _props14.labels) != null ? _props$labels : false,
|
|
52047
52315
|
removeStroke: false,
|
|
52048
52316
|
forceXAxisAsTime: !!props.timeDimension,
|
|
52049
52317
|
theme: theme == null ? void 0 : theme.charts,
|
|
52050
|
-
axisTitles: (
|
|
52318
|
+
axisTitles: (_props15 = props) == null ? void 0 : _props15.axisTitles,
|
|
52051
52319
|
formatSeriesName: formatSeriesName(props.result, textOverride, props.type, (_props$viewId2 = props.viewId) != null ? _props$viewId2 : '', labelFormat),
|
|
52052
52320
|
conditionalFormattingPossibilities: function conditionalFormattingPossibilities(dataKey) {
|
|
52053
52321
|
return getExplanationsOfConditionFormattingRulesThatApplyToSeries(props.dimension, props.conditionalFormattingRules,
|
|
@@ -52566,7 +52834,7 @@ var getScaleAndTicks$2 = function getScaleAndTicks(_ref) {
|
|
|
52566
52834
|
var maxY = y.max || 0;
|
|
52567
52835
|
var minY = Math.min(y.min || 0, 0);
|
|
52568
52836
|
var yTickInterval = getNiceInterval$2((maxY - minY) / (tickCountYAxis - 1));
|
|
52569
|
-
for (var i = 0; i <=
|
|
52837
|
+
for (var i = 0; i <= Math.ceil(maxY / yTickInterval); i++) {
|
|
52570
52838
|
var _value = yTickInterval * i;
|
|
52571
52839
|
var formattedValue = formattingFunctionY(_value, nullValue);
|
|
52572
52840
|
yTicks.push({
|
|
@@ -54276,14 +54544,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
54276
54544
|
if (xScaleDataType === 'string') return String(xValue);
|
|
54277
54545
|
return '';
|
|
54278
54546
|
}, [xScaleKey, xScaleDataType]);
|
|
54279
|
-
var
|
|
54280
|
-
|
|
54281
|
-
|
|
54282
|
-
});
|
|
54283
|
-
return getMinMaxChartValueFromNumberArray(stepValues);
|
|
54284
|
-
}, [formattedChartDataForBarChart.steps]),
|
|
54285
|
-
minValue = _useMemo.minValue,
|
|
54286
|
-
maxValue = _useMemo.maxValue;
|
|
54547
|
+
var labelDictionary = React.useMemo(function () {
|
|
54548
|
+
return getLabelDictionary(formattedChartDataForBarChart.data, formattedChartDataForBarChart.y.keys);
|
|
54549
|
+
}, [formattedChartDataForBarChart.data, formattedChartDataForBarChart.y.keys]);
|
|
54287
54550
|
if (width === 0 || height === 0 || xScale == null) return null;
|
|
54288
54551
|
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
54289
54552
|
children: [jsxRuntime.jsxs(ChartWrapper$1, {
|
|
@@ -54381,10 +54644,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
54381
54644
|
barGroup: barGroup,
|
|
54382
54645
|
yScale: yScale,
|
|
54383
54646
|
formattedChartDataForBarChart: formattedChartDataForBarChart,
|
|
54384
|
-
maxValue: maxValue,
|
|
54385
|
-
minValue: minValue,
|
|
54386
54647
|
showLabels: options.showLabels,
|
|
54387
|
-
totalItems: formattedChartDataForBarChart.steps.length
|
|
54648
|
+
totalItems: formattedChartDataForBarChart.steps.length,
|
|
54649
|
+
labelDictionary: labelDictionary
|
|
54388
54650
|
}, "bar-" + bar.index);
|
|
54389
54651
|
})
|
|
54390
54652
|
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
@@ -54419,20 +54681,24 @@ var Bar$2 = function Bar(_ref4) {
|
|
|
54419
54681
|
var bar = _ref4.bar,
|
|
54420
54682
|
barColor = _ref4.barColor,
|
|
54421
54683
|
barGroup = _ref4.barGroup,
|
|
54422
|
-
yScale = _ref4.yScale,
|
|
54423
54684
|
formattedChartDataForBarChart = _ref4.formattedChartDataForBarChart,
|
|
54685
|
+
labelDictionary = _ref4.labelDictionary,
|
|
54424
54686
|
showLabels = _ref4.showLabels,
|
|
54425
54687
|
totalItems = _ref4.totalItems,
|
|
54426
|
-
|
|
54427
|
-
maxValue = _ref4.maxValue;
|
|
54688
|
+
yScale = _ref4.yScale;
|
|
54428
54689
|
var step = formattedChartDataForBarChart.steps[barGroup.index];
|
|
54429
54690
|
var y = yScale(Math.max(step.start, step.end));
|
|
54430
54691
|
var barHeight = Math.abs(yScale(step.start) - yScale(step.end));
|
|
54431
|
-
var xPadding =
|
|
54432
|
-
var labelX = bar.
|
|
54692
|
+
var xPadding = 10;
|
|
54693
|
+
var labelX = bar.x - xPadding;
|
|
54433
54694
|
var labelY = getStepYPosition(step, barHeight, y);
|
|
54434
|
-
var
|
|
54435
|
-
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;
|
|
54436
54702
|
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
54437
54703
|
children: [jsxRuntime.jsx("rect", {
|
|
54438
54704
|
x: bar.x,
|
|
@@ -54444,7 +54710,7 @@ var Bar$2 = function Bar(_ref4) {
|
|
|
54444
54710
|
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key), shouldShowLabel && jsxRuntime.jsx(DataLabel, {
|
|
54445
54711
|
x: labelX,
|
|
54446
54712
|
y: labelY,
|
|
54447
|
-
title:
|
|
54713
|
+
title: displayValue,
|
|
54448
54714
|
dx: 1,
|
|
54449
54715
|
dy: 0
|
|
54450
54716
|
})]
|
|
@@ -54473,7 +54739,7 @@ var WaterfallChartView = function WaterfallChartView(props) {
|
|
|
54473
54739
|
displayTitle = props.displayTitle,
|
|
54474
54740
|
headline = props.headline,
|
|
54475
54741
|
id = props.id,
|
|
54476
|
-
|
|
54742
|
+
labels = props.labels,
|
|
54477
54743
|
legend = props.legend,
|
|
54478
54744
|
library = props.library,
|
|
54479
54745
|
localFilters = props.localFilters,
|
|
@@ -54493,7 +54759,8 @@ var WaterfallChartView = function WaterfallChartView(props) {
|
|
|
54493
54759
|
xAxisPrefix = props.xAxisPrefix,
|
|
54494
54760
|
yAxisFormat = props.yAxisFormat,
|
|
54495
54761
|
yAxisPostfix = props.yAxisPostfix,
|
|
54496
|
-
yAxisPrefix = props.yAxisPrefix
|
|
54762
|
+
yAxisPrefix = props.yAxisPrefix,
|
|
54763
|
+
increaseColor = props.increaseColor;
|
|
54497
54764
|
var _useDashboardBehaviou = useDashboardBehaviourContext(),
|
|
54498
54765
|
textOverride = _useDashboardBehaviou.textOverride,
|
|
54499
54766
|
valueAlias = _useDashboardBehaviou.valueAlias,
|
|
@@ -54581,7 +54848,7 @@ var WaterfallChartView = function WaterfallChartView(props) {
|
|
|
54581
54848
|
height: parent.height,
|
|
54582
54849
|
options: {
|
|
54583
54850
|
showLegend: showLegend(legend, (theme == null ? void 0 : theme.detail) === 'verbose'),
|
|
54584
|
-
showLabels: false,
|
|
54851
|
+
showLabels: labels != null ? labels : false,
|
|
54585
54852
|
showTooltipRoundedTotal: true,
|
|
54586
54853
|
removeStroke: false,
|
|
54587
54854
|
axis: {
|