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