@vizzly/dashboard 0.14.4-dev-97acb8d43347ac757049612930b3f8e69e913e55 → 0.14.4-dev-452014891c726bda8e71210563e32bb225b30c86
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/Axis/AxisLeft.d.ts +2 -1
- package/dist/charts/src/v2/components/BarChart/BarChart.d.ts +18 -2
- package/dist/charts/src/v2/components/BarChart/useBarXScale.d.ts +2 -0
- package/dist/charts/src/v2/components/ComboChart/ComboChart.d.ts +22 -0
- package/dist/charts/src/v2/components/Legend/Legend.d.ts +7 -5
- package/dist/charts/src/v2/components/LineChart/LineChart.d.ts +16 -1
- package/dist/charts/src/v2/components/Tooltip/Tooltip.d.ts +6 -4
- package/dist/charts/src/v2/components/WaterfallChart/Legend.d.ts +3 -1
- package/dist/charts/src/v2/components/WaterfallChart/WaterfallChart.d.ts +3 -1
- package/dist/charts/src/v2/components/hooks/useFlattenedData.d.ts +3 -8
- package/dist/charts/src/v2/components/hooks/useYScale.d.ts +2 -0
- package/dist/charts/src/v2/constants/PADDING.d.ts +4 -0
- package/dist/charts/src/v2/{components/BarChart → utils}/getBarFill.d.ts +2 -2
- package/dist/dashboard/src/contexts/GlobalProvider/useGlobalProvider.d.ts +12 -12
- package/dist/dashboard.cjs.development.js +435 -344
- package/dist/dashboard.cjs.production.min.js +1 -1
- package/dist/dashboard.esm.js +440 -349
- package/dist/shared-logic/src/ChartsV2/types.d.ts +8 -7
- package/dist/shared-logic/src/ComboChartV2/types.d.ts +15 -0
- package/dist/shared-logic/src/Component/types.d.ts +2 -0
- package/dist/shared-logic/src/ComponentInterface/types/namespaces.types.d.ts +1 -0
- package/dist/shared-logic/src/FeatureToggle/types.d.ts +0 -3
- package/dist/shared-logic/src/FormatPanelConfig/types.d.ts +2 -1
- package/dist/shared-ui/src/library/StylePanel/WaterfallColorsSection.d.ts +7 -0
- package/package.json +1 -1
- package/dist/charts/src/v2/components/WaterfallChart/getBarFill.d.ts +0 -5
package/dist/dashboard.esm.js
CHANGED
|
@@ -28,13 +28,13 @@ import { preserveOffsetOnSource } from '@atlaskit/pragmatic-drag-and-drop/elemen
|
|
|
28
28
|
import { dropTargetForExternal } from '@atlaskit/pragmatic-drag-and-drop/external/adapter';
|
|
29
29
|
import { DropIndicator } from '@atlaskit/pragmatic-drag-and-drop-react-drop-indicator/box';
|
|
30
30
|
import { ParentSize } from '@visx/responsive';
|
|
31
|
-
import { Annotation, AnnotationConnector, AnnotationLabel, DataContext, buildChartTheme, lightTheme, XYChart, Grid as Grid$2, Axis, AreaSeries, AreaStack, BarGroup, BarSeries, BarStack, GlyphSeries, LineSeries, Tooltip as Tooltip$3 } from '@visx/xychart';
|
|
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
32
|
import { LinearGradient } from '@visx/gradient';
|
|
33
33
|
import { LegendItem as LegendItem$1, LegendLabel } from '@visx/legend';
|
|
34
|
-
import { scaleOrdinal, scaleQuantize, scalePoint, scaleTime,
|
|
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
|
-
import { Line as Line$1, LinePath,
|
|
37
|
+
import { Line as Line$1, LinePath, BarStack as BarStack$1, BarGroup as BarGroup$2, AreaStack as AreaStack$1, AreaClosed, LineRadial } from '@visx/shape';
|
|
38
38
|
import { Mercator, Graticule } from '@visx/geo';
|
|
39
39
|
import { feature } from 'topojson-client';
|
|
40
40
|
import ParentSize$1 from '@visx/responsive/lib/components/ParentSize';
|
|
@@ -1550,7 +1550,7 @@ var upcastFilterType = function upcastFilterType(type) {
|
|
|
1550
1550
|
if (type === 'dateTimeFilter') {
|
|
1551
1551
|
return DATE_FILTER;
|
|
1552
1552
|
}
|
|
1553
|
-
if (type === 'numericFilter'
|
|
1553
|
+
if (type === 'numericFilter') {
|
|
1554
1554
|
return ADVANCED_FILTER;
|
|
1555
1555
|
}
|
|
1556
1556
|
return type;
|
|
@@ -10009,7 +10009,9 @@ var attributesSchema$h = function attributesSchema(config) {
|
|
|
10009
10009
|
parameters: parametersSchema(config.queryEngineConfig, config.attributesSchemaOptions),
|
|
10010
10010
|
axisTitles: axisTitleSchema(),
|
|
10011
10011
|
headline: headlineSchema(),
|
|
10012
|
-
tags: tagsSchema()
|
|
10012
|
+
tags: tagsSchema(),
|
|
10013
|
+
increaseColor: Joi.string().required(),
|
|
10014
|
+
decreaseColor: Joi.string().required()
|
|
10013
10015
|
}));
|
|
10014
10016
|
};
|
|
10015
10017
|
|
|
@@ -10173,6 +10175,11 @@ var CONSTANTS$j = {
|
|
|
10173
10175
|
type: 'headline',
|
|
10174
10176
|
title: 'Headline',
|
|
10175
10177
|
description: ''
|
|
10178
|
+
},
|
|
10179
|
+
waterfall_colors: {
|
|
10180
|
+
type: 'waterfallColors',
|
|
10181
|
+
title: 'Color selector',
|
|
10182
|
+
description: ''
|
|
10176
10183
|
}
|
|
10177
10184
|
}
|
|
10178
10185
|
};
|
|
@@ -10212,6 +10219,8 @@ var WaterfallChart = function WaterfallChart(config) {
|
|
|
10212
10219
|
axisTitles: dumped.axisTitles,
|
|
10213
10220
|
displaySubject: dumped.displaySubject,
|
|
10214
10221
|
displayTitle: dumped.displayTitle,
|
|
10222
|
+
increaseColor: dumped.increaseColor,
|
|
10223
|
+
decreaseColor: dumped.decreaseColor,
|
|
10215
10224
|
protectedByOrganisation: dumped.protectedByOrganisation,
|
|
10216
10225
|
type: dumped.type,
|
|
10217
10226
|
offset: dumped.offset
|
|
@@ -10246,6 +10255,8 @@ var WaterfallChart = function WaterfallChart(config) {
|
|
|
10246
10255
|
parameters: {},
|
|
10247
10256
|
axisTitles: undefined,
|
|
10248
10257
|
headline: undefined,
|
|
10258
|
+
increaseColor: '#00FF00',
|
|
10259
|
+
decreaseColor: '#FF0000',
|
|
10249
10260
|
tags: [],
|
|
10250
10261
|
approxXAxisLabelCount: 'auto',
|
|
10251
10262
|
approxYAxisLabelCount: 'auto'
|
|
@@ -10300,7 +10311,7 @@ var WaterfallChart = function WaterfallChart(config) {
|
|
|
10300
10311
|
}), namespace(CONSTANTS$j, 'sort'), namespace(CONSTANTS$j, 'filter'), namespace(CONSTANTS$j, 'custom_metrics'), namespace(CONSTANTS$j, 'limit')];
|
|
10301
10312
|
},
|
|
10302
10313
|
formatPanelConfig: function formatPanelConfig() {
|
|
10303
|
-
return [headingConstant(CONSTANTS$j), chartStylesConstant(CONSTANTS$j, false, false), axisLabelsConstants(CONSTANTS$j)];
|
|
10314
|
+
return [headingConstant(CONSTANTS$j), namespace(CONSTANTS$j, 'waterfall_colors'), chartStylesConstant(CONSTANTS$j, false, false), axisLabelsConstants(CONSTANTS$j)];
|
|
10304
10315
|
},
|
|
10305
10316
|
supportedCustomFields: {
|
|
10306
10317
|
percentages: true,
|
|
@@ -13767,8 +13778,7 @@ var ADMIN_FEATURE_TOGGLES = {
|
|
|
13767
13778
|
forceMobile: false,
|
|
13768
13779
|
unloadOffScreenViews: false,
|
|
13769
13780
|
showSavingIndicator: false,
|
|
13770
|
-
disablePersistingGlobalFiltersLocally: false
|
|
13771
|
-
simpleMultiSelectFilter: false
|
|
13781
|
+
disablePersistingGlobalFiltersLocally: false
|
|
13772
13782
|
};
|
|
13773
13783
|
var END_USER_DEFAULT_FEATURE_TOGGLES = {
|
|
13774
13784
|
parameters: true,
|
|
@@ -13805,8 +13815,7 @@ var END_USER_DEFAULT_FEATURE_TOGGLES = {
|
|
|
13805
13815
|
forceMobile: false,
|
|
13806
13816
|
unloadOffScreenViews: false,
|
|
13807
13817
|
showSavingIndicator: true,
|
|
13808
|
-
disablePersistingGlobalFiltersLocally: false
|
|
13809
|
-
simpleMultiSelectFilter: false
|
|
13818
|
+
disablePersistingGlobalFiltersLocally: false
|
|
13810
13819
|
};
|
|
13811
13820
|
var build$b = function build(partialFeatureToggles, queryEngineConfig, mode, scope) {
|
|
13812
13821
|
var featureToggles = {};
|
|
@@ -13863,7 +13872,7 @@ var build$b = function build(partialFeatureToggles, queryEngineConfig, mode, sco
|
|
|
13863
13872
|
return featureToggles;
|
|
13864
13873
|
};
|
|
13865
13874
|
var buildDefaults = function buildDefaults(partialFeatureToggles) {
|
|
13866
|
-
var _partialFeatureToggle, _partialFeatureToggle2
|
|
13875
|
+
var _partialFeatureToggle, _partialFeatureToggle2;
|
|
13867
13876
|
return {
|
|
13868
13877
|
showDateAndTimeFilter: partialFeatureToggles.showDateAndTimeFilter !== undefined ? partialFeatureToggles.showDateAndTimeFilter : true,
|
|
13869
13878
|
showDateFilter: partialFeatureToggles.showDateFilter !== undefined ? partialFeatureToggles.showDateFilter : true,
|
|
@@ -13874,8 +13883,7 @@ var buildDefaults = function buildDefaults(partialFeatureToggles) {
|
|
|
13874
13883
|
canDownloadViewAsPNG: partialFeatureToggles.canDownloadViewAsPNG !== undefined ? partialFeatureToggles.canDownloadViewAsPNG : true,
|
|
13875
13884
|
forceMobile: partialFeatureToggles.forceMobile !== undefined ? partialFeatureToggles.forceMobile : false,
|
|
13876
13885
|
unloadOffScreenViews: partialFeatureToggles.unloadOffScreenViews !== undefined ? partialFeatureToggles.unloadOffScreenViews : false,
|
|
13877
|
-
allowCalculatedField: (_partialFeatureToggle2 = partialFeatureToggles.allowCalculatedField) != null ? _partialFeatureToggle2 : false
|
|
13878
|
-
simpleMultiSelectFilter: (_partialFeatureToggle3 = partialFeatureToggles.simpleMultiSelectFilter) != null ? _partialFeatureToggle3 : false
|
|
13886
|
+
allowCalculatedField: (_partialFeatureToggle2 = partialFeatureToggles.allowCalculatedField) != null ? _partialFeatureToggle2 : false
|
|
13879
13887
|
};
|
|
13880
13888
|
};
|
|
13881
13889
|
|
|
@@ -28875,8 +28883,7 @@ var AdditionalFilter = function AdditionalFilter(props) {
|
|
|
28875
28883
|
onChange = props.onChange,
|
|
28876
28884
|
shouldAlwaysHaveValue = props.shouldAlwaysHaveValue;
|
|
28877
28885
|
var _useDashboardBehaviou = useDashboardBehaviourContext(),
|
|
28878
|
-
queryEngineConfig = _useDashboardBehaviou.queryEngineConfig
|
|
28879
|
-
featureToggles = _useDashboardBehaviou.featureToggles;
|
|
28886
|
+
queryEngineConfig = _useDashboardBehaviou.queryEngineConfig;
|
|
28880
28887
|
|
|
28881
28888
|
/** Validate the new filter before setting it */
|
|
28882
28889
|
var onChangeWithValidation = function onChangeWithValidation(newFilter) {
|
|
@@ -28927,7 +28934,7 @@ var AdditionalFilter = function AdditionalFilter(props) {
|
|
|
28927
28934
|
dataSets: props.dataSets
|
|
28928
28935
|
}, typeof props.filter.value === 'boolean' ? undefined : JSON.stringify(props.filter.value));
|
|
28929
28936
|
}
|
|
28930
|
-
if (filter.type == MULTI_SELECT_FILTER
|
|
28937
|
+
if (filter.type == MULTI_SELECT_FILTER) {
|
|
28931
28938
|
return jsx(MultiSelectFilter, {
|
|
28932
28939
|
showClearBtn: !shouldAlwaysHaveValue,
|
|
28933
28940
|
filter: filter,
|
|
@@ -33157,7 +33164,7 @@ var VizzlyXYChart = function VizzlyXYChart(props) {
|
|
|
33157
33164
|
}), (props == null ? void 0 : props.bars) && !props.bars.stacked && !(props != null && (_props$bars3 = props.bars) != null && _props$bars3.funnelChart) && jsxs(Fragment, {
|
|
33158
33165
|
children: [props.enableHover && jsx("style", {
|
|
33159
33166
|
children: "\n /* We need to find a more accurate way to target the rect element. */\n .vizzly-xy-chart > div > svg > rect {\n cursor: pointer;\n }"
|
|
33160
|
-
}), jsx(BarGroup, {
|
|
33167
|
+
}), jsx(BarGroup$1, {
|
|
33161
33168
|
children: props.bars.keys.map(function (key, keyIndex) {
|
|
33162
33169
|
var _props$bars$styles$co, _props$bars4, _props$bars5;
|
|
33163
33170
|
return jsx(BarSeries, _extends({
|
|
@@ -38117,13 +38124,11 @@ var AddFilterForm = function AddFilterForm(props) {
|
|
|
38117
38124
|
value: SINGLE_SELECT_FILTER,
|
|
38118
38125
|
subText: textOverride('single_select_filter_description', 'Choose a single option from the list to filter. ')
|
|
38119
38126
|
}];
|
|
38120
|
-
|
|
38121
|
-
|
|
38122
|
-
|
|
38123
|
-
|
|
38124
|
-
|
|
38125
|
-
});
|
|
38126
|
-
}
|
|
38127
|
+
filterTypes.push({
|
|
38128
|
+
label: textOverride('multi_select', 'Multi select'),
|
|
38129
|
+
value: MULTI_SELECT_FILTER,
|
|
38130
|
+
subText: textOverride('multi_select_description', 'Allow multiple selections.')
|
|
38131
|
+
});
|
|
38127
38132
|
filterTypes.push({
|
|
38128
38133
|
label: textOverride('advanced_filter', 'Advanced filter'),
|
|
38129
38134
|
value: ADVANCED_FILTER,
|
|
@@ -42354,16 +42359,14 @@ var SCROLLBAR_WIDTH = 40;
|
|
|
42354
42359
|
var Tooltip$1 = function Tooltip(_ref) {
|
|
42355
42360
|
var _tooltipData$xKey$for;
|
|
42356
42361
|
var keys = _ref.keys,
|
|
42357
|
-
legendItems = _ref.legendItems,
|
|
42358
42362
|
showRoundedTotal = _ref.showRoundedTotal,
|
|
42359
42363
|
tooltipData = _ref.tooltipData,
|
|
42360
42364
|
tooltipLeft = _ref.tooltipLeft,
|
|
42361
42365
|
tooltipTop = _ref.tooltipTop,
|
|
42362
|
-
visibleYKeys = _ref.visibleYKeys,
|
|
42363
42366
|
xKey = _ref.xKey,
|
|
42364
42367
|
yKeys = _ref.yKeys,
|
|
42365
|
-
|
|
42366
|
-
|
|
42368
|
+
theme = _ref.theme,
|
|
42369
|
+
items = _ref.items;
|
|
42367
42370
|
var tooltipRef = useRef(null);
|
|
42368
42371
|
var _useState = useState({
|
|
42369
42372
|
left: tooltipLeft
|
|
@@ -42412,7 +42415,7 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
42412
42415
|
fontSize: '15px',
|
|
42413
42416
|
width: '100%',
|
|
42414
42417
|
minWidth: MIN_TOOLTIP_WIDTH
|
|
42415
|
-
}, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42418
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBGcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5cbmNvbnN0IE1JTl9UT09MVElQX1dJRFRIID0gMTgwO1xuY29uc3QgVE9PTFRJUF9PRkZTRVQgPSAyMDtcbmNvbnN0IFNDUk9MTEJBUl9XSURUSCA9IDQwO1xuXG5pbnRlcmZhY2UgVG9vbHRpcFByb3BzPFQ+IHtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgc2hvd1JvdW5kZWRUb3RhbDogYm9vbGVhbjtcbiAgdG9vbHRpcERhdGE6IHtcbiAgICBba2V5SWQ6IHN0cmluZ106IERhdGFJdGVtO1xuICB9O1xuICB0b29sdGlwTGVmdDogbnVtYmVyO1xuICB0b29sdGlwVG9wOiBudW1iZXI7XG4gIHhLZXk6IHN0cmluZztcbiAgeUtleXM6IHN0cmluZ1tdO1xuICBpdGVtczoge1xuICAgIGxlZ2VuZEl0ZW1zOiBBcnJheTxTaGFwZURlZmluaXRpb248VD4+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgICB2aXNpYmxlWUtleXM6IHN0cmluZ1tdO1xuICB9W107XG4gIHRoZW1lOiBDU1NQcm9wZXJ0aWVzO1xufVxuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9ICh7XG4gIGtleXMsXG4gIHNob3dSb3VuZGVkVG90YWwsXG4gIHRvb2x0aXBEYXRhLFxuICB0b29sdGlwTGVmdCxcbiAgdG9vbHRpcFRvcCxcbiAgeEtleSxcbiAgeUtleXMsXG4gIHRoZW1lLFxuICBpdGVtcyxcbn06IFRvb2x0aXBQcm9wczxMaW5lU3R5bGVzIHwgQmFyU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgdG9vbHRpcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGU8eyBsZWZ0OiBudW1iZXIgfT4oe1xuICAgIGxlZnQ6IHRvb2x0aXBMZWZ0LFxuICB9KTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGFkanVzdFRvb2x0aXBQb3NpdGlvbiA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHRvb2x0aXBFbGVtZW50ID0gdG9vbHRpcFJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAodG9vbHRpcEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgc2NyZWVuV2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcblxuICAgICAgICBjb25zdCByZWN0ID0gdG9vbHRpcEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgbGV0IHdpZHRoID0gcmVjdC53aWR0aDtcblxuICAgICAgICBpZiAod2lkdGggPCBNSU5fVE9PTFRJUF9XSURUSCkge1xuICAgICAgICAgIHdpZHRoID0gTUlOX1RPT0xUSVBfV0lEVEg7XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgbGVmdCA9IHRvb2x0aXBMZWZ0ICsgVE9PTFRJUF9PRkZTRVQ7XG5cbiAgICAgICAgaWYgKHRvb2x0aXBMZWZ0ICsgd2lkdGggPiBzY3JlZW5XaWR0aCAtIFNDUk9MTEJBUl9XSURUSCkge1xuICAgICAgICAgIGxlZnQgPSB0b29sdGlwTGVmdCAtIHdpZHRoIC0gVE9PTFRJUF9PRkZTRVQ7XG4gICAgICAgIH1cblxuICAgICAgICBzZXRQb3NpdGlvbih7IGxlZnQgfSk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIGFkanVzdFRvb2x0aXBQb3NpdGlvbigpO1xuICB9LCBbdG9vbHRpcExlZnRdKTtcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxkaXZcbiAgICAgIHJlZj17dG9vbHRpcFJlZn1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICBsZWZ0OiBwb3NpdGlvbi5sZWZ0LFxuICAgICAgICB0b3A6IHRvb2x0aXBUb3AsXG4gICAgICAgIHpJbmRleDogMjE0NzQ4MzY0NyAqIDEwLFxuICAgICAgICAuLi50aGVtZSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyB3b3JkQnJlYWs6ICdicmVhay1hbGwnIH19PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGluZUhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGV0dGVyU3BhY2luZzogJ2luaGVyaXQnLFxuICAgICAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgICAgICAgZm9udFNpemU6ICcxNXB4JyxcbiAgICAgICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgICAgICBtaW5XaWR0aDogTUlOX1RPT0xUSVBfV0lEVEgsXG4gICAgICAgICAgfSl9XG4gICAgICAgID5cbiAgICAgICAgICB7dG9vbHRpcERhdGFbeEtleV0uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */"),
|
|
42416
42419
|
children: (_tooltipData$xKey$for = tooltipData[xKey].formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
|
|
42417
42420
|
}), jsx("table", {
|
|
42418
42421
|
cellPadding: 0,
|
|
@@ -42423,45 +42426,51 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
42423
42426
|
} : {
|
|
42424
42427
|
name: "9a1sa-Tooltip",
|
|
42425
42428
|
styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
|
|
42426
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42429
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlHcUIiLCJmaWxlIjoiVG9vbHRpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgQ1NTUHJvcGVydGllcywgRnJhZ21lbnQsIHVzZUVmZmVjdCwgdXNlUmVmLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSc7XG5cbmltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTGVnZW5kSXRlbUJveCB9IGZyb20gJy4uL0xlZ2VuZC9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgRGF0YUl0ZW0sIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5cbmNvbnN0IE1JTl9UT09MVElQX1dJRFRIID0gMTgwO1xuY29uc3QgVE9PTFRJUF9PRkZTRVQgPSAyMDtcbmNvbnN0IFNDUk9MTEJBUl9XSURUSCA9IDQwO1xuXG5pbnRlcmZhY2UgVG9vbHRpcFByb3BzPFQ+IHtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgc2hvd1JvdW5kZWRUb3RhbDogYm9vbGVhbjtcbiAgdG9vbHRpcERhdGE6IHtcbiAgICBba2V5SWQ6IHN0cmluZ106IERhdGFJdGVtO1xuICB9O1xuICB0b29sdGlwTGVmdDogbnVtYmVyO1xuICB0b29sdGlwVG9wOiBudW1iZXI7XG4gIHhLZXk6IHN0cmluZztcbiAgeUtleXM6IHN0cmluZ1tdO1xuICBpdGVtczoge1xuICAgIGxlZ2VuZEl0ZW1zOiBBcnJheTxTaGFwZURlZmluaXRpb248VD4+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgICB2aXNpYmxlWUtleXM6IHN0cmluZ1tdO1xuICB9W107XG4gIHRoZW1lOiBDU1NQcm9wZXJ0aWVzO1xufVxuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9ICh7XG4gIGtleXMsXG4gIHNob3dSb3VuZGVkVG90YWwsXG4gIHRvb2x0aXBEYXRhLFxuICB0b29sdGlwTGVmdCxcbiAgdG9vbHRpcFRvcCxcbiAgeEtleSxcbiAgeUtleXMsXG4gIHRoZW1lLFxuICBpdGVtcyxcbn06IFRvb2x0aXBQcm9wczxMaW5lU3R5bGVzIHwgQmFyU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgdG9vbHRpcFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFtwb3NpdGlvbiwgc2V0UG9zaXRpb25dID0gdXNlU3RhdGU8eyBsZWZ0OiBudW1iZXIgfT4oe1xuICAgIGxlZnQ6IHRvb2x0aXBMZWZ0LFxuICB9KTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGFkanVzdFRvb2x0aXBQb3NpdGlvbiA9ICgpID0+IHtcbiAgICAgIGNvbnN0IHRvb2x0aXBFbGVtZW50ID0gdG9vbHRpcFJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAodG9vbHRpcEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgc2NyZWVuV2lkdGggPSB3aW5kb3cuaW5uZXJXaWR0aDtcblxuICAgICAgICBjb25zdCByZWN0ID0gdG9vbHRpcEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgICAgICAgbGV0IHdpZHRoID0gcmVjdC53aWR0aDtcblxuICAgICAgICBpZiAod2lkdGggPCBNSU5fVE9PTFRJUF9XSURUSCkge1xuICAgICAgICAgIHdpZHRoID0gTUlOX1RPT0xUSVBfV0lEVEg7XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgbGVmdCA9IHRvb2x0aXBMZWZ0ICsgVE9PTFRJUF9PRkZTRVQ7XG5cbiAgICAgICAgaWYgKHRvb2x0aXBMZWZ0ICsgd2lkdGggPiBzY3JlZW5XaWR0aCAtIFNDUk9MTEJBUl9XSURUSCkge1xuICAgICAgICAgIGxlZnQgPSB0b29sdGlwTGVmdCAtIHdpZHRoIC0gVE9PTFRJUF9PRkZTRVQ7XG4gICAgICAgIH1cblxuICAgICAgICBzZXRQb3NpdGlvbih7IGxlZnQgfSk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIGFkanVzdFRvb2x0aXBQb3NpdGlvbigpO1xuICB9LCBbdG9vbHRpcExlZnRdKTtcblxuICByZXR1cm4gY3JlYXRlUG9ydGFsKFxuICAgIDxkaXZcbiAgICAgIHJlZj17dG9vbHRpcFJlZn1cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICBsZWZ0OiBwb3NpdGlvbi5sZWZ0LFxuICAgICAgICB0b3A6IHRvb2x0aXBUb3AsXG4gICAgICAgIHpJbmRleDogMjE0NzQ4MzY0NyAqIDEwLFxuICAgICAgICAuLi50aGVtZSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPGRpdiBzdHlsZT17eyB3b3JkQnJlYWs6ICdicmVhay1hbGwnIH19PlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGluZUhlaWdodDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgbGV0dGVyU3BhY2luZzogJ2luaGVyaXQnLFxuICAgICAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgICAgICAgZm9udFNpemU6ICcxNXB4JyxcbiAgICAgICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgICAgICBtaW5XaWR0aDogTUlOX1RPT0xUSVBfV0lEVEgsXG4gICAgICAgICAgfSl9XG4gICAgICAgID5cbiAgICAgICAgICB7dG9vbHRpcERhdGFbeEtleV0uZm9ybWF0dGVkVmFsdWUgPz8gdG9vbHRpcERhdGFbeEtleV0udmFsdWV9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8dGFibGVcbiAgICAgICAgICBjZWxsUGFkZGluZz17MH1cbiAgICAgICAgICBjZWxsU3BhY2luZz17MH1cbiAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICBtYXJnaW46ICcwJyxcbiAgICAgICAgICAgIGJvcmRlclNwYWNpbmc6ICcwJyxcbiAgICAgICAgICAgIGJvcmRlckNvbGxhcHNlOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDx0Ym9keT5cbiAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcCgobGVnZW5kSXRlbSwgaW5kZXgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldIHx8IHRvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0udmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICAgICAgICAgICAgICAvLyB5S2V5IGNvdWxkIG5vdCBiZSBmb3VuZCBpbiB0b29sdGlwRGF0YVxuICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgaXRlbS52aXNpYmxlWUtleXM/LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkgJiYgKFxuICAgICAgICAgICAgICAgICAgICAgICAgPHRyIGtleT17bGVnZW5kSXRlbS55S2V5fT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e3tcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogaW5kZXggPT09IDAgPyAnMTJweCA4cHggMCAwJyA6ICc4cHggOHB4IDAgMCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aWR0aDogJ2F1dG8nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbUJveFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3I9e2dldENvbG9yKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGVmYXVsdENvbG9yOiBsZWdlbmRJdGVtLmNvbG9yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZTogdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgeUtleTogbGVnZW5kSXRlbS55S2V5LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogaXRlbS5jb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyA/PyBbXSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3R5bGU9e2xlZ2VuZEl0ZW0uc3R5bGUgYXMgTGluZVN0eWxlc31cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXk9e2xlZ2VuZEl0ZW0ueUtleX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgcGFkZGluZzogJzhweCAwIDAgMCcgfX0+e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9PC90ZD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgPHRkIHN0eWxlPXt7IGZvbnRXZWlnaHQ6ICdib2xkJywgcGFkZGluZzogJzhweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge3Rvb2x0aXBEYXRhW2xlZ2VuZEl0ZW0ueUtleV0uZm9ybWF0dGVkVmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID8gdG9vbHRpcERhdGFbbGVnZW5kSXRlbS55S2V5XS5mb3JtYXR0ZWRWYWx1ZVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgOiB0b29sdGlwRGF0YVtsZWdlbmRJdGVtLnlLZXldLnZhbHVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICA8L3RkPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfSl9XG5cbiAgICAgICAgICAgIHtzaG93Um91bmRlZFRvdGFsICYmIChcbiAgICAgICAgICAgICAgPHRyPlxuICAgICAgICAgICAgICAgIDx0ZCBjb2xTcGFuPXsyfSBzdHlsZT17eyBwYWRkaW5nOiAnMTJweCAwIDAgMCcgfX0+XG4gICAgICAgICAgICAgICAgICBSb3VuZGVkIFRvdGFsXG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9e3sgZm9udFdlaWdodDogJ2JvbGQnLCBwYWRkaW5nOiAnMTJweCAwIDAgMTZweCcgfX0+XG4gICAgICAgICAgICAgICAgICB7eUtleXMucmVkdWNlKCh0b3RhbCwga2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB0b3RhbCArIE1hdGgucm91bmQodG9vbHRpcERhdGFba2V5XS52YWx1ZSBhcyBudW1iZXIpO1xuICAgICAgICAgICAgICAgICAgfSwgMCl9XG4gICAgICAgICAgICAgICAgPC90ZD5cbiAgICAgICAgICAgICAgPC90cj5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC90Ym9keT5cbiAgICAgICAgPC90YWJsZT5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PixcbiAgICBkb2N1bWVudC5ib2R5XG4gICk7XG59O1xuIl19 */",
|
|
42427
42430
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
42428
42431
|
}),
|
|
42429
42432
|
children: jsxs("tbody", {
|
|
42430
|
-
children: [
|
|
42431
|
-
|
|
42432
|
-
|
|
42433
|
-
|
|
42434
|
-
|
|
42435
|
-
|
|
42436
|
-
|
|
42437
|
-
|
|
42438
|
-
|
|
42439
|
-
|
|
42440
|
-
|
|
42441
|
-
|
|
42442
|
-
|
|
42443
|
-
|
|
42444
|
-
|
|
42445
|
-
|
|
42446
|
-
|
|
42447
|
-
|
|
42448
|
-
|
|
42449
|
-
|
|
42450
|
-
|
|
42451
|
-
|
|
42452
|
-
|
|
42453
|
-
|
|
42454
|
-
|
|
42455
|
-
|
|
42456
|
-
|
|
42457
|
-
|
|
42458
|
-
|
|
42459
|
-
|
|
42460
|
-
|
|
42461
|
-
|
|
42462
|
-
|
|
42463
|
-
|
|
42464
|
-
|
|
42433
|
+
children: [items.map(function (item, index) {
|
|
42434
|
+
var _item$legendItems;
|
|
42435
|
+
return jsx(Fragment, {
|
|
42436
|
+
children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem, index) {
|
|
42437
|
+
var _item$visibleYKeys, _item$conditionalForm;
|
|
42438
|
+
if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
|
|
42439
|
+
// yKey could not be found in tooltipData
|
|
42440
|
+
return null;
|
|
42441
|
+
}
|
|
42442
|
+
return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxs("tr", {
|
|
42443
|
+
children: [jsx("td", {
|
|
42444
|
+
style: {
|
|
42445
|
+
verticalAlign: 'middle',
|
|
42446
|
+
padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
|
|
42447
|
+
width: 'auto'
|
|
42448
|
+
},
|
|
42449
|
+
children: jsx(LegendItemBox, {
|
|
42450
|
+
color: getColor({
|
|
42451
|
+
defaultColor: legendItem.color,
|
|
42452
|
+
value: tooltipData[legendItem.yKey].value,
|
|
42453
|
+
yKey: legendItem.yKey,
|
|
42454
|
+
conditionalFormattingRules: (_item$conditionalForm = item.conditionalFormattingRules) != null ? _item$conditionalForm : []
|
|
42455
|
+
}),
|
|
42456
|
+
style: legendItem.style,
|
|
42457
|
+
yKey: legendItem.yKey
|
|
42458
|
+
})
|
|
42459
|
+
}), jsx("td", {
|
|
42460
|
+
style: {
|
|
42461
|
+
padding: '8px 0 0 0'
|
|
42462
|
+
},
|
|
42463
|
+
children: keys[legendItem.yKey].keyFormatted
|
|
42464
|
+
}), jsx("td", {
|
|
42465
|
+
style: {
|
|
42466
|
+
fontWeight: 'bold',
|
|
42467
|
+
padding: '8px 0 0 16px'
|
|
42468
|
+
},
|
|
42469
|
+
children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
|
|
42470
|
+
})]
|
|
42471
|
+
}, legendItem.yKey);
|
|
42472
|
+
})
|
|
42473
|
+
}, index);
|
|
42465
42474
|
}), showRoundedTotal && jsxs("tr", {
|
|
42466
42475
|
children: [jsx("td", {
|
|
42467
42476
|
colSpan: 2,
|
|
@@ -42584,11 +42593,9 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42584
42593
|
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)."; }
|
|
42585
42594
|
var Legend$1 = function Legend(_ref) {
|
|
42586
42595
|
var keys = _ref.keys,
|
|
42587
|
-
visibleYKeys = _ref.visibleYKeys,
|
|
42588
|
-
legendItems = _ref.legendItems,
|
|
42589
42596
|
setVisibleYKeys = _ref.setVisibleYKeys,
|
|
42590
|
-
|
|
42591
|
-
|
|
42597
|
+
marginLeft = _ref.marginLeft,
|
|
42598
|
+
items = _ref.items;
|
|
42592
42599
|
return jsx("div", {
|
|
42593
42600
|
className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
|
|
42594
42601
|
name: "1nbollx",
|
|
@@ -42596,7 +42603,7 @@ var Legend$1 = function Legend(_ref) {
|
|
|
42596
42603
|
} : {
|
|
42597
42604
|
name: "qz6h7j-Legend",
|
|
42598
42605
|
styles: "height:40px;padding-top:8px;label:Legend;",
|
|
42599
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42606
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
|
|
42600
42607
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
42601
42608
|
}),
|
|
42602
42609
|
children: jsx(Scrollbar, {
|
|
@@ -42606,34 +42613,39 @@ var Legend$1 = function Legend(_ref) {
|
|
|
42606
42613
|
flexWrap: 'nowrap',
|
|
42607
42614
|
alignItems: 'center',
|
|
42608
42615
|
marginLeft: marginLeft ? marginLeft + "px" : undefined
|
|
42609
|
-
}, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42616
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
|
|
42610
42617
|
x: true,
|
|
42611
|
-
children:
|
|
42612
|
-
|
|
42613
|
-
|
|
42614
|
-
|
|
42615
|
-
|
|
42616
|
-
|
|
42617
|
-
|
|
42618
|
-
|
|
42619
|
-
|
|
42620
|
-
|
|
42621
|
-
|
|
42622
|
-
|
|
42623
|
-
|
|
42624
|
-
|
|
42625
|
-
|
|
42626
|
-
|
|
42627
|
-
|
|
42628
|
-
|
|
42629
|
-
|
|
42630
|
-
|
|
42631
|
-
|
|
42632
|
-
|
|
42633
|
-
|
|
42634
|
-
|
|
42635
|
-
|
|
42636
|
-
|
|
42618
|
+
children: items == null ? void 0 : items.map(function (item, index) {
|
|
42619
|
+
var _item$legendItems;
|
|
42620
|
+
return jsx(Fragment, {
|
|
42621
|
+
children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem) {
|
|
42622
|
+
return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
|
|
42623
|
+
key: "legend-" + legendItem.yKey,
|
|
42624
|
+
yKeyFormatted: keys[legendItem.yKey].keyFormatted,
|
|
42625
|
+
onClick: function onClick() {
|
|
42626
|
+
return setVisibleYKeys && setVisibleYKeys(function (prev) {
|
|
42627
|
+
var newVisibleLegendItems = [];
|
|
42628
|
+
if (prev.length === item.legendItems.length) {
|
|
42629
|
+
newVisibleLegendItems = [legendItem.yKey];
|
|
42630
|
+
} else {
|
|
42631
|
+
if (prev.includes(legendItem.yKey)) {
|
|
42632
|
+
newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
|
|
42633
|
+
return prevLegendItemId !== legendItem.yKey;
|
|
42634
|
+
});
|
|
42635
|
+
} else {
|
|
42636
|
+
newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
|
|
42637
|
+
}
|
|
42638
|
+
}
|
|
42639
|
+
return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
|
|
42640
|
+
return legendItem.yKey;
|
|
42641
|
+
}) : newVisibleLegendItems;
|
|
42642
|
+
});
|
|
42643
|
+
},
|
|
42644
|
+
visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
|
|
42645
|
+
conditionalFormattingRules: item.conditionalFormattingRules
|
|
42646
|
+
}));
|
|
42647
|
+
})
|
|
42648
|
+
}, index);
|
|
42637
42649
|
})
|
|
42638
42650
|
})
|
|
42639
42651
|
});
|
|
@@ -42735,19 +42747,19 @@ var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, h
|
|
|
42735
42747
|
};
|
|
42736
42748
|
};
|
|
42737
42749
|
|
|
42738
|
-
function useFlattenedData(xScaleKey, xScaleDataType,
|
|
42750
|
+
function useFlattenedData(xScaleKey, xScaleDataType, data, yKeys) {
|
|
42739
42751
|
return useMemo(function () {
|
|
42740
|
-
if (xScaleKey && xScaleDataType) {
|
|
42752
|
+
if (xScaleKey && xScaleDataType && yKeys.length > 0) {
|
|
42741
42753
|
return flattenData({
|
|
42742
|
-
data:
|
|
42754
|
+
data: data,
|
|
42743
42755
|
xScaleKey: xScaleKey,
|
|
42744
42756
|
xScaleDataType: xScaleDataType,
|
|
42745
|
-
yKeys:
|
|
42757
|
+
yKeys: yKeys
|
|
42746
42758
|
});
|
|
42747
42759
|
} else {
|
|
42748
42760
|
return [];
|
|
42749
42761
|
}
|
|
42750
|
-
}, [
|
|
42762
|
+
}, [data, xScaleKey, xScaleDataType, yKeys]);
|
|
42751
42763
|
}
|
|
42752
42764
|
|
|
42753
42765
|
var GoalLine = function GoalLine(_ref) {
|
|
@@ -43099,6 +43111,17 @@ function useTooltip$1(initialTooltipState) {
|
|
|
43099
43111
|
};
|
|
43100
43112
|
}
|
|
43101
43113
|
|
|
43114
|
+
function useYScale(innerHeight, scale) {
|
|
43115
|
+
return useMemo(function () {
|
|
43116
|
+
return scaleLinear({
|
|
43117
|
+
range: [innerHeight, 0],
|
|
43118
|
+
domain: scale.ordering === 'asc' ? [scale.min, scale.max] : [scale.max, scale.min],
|
|
43119
|
+
nice: true,
|
|
43120
|
+
round: true
|
|
43121
|
+
});
|
|
43122
|
+
}, [innerHeight, scale]);
|
|
43123
|
+
}
|
|
43124
|
+
|
|
43102
43125
|
var LineChart$5 = function LineChart(_ref) {
|
|
43103
43126
|
var _theme$axis;
|
|
43104
43127
|
var chart = _ref.chart,
|
|
@@ -43164,14 +43187,8 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43164
43187
|
}
|
|
43165
43188
|
return null;
|
|
43166
43189
|
}, [innerWidth, chart.x, chart.data]);
|
|
43167
|
-
var _yScale =
|
|
43168
|
-
|
|
43169
|
-
range: [innerHeight, 0],
|
|
43170
|
-
domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
|
|
43171
|
-
nice: true
|
|
43172
|
-
});
|
|
43173
|
-
}, [innerHeight, chart.y]);
|
|
43174
|
-
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
|
|
43190
|
+
var _yScale = useYScale(innerHeight, chart.y.scale);
|
|
43191
|
+
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
43175
43192
|
var handleMouseMove = useCallback(function (event) {
|
|
43176
43193
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
43177
43194
|
var tooltipData = getTooltipData({
|
|
@@ -43198,6 +43215,11 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43198
43215
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
43199
43216
|
return Number(tick.value);
|
|
43200
43217
|
});
|
|
43218
|
+
var legendTooltipItems = [{
|
|
43219
|
+
legendItems: chart.lines,
|
|
43220
|
+
visibleYKeys: visibleYKeys,
|
|
43221
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
43222
|
+
}];
|
|
43201
43223
|
return jsxs(React__default.Fragment, {
|
|
43202
43224
|
children: [jsxs(ChartWrapper$1, {
|
|
43203
43225
|
width: width,
|
|
@@ -43232,93 +43254,19 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43232
43254
|
yScale: _yScale,
|
|
43233
43255
|
ticks: yTickValues,
|
|
43234
43256
|
stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
|
|
43235
|
-
}),
|
|
43236
|
-
children:
|
|
43237
|
-
|
|
43238
|
-
|
|
43239
|
-
|
|
43240
|
-
|
|
43241
|
-
|
|
43242
|
-
|
|
43243
|
-
|
|
43244
|
-
|
|
43245
|
-
|
|
43246
|
-
|
|
43247
|
-
|
|
43248
|
-
},
|
|
43249
|
-
y: function y(d) {
|
|
43250
|
-
return _yScale(Number(d[yKey]));
|
|
43251
|
-
},
|
|
43252
|
-
stroke: chart.lines.filter(function (legendItem) {
|
|
43253
|
-
return legendItem.yKey === yKey;
|
|
43254
|
-
})[0].color,
|
|
43255
|
-
strokeWidth: chart.lines.filter(function (legendItem) {
|
|
43256
|
-
return legendItem.yKey === yKey;
|
|
43257
|
-
})[0].style.strokeWidth,
|
|
43258
|
-
strokeLinecap: "round",
|
|
43259
|
-
strokeDasharray: (_chart$lines$filter$ = chart.lines.filter(function (legendItem) {
|
|
43260
|
-
return legendItem.yKey === yKey;
|
|
43261
|
-
})[0].style.strokeDasharray) != null ? _chart$lines$filter$ : undefined,
|
|
43262
|
-
shapeRendering: "smooth",
|
|
43263
|
-
defined: function defined(d) {
|
|
43264
|
-
return d[yKey] !== null;
|
|
43265
|
-
},
|
|
43266
|
-
curve: curve
|
|
43267
|
-
}, yKey);
|
|
43268
|
-
}), chart.conditionalFormattingRules.map(function (conditionalFormattingRule) {
|
|
43269
|
-
var _chart$lines$filter$2;
|
|
43270
|
-
if (conditionalFormattingRule.operator !== '<=' && conditionalFormattingRule.operator !== '>=') return null;
|
|
43271
|
-
var yKey = conditionalFormattingRule.yKey;
|
|
43272
|
-
var clipPathId = "clip-path-" + yKey + "-" + conditionalFormattingRule.value + "-" + conditionalFormattingRule.color + "-" + Math.random(); // Do not remove Math.random() - required to ensure unique clipPathId per view instance
|
|
43273
|
-
|
|
43274
|
-
var clipArea = getClipArea({
|
|
43275
|
-
conditionalFormattingRule: conditionalFormattingRule,
|
|
43276
|
-
chart: {
|
|
43277
|
-
width: innerWidth,
|
|
43278
|
-
height: innerHeight,
|
|
43279
|
-
yScale: _yScale
|
|
43280
|
-
}
|
|
43281
|
-
});
|
|
43282
|
-
|
|
43283
|
-
// return a new <LinePath /> for each conditional formatting rule with a matching <ReactClipPath /> to frame the part of the path that should be visible
|
|
43284
|
-
return jsxs(Group$2, {
|
|
43285
|
-
children: [jsx(LinePath, {
|
|
43286
|
-
clipPath: "url(#" + clipPathId + ")",
|
|
43287
|
-
visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
|
|
43288
|
-
data: dataFlattened,
|
|
43289
|
-
x: function x(d) {
|
|
43290
|
-
var _xScale2;
|
|
43291
|
-
// @ts-ignore
|
|
43292
|
-
var xValue = d[xScaleKey];
|
|
43293
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43294
|
-
// @ts-ignore
|
|
43295
|
-
return (_xScale2 = xScale(xValueAdjusted)) != null ? _xScale2 : 0;
|
|
43296
|
-
},
|
|
43297
|
-
y: function y(d) {
|
|
43298
|
-
return _yScale(Number(d[yKey]));
|
|
43299
|
-
},
|
|
43300
|
-
stroke: conditionalFormattingRule.color,
|
|
43301
|
-
strokeWidth: chart.lines.filter(function (legendItem) {
|
|
43302
|
-
return legendItem.yKey === yKey;
|
|
43303
|
-
})[0].style.strokeWidth,
|
|
43304
|
-
strokeLinecap: "round",
|
|
43305
|
-
strokeDasharray: (_chart$lines$filter$2 = chart.lines.filter(function (legendItem) {
|
|
43306
|
-
return legendItem.yKey === yKey;
|
|
43307
|
-
})[0].style.strokeDasharray) != null ? _chart$lines$filter$2 : undefined,
|
|
43308
|
-
shapeRendering: "smooth",
|
|
43309
|
-
defined: function defined(d) {
|
|
43310
|
-
return d[yKey] !== null;
|
|
43311
|
-
},
|
|
43312
|
-
curve: curve
|
|
43313
|
-
}, yKey), jsx(RectClipPath, {
|
|
43314
|
-
id: clipPathId,
|
|
43315
|
-
x: clipArea.x,
|
|
43316
|
-
y: clipArea.y,
|
|
43317
|
-
width: clipArea.width,
|
|
43318
|
-
height: clipArea.height
|
|
43319
|
-
})]
|
|
43320
|
-
}, clipPathId);
|
|
43321
|
-
})]
|
|
43257
|
+
}), jsx(Group$2, {
|
|
43258
|
+
children: xScaleKey !== null && jsx(Lines, {
|
|
43259
|
+
lines: chart.lines,
|
|
43260
|
+
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43261
|
+
curve: curve,
|
|
43262
|
+
yKeys: chart.y.keys,
|
|
43263
|
+
visibleYKeys: visibleYKeys,
|
|
43264
|
+
data: dataFlattened,
|
|
43265
|
+
xScaleKey: xScaleKey,
|
|
43266
|
+
xScaleDataType: xScaleDataType,
|
|
43267
|
+
xScale: xScale,
|
|
43268
|
+
yScale: _yScale
|
|
43269
|
+
})
|
|
43322
43270
|
})]
|
|
43323
43271
|
}), tooltipData && jsxs("g", {
|
|
43324
43272
|
children: [jsx(Line, {
|
|
@@ -43350,27 +43298,117 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
43350
43298
|
width: innerWidth
|
|
43351
43299
|
})]
|
|
43352
43300
|
}), options.showLegend && jsx(Legend$1, {
|
|
43353
|
-
|
|
43354
|
-
visibleYKeys: visibleYKeys,
|
|
43301
|
+
items: legendTooltipItems,
|
|
43355
43302
|
setVisibleYKeys: setVisibleYKeys,
|
|
43356
43303
|
keys: chart.keys,
|
|
43357
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43358
43304
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
43359
43305
|
}), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
|
|
43306
|
+
items: legendTooltipItems,
|
|
43360
43307
|
tooltipData: tooltipData,
|
|
43361
43308
|
tooltipLeft: tooltipLeft,
|
|
43362
43309
|
tooltipTop: tooltipTop,
|
|
43363
43310
|
xKey: xKey,
|
|
43364
43311
|
keys: chart.keys,
|
|
43365
|
-
visibleYKeys: visibleYKeys,
|
|
43366
43312
|
yKeys: chart.y.keys,
|
|
43367
|
-
legendItems: chart.lines,
|
|
43368
43313
|
showRoundedTotal: options.showRoundedTotal,
|
|
43369
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43370
43314
|
theme: themeCSS.popoverMenus
|
|
43371
43315
|
})]
|
|
43372
43316
|
});
|
|
43373
43317
|
};
|
|
43318
|
+
function Lines(_ref2) {
|
|
43319
|
+
var yKeys = _ref2.yKeys,
|
|
43320
|
+
visibleYKeys = _ref2.visibleYKeys,
|
|
43321
|
+
data = _ref2.data,
|
|
43322
|
+
xScaleKey = _ref2.xScaleKey,
|
|
43323
|
+
xScaleDataType = _ref2.xScaleDataType,
|
|
43324
|
+
xScale = _ref2.xScale,
|
|
43325
|
+
yScale = _ref2.yScale,
|
|
43326
|
+
lines = _ref2.lines,
|
|
43327
|
+
curve = _ref2.curve,
|
|
43328
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules;
|
|
43329
|
+
return jsxs(Fragment, {
|
|
43330
|
+
children: [yKeys.map(function (yKey) {
|
|
43331
|
+
var _lines$filter$0$style;
|
|
43332
|
+
return jsx(LinePath, {
|
|
43333
|
+
visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
|
|
43334
|
+
data: data,
|
|
43335
|
+
x: function x(d) {
|
|
43336
|
+
var _ref3;
|
|
43337
|
+
var xValue = d[xScaleKey];
|
|
43338
|
+
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43339
|
+
return (_ref3 = xScale(xValueAdjusted)) != null ? _ref3 : 0;
|
|
43340
|
+
},
|
|
43341
|
+
y: function y(d) {
|
|
43342
|
+
return yScale(d[yKey]);
|
|
43343
|
+
},
|
|
43344
|
+
stroke: lines.filter(function (legendItem) {
|
|
43345
|
+
return legendItem.yKey === yKey;
|
|
43346
|
+
})[0].color,
|
|
43347
|
+
strokeWidth: lines.filter(function (legendItem) {
|
|
43348
|
+
return legendItem.yKey === yKey;
|
|
43349
|
+
})[0].style.strokeWidth,
|
|
43350
|
+
strokeLinecap: "round",
|
|
43351
|
+
strokeDasharray: (_lines$filter$0$style = lines.filter(function (legendItem) {
|
|
43352
|
+
return legendItem.yKey === yKey;
|
|
43353
|
+
})[0].style.strokeDasharray) != null ? _lines$filter$0$style : undefined,
|
|
43354
|
+
shapeRendering: "smooth",
|
|
43355
|
+
defined: function defined(d) {
|
|
43356
|
+
return d[yKey] !== null;
|
|
43357
|
+
},
|
|
43358
|
+
curve: curve
|
|
43359
|
+
}, yKey);
|
|
43360
|
+
}), conditionalFormattingRules.map(function (conditionalFormattingRule) {
|
|
43361
|
+
var _lines$filter$0$style2;
|
|
43362
|
+
if (conditionalFormattingRule.operator !== '<=' && conditionalFormattingRule.operator !== '>=') return null;
|
|
43363
|
+
var yKey = conditionalFormattingRule.yKey;
|
|
43364
|
+
var clipPathId = "clip-path-" + yKey + "-" + conditionalFormattingRule.value + "-" + conditionalFormattingRule.color + "-" + Math.random(); // Do not remove Math.random() - required to ensure unique clipPathId per view instance
|
|
43365
|
+
|
|
43366
|
+
var clipArea = getClipArea({
|
|
43367
|
+
conditionalFormattingRule: conditionalFormattingRule,
|
|
43368
|
+
chart: {
|
|
43369
|
+
width: innerWidth,
|
|
43370
|
+
height: innerHeight,
|
|
43371
|
+
yScale: yScale
|
|
43372
|
+
}
|
|
43373
|
+
});
|
|
43374
|
+
return jsxs(Group$2, {
|
|
43375
|
+
children: [jsx(LinePath, {
|
|
43376
|
+
clipPath: "url(#" + clipPathId + ")",
|
|
43377
|
+
visibility: visibleYKeys.includes(yKey) ? 'visible' : 'hidden',
|
|
43378
|
+
data: data,
|
|
43379
|
+
x: function x(d) {
|
|
43380
|
+
var _ref4;
|
|
43381
|
+
var xValue = d[xScaleKey];
|
|
43382
|
+
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43383
|
+
return (_ref4 = xScale(xValueAdjusted)) != null ? _ref4 : 0;
|
|
43384
|
+
},
|
|
43385
|
+
y: function y(d) {
|
|
43386
|
+
return yScale(d[yKey]);
|
|
43387
|
+
},
|
|
43388
|
+
stroke: conditionalFormattingRule.color,
|
|
43389
|
+
strokeWidth: lines.filter(function (legendItem) {
|
|
43390
|
+
return legendItem.yKey === yKey;
|
|
43391
|
+
})[0].style.strokeWidth,
|
|
43392
|
+
strokeLinecap: "round",
|
|
43393
|
+
strokeDasharray: (_lines$filter$0$style2 = lines.filter(function (legendItem) {
|
|
43394
|
+
return legendItem.yKey === yKey;
|
|
43395
|
+
})[0].style.strokeDasharray) != null ? _lines$filter$0$style2 : undefined,
|
|
43396
|
+
shapeRendering: "smooth",
|
|
43397
|
+
defined: function defined(d) {
|
|
43398
|
+
return d[yKey] !== null;
|
|
43399
|
+
},
|
|
43400
|
+
curve: curve
|
|
43401
|
+
}, yKey), jsx(RectClipPath, {
|
|
43402
|
+
id: clipPathId,
|
|
43403
|
+
x: clipArea.x,
|
|
43404
|
+
y: clipArea.y,
|
|
43405
|
+
width: clipArea.width,
|
|
43406
|
+
height: clipArea.height
|
|
43407
|
+
})]
|
|
43408
|
+
}, clipPathId);
|
|
43409
|
+
})]
|
|
43410
|
+
});
|
|
43411
|
+
}
|
|
43374
43412
|
|
|
43375
43413
|
function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
43376
43414
|
var _bars$find;
|
|
@@ -43387,7 +43425,7 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
|
43387
43425
|
if (compare({
|
|
43388
43426
|
op: rule.operator,
|
|
43389
43427
|
value: rule.value
|
|
43390
|
-
}, value)) {
|
|
43428
|
+
}, value) && rule.yKey === barKey) {
|
|
43391
43429
|
fill = rule.color;
|
|
43392
43430
|
break;
|
|
43393
43431
|
}
|
|
@@ -43396,12 +43434,43 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
|
43396
43434
|
return fill;
|
|
43397
43435
|
}
|
|
43398
43436
|
|
|
43399
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { 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)."; }
|
|
43400
|
-
var BAR_RADIUS = 2;
|
|
43401
43437
|
var PADDING = {
|
|
43402
43438
|
paddingOuter: 0.05,
|
|
43403
43439
|
paddingInner: 0.3
|
|
43404
43440
|
};
|
|
43441
|
+
|
|
43442
|
+
function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
|
|
43443
|
+
return useMemo(function () {
|
|
43444
|
+
if (xScaleDataType === 'string') {
|
|
43445
|
+
return scaleBand(_extends({
|
|
43446
|
+
range: [0, innerWidth],
|
|
43447
|
+
domain: xScaleKey ? [].concat(data.map(function (d) {
|
|
43448
|
+
return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
|
|
43449
|
+
})) : []
|
|
43450
|
+
}, PADDING));
|
|
43451
|
+
}
|
|
43452
|
+
if (xScaleDataType === 'date_time' && xScaleKey) {
|
|
43453
|
+
return scaleBand(_extends({
|
|
43454
|
+
range: [0, innerWidth],
|
|
43455
|
+
domain: data.map(function (d) {
|
|
43456
|
+
return new Date(d[xScaleKey].value);
|
|
43457
|
+
})
|
|
43458
|
+
}, PADDING));
|
|
43459
|
+
}
|
|
43460
|
+
if (xScaleDataType === 'number' && xScaleKey) {
|
|
43461
|
+
return scaleBand(_extends({
|
|
43462
|
+
range: [0, innerWidth],
|
|
43463
|
+
domain: data.map(function (d) {
|
|
43464
|
+
return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
|
|
43465
|
+
})
|
|
43466
|
+
}, PADDING));
|
|
43467
|
+
}
|
|
43468
|
+
return null;
|
|
43469
|
+
}, [innerWidth, data]);
|
|
43470
|
+
}
|
|
43471
|
+
|
|
43472
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { 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)."; }
|
|
43473
|
+
var BAR_RADIUS = 2;
|
|
43405
43474
|
var BarChart$5 = function BarChart(_ref) {
|
|
43406
43475
|
var _theme$axis;
|
|
43407
43476
|
var chart = _ref.chart,
|
|
@@ -43432,41 +43501,8 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43432
43501
|
var xScaleKey = chart.x.scale.key;
|
|
43433
43502
|
var yScaleKeys = chart.y.keys;
|
|
43434
43503
|
var xScaleDataType = chart.x.scale.dataType;
|
|
43435
|
-
var xScale =
|
|
43436
|
-
|
|
43437
|
-
return scaleBand(_extends({
|
|
43438
|
-
range: [0, innerWidth],
|
|
43439
|
-
domain: xScaleKey ? [].concat(chart.data.map(function (d) {
|
|
43440
|
-
return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
|
|
43441
|
-
})) : []
|
|
43442
|
-
}, PADDING));
|
|
43443
|
-
}
|
|
43444
|
-
if (xScaleDataType === 'date_time' && xScaleKey) {
|
|
43445
|
-
return scaleBand(_extends({
|
|
43446
|
-
range: [0, innerWidth],
|
|
43447
|
-
domain: chart.data.map(function (d) {
|
|
43448
|
-
return new Date(d[xScaleKey].value);
|
|
43449
|
-
})
|
|
43450
|
-
}, PADDING));
|
|
43451
|
-
}
|
|
43452
|
-
if (xScaleDataType === 'number' && xScaleKey) {
|
|
43453
|
-
return scaleBand(_extends({
|
|
43454
|
-
range: [0, innerWidth],
|
|
43455
|
-
domain: chart.data.map(function (d) {
|
|
43456
|
-
return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
|
|
43457
|
-
})
|
|
43458
|
-
}, PADDING));
|
|
43459
|
-
}
|
|
43460
|
-
return null;
|
|
43461
|
-
}, [innerWidth, chart.x, chart.data]);
|
|
43462
|
-
var yScale = useMemo(function () {
|
|
43463
|
-
return scaleLinear({
|
|
43464
|
-
range: [innerHeight, 0],
|
|
43465
|
-
domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
|
|
43466
|
-
nice: true,
|
|
43467
|
-
round: true
|
|
43468
|
-
});
|
|
43469
|
-
}, [innerHeight, chart.y]);
|
|
43504
|
+
var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);
|
|
43505
|
+
var yScale = useYScale(innerHeight, chart.y.scale);
|
|
43470
43506
|
var innerXScale = useMemo(function () {
|
|
43471
43507
|
if (!options.stacked && xScale && 'bandwidth' in xScale) {
|
|
43472
43508
|
return scaleBand({
|
|
@@ -43477,7 +43513,7 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43477
43513
|
}
|
|
43478
43514
|
return undefined;
|
|
43479
43515
|
}, [xScale, yScaleKeys, options.stacked, xScaleDataType]);
|
|
43480
|
-
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
|
|
43516
|
+
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
43481
43517
|
var handleMouseMove = useCallback(function (event) {
|
|
43482
43518
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
43483
43519
|
var tooltipData = getTooltipData({
|
|
@@ -43523,6 +43559,13 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43523
43559
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
43524
43560
|
return Number(tick.value);
|
|
43525
43561
|
});
|
|
43562
|
+
var legendTooltipItems = [{
|
|
43563
|
+
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
43564
|
+
return legendItem.yKey;
|
|
43565
|
+
}),
|
|
43566
|
+
legendItems: chart.bars,
|
|
43567
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
43568
|
+
}];
|
|
43526
43569
|
return jsxs(Fragment, {
|
|
43527
43570
|
children: [jsxs(ChartWrapper$1, {
|
|
43528
43571
|
width: width,
|
|
@@ -43558,57 +43601,25 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43558
43601
|
ticks: yTickValues,
|
|
43559
43602
|
stroke: theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke
|
|
43560
43603
|
}), jsxs(Group$2, {
|
|
43561
|
-
children: [!options.stacked && jsx(BarGroup
|
|
43604
|
+
children: [!options.stacked && jsx(BarGroup, {
|
|
43562
43605
|
data: dataFlattened,
|
|
43563
43606
|
keys: yScaleKeys,
|
|
43564
43607
|
height: innerHeight,
|
|
43565
|
-
|
|
43566
|
-
|
|
43567
|
-
|
|
43568
|
-
|
|
43569
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43570
|
-
// @ts-ignore
|
|
43571
|
-
return xValueAdjusted;
|
|
43572
|
-
}
|
|
43573
|
-
// @ts-ignore
|
|
43574
|
-
,
|
|
43575
|
-
x0Scale: xScale
|
|
43576
|
-
// @ts-ignore
|
|
43577
|
-
,
|
|
43578
|
-
x1Scale: innerXScale,
|
|
43608
|
+
xKey: xKey,
|
|
43609
|
+
xScaleDataType: xScaleDataType,
|
|
43610
|
+
xScale: xScale,
|
|
43611
|
+
innerXScale: innerXScale,
|
|
43579
43612
|
yScale: yScale,
|
|
43580
|
-
|
|
43581
|
-
|
|
43582
|
-
|
|
43583
|
-
|
|
43584
|
-
return barGroups.map(function (barGroup) {
|
|
43585
|
-
return jsx(Group$2, {
|
|
43586
|
-
left: barGroup.x0,
|
|
43587
|
-
children: barGroup.bars.map(function (bar) {
|
|
43588
|
-
if (bar.value === null) return null;
|
|
43589
|
-
if (bar.height < 0 || bar.width < 0) return null;
|
|
43590
|
-
return jsx(Bar, {
|
|
43591
|
-
x: bar.x,
|
|
43592
|
-
y: bar.y,
|
|
43593
|
-
width: bar.width,
|
|
43594
|
-
height: bar.height,
|
|
43595
|
-
fill: getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.value),
|
|
43596
|
-
onClick: function onClick(e) {
|
|
43597
|
-
return handleOnBarClick(e, barGroup, bar);
|
|
43598
|
-
},
|
|
43599
|
-
enableHover: enableHover
|
|
43600
|
-
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key);
|
|
43601
|
-
})
|
|
43602
|
-
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
43603
|
-
});
|
|
43604
|
-
}
|
|
43613
|
+
onClick: handleOnBarClick,
|
|
43614
|
+
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43615
|
+
bars: chart.bars,
|
|
43616
|
+
enableHover: enableHover
|
|
43605
43617
|
}), options.stacked && jsx(BarStack$1, {
|
|
43606
43618
|
x: function x(d) {
|
|
43607
43619
|
// @ts-ignore
|
|
43608
43620
|
var xValue = d[xScaleKey];
|
|
43609
43621
|
if (xScaleDataType === 'string') return xValue;
|
|
43610
43622
|
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43611
|
-
// @ts-ignore
|
|
43612
43623
|
return xValueAdjusted;
|
|
43613
43624
|
}
|
|
43614
43625
|
// @ts-ignore
|
|
@@ -43656,31 +43667,79 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43656
43667
|
width: innerWidth
|
|
43657
43668
|
})]
|
|
43658
43669
|
}), options.showLegend && jsx(Legend$1, {
|
|
43659
|
-
|
|
43660
|
-
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
43661
|
-
return legendItem.yKey;
|
|
43662
|
-
}),
|
|
43670
|
+
items: legendTooltipItems,
|
|
43663
43671
|
setVisibleYKeys: function setVisibleYKeys() {},
|
|
43664
43672
|
keys: chart.keys,
|
|
43665
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43666
43673
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
43667
43674
|
}), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
|
|
43675
|
+
items: legendTooltipItems,
|
|
43668
43676
|
tooltipData: tooltipData,
|
|
43669
43677
|
tooltipLeft: tooltipLeft,
|
|
43670
43678
|
tooltipTop: tooltipTop,
|
|
43671
43679
|
xKey: xKey,
|
|
43672
43680
|
keys: chart.keys,
|
|
43673
|
-
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
43674
|
-
return legendItem.yKey;
|
|
43675
|
-
}),
|
|
43676
43681
|
yKeys: chart.y.keys,
|
|
43677
|
-
legendItems: chart.bars,
|
|
43678
43682
|
showRoundedTotal: options.showRoundedTotal,
|
|
43679
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
43680
43683
|
theme: themeCSS.popoverMenus
|
|
43681
43684
|
})]
|
|
43682
43685
|
});
|
|
43683
43686
|
};
|
|
43687
|
+
function BarGroup(_ref2) {
|
|
43688
|
+
var data = _ref2.data,
|
|
43689
|
+
keys = _ref2.keys,
|
|
43690
|
+
height = _ref2.height,
|
|
43691
|
+
xKey = _ref2.xKey,
|
|
43692
|
+
xScaleDataType = _ref2.xScaleDataType,
|
|
43693
|
+
xScale = _ref2.xScale,
|
|
43694
|
+
innerXScale = _ref2.innerXScale,
|
|
43695
|
+
yScale = _ref2.yScale,
|
|
43696
|
+
_onClick = _ref2.onClick,
|
|
43697
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules,
|
|
43698
|
+
bars = _ref2.bars,
|
|
43699
|
+
enableHover = _ref2.enableHover;
|
|
43700
|
+
return jsx(BarGroup$2, {
|
|
43701
|
+
data: data,
|
|
43702
|
+
keys: keys,
|
|
43703
|
+
height: height,
|
|
43704
|
+
x0: function x0(d) {
|
|
43705
|
+
var xValue = d[xKey];
|
|
43706
|
+
if (xScaleDataType === 'string') return String(xValue);
|
|
43707
|
+
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(String(xValue)) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
43708
|
+
return xValueAdjusted;
|
|
43709
|
+
}
|
|
43710
|
+
// @ts-ignore
|
|
43711
|
+
,
|
|
43712
|
+
x0Scale: xScale
|
|
43713
|
+
// @ts-ignore
|
|
43714
|
+
,
|
|
43715
|
+
x1Scale: innerXScale,
|
|
43716
|
+
yScale: yScale,
|
|
43717
|
+
color: function color() {
|
|
43718
|
+
return '';
|
|
43719
|
+
},
|
|
43720
|
+
children: function children(barGroups) {
|
|
43721
|
+
return barGroups.map(function (barGroup) {
|
|
43722
|
+
return jsx(Group$2, {
|
|
43723
|
+
left: barGroup.x0,
|
|
43724
|
+
children: barGroup.bars.map(function (bar) {
|
|
43725
|
+
if (bar.value === null || bar.height < 0 || bar.width < 0) return null;
|
|
43726
|
+
return jsx(Bar, {
|
|
43727
|
+
x: bar.x,
|
|
43728
|
+
y: bar.y,
|
|
43729
|
+
width: bar.width,
|
|
43730
|
+
height: bar.height,
|
|
43731
|
+
fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
|
|
43732
|
+
onClick: function onClick(e) {
|
|
43733
|
+
return _onClick(e, barGroup, bar);
|
|
43734
|
+
},
|
|
43735
|
+
enableHover: enableHover
|
|
43736
|
+
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key));
|
|
43737
|
+
})
|
|
43738
|
+
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
43739
|
+
});
|
|
43740
|
+
}
|
|
43741
|
+
});
|
|
43742
|
+
}
|
|
43684
43743
|
var Bar = function Bar(props) {
|
|
43685
43744
|
var _useState = useState(props.fill),
|
|
43686
43745
|
fillColor = _useState[0],
|
|
@@ -43705,7 +43764,7 @@ var Bar = function Bar(props) {
|
|
|
43705
43764
|
} : {
|
|
43706
43765
|
name: "4nk3o1-Bar",
|
|
43707
43766
|
styles: "cursor:pointer;label:Bar;",
|
|
43708
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AA0YqC","file":"BarChart.tsx","sourcesContent":["import { BarChartRepresentation } from 'shared-logic/src/BarChartV2/types';\nimport { ChartTheme } from '../../../types';\nimport { Group } from '@visx/group';\nimport { getChartThemeCSS, getTooltipData } from '../../utils';\nimport { Fragment, useCallback, useMemo, useState } from 'react';\nimport { Tooltip } from '../Tooltip';\nimport { Legend } from '../Legend';\nimport { BarGroup, BarStack } from '@visx/shape';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { scaleLinear, scaleBand } from '@visx/scale';\nimport { getBarFill } from './getBarFill';\nimport { buildMargin } from '../../utils/buildMargin';\nimport { ChartOnViewClick, ChartDataDefinition, DataItem } from 'shared-logic/src/ChartsV2/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { css } from '@emotion/css';\nimport { BarGroupBar, BarGroup as BarGroupType } from '@visx/shape/lib/types';\nimport { useFlattenedData } from '../hooks/useFlattenedData';\nimport GoalLines from '../GoalLine/GoalLines';\nimport { AxisBottom } from '../Axis/AxisBottom';\nimport { AxisLeft } from '../Axis/AxisLeft';\nimport { GridRows } from '../GridRows/GridRows';\nimport { ChartWrapper } from '../ChartWrapper/ChartWrapper';\nimport { Line } from '../Tooltip/Line';\nimport useTooltip from '../hooks/useTooltip';\n\n// Need to look at updating BarChart to use this type method of rendering - https://codesandbox.io/p/sandbox/visx-bar-chart-j9smpj?file=%2FExample.tsx\n// Currently it's using Stacked Chart which isn't technically correct\n\nexport type BarChartProps = {\n  width: number;\n  height: number;\n  theme?: ChartTheme;\n  chart: BarChartRepresentation;\n  options: {\n    stacked: boolean;\n    showRoundedTotal: boolean;\n    showLegend: boolean;\n    removeStroke: boolean;\n    axis: {\n      showXAxisLabels: boolean;\n      showYAxisLabels: boolean;\n    };\n  };\n  onClick: (params: ChartOnViewClick) => void;\n  enableHover?: boolean;\n};\n\nconst BAR_RADIUS = 2;\n\nconst PADDING = {\n  paddingOuter: 0.05,\n  paddingInner: 0.3,\n};\n\nexport const BarChart = ({ chart, width, height, options, theme, onClick, enableHover }: BarChartProps) => {\n  const {\n    tooltipOpen,\n    tooltipLeft = 0,\n    tooltipTop = 0,\n    lineLeft = 0,\n    tooltipData,\n    hideTooltip,\n    showTooltip,\n  } = useTooltip<{\n    [keyId: string]: DataItem;\n  } | null>();\n\n  const margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);\n\n  // const [visibleYKeys, setVisibleYKeys] = useState(chart.bars.map((legendItem) => legendItem.yKey));\n\n  const innerWidth = width - margin.left - margin.right;\n  const innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 40 : 0);\n  const xKey = chart.x.key;\n  const xScaleKey = chart.x.scale.key;\n  const yScaleKeys = chart.y.keys;\n  const xScaleDataType: DataType = chart.x.scale.dataType;\n\n  const xScale = useMemo(() => {\n    if (xScaleDataType === 'string') {\n      return scaleBand<string>({\n        range: [0, innerWidth],\n        domain: xScaleKey\n          ? [...chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : ''))]\n          : [],\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'date_time' && xScaleKey) {\n      return scaleBand<Date>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => new Date(d[xScaleKey].value as string)),\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'number' && xScaleKey) {\n      return scaleBand<number>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0)),\n        ...PADDING,\n      });\n    }\n\n    return null;\n  }, [innerWidth, chart.x, chart.data]);\n\n  const yScale = useMemo(\n    () =>\n      scaleLinear<number>({\n        range: [innerHeight, 0],\n        domain:\n          chart.y.scale.ordering === 'asc'\n            ? [chart.y.scale.min as number, chart.y.scale.max as number]\n            : [chart.y.scale.max as number, chart.y.scale.min as number],\n        nice: true,\n        round: true,\n      }),\n    [innerHeight, chart.y]\n  );\n\n  const innerXScale = useMemo(() => {\n    if (!options.stacked && xScale && 'bandwidth' in xScale) {\n      return scaleBand<string>({\n        range: [0, xScale?.bandwidth()],\n        domain: yScaleKeys,\n        padding: 0.1,\n      });\n    }\n\n    return undefined;\n  }, [xScale, yScaleKeys, options.stacked, xScaleDataType]);\n\n  const dataFlattened = useFlattenedData<BarChartRepresentation, ChartDataDefinition>(xScaleKey, xScaleDataType, chart);\n\n  const handleMouseMove = useCallback(\n    (event: React.MouseEvent<SVGElement>) => {\n      if (!xKey || !xScaleKey || xScale === null) return;\n\n      const tooltipData = getTooltipData({\n        data: chart.data,\n        event,\n        margin,\n        xScaleKey,\n        xScaleDataType,\n        xOrdering: chart.x.scale.ordering,\n        xScale,\n        chartType: 'bar',\n      });\n\n      showTooltip({\n        lineLeft: tooltipData?.lineLeft,\n        tooltipLeft: event.pageX,\n        tooltipTop: event.pageY,\n        tooltipData: tooltipData?.tooltipData,\n      });\n    },\n    [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]\n  );\n\n  const handleMouseLeave = useCallback(() => {\n    hideTooltip();\n  }, [hideTooltip]);\n\n  const handleOnBarClick = useCallback(\n    (event: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: BarGroupType<string>, bar: BarGroupBar<string>) => {\n      onClick({\n        clickedValue: {\n          index: barGroup.index,\n          y: {\n            key: bar.key,\n            value: bar.value,\n          },\n          x: {\n            ...chart.x.ticks[barGroup.index],\n            value: chart.data[barGroup.index][xKey].value ?? '',\n            key: xKey,\n          },\n        },\n        clickEvent: event,\n      });\n    },\n    [onClick, chart.data, xKey]\n  );\n\n  const themeCSS = useMemo(() => getChartThemeCSS(theme), [theme]);\n\n  const yTickValues = chart.y.ticks.map(tick => Number(tick.value));\n\n  return (\n    <Fragment>\n      {/* width/height 100% required or useParentSize() continuously scales as parent element has no specified height */}\n      <ChartWrapper\n        width={width}\n        height={height}\n        onMouseMove={handleMouseMove}\n        onMouseLeave={handleMouseLeave}\n        showLegend={options.showLegend}\n      >\n        <Group left={margin.left} top={margin.top}>\n          <GridRows\n            ticks={yTickValues}\n            yScale={yScale}\n            width={innerWidth}\n            height={innerHeight}\n            removeStroke={options.removeStroke}\n            themeCSS={themeCSS}\n          />\n          <AxisBottom\n            x={chart.x}\n            margin={margin}\n            themeCSS={themeCSS}\n            show={options.axis.showXAxisLabels}\n            removeStroke={options.removeStroke}\n            xScaleDataType={xScaleDataType}\n            xScale={xScale}\n            height={innerHeight}\n          />\n          <AxisLeft\n            show={options.axis.showYAxisLabels}\n            y={chart.y}\n            margin={margin}\n            themeCSS={themeCSS}\n            yScale={yScale}\n            ticks={yTickValues}\n            stroke={theme?.axis?.stroke}\n          />\n          <Group>\n            {!options.stacked && (\n              <BarGroup\n                data={dataFlattened}\n                keys={yScaleKeys}\n                height={innerHeight}\n                x0={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\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                        if (bar.value === null) return null;\n                        if (bar.height < 0 || bar.width < 0) return null;\n                        return (\n                          <Bar\n                            key={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${bar.key}`}\n                            x={bar.x}\n                            y={bar.y}\n                            width={bar.width}\n                            height={bar.height}\n                            fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.value)}\n                            onClick={e => handleOnBarClick(e, barGroup, bar)}\n                            enableHover={enableHover}\n                          />\n                        );\n                      })}\n                    </Group>\n                  ));\n                }}\n              </BarGroup>\n            )}\n\n            {/* How to we get 'scaleValue' here? Will we need to start storing scaleKey as well as xKey? */}\n            {options.stacked && (\n              <BarStack\n                x={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                xScale={xScale}\n                yScale={yScale}\n                data={dataFlattened}\n                keys={chart.y.keys}\n                color={() => ''}\n                height={innerHeight}\n                width={innerWidth}\n                offset=\"none\"\n              >\n                {barStacks =>\n                  barStacks.map(barStack =>\n                    barStack.bars.map(bar => {\n                      if (bar.height < 3) return null;\n                      const BAR_PADDING = 1.5;\n                      return (\n                        <rect\n                          key={`bar-stack-${barStack.index}-${bar.index}`}\n                          x={bar.x}\n                          y={bar.y}\n                          width={bar.width}\n                          height={bar.height - BAR_PADDING}\n                          fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.bar.data)}\n                          rx={BAR_RADIUS}\n                        />\n                      );\n                    })\n                  )\n                }\n              </BarStack>\n            )}\n          </Group>\n        </Group>\n        {/* ----- TOOLTIP CROSSHAIR ----- */}\n        {tooltipData && (\n          <g>\n            <Line x={lineLeft} margin={margin} height={innerHeight} />\n          </g>\n        )}\n        {/* ----- GOAL LINES ------ */}\n        <GoalLines goalLines={chart.goalLines} y={d => yScale(d)} margin={margin} width={innerWidth} />\n      </ChartWrapper>\n      {/* ----- LEGEND ----- */}\n      {options.showLegend && (\n        <Legend\n          legendItems={chart.bars}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          setVisibleYKeys={() => {}}\n          keys={chart.keys}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          marginLeft={margin.left - margin.leftTitleOffset}\n        />\n      )}\n      {/* ----- TOOLTIP ----- */}\n      {tooltipOpen && tooltipData && xKey && (\n        <Tooltip\n          tooltipData={tooltipData}\n          tooltipLeft={tooltipLeft}\n          tooltipTop={tooltipTop}\n          xKey={xKey}\n          keys={chart.keys}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          yKeys={chart.y.keys}\n          legendItems={chart.bars}\n          showRoundedTotal={options.showRoundedTotal}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          theme={themeCSS.popoverMenus}\n        />\n      )}\n    </Fragment>\n  );\n};\n\nconst Bar = (props: {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  key: string;\n  enableHover?: boolean;\n}) => {\n  const [fillColor, setFillColor] = useState(props.fill);\n  return (\n    <rect\n      key={props.key}\n      x={props.x}\n      y={props.y}\n      width={props.width}\n      height={props.height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={props.onClick}\n      onMouseEnter={() => props.enableHover && setFillColor(lightenColor(props.fill, 0.8))}\n      onMouseLeave={() => props.enableHover && setFillColor(props.fill)}\n      className={props.enableHover ? css({ cursor: 'pointer' }) : ''}\n    />\n  );\n};\n"]} */",
|
|
43767
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AA8YqC","file":"BarChart.tsx","sourcesContent":["import { BarChartRepresentation, BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartTheme } from '../../../types';\nimport { Group } from '@visx/group';\nimport { getChartThemeCSS, getTooltipData } from '../../utils';\nimport { Fragment, useCallback, useMemo, useState } from 'react';\nimport { Tooltip } from '../Tooltip';\nimport { Legend } from '../Legend';\nimport { BarGroup as VisxBarGroup, BarStack } from '@visx/shape';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { scaleBand } from '@visx/scale';\nimport { getBarFill } from '../../utils/getBarFill';\nimport { buildMargin } from '../../utils/buildMargin';\nimport {\n  ChartDataDefinition,\n  ChartOnViewClick,\n  ConditionalFormattingRule,\n  DataItem,\n  ShapeDefinition,\n} from 'shared-logic/src/ChartsV2/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { css } from '@emotion/css';\nimport { BarGroupBar, BarGroup as BarGroupType, DatumObject } from '@visx/shape/lib/types';\nimport { useFlattenedData } from '../hooks/useFlattenedData';\nimport GoalLines from '../GoalLine/GoalLines';\nimport { AxisBottom } from '../Axis/AxisBottom';\nimport { AxisLeft } from '../Axis/AxisLeft';\nimport { GridRows } from '../GridRows/GridRows';\nimport { ChartWrapper } from '../ChartWrapper/ChartWrapper';\nimport { ScaleLinear, ScaleBand } from '@visx/vendor/d3-scale';\nimport { Line } from '../Tooltip/Line';\nimport useTooltip from '../hooks/useTooltip';\nimport { useBarXScale } from './useBarXScale';\nimport { useYScale } from '../hooks/useYScale';\n\n// Need to look at updating BarChart to use this type method of rendering - https://codesandbox.io/p/sandbox/visx-bar-chart-j9smpj?file=%2FExample.tsx\n// Currently it's using Stacked Chart which isn't technically correct\n\nexport type BarChartProps = {\n  width: number;\n  height: number;\n  theme?: ChartTheme;\n  chart: BarChartRepresentation;\n  options: {\n    stacked: boolean;\n    showRoundedTotal: boolean;\n    showLegend: boolean;\n    removeStroke: boolean;\n    axis: {\n      showXAxisLabels: boolean;\n      showYAxisLabels: boolean;\n    };\n  };\n  onClick: (params: ChartOnViewClick) => void;\n  enableHover?: boolean;\n};\n\nconst BAR_RADIUS = 2;\n\nexport const BarChart = ({ chart, width, height, options, theme, onClick, enableHover }: BarChartProps) => {\n  const {\n    tooltipOpen,\n    tooltipLeft = 0,\n    tooltipTop = 0,\n    lineLeft = 0,\n    tooltipData,\n    hideTooltip,\n    showTooltip,\n  } = useTooltip<{\n    [keyId: string]: DataItem;\n  } | null>();\n\n  const margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);\n\n  // const [visibleYKeys, setVisibleYKeys] = useState(chart.bars.map((legendItem) => legendItem.yKey));\n\n  const innerWidth = width - margin.left - margin.right;\n  const innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 40 : 0);\n  const xKey = chart.x.key;\n  const xScaleKey = chart.x.scale.key;\n  const yScaleKeys = chart.y.keys;\n  const xScaleDataType: DataType = chart.x.scale.dataType;\n\n  const xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);\n\n  const yScale = useYScale(innerHeight, chart.y.scale);\n\n  const innerXScale = useMemo(() => {\n    if (!options.stacked && xScale && 'bandwidth' in xScale) {\n      return scaleBand<string>({\n        range: [0, xScale?.bandwidth()],\n        domain: yScaleKeys,\n        padding: 0.1,\n      });\n    }\n\n    return undefined;\n  }, [xScale, yScaleKeys, options.stacked, xScaleDataType]);\n\n  const dataFlattened = useFlattenedData<ChartDataDefinition>(xScaleKey, xScaleDataType, chart.data, chart.y.keys);\n\n  const handleMouseMove = useCallback(\n    (event: React.MouseEvent<SVGElement>) => {\n      if (!xKey || !xScaleKey || xScale === null) return;\n\n      const tooltipData = getTooltipData({\n        data: chart.data,\n        event,\n        margin,\n        xScaleKey,\n        xScaleDataType,\n        xOrdering: chart.x.scale.ordering,\n        xScale,\n        chartType: 'bar',\n      });\n\n      showTooltip({\n        lineLeft: tooltipData?.lineLeft,\n        tooltipLeft: event.pageX,\n        tooltipTop: event.pageY,\n        tooltipData: tooltipData?.tooltipData,\n      });\n    },\n    [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]\n  );\n\n  const handleMouseLeave = useCallback(() => {\n    hideTooltip();\n  }, [hideTooltip]);\n\n  const handleOnBarClick = useCallback(\n    (event: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: BarGroupType<string>, bar: BarGroupBar<string>) => {\n      onClick({\n        clickedValue: {\n          index: barGroup.index,\n          y: {\n            key: bar.key,\n            value: bar.value,\n          },\n          x: {\n            ...chart.x.ticks[barGroup.index],\n            value: chart.data[barGroup.index][xKey].value ?? '',\n            key: xKey,\n          },\n        },\n        clickEvent: event,\n      });\n    },\n    [onClick, chart.data, xKey]\n  );\n\n  const themeCSS = useMemo(() => getChartThemeCSS(theme), [theme]);\n\n  const yTickValues = chart.y.ticks.map(tick => Number(tick.value));\n\n  const legendTooltipItems = [\n    {\n      visibleYKeys: chart.bars.map(legendItem => legendItem.yKey),\n      legendItems: chart.bars,\n      conditionalFormattingRules: chart.conditionalFormattingRules,\n    },\n  ];\n  return (\n    <Fragment>\n      <ChartWrapper\n        width={width}\n        height={height}\n        onMouseMove={handleMouseMove}\n        onMouseLeave={handleMouseLeave}\n        showLegend={options.showLegend}\n      >\n        <Group left={margin.left} top={margin.top}>\n          <GridRows\n            ticks={yTickValues}\n            yScale={yScale}\n            width={innerWidth}\n            height={innerHeight}\n            removeStroke={options.removeStroke}\n            themeCSS={themeCSS}\n          />\n          <AxisBottom\n            x={chart.x}\n            margin={margin}\n            themeCSS={themeCSS}\n            show={options.axis.showXAxisLabels}\n            removeStroke={options.removeStroke}\n            xScaleDataType={xScaleDataType}\n            xScale={xScale}\n            height={innerHeight}\n          />\n          <AxisLeft\n            show={options.axis.showYAxisLabels}\n            y={chart.y}\n            margin={margin}\n            themeCSS={themeCSS}\n            yScale={yScale}\n            ticks={yTickValues}\n            stroke={theme?.axis?.stroke}\n          />\n          <Group>\n            {!options.stacked && (\n              <BarGroup\n                data={dataFlattened}\n                keys={yScaleKeys}\n                height={innerHeight}\n                xKey={xKey}\n                xScaleDataType={xScaleDataType}\n                xScale={xScale}\n                innerXScale={innerXScale}\n                yScale={yScale}\n                onClick={handleOnBarClick}\n                conditionalFormattingRules={chart.conditionalFormattingRules}\n                bars={chart.bars}\n                enableHover={enableHover}\n              />\n            )}\n\n            {options.stacked && (\n              <BarStack\n                x={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                xScale={xScale}\n                yScale={yScale}\n                data={dataFlattened}\n                keys={chart.y.keys}\n                color={() => ''}\n                height={innerHeight}\n                width={innerWidth}\n                offset=\"none\"\n              >\n                {barStacks =>\n                  barStacks.map(barStack =>\n                    barStack.bars.map(bar => {\n                      if (bar.height < 3) return null;\n                      const BAR_PADDING = 1.5;\n                      return (\n                        <rect\n                          key={`bar-stack-${barStack.index}-${bar.index}`}\n                          x={bar.x}\n                          y={bar.y}\n                          width={bar.width}\n                          height={bar.height - BAR_PADDING}\n                          fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.bar.data)}\n                          rx={BAR_RADIUS}\n                        />\n                      );\n                    })\n                  )\n                }\n              </BarStack>\n            )}\n          </Group>\n        </Group>\n        {/* ----- TOOLTIP CROSSHAIR ----- */}\n        {tooltipData && (\n          <g>\n            <Line x={lineLeft} margin={margin} height={innerHeight} />\n          </g>\n        )}\n        {/* ----- GOAL LINES ------ */}\n        <GoalLines goalLines={chart.goalLines} y={d => yScale(d)} margin={margin} width={innerWidth} />\n      </ChartWrapper>\n      {/* ----- LEGEND ----- */}\n      {options.showLegend && (\n        <Legend\n          items={legendTooltipItems}\n          setVisibleYKeys={() => {}}\n          keys={chart.keys}\n          marginLeft={margin.left - margin.leftTitleOffset}\n        />\n      )}\n      {/* ----- TOOLTIP ----- */}\n      {tooltipOpen && tooltipData && xKey && (\n        <Tooltip\n          items={legendTooltipItems}\n          tooltipData={tooltipData}\n          tooltipLeft={tooltipLeft}\n          tooltipTop={tooltipTop}\n          xKey={xKey}\n          keys={chart.keys}\n          yKeys={chart.y.keys}\n          showRoundedTotal={options.showRoundedTotal}\n          theme={themeCSS.popoverMenus}\n        />\n      )}\n    </Fragment>\n  );\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}: {\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}) {\n  return (\n    <VisxBarGroup<DatumObject>\n      data={data as DatumObject[]}\n      keys={keys}\n      height={height}\n      x0={d => {\n        const xValue = d[xKey as keyof typeof d];\n        if (xScaleDataType === 'string') return String(xValue);\n        const xValueAdjusted =\n          xScaleDataType === 'date_time'\n            ? new Date(String(xValue))\n            : xScaleDataType === 'number'\n            ? Number(xValue)\n            : String(xValue);\n        return xValueAdjusted;\n      }}\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              if (bar.value === null || bar.height < 0 || bar.width < 0) return null;\n              return (\n                <Bar\n                  key={`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          </Group>\n        ));\n      }}\n    </VisxBarGroup>\n  );\n}\n\nconst Bar = (props: {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  key: string;\n  enableHover?: boolean;\n}) => {\n  const [fillColor, setFillColor] = useState(props.fill);\n  return (\n    <rect\n      key={props.key}\n      x={props.x}\n      y={props.y}\n      width={props.width}\n      height={props.height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={props.onClick}\n      onMouseEnter={() => props.enableHover && setFillColor(lightenColor(props.fill, 0.8))}\n      onMouseLeave={() => props.enableHover && setFillColor(props.fill)}\n      className={props.enableHover ? css({ cursor: 'pointer' }) : ''}\n    />\n  );\n};\n"]} */",
|
|
43709
43768
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
43710
43769
|
}) : ''
|
|
43711
43770
|
}, props.key);
|
|
@@ -43881,14 +43940,8 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
43881
43940
|
}
|
|
43882
43941
|
return null;
|
|
43883
43942
|
}, [innerWidth, chart.x, chart.data]);
|
|
43884
|
-
var _yScale =
|
|
43885
|
-
|
|
43886
|
-
range: [innerHeight, 0],
|
|
43887
|
-
domain: chart.y.scale.ordering === 'asc' ? [chart.y.scale.min, chart.y.scale.max] : [chart.y.scale.max, chart.y.scale.min],
|
|
43888
|
-
nice: true
|
|
43889
|
-
});
|
|
43890
|
-
}, [innerHeight, chart.y.scale]);
|
|
43891
|
-
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart);
|
|
43943
|
+
var _yScale = useYScale(innerHeight, chart.y.scale);
|
|
43944
|
+
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
43892
43945
|
var handleMouseMove = useCallback(function (event) {
|
|
43893
43946
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
43894
43947
|
var tooltipData = getTooltipData({
|
|
@@ -43918,12 +43971,17 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
43918
43971
|
step: curveStep,
|
|
43919
43972
|
straight: curveLinear
|
|
43920
43973
|
};
|
|
43921
|
-
return curveMap[(_options$curve = options.curve) != null ? _options$curve : '
|
|
43974
|
+
return curveMap[(_options$curve = options.curve) != null ? _options$curve : 'natural'];
|
|
43922
43975
|
}, [options.curve]);
|
|
43923
43976
|
if (width === 0 || height === 0 || xScale === null) return jsx(React__default.Fragment, {});
|
|
43924
43977
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
43925
43978
|
return Number(tick.value);
|
|
43926
43979
|
});
|
|
43980
|
+
var legendTooltipItems = [{
|
|
43981
|
+
visibleYKeys: visibleYKeys,
|
|
43982
|
+
legendItems: chart.areas,
|
|
43983
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
43984
|
+
}];
|
|
43927
43985
|
return jsxs(React__default.Fragment, {
|
|
43928
43986
|
children: [jsxs(ChartWrapper$1, {
|
|
43929
43987
|
width: width,
|
|
@@ -44079,23 +44137,19 @@ var AreaChart$5 = function AreaChart(_ref) {
|
|
|
44079
44137
|
width: innerWidth
|
|
44080
44138
|
})]
|
|
44081
44139
|
}), options.showLegend && jsx(Legend$1, {
|
|
44082
|
-
|
|
44083
|
-
visibleYKeys: visibleYKeys,
|
|
44140
|
+
items: legendTooltipItems,
|
|
44084
44141
|
setVisibleYKeys: setVisibleYKeys,
|
|
44085
44142
|
keys: chart.keys,
|
|
44086
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
44087
44143
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
44088
44144
|
}), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
|
|
44145
|
+
items: legendTooltipItems,
|
|
44089
44146
|
tooltipData: tooltipData,
|
|
44090
44147
|
tooltipLeft: tooltipLeft,
|
|
44091
44148
|
tooltipTop: tooltipTop,
|
|
44092
44149
|
xKey: xKey,
|
|
44093
44150
|
keys: chart.keys,
|
|
44094
|
-
visibleYKeys: visibleYKeys,
|
|
44095
44151
|
yKeys: chart.y.keys,
|
|
44096
|
-
legendItems: chart.areas,
|
|
44097
44152
|
showRoundedTotal: options.showRoundedTotal,
|
|
44098
|
-
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
44099
44153
|
theme: themeCSS.popoverMenus
|
|
44100
44154
|
})]
|
|
44101
44155
|
});
|
|
@@ -44398,11 +44452,13 @@ var RadarChart$2 = function RadarChart(_ref) {
|
|
|
44398
44452
|
})]
|
|
44399
44453
|
})
|
|
44400
44454
|
}), options.showLegend && jsx(Legend$1, {
|
|
44401
|
-
|
|
44402
|
-
|
|
44455
|
+
items: [{
|
|
44456
|
+
legendItems: chart.lines,
|
|
44457
|
+
visibleYKeys: visibleYKeys,
|
|
44458
|
+
conditionalFormattingRules: []
|
|
44459
|
+
}],
|
|
44403
44460
|
setVisibleYKeys: setVisibleYKeys,
|
|
44404
44461
|
keys: chart.keys,
|
|
44405
|
-
conditionalFormattingRules: [],
|
|
44406
44462
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
44407
44463
|
})]
|
|
44408
44464
|
});
|
|
@@ -49114,30 +49170,6 @@ var BarChartV2 = function BarChartV2(props) {
|
|
|
49114
49170
|
});
|
|
49115
49171
|
};
|
|
49116
49172
|
|
|
49117
|
-
function getBarFill$1(bars, conditionalFormattingRules, barKey, barValues) {
|
|
49118
|
-
var _bars$find;
|
|
49119
|
-
// Default fill color from the corresponding bar
|
|
49120
|
-
var fill = (_bars$find = bars.find(function (chartBar) {
|
|
49121
|
-
return chartBar.yKey === barKey;
|
|
49122
|
-
})) == null ? void 0 : _bars$find.color;
|
|
49123
|
-
|
|
49124
|
-
// Determine the value based on barValues type
|
|
49125
|
-
var value = typeof barValues === 'number' ? barValues : barValues == null ? void 0 : barValues[barKey];
|
|
49126
|
-
if (typeof value === 'number') {
|
|
49127
|
-
for (var _iterator = _createForOfIteratorHelperLoose(conditionalFormattingRules), _step; !(_step = _iterator()).done;) {
|
|
49128
|
-
var rule = _step.value;
|
|
49129
|
-
if (compare({
|
|
49130
|
-
op: rule.operator,
|
|
49131
|
-
value: rule.value
|
|
49132
|
-
}, value)) {
|
|
49133
|
-
fill = rule.color;
|
|
49134
|
-
break;
|
|
49135
|
-
}
|
|
49136
|
-
}
|
|
49137
|
-
}
|
|
49138
|
-
return fill;
|
|
49139
|
-
}
|
|
49140
|
-
|
|
49141
49173
|
var ASSUMED_AVERAGE_CHAR_WIDTH$1 = 8.8;
|
|
49142
49174
|
function calculateWordWidth$1(word, avgCharWidth) {
|
|
49143
49175
|
if (avgCharWidth === void 0) {
|
|
@@ -49319,15 +49351,17 @@ var IconTrendingDown$1 = function IconTrendingDown() {
|
|
|
49319
49351
|
|
|
49320
49352
|
var Legend$2 = function Legend(_ref) {
|
|
49321
49353
|
var showLegend = _ref.showLegend,
|
|
49322
|
-
margin = _ref.margin
|
|
49354
|
+
margin = _ref.margin,
|
|
49355
|
+
increaseColor = _ref.increaseColor,
|
|
49356
|
+
decreaseColor = _ref.decreaseColor;
|
|
49323
49357
|
var items = [{
|
|
49324
|
-
color:
|
|
49358
|
+
color: increaseColor,
|
|
49325
49359
|
yKey: 'increase',
|
|
49326
49360
|
style: {
|
|
49327
49361
|
type: 'bar'
|
|
49328
49362
|
}
|
|
49329
49363
|
}, {
|
|
49330
|
-
color:
|
|
49364
|
+
color: decreaseColor,
|
|
49331
49365
|
yKey: 'decrease',
|
|
49332
49366
|
style: {
|
|
49333
49367
|
type: 'bar'
|
|
@@ -49347,11 +49381,13 @@ var Legend$2 = function Legend(_ref) {
|
|
|
49347
49381
|
};
|
|
49348
49382
|
if (!showLegend) return null;
|
|
49349
49383
|
return jsx(Legend$1, {
|
|
49350
|
-
|
|
49351
|
-
|
|
49384
|
+
items: [{
|
|
49385
|
+
legendItems: items,
|
|
49386
|
+
visibleYKeys: ['increase', 'decrease'],
|
|
49387
|
+
conditionalFormattingRules: []
|
|
49388
|
+
}],
|
|
49352
49389
|
keys: keys,
|
|
49353
49390
|
marginLeft: margin.left - margin.leftTitleOffset,
|
|
49354
|
-
conditionalFormattingRules: [],
|
|
49355
49391
|
setVisibleYKeys: function setVisibleYKeys() {}
|
|
49356
49392
|
});
|
|
49357
49393
|
};
|
|
@@ -49369,7 +49405,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
49369
49405
|
options = _ref.options,
|
|
49370
49406
|
chart = _ref.chart,
|
|
49371
49407
|
steps = _ref.steps,
|
|
49372
|
-
theme = _ref.theme
|
|
49408
|
+
theme = _ref.theme,
|
|
49409
|
+
increaseColor = _ref.increaseColor,
|
|
49410
|
+
decreaseColor = _ref.decreaseColor;
|
|
49373
49411
|
//Waterfall TODO: fix chart for other x types
|
|
49374
49412
|
if (chart.x.scale.dataType === 'date_time' || chart.x.scale.dataType === 'number') {
|
|
49375
49413
|
return null;
|
|
@@ -49597,7 +49635,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
49597
49635
|
},
|
|
49598
49636
|
stroke: (_theme$axis$stroke = theme == null || (_theme$axis = theme.axis) == null ? void 0 : _theme$axis.stroke) != null ? _theme$axis$stroke : 'transparent'
|
|
49599
49637
|
}), jsx(Group$2, {
|
|
49600
|
-
children: jsx(BarGroup$
|
|
49638
|
+
children: jsx(BarGroup$2, {
|
|
49601
49639
|
data: dataFlattened,
|
|
49602
49640
|
keys: yScaleKeys,
|
|
49603
49641
|
height: innerHeight,
|
|
@@ -49618,6 +49656,8 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
49618
49656
|
left: barGroup.x0,
|
|
49619
49657
|
children: barGroup.bars.map(function (bar) {
|
|
49620
49658
|
return jsx(Bar$1, {
|
|
49659
|
+
increaseColor: increaseColor,
|
|
49660
|
+
decreaseColor: decreaseColor,
|
|
49621
49661
|
bar: bar,
|
|
49622
49662
|
barGroup: barGroup,
|
|
49623
49663
|
yScale: yScale,
|
|
@@ -49638,7 +49678,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
49638
49678
|
})]
|
|
49639
49679
|
}), jsx(Legend$2, {
|
|
49640
49680
|
showLegend: options.showLegend,
|
|
49641
|
-
margin: margin
|
|
49681
|
+
margin: margin,
|
|
49682
|
+
increaseColor: increaseColor,
|
|
49683
|
+
decreaseColor: decreaseColor
|
|
49642
49684
|
}), jsx(Tooltip$2, {
|
|
49643
49685
|
showTooltip: tooltipOpen,
|
|
49644
49686
|
tooltipData: tooltipData,
|
|
@@ -49654,7 +49696,9 @@ var Bar$1 = function Bar(_ref4) {
|
|
|
49654
49696
|
var bar = _ref4.bar,
|
|
49655
49697
|
barGroup = _ref4.barGroup,
|
|
49656
49698
|
yScale = _ref4.yScale,
|
|
49657
|
-
formattedChartDataForBarChart = _ref4.formattedChartDataForBarChart
|
|
49699
|
+
formattedChartDataForBarChart = _ref4.formattedChartDataForBarChart,
|
|
49700
|
+
increaseColor = _ref4.increaseColor,
|
|
49701
|
+
decreaseColor = _ref4.decreaseColor;
|
|
49658
49702
|
var step = formattedChartDataForBarChart.steps[barGroup.index];
|
|
49659
49703
|
var y = yScale(Math.max(step.start, step.end));
|
|
49660
49704
|
var barHeight = Math.abs(yScale(step.start) - yScale(step.end));
|
|
@@ -49664,7 +49708,7 @@ var Bar$1 = function Bar(_ref4) {
|
|
|
49664
49708
|
y: y,
|
|
49665
49709
|
width: bar.width,
|
|
49666
49710
|
height: barHeight,
|
|
49667
|
-
fill:
|
|
49711
|
+
fill: bar.value > 0 ? increaseColor : decreaseColor,
|
|
49668
49712
|
rx: 4
|
|
49669
49713
|
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + bar.key)
|
|
49670
49714
|
});
|
|
@@ -49940,7 +49984,9 @@ var WaterfallChartView = function WaterfallChartView(props) {
|
|
|
49940
49984
|
xAxisPrefix = props.xAxisPrefix,
|
|
49941
49985
|
yAxisFormat = props.yAxisFormat,
|
|
49942
49986
|
yAxisPostfix = props.yAxisPostfix,
|
|
49943
|
-
yAxisPrefix = props.yAxisPrefix
|
|
49987
|
+
yAxisPrefix = props.yAxisPrefix,
|
|
49988
|
+
increaseColor = props.increaseColor,
|
|
49989
|
+
decreaseColor = props.decreaseColor;
|
|
49944
49990
|
var _useDashboardBehaviou = useDashboardBehaviourContext(),
|
|
49945
49991
|
textOverride = _useDashboardBehaviou.textOverride,
|
|
49946
49992
|
valueAlias = _useDashboardBehaviou.valueAlias,
|
|
@@ -50034,7 +50080,9 @@ var WaterfallChartView = function WaterfallChartView(props) {
|
|
|
50034
50080
|
},
|
|
50035
50081
|
theme: theme == null ? void 0 : theme.charts,
|
|
50036
50082
|
chart: chartRepresentation,
|
|
50037
|
-
steps: steps
|
|
50083
|
+
steps: steps,
|
|
50084
|
+
increaseColor: increaseColor,
|
|
50085
|
+
decreaseColor: decreaseColor
|
|
50038
50086
|
});
|
|
50039
50087
|
}
|
|
50040
50088
|
})
|
|
@@ -60530,6 +60578,47 @@ var RichTextFormatSection = function RichTextFormatSection(props) {
|
|
|
60530
60578
|
});
|
|
60531
60579
|
};
|
|
60532
60580
|
|
|
60581
|
+
var WaterfallColorsSection = function WaterfallColorsSection(props) {
|
|
60582
|
+
var _props$section;
|
|
60583
|
+
var _useDashboardBehaviou = useDashboardBehaviourContext(),
|
|
60584
|
+
textOverride = _useDashboardBehaviou.textOverride;
|
|
60585
|
+
if (props.attributes.type != 'waterfallChart') return null;
|
|
60586
|
+
var _props$attributes = props.attributes,
|
|
60587
|
+
increaseColor = _props$attributes.increaseColor,
|
|
60588
|
+
decreaseColor = _props$attributes.decreaseColor;
|
|
60589
|
+
var debouncedSetAttributes = debounce$1(props.setAttributes, 200);
|
|
60590
|
+
return jsx(Section, {
|
|
60591
|
+
title: props == null ? void 0 : props.section.title,
|
|
60592
|
+
tooltip: props == null || (_props$section = props.section) == null ? void 0 : _props$section.description,
|
|
60593
|
+
children: jsxs(Section.Grid, {
|
|
60594
|
+
columns: 2,
|
|
60595
|
+
children: [jsx("div", {
|
|
60596
|
+
children: jsx(ColorInput, {
|
|
60597
|
+
id: 'waterfall-increase-color',
|
|
60598
|
+
label: textOverride('increase_color', 'Positive value'),
|
|
60599
|
+
currentValue: increaseColor,
|
|
60600
|
+
setColor: function setColor(increaseColor) {
|
|
60601
|
+
return debouncedSetAttributes({
|
|
60602
|
+
increaseColor: increaseColor
|
|
60603
|
+
});
|
|
60604
|
+
}
|
|
60605
|
+
})
|
|
60606
|
+
}), jsx("div", {
|
|
60607
|
+
children: jsx(ColorInput, {
|
|
60608
|
+
id: 'waterfall-decrease-color',
|
|
60609
|
+
label: textOverride('decrease_color', 'Negative value'),
|
|
60610
|
+
currentValue: decreaseColor,
|
|
60611
|
+
setColor: function setColor(decreaseColor) {
|
|
60612
|
+
return debouncedSetAttributes({
|
|
60613
|
+
decreaseColor: decreaseColor
|
|
60614
|
+
});
|
|
60615
|
+
}
|
|
60616
|
+
})
|
|
60617
|
+
})]
|
|
60618
|
+
})
|
|
60619
|
+
});
|
|
60620
|
+
};
|
|
60621
|
+
|
|
60533
60622
|
var FormatPanelFromConfig = function FormatPanelFromConfig(props) {
|
|
60534
60623
|
return jsx(EditorGrid, {
|
|
60535
60624
|
children: props == null ? void 0 : props.formatPanelConfig.map(function (section, i) {
|
|
@@ -60560,6 +60649,8 @@ var FormatPanelFromConfig = function FormatPanelFromConfig(props) {
|
|
|
60560
60649
|
section: section
|
|
60561
60650
|
})), section.type === 'mapColors' && jsx(MapColorsSection, _extends({}, props, {
|
|
60562
60651
|
section: section
|
|
60652
|
+
})), section.type === 'waterfallColors' && jsx(WaterfallColorsSection, _extends({}, props, {
|
|
60653
|
+
section: section
|
|
60563
60654
|
})), section.type === 'conditionalFormatting' && jsx(ConditionalFormattingSection, _extends({}, props, {
|
|
60564
60655
|
section: section
|
|
60565
60656
|
})), section.type === 'goalLine' && jsx(GoalLineSection, _extends({}, props, {
|