@vizzly/dashboard 0.14.4-dev-24f9cd0bb1a4c71a63f54ca0536be5df044db3a4 → 0.14.4-dev-e92d7e73ad10f9a39cbd6f8d0ebbd4f8db295c86
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/AxisBottom.d.ts +5 -3
- package/dist/charts/src/v2/components/BarChart/BarChart.d.ts +5 -33
- package/dist/charts/src/v2/components/Legend/Legend.d.ts +8 -7
- package/dist/charts/src/v2/components/hooks/useBottomAxisBaselineShift.d.ts +10 -0
- package/dist/charts/src/v2/constants/BORDER_RADIUS.d.ts +1 -0
- package/dist/charts/src/v2/utils/buildMargin.d.ts +1 -1
- package/dist/charts/src/v2/utils/components/BarGroup.d.ts +24 -0
- package/dist/charts/src/v2/utils/components/BarStacked.d.ts +18 -0
- package/dist/dashboard.cjs.development.js +423 -261
- package/dist/dashboard.cjs.production.min.js +1 -1
- package/dist/dashboard.esm.js +427 -265
- package/dist/shared-logic/src/ChartsV2/adjustTicks.d.ts +1 -1
- package/package.json +3 -3
- package/dist/shared-logic/src/BubbleChart/adjustTicks.d.ts +0 -3
- package/dist/shared-logic/src/ChartsV2/getAxisFormattingFunction.d.ts +0 -13
- package/dist/shared-logic/src/ChartsV2/getMinAndMax.d.ts +0 -15
- package/dist/shared-logic/src/ChartsV2/getScaleAndTicks.d.ts +0 -41
|
@@ -43377,11 +43377,30 @@ var Legend$1 = function Legend(_ref) {
|
|
|
43377
43377
|
setVisibleYKeys = _ref.setVisibleYKeys,
|
|
43378
43378
|
marginLeft = _ref.marginLeft,
|
|
43379
43379
|
items = _ref.items;
|
|
43380
|
+
var handleOnClick = function handleOnClick(item, legendItem) {
|
|
43381
|
+
setVisibleYKeys && setVisibleYKeys(function (prev) {
|
|
43382
|
+
var newVisibleLegendItems = [];
|
|
43383
|
+
if (prev.length === item.legendItems.length) {
|
|
43384
|
+
newVisibleLegendItems = [legendItem.yKey];
|
|
43385
|
+
} else {
|
|
43386
|
+
if (prev.includes(legendItem.yKey)) {
|
|
43387
|
+
newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
|
|
43388
|
+
return prevLegendItemId !== legendItem.yKey;
|
|
43389
|
+
});
|
|
43390
|
+
} else {
|
|
43391
|
+
newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
|
|
43392
|
+
}
|
|
43393
|
+
}
|
|
43394
|
+
return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
|
|
43395
|
+
return legendItem.yKey;
|
|
43396
|
+
}) : newVisibleLegendItems;
|
|
43397
|
+
});
|
|
43398
|
+
};
|
|
43380
43399
|
return jsxRuntime.jsx("div", {
|
|
43381
43400
|
className: /*#__PURE__*/css$1.css( {
|
|
43382
43401
|
name: "qz6h7j-Legend",
|
|
43383
43402
|
styles: "height:40px;padding-top:8px;label:Legend;",
|
|
43384
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
43403
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0R3QiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG50eXBlIEl0ZW08VD4gPSB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbn1cbmV4cG9ydCB0eXBlIExlZ2VuZFByb3BzPFQ+ID0ge1xuICAgIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAgICBrZXlzOiB7IFtrZXk6IHN0cmluZ106IEtleSB9O1xuICAgIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgICBpdGVtczogSXRlbTxUPltdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAgICBrZXlzLFxuICAgIHNldFZpc2libGVZS2V5cyxcbiAgICBtYXJnaW5MZWZ0LFxuICAgIGl0ZW1zLFxufTogTGVnZW5kUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXM+KSA9PiB7XG4gICAgY29uc3QgaGFuZGxlT25DbGljayA9IChpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPiwgbGVnZW5kSXRlbTogU2hhcGVEZWZpbml0aW9uPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICAgICAgICBzZXRWaXNpYmxlWUtleXMgJiZcbiAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5XG4gICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICA6IG5ld1Zpc2libGVMZWdlbmRJdGVtcztcbiAgICAgICAgICAgIH0pO1xuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgICAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICAgICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgICAgICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgICAgICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICB4PXt0cnVlfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgICAgICAgIDxGcmFnbWVudCBrZXk9e2luZGV4fT5cbiAgICAgICAgICAgICAgICAgICAgICAgIHtpdGVtLmxlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4geyBoYW5kbGVPbkNsaWNrKGl0ZW0sIGxlZ2VuZEl0ZW0pIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2l0ZW0uY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXN9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICAgICkpfVxuICAgICAgICAgICAgPC9TY3JvbGxiYXI+XG4gICAgICAgIDwvZGl2PlxuICAgICk7XG59O1xuIl19 */",
|
|
43385
43404
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
43386
43405
|
}),
|
|
43387
43406
|
children: jsxRuntime.jsx(Scrollbar, {
|
|
@@ -43391,33 +43410,16 @@ var Legend$1 = function Legend(_ref) {
|
|
|
43391
43410
|
flexWrap: 'nowrap',
|
|
43392
43411
|
alignItems: 'center',
|
|
43393
43412
|
marginLeft: marginLeft ? marginLeft + "px" : undefined
|
|
43394
|
-
}, ";label:Legend;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
43413
|
+
}, ";label:Legend;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0QyQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG50eXBlIEl0ZW08VD4gPSB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbn1cbmV4cG9ydCB0eXBlIExlZ2VuZFByb3BzPFQ+ID0ge1xuICAgIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAgICBrZXlzOiB7IFtrZXk6IHN0cmluZ106IEtleSB9O1xuICAgIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgICBpdGVtczogSXRlbTxUPltdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAgICBrZXlzLFxuICAgIHNldFZpc2libGVZS2V5cyxcbiAgICBtYXJnaW5MZWZ0LFxuICAgIGl0ZW1zLFxufTogTGVnZW5kUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXM+KSA9PiB7XG4gICAgY29uc3QgaGFuZGxlT25DbGljayA9IChpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPiwgbGVnZW5kSXRlbTogU2hhcGVEZWZpbml0aW9uPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICAgICAgICBzZXRWaXNpYmxlWUtleXMgJiZcbiAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5XG4gICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICA6IG5ld1Zpc2libGVMZWdlbmRJdGVtcztcbiAgICAgICAgICAgIH0pO1xuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgICAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICAgICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgICAgICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgICAgICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICB4PXt0cnVlfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgICAgICAgIDxGcmFnbWVudCBrZXk9e2luZGV4fT5cbiAgICAgICAgICAgICAgICAgICAgICAgIHtpdGVtLmxlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4geyBoYW5kbGVPbkNsaWNrKGl0ZW0sIGxlZ2VuZEl0ZW0pIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2l0ZW0uY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXN9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICAgICkpfVxuICAgICAgICAgICAgPC9TY3JvbGxiYXI+XG4gICAgICAgIDwvZGl2PlxuICAgICk7XG59O1xuIl19 */"),
|
|
43395
43414
|
x: true,
|
|
43396
|
-
children: items
|
|
43397
|
-
var _item$legendItems;
|
|
43415
|
+
children: items.map(function (item, index) {
|
|
43398
43416
|
return jsxRuntime.jsx(React.Fragment, {
|
|
43399
|
-
children:
|
|
43417
|
+
children: item.legendItems.map(function (legendItem) {
|
|
43400
43418
|
return keys[legendItem.yKey] && react.createElement(LegendItem, _extends({}, legendItem, {
|
|
43401
43419
|
key: "legend-" + legendItem.yKey,
|
|
43402
43420
|
yKeyFormatted: keys[legendItem.yKey].keyFormatted,
|
|
43403
43421
|
onClick: function onClick() {
|
|
43404
|
-
|
|
43405
|
-
var newVisibleLegendItems = [];
|
|
43406
|
-
if (prev.length === item.legendItems.length) {
|
|
43407
|
-
newVisibleLegendItems = [legendItem.yKey];
|
|
43408
|
-
} else {
|
|
43409
|
-
if (prev.includes(legendItem.yKey)) {
|
|
43410
|
-
newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
|
|
43411
|
-
return prevLegendItemId !== legendItem.yKey;
|
|
43412
|
-
});
|
|
43413
|
-
} else {
|
|
43414
|
-
newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
|
|
43415
|
-
}
|
|
43416
|
-
}
|
|
43417
|
-
return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
|
|
43418
|
-
return legendItem.yKey;
|
|
43419
|
-
}) : newVisibleLegendItems;
|
|
43420
|
-
});
|
|
43422
|
+
handleOnClick(item, legendItem);
|
|
43421
43423
|
},
|
|
43422
43424
|
visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
|
|
43423
43425
|
conditionalFormattingRules: item.conditionalFormattingRules
|
|
@@ -43429,11 +43431,8 @@ var Legend$1 = function Legend(_ref) {
|
|
|
43429
43431
|
});
|
|
43430
43432
|
};
|
|
43431
43433
|
|
|
43432
|
-
var ASSUMED_AVERAGE_CHAR_WIDTH =
|
|
43434
|
+
var ASSUMED_AVERAGE_CHAR_WIDTH = 4;
|
|
43433
43435
|
function calculateWordWidth(word, avgCharWidth) {
|
|
43434
|
-
if (avgCharWidth === void 0) {
|
|
43435
|
-
avgCharWidth = ASSUMED_AVERAGE_CHAR_WIDTH;
|
|
43436
|
-
}
|
|
43437
43436
|
return word.length * avgCharWidth;
|
|
43438
43437
|
}
|
|
43439
43438
|
|
|
@@ -43506,7 +43505,10 @@ function adjustTicks(representation, width, height) {
|
|
|
43506
43505
|
return representation;
|
|
43507
43506
|
}
|
|
43508
43507
|
|
|
43509
|
-
var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, hasXAxisTitle) {
|
|
43508
|
+
var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, hasXAxisTitle, showDetailedSubGroupingLabels) {
|
|
43509
|
+
if (showDetailedSubGroupingLabels === void 0) {
|
|
43510
|
+
showDetailedSubGroupingLabels = false;
|
|
43511
|
+
}
|
|
43510
43512
|
var maxWidth = _.max(yTicks.map(function (tick) {
|
|
43511
43513
|
return (tick.formattedValue || '').length * ASSUMED_AVERAGE_CHAR_WIDTH;
|
|
43512
43514
|
}));
|
|
@@ -43514,13 +43516,14 @@ var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, h
|
|
|
43514
43516
|
var MINIMUM_Y_AXIS_WIDTH = 40;
|
|
43515
43517
|
var yAxisTitleOffset = hasYAxisTitle ? 40 : 0;
|
|
43516
43518
|
var xAxisTitleOffset = hasXAxisTitle ? 40 : 0;
|
|
43519
|
+
var bottom = showDetailedSubGroupingLabels ? 90 : 40;
|
|
43517
43520
|
var left = showYTicks ? _.max([maxWidth, MINIMUM_Y_AXIS_WIDTH]) : MINIMUM_Y_AXIS_WIDTH;
|
|
43518
43521
|
return {
|
|
43519
43522
|
top: 15,
|
|
43520
43523
|
right: MINIMUM_Y_AXIS_WIDTH,
|
|
43521
43524
|
bottom: 30 + xAxisTitleOffset,
|
|
43522
43525
|
left: left + yAxisTitleOffset,
|
|
43523
|
-
bottomTitleOffset:
|
|
43526
|
+
bottomTitleOffset: bottom,
|
|
43524
43527
|
leftTitleOffset: left
|
|
43525
43528
|
};
|
|
43526
43529
|
};
|
|
@@ -43637,7 +43640,7 @@ var AXIS_TITLE_STYLES = {
|
|
|
43637
43640
|
};
|
|
43638
43641
|
|
|
43639
43642
|
var _excluded$e = ["formattedValue"];
|
|
43640
|
-
|
|
43643
|
+
function AxisBottom(_ref) {
|
|
43641
43644
|
var _x$ticks;
|
|
43642
43645
|
var x = _ref.x,
|
|
43643
43646
|
margin = _ref.margin,
|
|
@@ -43646,7 +43649,8 @@ var AxisBottom = function AxisBottom(_ref) {
|
|
|
43646
43649
|
removeStroke = _ref.removeStroke,
|
|
43647
43650
|
xScaleDataType = _ref.xScaleDataType,
|
|
43648
43651
|
xScale = _ref.xScale,
|
|
43649
|
-
height = _ref.height
|
|
43652
|
+
height = _ref.height,
|
|
43653
|
+
baselineShift = _ref.baselineShift;
|
|
43650
43654
|
var tickFormat = React.useCallback(function (value) {
|
|
43651
43655
|
var tick = null;
|
|
43652
43656
|
if (xScaleDataType === 'date_time' && value instanceof Date) {
|
|
@@ -43689,13 +43693,14 @@ var AxisBottom = function AxisBottom(_ref) {
|
|
|
43689
43693
|
return jsxRuntime.jsx(text$3.Text, _extends({
|
|
43690
43694
|
style: themeCSS.labels
|
|
43691
43695
|
}, tickProps, {
|
|
43696
|
+
baselineShift: baselineShift != null ? baselineShift : tickProps.baselineShift,
|
|
43692
43697
|
children: formattedValue
|
|
43693
43698
|
}));
|
|
43694
43699
|
},
|
|
43695
43700
|
stroke: themeCSS.axis.stroke,
|
|
43696
43701
|
strokeWidth: removeStroke ? 0 : 1
|
|
43697
43702
|
});
|
|
43698
|
-
}
|
|
43703
|
+
}
|
|
43699
43704
|
|
|
43700
43705
|
var _excluded$f = ["formattedValue"];
|
|
43701
43706
|
var AxisLeft = function AxisLeft(_ref) {
|
|
@@ -44195,30 +44200,6 @@ function Lines(_ref2) {
|
|
|
44195
44200
|
});
|
|
44196
44201
|
}
|
|
44197
44202
|
|
|
44198
|
-
function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
44199
|
-
var _bars$find;
|
|
44200
|
-
// Default fill color from the corresponding bar
|
|
44201
|
-
var fill = (_bars$find = bars.find(function (chartBar) {
|
|
44202
|
-
return chartBar.yKey === barKey;
|
|
44203
|
-
})) == null ? void 0 : _bars$find.color;
|
|
44204
|
-
|
|
44205
|
-
// Determine the value based on barValues type
|
|
44206
|
-
var value = typeof barValues === 'number' ? barValues : barValues == null ? void 0 : barValues[barKey];
|
|
44207
|
-
if (typeof value === 'number') {
|
|
44208
|
-
for (var _iterator = _createForOfIteratorHelperLoose(conditionalFormattingRules), _step; !(_step = _iterator()).done;) {
|
|
44209
|
-
var rule = _step.value;
|
|
44210
|
-
if (compare({
|
|
44211
|
-
op: rule.operator,
|
|
44212
|
-
value: rule.value
|
|
44213
|
-
}, value) && rule.yKey === barKey) {
|
|
44214
|
-
fill = rule.color;
|
|
44215
|
-
break;
|
|
44216
|
-
}
|
|
44217
|
-
}
|
|
44218
|
-
}
|
|
44219
|
-
return fill;
|
|
44220
|
-
}
|
|
44221
|
-
|
|
44222
44203
|
var PADDING = {
|
|
44223
44204
|
paddingOuter: 0.05,
|
|
44224
44205
|
paddingInner: 0.3
|
|
@@ -44254,8 +44235,287 @@ function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
|
|
|
44254
44235
|
}, [innerWidth, data]);
|
|
44255
44236
|
}
|
|
44256
44237
|
|
|
44257
|
-
|
|
44238
|
+
var useBottomAxisBaseLineShift = function useBottomAxisBaseLineShift(_ref) {
|
|
44239
|
+
var showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
|
|
44240
|
+
hasBottomTitle = _ref.hasBottomTitle,
|
|
44241
|
+
hasLeftTitle = _ref.hasLeftTitle;
|
|
44242
|
+
if (!showDetailedSubGroupingLabels) {
|
|
44243
|
+
return {
|
|
44244
|
+
bottomAxisBaselineShift: 0,
|
|
44245
|
+
bottomOffset: 0,
|
|
44246
|
+
leftOffset: 0
|
|
44247
|
+
};
|
|
44248
|
+
}
|
|
44249
|
+
return {
|
|
44250
|
+
bottomAxisBaselineShift: hasBottomTitle ? -65 : -60,
|
|
44251
|
+
bottomOffset: hasBottomTitle ? -15 : 10,
|
|
44252
|
+
leftOffset: hasLeftTitle ? -10 : 0
|
|
44253
|
+
};
|
|
44254
|
+
};
|
|
44255
|
+
|
|
44256
|
+
function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
44257
|
+
var _bars$find;
|
|
44258
|
+
// Default fill color from the corresponding bar
|
|
44259
|
+
var fill = (_bars$find = bars.find(function (chartBar) {
|
|
44260
|
+
return chartBar.yKey === barKey;
|
|
44261
|
+
})) == null ? void 0 : _bars$find.color;
|
|
44262
|
+
|
|
44263
|
+
// Determine the value based on barValues type
|
|
44264
|
+
var value = typeof barValues === 'number' ? barValues : barValues == null ? void 0 : barValues[barKey];
|
|
44265
|
+
if (typeof value === 'number') {
|
|
44266
|
+
for (var _iterator = _createForOfIteratorHelperLoose(conditionalFormattingRules), _step; !(_step = _iterator()).done;) {
|
|
44267
|
+
var rule = _step.value;
|
|
44268
|
+
if (compare({
|
|
44269
|
+
op: rule.operator,
|
|
44270
|
+
value: rule.value
|
|
44271
|
+
}, value) && rule.yKey === barKey) {
|
|
44272
|
+
fill = rule.color;
|
|
44273
|
+
break;
|
|
44274
|
+
}
|
|
44275
|
+
}
|
|
44276
|
+
}
|
|
44277
|
+
return fill;
|
|
44278
|
+
}
|
|
44279
|
+
|
|
44258
44280
|
var BAR_RADIUS = 2;
|
|
44281
|
+
|
|
44282
|
+
var BarStacked = function BarStacked(_ref) {
|
|
44283
|
+
var xScaleDataType = _ref.xScaleDataType,
|
|
44284
|
+
data = _ref.data,
|
|
44285
|
+
xScaleKey = _ref.xScaleKey,
|
|
44286
|
+
yScale = _ref.yScale,
|
|
44287
|
+
keys = _ref.keys,
|
|
44288
|
+
bars = _ref.bars,
|
|
44289
|
+
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
44290
|
+
xScale = _ref.xScale,
|
|
44291
|
+
height = _ref.height,
|
|
44292
|
+
width = _ref.width;
|
|
44293
|
+
var handleGetXValue = function handleGetXValue(d) {
|
|
44294
|
+
var xValue = d[xScaleKey];
|
|
44295
|
+
if (xScaleDataType === 'string') return String(xValue);
|
|
44296
|
+
if (xScaleDataType === 'date_time') {
|
|
44297
|
+
return new Date(xValue);
|
|
44298
|
+
}
|
|
44299
|
+
if (xScaleDataType === 'number') {
|
|
44300
|
+
return Number(xValue);
|
|
44301
|
+
}
|
|
44302
|
+
return String(xValue);
|
|
44303
|
+
};
|
|
44304
|
+
return jsxRuntime.jsx(shape.BarStack, {
|
|
44305
|
+
x: handleGetXValue,
|
|
44306
|
+
xScale: xScale,
|
|
44307
|
+
yScale: yScale,
|
|
44308
|
+
data: data,
|
|
44309
|
+
keys: keys,
|
|
44310
|
+
color: function color() {
|
|
44311
|
+
return '';
|
|
44312
|
+
},
|
|
44313
|
+
height: height,
|
|
44314
|
+
width: width,
|
|
44315
|
+
offset: "none",
|
|
44316
|
+
children: function children(barStacks) {
|
|
44317
|
+
return barStacks.map(function (barStack) {
|
|
44318
|
+
return barStack.bars.map(function (bar) {
|
|
44319
|
+
return jsxRuntime.jsx(Bar, {
|
|
44320
|
+
bar: bar,
|
|
44321
|
+
barStack: barStack,
|
|
44322
|
+
bars: bars,
|
|
44323
|
+
conditionalFormattingRules: conditionalFormattingRules
|
|
44324
|
+
}, bar.key.toString());
|
|
44325
|
+
});
|
|
44326
|
+
});
|
|
44327
|
+
}
|
|
44328
|
+
});
|
|
44329
|
+
};
|
|
44330
|
+
var Bar = function Bar(_ref2) {
|
|
44331
|
+
var bar = _ref2.bar,
|
|
44332
|
+
barStack = _ref2.barStack,
|
|
44333
|
+
bars = _ref2.bars,
|
|
44334
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules;
|
|
44335
|
+
var BAR_PADDING = 1.5;
|
|
44336
|
+
if (bar.height < 3) return null;
|
|
44337
|
+
return jsxRuntime.jsx("rect", {
|
|
44338
|
+
x: bar.x,
|
|
44339
|
+
y: bar.y,
|
|
44340
|
+
width: bar.width,
|
|
44341
|
+
height: bar.height - BAR_PADDING,
|
|
44342
|
+
fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
|
|
44343
|
+
rx: BAR_RADIUS
|
|
44344
|
+
}, "bar-stack-" + barStack.index + "-" + bar.index);
|
|
44345
|
+
};
|
|
44346
|
+
|
|
44347
|
+
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)."; }
|
|
44348
|
+
function BarGroup(_ref) {
|
|
44349
|
+
var data = _ref.data,
|
|
44350
|
+
keys = _ref.keys,
|
|
44351
|
+
height = _ref.height,
|
|
44352
|
+
xKey = _ref.xKey,
|
|
44353
|
+
xScaleDataType = _ref.xScaleDataType,
|
|
44354
|
+
xScale = _ref.xScale,
|
|
44355
|
+
innerXScale = _ref.innerXScale,
|
|
44356
|
+
yScale = _ref.yScale,
|
|
44357
|
+
onClick = _ref.onClick,
|
|
44358
|
+
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
44359
|
+
bars = _ref.bars,
|
|
44360
|
+
enableHover = _ref.enableHover,
|
|
44361
|
+
yAxisLabels = _ref.yAxisLabels,
|
|
44362
|
+
yLabelPosition = _ref.yLabelPosition,
|
|
44363
|
+
showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
|
|
44364
|
+
labelStyle = _ref.labelStyle;
|
|
44365
|
+
var getGroupPosition = function getGroupPosition(d) {
|
|
44366
|
+
var xValue = d[xKey];
|
|
44367
|
+
if (xScaleDataType === 'string') return String(xValue);
|
|
44368
|
+
if (xScaleDataType === 'date_time') {
|
|
44369
|
+
return new Date(String(xValue));
|
|
44370
|
+
}
|
|
44371
|
+
if (xScaleDataType === 'number') {
|
|
44372
|
+
return Number(xValue);
|
|
44373
|
+
}
|
|
44374
|
+
return String(xValue);
|
|
44375
|
+
};
|
|
44376
|
+
return jsxRuntime.jsx(shape.BarGroup, {
|
|
44377
|
+
data: data,
|
|
44378
|
+
keys: keys,
|
|
44379
|
+
height: height,
|
|
44380
|
+
x0: getGroupPosition
|
|
44381
|
+
// @ts-ignore
|
|
44382
|
+
,
|
|
44383
|
+
x0Scale: xScale
|
|
44384
|
+
// @ts-ignore
|
|
44385
|
+
,
|
|
44386
|
+
x1Scale: innerXScale,
|
|
44387
|
+
yScale: yScale,
|
|
44388
|
+
color: function color() {
|
|
44389
|
+
return '';
|
|
44390
|
+
},
|
|
44391
|
+
children: function children(barGroups) {
|
|
44392
|
+
return barGroups.map(function (barGroup) {
|
|
44393
|
+
return jsxRuntime.jsx(group.Group, {
|
|
44394
|
+
left: barGroup.x0,
|
|
44395
|
+
children: barGroup.bars.map(function (bar) {
|
|
44396
|
+
return jsxRuntime.jsx(Bar$1, {
|
|
44397
|
+
bar: bar,
|
|
44398
|
+
barGroup: barGroup,
|
|
44399
|
+
bars: bars,
|
|
44400
|
+
conditionalFormattingRules: conditionalFormattingRules,
|
|
44401
|
+
enableHover: enableHover,
|
|
44402
|
+
labelStyle: labelStyle,
|
|
44403
|
+
onClick: onClick,
|
|
44404
|
+
showDetailedSubGroupingLabels: showDetailedSubGroupingLabels,
|
|
44405
|
+
yAxisLabels: yAxisLabels,
|
|
44406
|
+
yLabelPosition: yLabelPosition
|
|
44407
|
+
}, "bar-" + bar.index + "-" + bar.x);
|
|
44408
|
+
})
|
|
44409
|
+
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
44410
|
+
});
|
|
44411
|
+
}
|
|
44412
|
+
});
|
|
44413
|
+
}
|
|
44414
|
+
var Bar$1 = function Bar(_ref2) {
|
|
44415
|
+
var bar = _ref2.bar,
|
|
44416
|
+
barGroup = _ref2.barGroup,
|
|
44417
|
+
bars = _ref2.bars,
|
|
44418
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules,
|
|
44419
|
+
enableHover = _ref2.enableHover,
|
|
44420
|
+
labelStyle = _ref2.labelStyle,
|
|
44421
|
+
_onClick = _ref2.onClick,
|
|
44422
|
+
showDetailedSubGroupingLabels = _ref2.showDetailedSubGroupingLabels,
|
|
44423
|
+
yAxisLabels = _ref2.yAxisLabels,
|
|
44424
|
+
yLabelPosition = _ref2.yLabelPosition;
|
|
44425
|
+
var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
|
|
44426
|
+
return jsxRuntime.jsxs(React.Fragment, {
|
|
44427
|
+
children: [showBar && jsxRuntime.jsx(BarRect, {
|
|
44428
|
+
x: bar.x,
|
|
44429
|
+
y: bar.y,
|
|
44430
|
+
width: bar.width,
|
|
44431
|
+
height: bar.height,
|
|
44432
|
+
fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
|
|
44433
|
+
onClick: function onClick(e) {
|
|
44434
|
+
return _onClick(e, barGroup, bar);
|
|
44435
|
+
},
|
|
44436
|
+
enableHover: enableHover
|
|
44437
|
+
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key)), jsxRuntime.jsx(BarLabel, {
|
|
44438
|
+
bar: bar,
|
|
44439
|
+
barGroup: barGroup,
|
|
44440
|
+
yLabelPosition: yLabelPosition,
|
|
44441
|
+
yAxisLabels: yAxisLabels,
|
|
44442
|
+
showDetailedSubGroupingLabels: showDetailedSubGroupingLabels,
|
|
44443
|
+
labelStyle: labelStyle
|
|
44444
|
+
})]
|
|
44445
|
+
});
|
|
44446
|
+
};
|
|
44447
|
+
var BarRect = function BarRect(_ref3) {
|
|
44448
|
+
var onClick = _ref3.onClick,
|
|
44449
|
+
fill = _ref3.fill,
|
|
44450
|
+
x = _ref3.x,
|
|
44451
|
+
y = _ref3.y,
|
|
44452
|
+
width = _ref3.width,
|
|
44453
|
+
height = _ref3.height,
|
|
44454
|
+
key = _ref3.key,
|
|
44455
|
+
enableHover = _ref3.enableHover;
|
|
44456
|
+
var _useState = React.useState(fill),
|
|
44457
|
+
fillColor = _useState[0],
|
|
44458
|
+
setFillColor = _useState[1];
|
|
44459
|
+
var classes = enableHover ? /*#__PURE__*/css$1.css( {
|
|
44460
|
+
name: "1ltmijl-classes",
|
|
44461
|
+
styles: "cursor:pointer;label:classes;",
|
|
44462
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AAmLkC","file":"BarGroup.tsx","sourcesContent":["import { css } from \"@emotion/css\";\nimport { Fragment, useState } from \"react\";\nimport { lightenColor } from \"../../../styles/color.functions\";\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS'\nimport { getBarFill } from \"../getBarFill\";\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from \"shared-logic/src/ChartsV2/types\";\nimport { BarStyles } from \"shared-logic/src/BarChartV2/types\";\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { ScaleLinear, ScaleBand } from '@visx/vendor/d3-scale';\nimport { DataType } from \"shared-logic/src/Field/types\";\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { Group } from '@visx/group';\n\nexport type BarGroupProps = {\n    data: ChartDataDefinition[];\n    keys: string[];\n    height: number;\n    xKey: string;\n    xScaleDataType: DataType;\n    xScale: ScaleBand<string> | ScaleBand<Date> | ScaleBand<number> | null;\n    innerXScale: ScaleBand<string> | undefined;\n    yScale: ScaleLinear<number, number, never>;\n    onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n    conditionalFormattingRules: ConditionalFormattingRule[];\n    bars: ShapeDefinition<BarStyles>[];\n    enableHover?: boolean;\n    yAxisLabels?: string[];\n    yLabelPosition?: number;\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n};\n\nexport function BarGroup({\n    data,\n    keys,\n    height,\n    xKey,\n    xScaleDataType,\n    xScale,\n    innerXScale,\n    yScale,\n    onClick,\n    conditionalFormattingRules,\n    bars,\n    enableHover,\n    yAxisLabels,\n    yLabelPosition,\n    showDetailedSubGroupingLabels,\n    labelStyle,\n}: BarGroupProps) {\n    const getGroupPosition = (d: DatumObject) => {\n        const xValue = d[xKey as keyof typeof d];\n\n        if (xScaleDataType === 'string') return String(xValue);\n\n        if (xScaleDataType === 'date_time') {\n            return new Date(String(xValue));\n        }\n\n        if (xScaleDataType === 'number') {\n            return Number(xValue);\n        }\n\n        return String(xValue);\n    };\n\n    return (\n        <VisxBarGroup<DatumObject>\n            data={data as DatumObject[]}\n            keys={keys}\n            height={height}\n            x0={getGroupPosition}\n            // @ts-ignore\n            x0Scale={xScale}\n            // @ts-ignore\n            x1Scale={innerXScale}\n            yScale={yScale}\n            color={() => ''}\n        >\n            {barGroups => {\n                return barGroups.map(barGroup => (\n                    <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n                        {barGroup.bars.map(bar => (\n                            <Bar\n                                key={`bar-${bar.index}-${bar.x}`}\n                                bar={bar}\n                                barGroup={barGroup}\n                                bars={bars}\n                                conditionalFormattingRules={conditionalFormattingRules}\n                                enableHover={enableHover}\n                                labelStyle={labelStyle}\n                                onClick={onClick}\n                                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                                yAxisLabels={yAxisLabels}\n                                yLabelPosition={yLabelPosition}\n                            />\n                        ))}\n                    </Group>\n                ));\n            }}\n        </VisxBarGroup>\n    );\n}\n\ntype BarProps = {\n    bar: any,\n    barGroup: any,\n    bars: ShapeDefinition<BarStyles>[];\n    conditionalFormattingRules: ConditionalFormattingRule[];\n    enableHover?: boolean;\n    onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: any, bar: any) => void;\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n    yAxisLabels?: string[];\n    yLabelPosition?: number;\n}\n\nconst Bar = ({\n    bar,\n    barGroup,\n    bars,\n    conditionalFormattingRules,\n    enableHover,\n    labelStyle,\n    onClick,\n    showDetailedSubGroupingLabels,\n    yAxisLabels,\n    yLabelPosition,\n}: BarProps) => {\n    const showBar = bar.value !== null && bar.height > 0 && bar.width > 0;\n\n    return (\n        <Fragment>\n            {showBar && <BarRect\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            <BarLabel\n                bar={bar}\n                barGroup={barGroup}\n                yLabelPosition={yLabelPosition}\n                yAxisLabels={yAxisLabels}\n                showDetailedSubGroupingLabels={showDetailedSubGroupingLabels}\n                labelStyle={labelStyle}\n            />\n        </Fragment>\n    );\n};\n\ntype BarRectProps = {\n    onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n    fill?: string;\n    x: number;\n    y: number;\n    width: number;\n    height: number;\n    key: string;\n    enableHover?: boolean;\n};\n\nconst BarRect = ({\n    onClick,\n    fill,\n    x,\n    y,\n    width,\n    height,\n    key,\n    enableHover,\n}: BarRectProps) => {\n    const [fillColor, setFillColor] = useState(fill);\n\n    const classes = enableHover ? css({ cursor: 'pointer' }) : '';\n\n    const handleOnMouseEnter = () => {\n        if (enableHover) {\n            setFillColor(lightenColor(fill, 0.8));\n        }\n    }\n\n    const handleOnMouseLeave = () => {\n        if (enableHover) {\n            setFillColor(fill);\n        }\n    }\n\n    return (\n        <rect\n            key={key}\n            x={x}\n            y={y}\n            width={width}\n            height={height}\n            fill={fillColor}\n            rx={BAR_RADIUS}\n            onClick={onClick}\n            onMouseEnter={handleOnMouseEnter}\n            onMouseLeave={handleOnMouseLeave}\n            className={classes}\n        />\n    );\n};\n\ntype BarLabelProps = {\n    bar: any;\n    barGroup: any;\n    yLabelPosition?: number;\n    yAxisLabels?: string[];\n    showDetailedSubGroupingLabels: boolean;\n    labelStyle?: React.CSSProperties;\n};\n\nconst BarLabel = ({\n    bar,\n    barGroup,\n    yLabelPosition,\n    yAxisLabels,\n    showDetailedSubGroupingLabels,\n    labelStyle,\n}: BarLabelProps) => {\n    if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;\n\n    const label = yAxisLabels[bar.index];\n    const columnLabel = label.split('•')[0];\n\n    let formattedColumnLabel: string;\n    if (columnLabel.length >= 13) {\n        formattedColumnLabel = columnLabel.slice(0, 10) + '...';\n    } else {\n        formattedColumnLabel = columnLabel.slice(0, 13);\n    }\n\n    const labelXGap = 4;\n    const labelXPosition = bar.x + (bar.width / 2) + labelXGap;\n\n    const labelYGap = 15;\n    const labelYPosition = yLabelPosition + labelYGap;\n\n    const labelKey = `label-${barGroup.index}-${bar.index}-${label}`;\n\n    return <text\n        key={labelKey}\n        x={labelXPosition}\n        y={labelYPosition}\n        style={labelStyle}\n        transform={`rotate(-70, ${labelXPosition}, ${labelYPosition})`}\n        textAnchor='end'\n    >\n        {formattedColumnLabel}\n    </text>\n}"]} */",
|
|
44463
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
44464
|
+
}) : '';
|
|
44465
|
+
var handleOnMouseEnter = function handleOnMouseEnter() {
|
|
44466
|
+
if (enableHover) {
|
|
44467
|
+
setFillColor(lightenColor$2(fill, 0.8));
|
|
44468
|
+
}
|
|
44469
|
+
};
|
|
44470
|
+
var handleOnMouseLeave = function handleOnMouseLeave() {
|
|
44471
|
+
if (enableHover) {
|
|
44472
|
+
setFillColor(fill);
|
|
44473
|
+
}
|
|
44474
|
+
};
|
|
44475
|
+
return jsxRuntime.jsx("rect", {
|
|
44476
|
+
x: x,
|
|
44477
|
+
y: y,
|
|
44478
|
+
width: width,
|
|
44479
|
+
height: height,
|
|
44480
|
+
fill: fillColor,
|
|
44481
|
+
rx: BAR_RADIUS,
|
|
44482
|
+
onClick: onClick,
|
|
44483
|
+
onMouseEnter: handleOnMouseEnter,
|
|
44484
|
+
onMouseLeave: handleOnMouseLeave,
|
|
44485
|
+
className: classes
|
|
44486
|
+
}, key);
|
|
44487
|
+
};
|
|
44488
|
+
var BarLabel = function BarLabel(_ref4) {
|
|
44489
|
+
var bar = _ref4.bar,
|
|
44490
|
+
barGroup = _ref4.barGroup,
|
|
44491
|
+
yLabelPosition = _ref4.yLabelPosition,
|
|
44492
|
+
yAxisLabels = _ref4.yAxisLabels,
|
|
44493
|
+
showDetailedSubGroupingLabels = _ref4.showDetailedSubGroupingLabels,
|
|
44494
|
+
labelStyle = _ref4.labelStyle;
|
|
44495
|
+
if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;
|
|
44496
|
+
var label = yAxisLabels[bar.index];
|
|
44497
|
+
var columnLabel = label.split('•')[0];
|
|
44498
|
+
var formattedColumnLabel;
|
|
44499
|
+
if (columnLabel.length >= 13) {
|
|
44500
|
+
formattedColumnLabel = columnLabel.slice(0, 10) + '...';
|
|
44501
|
+
} else {
|
|
44502
|
+
formattedColumnLabel = columnLabel.slice(0, 13);
|
|
44503
|
+
}
|
|
44504
|
+
var labelXGap = 4;
|
|
44505
|
+
var labelXPosition = bar.x + bar.width / 2 + labelXGap;
|
|
44506
|
+
var labelYGap = 15;
|
|
44507
|
+
var labelYPosition = yLabelPosition + labelYGap;
|
|
44508
|
+
var labelKey = "label-" + barGroup.index + "-" + bar.index + "-" + label;
|
|
44509
|
+
return jsxRuntime.jsx("text", {
|
|
44510
|
+
x: labelXPosition,
|
|
44511
|
+
y: labelYPosition,
|
|
44512
|
+
style: labelStyle,
|
|
44513
|
+
transform: "rotate(-70, " + labelXPosition + ", " + labelYPosition + ")",
|
|
44514
|
+
textAnchor: "end",
|
|
44515
|
+
children: formattedColumnLabel
|
|
44516
|
+
}, labelKey);
|
|
44517
|
+
};
|
|
44518
|
+
|
|
44259
44519
|
var BarChart$5 = function BarChart(_ref) {
|
|
44260
44520
|
var _theme$axis;
|
|
44261
44521
|
var chart = _ref.chart,
|
|
@@ -44264,7 +44524,8 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44264
44524
|
options = _ref.options,
|
|
44265
44525
|
theme = _ref.theme,
|
|
44266
44526
|
onClick = _ref.onClick,
|
|
44267
|
-
enableHover = _ref.enableHover
|
|
44527
|
+
enableHover = _ref.enableHover,
|
|
44528
|
+
numberOfDimensions = _ref.numberOfDimensions;
|
|
44268
44529
|
var _useTooltip = useTooltip$1(),
|
|
44269
44530
|
tooltipOpen = _useTooltip.tooltipOpen,
|
|
44270
44531
|
_useTooltip$tooltipLe = _useTooltip.tooltipLeft,
|
|
@@ -44276,18 +44537,34 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44276
44537
|
tooltipData = _useTooltip.tooltipData,
|
|
44277
44538
|
hideTooltip = _useTooltip.hideTooltip,
|
|
44278
44539
|
showTooltip = _useTooltip.showTooltip;
|
|
44279
|
-
var
|
|
44280
|
-
|
|
44281
|
-
|
|
44282
|
-
|
|
44540
|
+
var showDetailedSubGroupingLabels = numberOfDimensions === 2 && width > 450;
|
|
44541
|
+
var hasBottomTitle = chart.x.title != null;
|
|
44542
|
+
var hasLeftTitle = chart.y.title != null;
|
|
44543
|
+
var _useBottomAxisBaseLin = useBottomAxisBaseLineShift({
|
|
44544
|
+
hasBottomTitle: hasBottomTitle,
|
|
44545
|
+
hasLeftTitle: hasLeftTitle,
|
|
44546
|
+
showDetailedSubGroupingLabels: showDetailedSubGroupingLabels
|
|
44547
|
+
}),
|
|
44548
|
+
bottomAxisBaselineShift = _useBottomAxisBaseLin.bottomAxisBaselineShift,
|
|
44549
|
+
bottomOffset = _useBottomAxisBaseLin.bottomOffset,
|
|
44550
|
+
leftOffset = _useBottomAxisBaseLin.leftOffset;
|
|
44551
|
+
var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, hasLeftTitle, hasBottomTitle, showDetailedSubGroupingLabels);
|
|
44283
44552
|
var innerWidth = width - margin.left - margin.right;
|
|
44284
|
-
var innerHeight = height - margin.top - margin.bottom - (options.showLegend ?
|
|
44553
|
+
var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 50 : 0) - (showDetailedSubGroupingLabels ? 50 : 0);
|
|
44285
44554
|
var xKey = chart.x.key;
|
|
44286
44555
|
var xScaleKey = chart.x.scale.key;
|
|
44287
|
-
var yScaleKeys = chart.y.keys;
|
|
44288
44556
|
var xScaleDataType = chart.x.scale.dataType;
|
|
44289
44557
|
var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);
|
|
44558
|
+
var yScaleKeys = chart.y.keys;
|
|
44290
44559
|
var yScale = useYScale(innerHeight, chart.y.scale);
|
|
44560
|
+
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
44561
|
+
return Number(tick.value);
|
|
44562
|
+
});
|
|
44563
|
+
var yAxisLabels = chart.bars.map(function (legendItem) {
|
|
44564
|
+
var _chart$keys$legendIte, _chart$keys$legendIte2;
|
|
44565
|
+
return (_chart$keys$legendIte = (_chart$keys$legendIte2 = chart.keys[legendItem.yKey]) == null ? void 0 : _chart$keys$legendIte2.keyFormatted) != null ? _chart$keys$legendIte : '';
|
|
44566
|
+
});
|
|
44567
|
+
var ySubLabelPosition = yScale(yTickValues[0]) + margin.left + bottomAxisBaselineShift + bottomOffset + leftOffset;
|
|
44291
44568
|
var innerXScale = React.useMemo(function () {
|
|
44292
44569
|
if (!options.stacked && xScale && 'bandwidth' in xScale) {
|
|
44293
44570
|
return scale.scaleBand({
|
|
@@ -44299,6 +44576,16 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44299
44576
|
return undefined;
|
|
44300
44577
|
}, [xScale, yScaleKeys, options.stacked, xScaleDataType]);
|
|
44301
44578
|
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
44579
|
+
var themeCSS = React.useMemo(function () {
|
|
44580
|
+
return getChartThemeCSS(theme);
|
|
44581
|
+
}, [theme]);
|
|
44582
|
+
var legendTooltipItems = [{
|
|
44583
|
+
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
44584
|
+
return legendItem.yKey;
|
|
44585
|
+
}),
|
|
44586
|
+
legendItems: chart.bars,
|
|
44587
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
44588
|
+
}];
|
|
44302
44589
|
var handleMouseMove = React.useCallback(function (event) {
|
|
44303
44590
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
44304
44591
|
var tooltipData = getTooltipData({
|
|
@@ -44338,19 +44625,6 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44338
44625
|
clickEvent: event
|
|
44339
44626
|
});
|
|
44340
44627
|
}, [onClick, chart.data, xKey]);
|
|
44341
|
-
var themeCSS = React.useMemo(function () {
|
|
44342
|
-
return getChartThemeCSS(theme);
|
|
44343
|
-
}, [theme]);
|
|
44344
|
-
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
44345
|
-
return Number(tick.value);
|
|
44346
|
-
});
|
|
44347
|
-
var legendTooltipItems = [{
|
|
44348
|
-
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
44349
|
-
return legendItem.yKey;
|
|
44350
|
-
}),
|
|
44351
|
-
legendItems: chart.bars,
|
|
44352
|
-
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
44353
|
-
}];
|
|
44354
44628
|
return jsxRuntime.jsxs(React.Fragment, {
|
|
44355
44629
|
children: [jsxRuntime.jsxs(ChartWrapper$1, {
|
|
44356
44630
|
width: width,
|
|
@@ -44376,7 +44650,8 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44376
44650
|
removeStroke: options.removeStroke,
|
|
44377
44651
|
xScaleDataType: xScaleDataType,
|
|
44378
44652
|
xScale: xScale,
|
|
44379
|
-
height: innerHeight
|
|
44653
|
+
height: innerHeight,
|
|
44654
|
+
baselineShift: bottomAxisBaselineShift
|
|
44380
44655
|
}), jsxRuntime.jsx(AxisLeft, {
|
|
44381
44656
|
show: options.axis.showYAxisLabels,
|
|
44382
44657
|
y: chart.y,
|
|
@@ -44398,7 +44673,11 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44398
44673
|
onClick: handleOnBarClick,
|
|
44399
44674
|
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
44400
44675
|
bars: chart.bars,
|
|
44401
|
-
enableHover: enableHover
|
|
44676
|
+
enableHover: enableHover,
|
|
44677
|
+
showDetailedSubGroupingLabels: showDetailedSubGroupingLabels,
|
|
44678
|
+
yAxisLabels: yAxisLabels,
|
|
44679
|
+
yLabelPosition: ySubLabelPosition,
|
|
44680
|
+
labelStyle: themeCSS.labels
|
|
44402
44681
|
}), options.stacked && xScaleKey !== null && jsxRuntime.jsx(BarStacked, {
|
|
44403
44682
|
data: dataFlattened,
|
|
44404
44683
|
keys: chart.y.keys,
|
|
@@ -44428,7 +44707,6 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44428
44707
|
})]
|
|
44429
44708
|
}), options.showLegend && jsxRuntime.jsx(Legend$1, {
|
|
44430
44709
|
items: legendTooltipItems,
|
|
44431
|
-
setVisibleYKeys: function setVisibleYKeys() {},
|
|
44432
44710
|
keys: chart.keys,
|
|
44433
44711
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
44434
44712
|
}), tooltipOpen && tooltipData && xKey && jsxRuntime.jsx(Tooltip$1, {
|
|
@@ -44444,134 +44722,6 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44444
44722
|
})]
|
|
44445
44723
|
});
|
|
44446
44724
|
};
|
|
44447
|
-
function BarGroup(_ref2) {
|
|
44448
|
-
var data = _ref2.data,
|
|
44449
|
-
keys = _ref2.keys,
|
|
44450
|
-
height = _ref2.height,
|
|
44451
|
-
xKey = _ref2.xKey,
|
|
44452
|
-
xScaleDataType = _ref2.xScaleDataType,
|
|
44453
|
-
xScale = _ref2.xScale,
|
|
44454
|
-
innerXScale = _ref2.innerXScale,
|
|
44455
|
-
yScale = _ref2.yScale,
|
|
44456
|
-
_onClick = _ref2.onClick,
|
|
44457
|
-
conditionalFormattingRules = _ref2.conditionalFormattingRules,
|
|
44458
|
-
bars = _ref2.bars,
|
|
44459
|
-
enableHover = _ref2.enableHover;
|
|
44460
|
-
return jsxRuntime.jsx(shape.BarGroup, {
|
|
44461
|
-
data: data,
|
|
44462
|
-
keys: keys,
|
|
44463
|
-
height: height,
|
|
44464
|
-
x0: function x0(d) {
|
|
44465
|
-
var xValue = d[xKey];
|
|
44466
|
-
if (xScaleDataType === 'string') return String(xValue);
|
|
44467
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(String(xValue)) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
44468
|
-
return xValueAdjusted;
|
|
44469
|
-
}
|
|
44470
|
-
// @ts-ignore
|
|
44471
|
-
,
|
|
44472
|
-
x0Scale: xScale
|
|
44473
|
-
// @ts-ignore
|
|
44474
|
-
,
|
|
44475
|
-
x1Scale: innerXScale,
|
|
44476
|
-
yScale: yScale,
|
|
44477
|
-
color: function color() {
|
|
44478
|
-
return '';
|
|
44479
|
-
},
|
|
44480
|
-
children: function children(barGroups) {
|
|
44481
|
-
return barGroups.map(function (barGroup) {
|
|
44482
|
-
return jsxRuntime.jsx(group.Group, {
|
|
44483
|
-
left: barGroup.x0,
|
|
44484
|
-
children: barGroup.bars.map(function (bar) {
|
|
44485
|
-
if (bar.value === null || bar.height < 0 || bar.width < 0) return null;
|
|
44486
|
-
return jsxRuntime.jsx(Bar, {
|
|
44487
|
-
x: bar.x,
|
|
44488
|
-
y: bar.y,
|
|
44489
|
-
width: bar.width,
|
|
44490
|
-
height: bar.height,
|
|
44491
|
-
fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
|
|
44492
|
-
onClick: function onClick(e) {
|
|
44493
|
-
return _onClick(e, barGroup, bar);
|
|
44494
|
-
},
|
|
44495
|
-
enableHover: enableHover
|
|
44496
|
-
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key));
|
|
44497
|
-
})
|
|
44498
|
-
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
44499
|
-
});
|
|
44500
|
-
}
|
|
44501
|
-
});
|
|
44502
|
-
}
|
|
44503
|
-
var BarStacked = function BarStacked(_ref3) {
|
|
44504
|
-
var xScaleDataType = _ref3.xScaleDataType,
|
|
44505
|
-
data = _ref3.data,
|
|
44506
|
-
xScaleKey = _ref3.xScaleKey,
|
|
44507
|
-
yScale = _ref3.yScale,
|
|
44508
|
-
keys = _ref3.keys,
|
|
44509
|
-
bars = _ref3.bars,
|
|
44510
|
-
conditionalFormattingRules = _ref3.conditionalFormattingRules,
|
|
44511
|
-
xScale = _ref3.xScale,
|
|
44512
|
-
height = _ref3.height,
|
|
44513
|
-
width = _ref3.width;
|
|
44514
|
-
return jsxRuntime.jsx(shape.BarStack, {
|
|
44515
|
-
x: function x(d) {
|
|
44516
|
-
var xValue = d[xScaleKey];
|
|
44517
|
-
if (xScaleDataType === 'string') return xValue;
|
|
44518
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
44519
|
-
return xValueAdjusted;
|
|
44520
|
-
},
|
|
44521
|
-
xScale: xScale,
|
|
44522
|
-
yScale: yScale,
|
|
44523
|
-
data: data,
|
|
44524
|
-
keys: keys,
|
|
44525
|
-
color: function color() {
|
|
44526
|
-
return '';
|
|
44527
|
-
},
|
|
44528
|
-
height: height,
|
|
44529
|
-
width: width,
|
|
44530
|
-
offset: "none",
|
|
44531
|
-
children: function children(barStacks) {
|
|
44532
|
-
return barStacks.map(function (barStack) {
|
|
44533
|
-
return barStack.bars.map(function (bar) {
|
|
44534
|
-
if (bar.height < 3) return null;
|
|
44535
|
-
var BAR_PADDING = 1.5;
|
|
44536
|
-
return jsxRuntime.jsx("rect", {
|
|
44537
|
-
x: bar.x,
|
|
44538
|
-
y: bar.y,
|
|
44539
|
-
width: bar.width,
|
|
44540
|
-
height: bar.height - BAR_PADDING,
|
|
44541
|
-
fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
|
|
44542
|
-
rx: BAR_RADIUS
|
|
44543
|
-
}, "bar-stack-" + barStack.index + "-" + bar.index);
|
|
44544
|
-
});
|
|
44545
|
-
});
|
|
44546
|
-
}
|
|
44547
|
-
});
|
|
44548
|
-
};
|
|
44549
|
-
var Bar = function Bar(props) {
|
|
44550
|
-
var _useState = React.useState(props.fill),
|
|
44551
|
-
fillColor = _useState[0],
|
|
44552
|
-
setFillColor = _useState[1];
|
|
44553
|
-
return jsxRuntime.jsx("rect", {
|
|
44554
|
-
x: props.x,
|
|
44555
|
-
y: props.y,
|
|
44556
|
-
width: props.width,
|
|
44557
|
-
height: props.height,
|
|
44558
|
-
fill: fillColor,
|
|
44559
|
-
rx: BAR_RADIUS,
|
|
44560
|
-
onClick: props.onClick,
|
|
44561
|
-
onMouseEnter: function onMouseEnter() {
|
|
44562
|
-
return props.enableHover && setFillColor(lightenColor$2(props.fill, 0.8));
|
|
44563
|
-
},
|
|
44564
|
-
onMouseLeave: function onMouseLeave() {
|
|
44565
|
-
return props.enableHover && setFillColor(props.fill);
|
|
44566
|
-
},
|
|
44567
|
-
className: props.enableHover ? /*#__PURE__*/css$1.css( {
|
|
44568
|
-
name: "4nk3o1-Bar",
|
|
44569
|
-
styles: "cursor:pointer;label:Bar;",
|
|
44570
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AAqaqC","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, FunctionComponent, 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, StackKey } 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            {options.stacked && xScaleKey !== null && (\n              <BarStacked\n                data={dataFlattened}\n                keys={chart.y.keys}\n                yScale={yScale}\n                xScale={xScale}\n                xScaleKey={xScaleKey}\n                xScaleDataType={xScaleDataType}\n                bars={chart.bars}\n                conditionalFormattingRules={chart.conditionalFormattingRules}\n                height={innerHeight}\n                width={innerWidth}\n              />\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\nexport const BarStacked: FunctionComponent<{\n  conditionalFormattingRules: ConditionalFormattingRule[];\n  bars: ShapeDefinition<BarStyles>[];\n  keys?: string[];\n  yScale: ScaleLinear<number, number, never>;\n  xScale: any;\n  xScaleDataType: string;\n  xScaleKey: string;\n  data: DatumObject[];\n  height: number;\n  width: number;\n}> = ({ xScaleDataType, data, xScaleKey, yScale, keys, bars, conditionalFormattingRules, xScale, height, width }) => {\n  return (\n    <BarStack<DatumObject>\n      x={d => {\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      xScale={xScale}\n      yScale={yScale}\n      data={data}\n      keys={keys}\n      color={() => ''}\n      height={height}\n      width={width}\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(bars, conditionalFormattingRules, bar.key as string, bar.bar.data)}\n                rx={BAR_RADIUS}\n              />\n            );\n          })\n        )\n      }\n    </BarStack>\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  enableHover?: boolean;\n}) => {\n  const [fillColor, setFillColor] = useState(props.fill);\n  return (\n    <rect\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"]} */",
|
|
44571
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
44572
|
-
}) : ''
|
|
44573
|
-
});
|
|
44574
|
-
};
|
|
44575
44725
|
|
|
44576
44726
|
var useableId = function useableId(key, prefix) {
|
|
44577
44727
|
var newKey = key.toLowerCase()
|
|
@@ -45272,7 +45422,7 @@ function getStyleDefinition(_ref) {
|
|
|
45272
45422
|
NOTES
|
|
45273
45423
|
-----
|
|
45274
45424
|
- Some logic will be needed here to determine trend and forecasts
|
|
45275
|
-
|
|
45425
|
+
- This will determine the strokeStyle, strokeDasharray, and strokeWidth
|
|
45276
45426
|
*/
|
|
45277
45427
|
|
|
45278
45428
|
return yKeys.map(function (yKey, index) {
|
|
@@ -45662,7 +45812,7 @@ var getTrendsAndForecastsData = function getTrendsAndForecastsData(_ref) {
|
|
|
45662
45812
|
var getGoalLines = function getGoalLines(_ref) {
|
|
45663
45813
|
var goalLineAttributes = _ref.goalLineAttributes,
|
|
45664
45814
|
formattingFunctionY = _ref.formattingFunctionY;
|
|
45665
|
-
return goalLineAttributes
|
|
45815
|
+
return goalLineAttributes.map(function (goalLine) {
|
|
45666
45816
|
return {
|
|
45667
45817
|
value: Number(goalLine.value),
|
|
45668
45818
|
formattedValue: "" + formattingFunctionY(Number(goalLine.value)),
|
|
@@ -45680,8 +45830,6 @@ var getConditionalFormatting = function getConditionalFormatting(_ref) {
|
|
|
45680
45830
|
var _rule$filters;
|
|
45681
45831
|
var firstFilterGroup = (_rule$filters = rule.filters) == null ? void 0 : _rule$filters[0];
|
|
45682
45832
|
var firstFilter = firstFilterGroup == null ? void 0 : firstFilterGroup[0];
|
|
45683
|
-
|
|
45684
|
-
// If either is missing, skip
|
|
45685
45833
|
if (!firstFilter) return;
|
|
45686
45834
|
conditionalFormattingRules.push({
|
|
45687
45835
|
operator: firstFilter.op,
|
|
@@ -45766,7 +45914,8 @@ var getStackedMinAndMax = function getStackedMinAndMax(_ref) {
|
|
|
45766
45914
|
max: Math.max.apply(Math, dataToAnalyse),
|
|
45767
45915
|
min: Math.min.apply(Math, dataToAnalyse)
|
|
45768
45916
|
};
|
|
45769
|
-
}
|
|
45917
|
+
}
|
|
45918
|
+
if (dataType === 'number') {
|
|
45770
45919
|
var _dataToAnalyse = [].concat(data.flatMap(function (dataItem) {
|
|
45771
45920
|
return keys.map(function (key) {
|
|
45772
45921
|
return dataItem[key] ? dataItem[key].value : 0;
|
|
@@ -45778,12 +45927,11 @@ var getStackedMinAndMax = function getStackedMinAndMax(_ref) {
|
|
|
45778
45927
|
max: Math.max.apply(Math, _dataToAnalyse),
|
|
45779
45928
|
min: Math.min.apply(Math, _dataToAnalyse)
|
|
45780
45929
|
};
|
|
45781
|
-
} else {
|
|
45782
|
-
return {
|
|
45783
|
-
max: null,
|
|
45784
|
-
min: null
|
|
45785
|
-
};
|
|
45786
45930
|
}
|
|
45931
|
+
return {
|
|
45932
|
+
max: null,
|
|
45933
|
+
min: null
|
|
45934
|
+
};
|
|
45787
45935
|
};
|
|
45788
45936
|
|
|
45789
45937
|
var DEFAULT_TICK_COUNT = 10;
|
|
@@ -45842,12 +45990,21 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
|
|
|
45842
45990
|
xTicks = data.map(function (dataItem) {
|
|
45843
45991
|
var _dataItem$xKey, _dataItem$xScale$key, _dataItem$xScale$key2;
|
|
45844
45992
|
var xValue = (_dataItem$xKey = dataItem[xKey]) != null && _dataItem$xKey.value ? dataItem[xKey].value : null;
|
|
45845
|
-
var
|
|
45993
|
+
var xFormattedValue = formattingFunctionX(xValue, nullValue);
|
|
45846
45994
|
var xScaleValue = xScale.key !== null && (_dataItem$xScale$key = dataItem[xScale.key]) != null && _dataItem$xScale$key.value ? (_dataItem$xScale$key2 = dataItem[xScale.key]) == null ? void 0 : _dataItem$xScale$key2.value : '';
|
|
45847
|
-
var xScaleValueAdjusted
|
|
45995
|
+
var xScaleValueAdjusted;
|
|
45996
|
+
if (xScale.dataType === 'date_time') {
|
|
45997
|
+
xScaleValueAdjusted = new Date(xScaleValue);
|
|
45998
|
+
} else if (xScale.dataType === 'string') {
|
|
45999
|
+
xScaleValueAdjusted = String(xScaleValue);
|
|
46000
|
+
} else if (xScale.dataType === 'number') {
|
|
46001
|
+
xScaleValueAdjusted = Number(xScaleValue);
|
|
46002
|
+
} else {
|
|
46003
|
+
xScaleValueAdjusted = xScaleValue;
|
|
46004
|
+
}
|
|
45848
46005
|
return {
|
|
45849
46006
|
value: xValue !== null ? xValue : '',
|
|
45850
|
-
formattedValue:
|
|
46007
|
+
formattedValue: xFormattedValue,
|
|
45851
46008
|
scaleValue: xScaleValueAdjusted
|
|
45852
46009
|
};
|
|
45853
46010
|
});
|
|
@@ -50121,6 +50278,7 @@ var BarChartV2View = function BarChartV2View(props) {
|
|
|
50121
50278
|
var theme = useTheme();
|
|
50122
50279
|
var BarChartV2Component = getComponentInterface(props.attributes.type);
|
|
50123
50280
|
var pivotConfig = init$d(props.attributes);
|
|
50281
|
+
var numberOfDimensions = props.attributes.dimension.length;
|
|
50124
50282
|
var chartRepresentation = React.useMemo(function () {
|
|
50125
50283
|
if (!isLoading(props.result) && !hasFailed(props.result) && !isEmpty(props.result) && BarChartV2Component.isRunnable(props.attributes)) {
|
|
50126
50284
|
var _theme$charts$colors, _theme$charts, _props$attributes$goa;
|
|
@@ -50257,7 +50415,8 @@ var BarChartV2View = function BarChartV2View(props) {
|
|
|
50257
50415
|
},
|
|
50258
50416
|
theme: theme == null ? void 0 : theme.charts,
|
|
50259
50417
|
onClick: handleOnClick,
|
|
50260
|
-
enableHover: drilldownEnabled(props.attributes.drilldownOptions) && !drilldownDepthReached(props.drilldownSelections)
|
|
50418
|
+
enableHover: drilldownEnabled(props.attributes.drilldownOptions) && !drilldownDepthReached(props.drilldownSelections),
|
|
50419
|
+
numberOfDimensions: numberOfDimensions
|
|
50261
50420
|
});
|
|
50262
50421
|
}
|
|
50263
50422
|
})
|
|
@@ -50802,7 +50961,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
50802
50961
|
return jsxRuntime.jsx(group.Group, {
|
|
50803
50962
|
left: barGroup.x0,
|
|
50804
50963
|
children: barGroup.bars.map(function (bar) {
|
|
50805
|
-
return jsxRuntime.jsx(Bar$
|
|
50964
|
+
return jsxRuntime.jsx(Bar$2, {
|
|
50806
50965
|
increaseColor: increaseColor,
|
|
50807
50966
|
decreaseColor: decreaseColor,
|
|
50808
50967
|
bar: bar,
|
|
@@ -50839,7 +50998,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
50839
50998
|
})]
|
|
50840
50999
|
});
|
|
50841
51000
|
};
|
|
50842
|
-
var Bar$
|
|
51001
|
+
var Bar$2 = function Bar(_ref4) {
|
|
50843
51002
|
var bar = _ref4.bar,
|
|
50844
51003
|
barGroup = _ref4.barGroup,
|
|
50845
51004
|
yScale = _ref4.yScale,
|
|
@@ -52156,17 +52315,21 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
52156
52315
|
showTooltip = _useTooltip.showTooltip,
|
|
52157
52316
|
_useTooltip$lineLeft = _useTooltip.lineLeft,
|
|
52158
52317
|
lineLeft = _useTooltip$lineLeft === void 0 ? 0 : _useTooltip$lineLeft;
|
|
52318
|
+
var themeCSS = React.useMemo(function () {
|
|
52319
|
+
return getChartThemeCSS(theme);
|
|
52320
|
+
}, [theme]);
|
|
52159
52321
|
var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);
|
|
52160
52322
|
var innerWidth = width - margin.left - margin.right;
|
|
52161
52323
|
var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 40 : 0);
|
|
52162
52324
|
var xKey = chart.x.key;
|
|
52163
52325
|
var xScaleKey = chart.x.scale.key;
|
|
52164
|
-
var yBarKeys = chart.y.barKeys;
|
|
52165
52326
|
var xScaleDataType = chart.x.scale.dataType;
|
|
52166
52327
|
var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.bars.data);
|
|
52328
|
+
var yBarKeys = chart.y.barKeys;
|
|
52167
52329
|
var yScale = useYScale(innerHeight, chart.y.scale);
|
|
52168
|
-
var
|
|
52169
|
-
|
|
52330
|
+
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
52331
|
+
return Number(tick.value);
|
|
52332
|
+
});
|
|
52170
52333
|
var innerXScale = React.useMemo(function () {
|
|
52171
52334
|
if (!options.stacked && xScale && 'bandwidth' in xScale) {
|
|
52172
52335
|
return scale.scaleBand({
|
|
@@ -52177,6 +52340,35 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
52177
52340
|
}
|
|
52178
52341
|
return undefined;
|
|
52179
52342
|
}, [options.stacked, xScale, yBarKeys, xScaleDataType]);
|
|
52343
|
+
var barDataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.bars.data, chart.y.barKeys);
|
|
52344
|
+
var lineDataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.lines.data, (_chart$y$lineKeys = chart.y.lineKeys) != null ? _chart$y$lineKeys : []);
|
|
52345
|
+
var lineOffset = React.useMemo(function () {
|
|
52346
|
+
var barWidths = chart.bars.data.flatMap(function (dataItem) {
|
|
52347
|
+
return yBarKeys.map(function (yKey) {
|
|
52348
|
+
var value = dataItem[yKey];
|
|
52349
|
+
if (value === null || xScale === null || !xScaleKey) return null;
|
|
52350
|
+
return xScale.bandwidth();
|
|
52351
|
+
});
|
|
52352
|
+
}).filter(function (width) {
|
|
52353
|
+
return width !== null;
|
|
52354
|
+
});
|
|
52355
|
+
var calulatedOffset = barWidths[0] / 2;
|
|
52356
|
+
return calulatedOffset;
|
|
52357
|
+
}, [chart.bars.data, yBarKeys, xScale, xScaleKey, xScaleDataType, innerXScale]);
|
|
52358
|
+
var getVisibleYKeys = function getVisibleYKeys(what) {
|
|
52359
|
+
return chart[what].definitions.map(function (legendItem) {
|
|
52360
|
+
return legendItem.yKey;
|
|
52361
|
+
});
|
|
52362
|
+
};
|
|
52363
|
+
var legendTooltipItems = [{
|
|
52364
|
+
visibleYKeys: getVisibleYKeys('bars'),
|
|
52365
|
+
conditionalFormattingRules: chart.bars.conditionalFormattingRules,
|
|
52366
|
+
legendItems: chart.bars.definitions
|
|
52367
|
+
}, {
|
|
52368
|
+
visibleYKeys: getVisibleYKeys('lines'),
|
|
52369
|
+
conditionalFormattingRules: chart.lines.conditionalFormattingRules,
|
|
52370
|
+
legendItems: chart.lines.definitions
|
|
52371
|
+
}];
|
|
52180
52372
|
var handleMouseMove = React.useCallback(function (event) {
|
|
52181
52373
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
52182
52374
|
var barTooltip = getTooltipData({
|
|
@@ -52209,39 +52401,6 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
52209
52401
|
var handleMouseLeave = React.useCallback(function () {
|
|
52210
52402
|
hideTooltip();
|
|
52211
52403
|
}, [hideTooltip]);
|
|
52212
|
-
var themeCSS = React.useMemo(function () {
|
|
52213
|
-
return getChartThemeCSS(theme);
|
|
52214
|
-
}, [theme]);
|
|
52215
|
-
var lineOffset = React.useMemo(function () {
|
|
52216
|
-
var barWidths = chart.bars.data.flatMap(function (dataItem) {
|
|
52217
|
-
return yBarKeys.map(function (yKey) {
|
|
52218
|
-
var value = dataItem[yKey];
|
|
52219
|
-
if (value === null || xScale === null || !xScaleKey) return null;
|
|
52220
|
-
return xScale.bandwidth();
|
|
52221
|
-
});
|
|
52222
|
-
}).filter(function (width) {
|
|
52223
|
-
return width !== null;
|
|
52224
|
-
});
|
|
52225
|
-
var calulatedOffset = barWidths[0] / 2;
|
|
52226
|
-
return calulatedOffset;
|
|
52227
|
-
}, [chart.bars.data, yBarKeys, xScale, xScaleKey, xScaleDataType, innerXScale]);
|
|
52228
|
-
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
52229
|
-
return Number(tick.value);
|
|
52230
|
-
});
|
|
52231
|
-
var visibleYKeys = function visibleYKeys(what) {
|
|
52232
|
-
return chart[what].definitions.map(function (legendItem) {
|
|
52233
|
-
return legendItem.yKey;
|
|
52234
|
-
});
|
|
52235
|
-
};
|
|
52236
|
-
var legendTooltipItems = [{
|
|
52237
|
-
visibleYKeys: visibleYKeys('bars'),
|
|
52238
|
-
conditionalFormattingRules: chart.bars.conditionalFormattingRules,
|
|
52239
|
-
legendItems: chart.bars.definitions
|
|
52240
|
-
}, {
|
|
52241
|
-
visibleYKeys: visibleYKeys('lines'),
|
|
52242
|
-
conditionalFormattingRules: chart.lines.conditionalFormattingRules,
|
|
52243
|
-
legendItems: chart.lines.definitions
|
|
52244
|
-
}];
|
|
52245
52404
|
return jsxRuntime.jsxs(React.Fragment, {
|
|
52246
52405
|
children: [jsxRuntime.jsxs(ChartWrapper$1, {
|
|
52247
52406
|
width: width,
|
|
@@ -52289,7 +52448,10 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
52289
52448
|
bars: chart.bars.definitions,
|
|
52290
52449
|
conditionalFormattingRules: chart.bars.conditionalFormattingRules,
|
|
52291
52450
|
xKey: xScaleKey,
|
|
52292
|
-
xScaleDataType: xScaleDataType
|
|
52451
|
+
xScaleDataType: xScaleDataType,
|
|
52452
|
+
showDetailedSubGroupingLabels: false,
|
|
52453
|
+
yAxisLabels: [],
|
|
52454
|
+
yLabelPosition: 0
|
|
52293
52455
|
}), options.stacked && xScaleKey !== null && jsxRuntime.jsx(BarStacked, {
|
|
52294
52456
|
data: barDataFlattened,
|
|
52295
52457
|
keys: yBarKeys,
|
|
@@ -52308,7 +52470,7 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
52308
52470
|
conditionalFormattingRules: chart.lines.conditionalFormattingRules,
|
|
52309
52471
|
curve: Curves.curveMonotoneX,
|
|
52310
52472
|
yKeys: chart.y.lineKeys,
|
|
52311
|
-
visibleYKeys:
|
|
52473
|
+
visibleYKeys: getVisibleYKeys('lines'),
|
|
52312
52474
|
data: lineDataFlattened,
|
|
52313
52475
|
xScaleKey: xScaleKey,
|
|
52314
52476
|
xScaleDataType: xScaleDataType,
|