@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
package/dist/dashboard.esm.js
CHANGED
|
@@ -34,7 +34,7 @@ import { LegendItem as LegendItem$1, LegendLabel } from '@visx/legend';
|
|
|
34
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';
|
|
@@ -43426,6 +43426,25 @@ var Legend$1 = function Legend(_ref) {
|
|
|
43426
43426
|
setVisibleYKeys = _ref.setVisibleYKeys,
|
|
43427
43427
|
marginLeft = _ref.marginLeft,
|
|
43428
43428
|
items = _ref.items;
|
|
43429
|
+
var handleOnClick = function handleOnClick(item, legendItem) {
|
|
43430
|
+
setVisibleYKeys && setVisibleYKeys(function (prev) {
|
|
43431
|
+
var newVisibleLegendItems = [];
|
|
43432
|
+
if (prev.length === item.legendItems.length) {
|
|
43433
|
+
newVisibleLegendItems = [legendItem.yKey];
|
|
43434
|
+
} else {
|
|
43435
|
+
if (prev.includes(legendItem.yKey)) {
|
|
43436
|
+
newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
|
|
43437
|
+
return prevLegendItemId !== legendItem.yKey;
|
|
43438
|
+
});
|
|
43439
|
+
} else {
|
|
43440
|
+
newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
|
|
43441
|
+
}
|
|
43442
|
+
}
|
|
43443
|
+
return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
|
|
43444
|
+
return legendItem.yKey;
|
|
43445
|
+
}) : newVisibleLegendItems;
|
|
43446
|
+
});
|
|
43447
|
+
};
|
|
43429
43448
|
return jsx("div", {
|
|
43430
43449
|
className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
|
|
43431
43450
|
name: "1nbollx",
|
|
@@ -43433,7 +43452,7 @@ var Legend$1 = function Legend(_ref) {
|
|
|
43433
43452
|
} : {
|
|
43434
43453
|
name: "qz6h7j-Legend",
|
|
43435
43454
|
styles: "height:40px;padding-top:8px;label:Legend;",
|
|
43436
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
43455
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0R3QiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG50eXBlIEl0ZW08VD4gPSB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbn1cbmV4cG9ydCB0eXBlIExlZ2VuZFByb3BzPFQ+ID0ge1xuICAgIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAgICBrZXlzOiB7IFtrZXk6IHN0cmluZ106IEtleSB9O1xuICAgIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgICBpdGVtczogSXRlbTxUPltdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAgICBrZXlzLFxuICAgIHNldFZpc2libGVZS2V5cyxcbiAgICBtYXJnaW5MZWZ0LFxuICAgIGl0ZW1zLFxufTogTGVnZW5kUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXM+KSA9PiB7XG4gICAgY29uc3QgaGFuZGxlT25DbGljayA9IChpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPiwgbGVnZW5kSXRlbTogU2hhcGVEZWZpbml0aW9uPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICAgICAgICBzZXRWaXNpYmxlWUtleXMgJiZcbiAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5XG4gICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICA6IG5ld1Zpc2libGVMZWdlbmRJdGVtcztcbiAgICAgICAgICAgIH0pO1xuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgICAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICAgICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgICAgICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgICAgICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICB4PXt0cnVlfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgICAgICAgIDxGcmFnbWVudCBrZXk9e2luZGV4fT5cbiAgICAgICAgICAgICAgICAgICAgICAgIHtpdGVtLmxlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4geyBoYW5kbGVPbkNsaWNrKGl0ZW0sIGxlZ2VuZEl0ZW0pIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2l0ZW0uY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXN9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICAgICkpfVxuICAgICAgICAgICAgPC9TY3JvbGxiYXI+XG4gICAgICAgIDwvZGl2PlxuICAgICk7XG59O1xuIl19 */",
|
|
43437
43456
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
43438
43457
|
}),
|
|
43439
43458
|
children: jsx(Scrollbar, {
|
|
@@ -43443,33 +43462,16 @@ var Legend$1 = function Legend(_ref) {
|
|
|
43443
43462
|
flexWrap: 'nowrap',
|
|
43444
43463
|
alignItems: 'center',
|
|
43445
43464
|
marginLeft: marginLeft ? marginLeft + "px" : undefined
|
|
43446
|
-
}, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
43465
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:Legend;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0QyQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG50eXBlIEl0ZW08VD4gPSB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbn1cbmV4cG9ydCB0eXBlIExlZ2VuZFByb3BzPFQ+ID0ge1xuICAgIHNldFZpc2libGVZS2V5cz86IFJlYWN0LkRpc3BhdGNoPFJlYWN0LlNldFN0YXRlQWN0aW9uPEFycmF5PHN0cmluZz4+PjtcbiAgICBrZXlzOiB7IFtrZXk6IHN0cmluZ106IEtleSB9O1xuICAgIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgICBpdGVtczogSXRlbTxUPltdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAgICBrZXlzLFxuICAgIHNldFZpc2libGVZS2V5cyxcbiAgICBtYXJnaW5MZWZ0LFxuICAgIGl0ZW1zLFxufTogTGVnZW5kUHJvcHM8QmFyU3R5bGVzIHwgTGluZVN0eWxlcyB8IEFyZWFTdHlsZXM+KSA9PiB7XG4gICAgY29uc3QgaGFuZGxlT25DbGljayA9IChpdGVtOiBJdGVtPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPiwgbGVnZW5kSXRlbTogU2hhcGVEZWZpbml0aW9uPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICAgICAgICBzZXRWaXNpYmxlWUtleXMgJiZcbiAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICBsZXQgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2LmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSkpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHByZXZMZWdlbmRJdGVtSWQgPT4gcHJldkxlZ2VuZEl0ZW1JZCAhPT0gbGVnZW5kSXRlbS55S2V5XG4gICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gWy4uLnByZXYsIGxlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICA/IGl0ZW0ubGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICA6IG5ld1Zpc2libGVMZWdlbmRJdGVtcztcbiAgICAgICAgICAgIH0pO1xuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgICAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgICAgICAgICBjbGFzc05hbWU9e2Nzcyh7XG4gICAgICAgICAgICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICAgICAgICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICAgICAgICAgICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgICAgICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgICAgICAgICAgIG1hcmdpbkxlZnQ6IG1hcmdpbkxlZnQgPyBgJHttYXJnaW5MZWZ0fXB4YCA6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgICB4PXt0cnVlfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtpdGVtcy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgICAgICAgIDxGcmFnbWVudCBrZXk9e2luZGV4fT5cbiAgICAgICAgICAgICAgICAgICAgICAgIHtpdGVtLmxlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4geyBoYW5kbGVPbkNsaWNrKGl0ZW0sIGxlZ2VuZEl0ZW0pIH19XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2l0ZW0uY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXN9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgICAgICAgICAgICkpfVxuICAgICAgICAgICAgPC9TY3JvbGxiYXI+XG4gICAgICAgIDwvZGl2PlxuICAgICk7XG59O1xuIl19 */"),
|
|
43447
43466
|
x: true,
|
|
43448
|
-
children: items
|
|
43449
|
-
var _item$legendItems;
|
|
43467
|
+
children: items.map(function (item, index) {
|
|
43450
43468
|
return jsx(Fragment, {
|
|
43451
|
-
children:
|
|
43469
|
+
children: item.legendItems.map(function (legendItem) {
|
|
43452
43470
|
return keys[legendItem.yKey] && createElement$1(LegendItem, _extends({}, legendItem, {
|
|
43453
43471
|
key: "legend-" + legendItem.yKey,
|
|
43454
43472
|
yKeyFormatted: keys[legendItem.yKey].keyFormatted,
|
|
43455
43473
|
onClick: function onClick() {
|
|
43456
|
-
|
|
43457
|
-
var newVisibleLegendItems = [];
|
|
43458
|
-
if (prev.length === item.legendItems.length) {
|
|
43459
|
-
newVisibleLegendItems = [legendItem.yKey];
|
|
43460
|
-
} else {
|
|
43461
|
-
if (prev.includes(legendItem.yKey)) {
|
|
43462
|
-
newVisibleLegendItems = prev.filter(function (prevLegendItemId) {
|
|
43463
|
-
return prevLegendItemId !== legendItem.yKey;
|
|
43464
|
-
});
|
|
43465
|
-
} else {
|
|
43466
|
-
newVisibleLegendItems = [].concat(prev, [legendItem.yKey]);
|
|
43467
|
-
}
|
|
43468
|
-
}
|
|
43469
|
-
return newVisibleLegendItems.length === 0 ? item.legendItems.map(function (legendItem) {
|
|
43470
|
-
return legendItem.yKey;
|
|
43471
|
-
}) : newVisibleLegendItems;
|
|
43472
|
-
});
|
|
43474
|
+
handleOnClick(item, legendItem);
|
|
43473
43475
|
},
|
|
43474
43476
|
visible: setVisibleYKeys ? item.visibleYKeys.includes(legendItem.yKey) : true,
|
|
43475
43477
|
conditionalFormattingRules: item.conditionalFormattingRules
|
|
@@ -43481,11 +43483,8 @@ var Legend$1 = function Legend(_ref) {
|
|
|
43481
43483
|
});
|
|
43482
43484
|
};
|
|
43483
43485
|
|
|
43484
|
-
var ASSUMED_AVERAGE_CHAR_WIDTH =
|
|
43486
|
+
var ASSUMED_AVERAGE_CHAR_WIDTH = 4;
|
|
43485
43487
|
function calculateWordWidth(word, avgCharWidth) {
|
|
43486
|
-
if (avgCharWidth === void 0) {
|
|
43487
|
-
avgCharWidth = ASSUMED_AVERAGE_CHAR_WIDTH;
|
|
43488
|
-
}
|
|
43489
43488
|
return word.length * avgCharWidth;
|
|
43490
43489
|
}
|
|
43491
43490
|
|
|
@@ -43558,7 +43557,10 @@ function adjustTicks(representation, width, height) {
|
|
|
43558
43557
|
return representation;
|
|
43559
43558
|
}
|
|
43560
43559
|
|
|
43561
|
-
var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, hasXAxisTitle) {
|
|
43560
|
+
var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, hasXAxisTitle, showDetailedSubGroupingLabels) {
|
|
43561
|
+
if (showDetailedSubGroupingLabels === void 0) {
|
|
43562
|
+
showDetailedSubGroupingLabels = false;
|
|
43563
|
+
}
|
|
43562
43564
|
var maxWidth = max(yTicks.map(function (tick) {
|
|
43563
43565
|
return (tick.formattedValue || '').length * ASSUMED_AVERAGE_CHAR_WIDTH;
|
|
43564
43566
|
}));
|
|
@@ -43566,13 +43568,14 @@ var buildMargin = function buildMargin(yTicks, showYAxisLabels, hasYAxisTitle, h
|
|
|
43566
43568
|
var MINIMUM_Y_AXIS_WIDTH = 40;
|
|
43567
43569
|
var yAxisTitleOffset = hasYAxisTitle ? 40 : 0;
|
|
43568
43570
|
var xAxisTitleOffset = hasXAxisTitle ? 40 : 0;
|
|
43571
|
+
var bottom = showDetailedSubGroupingLabels ? 90 : 40;
|
|
43569
43572
|
var left = showYTicks ? max([maxWidth, MINIMUM_Y_AXIS_WIDTH]) : MINIMUM_Y_AXIS_WIDTH;
|
|
43570
43573
|
return {
|
|
43571
43574
|
top: 15,
|
|
43572
43575
|
right: MINIMUM_Y_AXIS_WIDTH,
|
|
43573
43576
|
bottom: 30 + xAxisTitleOffset,
|
|
43574
43577
|
left: left + yAxisTitleOffset,
|
|
43575
|
-
bottomTitleOffset:
|
|
43578
|
+
bottomTitleOffset: bottom,
|
|
43576
43579
|
leftTitleOffset: left
|
|
43577
43580
|
};
|
|
43578
43581
|
};
|
|
@@ -43689,7 +43692,7 @@ var AXIS_TITLE_STYLES = {
|
|
|
43689
43692
|
};
|
|
43690
43693
|
|
|
43691
43694
|
var _excluded$e = ["formattedValue"];
|
|
43692
|
-
|
|
43695
|
+
function AxisBottom(_ref) {
|
|
43693
43696
|
var _x$ticks;
|
|
43694
43697
|
var x = _ref.x,
|
|
43695
43698
|
margin = _ref.margin,
|
|
@@ -43698,7 +43701,8 @@ var AxisBottom = function AxisBottom(_ref) {
|
|
|
43698
43701
|
removeStroke = _ref.removeStroke,
|
|
43699
43702
|
xScaleDataType = _ref.xScaleDataType,
|
|
43700
43703
|
xScale = _ref.xScale,
|
|
43701
|
-
height = _ref.height
|
|
43704
|
+
height = _ref.height,
|
|
43705
|
+
baselineShift = _ref.baselineShift;
|
|
43702
43706
|
var tickFormat = useCallback(function (value) {
|
|
43703
43707
|
var tick = null;
|
|
43704
43708
|
if (xScaleDataType === 'date_time' && value instanceof Date) {
|
|
@@ -43741,13 +43745,14 @@ var AxisBottom = function AxisBottom(_ref) {
|
|
|
43741
43745
|
return jsx(Text, _extends({
|
|
43742
43746
|
style: themeCSS.labels
|
|
43743
43747
|
}, tickProps, {
|
|
43748
|
+
baselineShift: baselineShift != null ? baselineShift : tickProps.baselineShift,
|
|
43744
43749
|
children: formattedValue
|
|
43745
43750
|
}));
|
|
43746
43751
|
},
|
|
43747
43752
|
stroke: themeCSS.axis.stroke,
|
|
43748
43753
|
strokeWidth: removeStroke ? 0 : 1
|
|
43749
43754
|
});
|
|
43750
|
-
}
|
|
43755
|
+
}
|
|
43751
43756
|
|
|
43752
43757
|
var _excluded$f = ["formattedValue"];
|
|
43753
43758
|
var AxisLeft = function AxisLeft(_ref) {
|
|
@@ -44250,30 +44255,6 @@ function Lines(_ref2) {
|
|
|
44250
44255
|
});
|
|
44251
44256
|
}
|
|
44252
44257
|
|
|
44253
|
-
function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
44254
|
-
var _bars$find;
|
|
44255
|
-
// Default fill color from the corresponding bar
|
|
44256
|
-
var fill = (_bars$find = bars.find(function (chartBar) {
|
|
44257
|
-
return chartBar.yKey === barKey;
|
|
44258
|
-
})) == null ? void 0 : _bars$find.color;
|
|
44259
|
-
|
|
44260
|
-
// Determine the value based on barValues type
|
|
44261
|
-
var value = typeof barValues === 'number' ? barValues : barValues == null ? void 0 : barValues[barKey];
|
|
44262
|
-
if (typeof value === 'number') {
|
|
44263
|
-
for (var _iterator = _createForOfIteratorHelperLoose(conditionalFormattingRules), _step; !(_step = _iterator()).done;) {
|
|
44264
|
-
var rule = _step.value;
|
|
44265
|
-
if (compare({
|
|
44266
|
-
op: rule.operator,
|
|
44267
|
-
value: rule.value
|
|
44268
|
-
}, value) && rule.yKey === barKey) {
|
|
44269
|
-
fill = rule.color;
|
|
44270
|
-
break;
|
|
44271
|
-
}
|
|
44272
|
-
}
|
|
44273
|
-
}
|
|
44274
|
-
return fill;
|
|
44275
|
-
}
|
|
44276
|
-
|
|
44277
44258
|
var PADDING = {
|
|
44278
44259
|
paddingOuter: 0.05,
|
|
44279
44260
|
paddingInner: 0.3
|
|
@@ -44309,8 +44290,290 @@ function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
|
|
|
44309
44290
|
}, [innerWidth, data]);
|
|
44310
44291
|
}
|
|
44311
44292
|
|
|
44312
|
-
|
|
44293
|
+
var useBottomAxisBaseLineShift = function useBottomAxisBaseLineShift(_ref) {
|
|
44294
|
+
var showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
|
|
44295
|
+
hasBottomTitle = _ref.hasBottomTitle,
|
|
44296
|
+
hasLeftTitle = _ref.hasLeftTitle;
|
|
44297
|
+
if (!showDetailedSubGroupingLabels) {
|
|
44298
|
+
return {
|
|
44299
|
+
bottomAxisBaselineShift: 0,
|
|
44300
|
+
bottomOffset: 0,
|
|
44301
|
+
leftOffset: 0
|
|
44302
|
+
};
|
|
44303
|
+
}
|
|
44304
|
+
return {
|
|
44305
|
+
bottomAxisBaselineShift: hasBottomTitle ? -65 : -60,
|
|
44306
|
+
bottomOffset: hasBottomTitle ? -15 : 10,
|
|
44307
|
+
leftOffset: hasLeftTitle ? -10 : 0
|
|
44308
|
+
};
|
|
44309
|
+
};
|
|
44310
|
+
|
|
44311
|
+
function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
44312
|
+
var _bars$find;
|
|
44313
|
+
// Default fill color from the corresponding bar
|
|
44314
|
+
var fill = (_bars$find = bars.find(function (chartBar) {
|
|
44315
|
+
return chartBar.yKey === barKey;
|
|
44316
|
+
})) == null ? void 0 : _bars$find.color;
|
|
44317
|
+
|
|
44318
|
+
// Determine the value based on barValues type
|
|
44319
|
+
var value = typeof barValues === 'number' ? barValues : barValues == null ? void 0 : barValues[barKey];
|
|
44320
|
+
if (typeof value === 'number') {
|
|
44321
|
+
for (var _iterator = _createForOfIteratorHelperLoose(conditionalFormattingRules), _step; !(_step = _iterator()).done;) {
|
|
44322
|
+
var rule = _step.value;
|
|
44323
|
+
if (compare({
|
|
44324
|
+
op: rule.operator,
|
|
44325
|
+
value: rule.value
|
|
44326
|
+
}, value) && rule.yKey === barKey) {
|
|
44327
|
+
fill = rule.color;
|
|
44328
|
+
break;
|
|
44329
|
+
}
|
|
44330
|
+
}
|
|
44331
|
+
}
|
|
44332
|
+
return fill;
|
|
44333
|
+
}
|
|
44334
|
+
|
|
44313
44335
|
var BAR_RADIUS = 2;
|
|
44336
|
+
|
|
44337
|
+
var BarStacked = function BarStacked(_ref) {
|
|
44338
|
+
var xScaleDataType = _ref.xScaleDataType,
|
|
44339
|
+
data = _ref.data,
|
|
44340
|
+
xScaleKey = _ref.xScaleKey,
|
|
44341
|
+
yScale = _ref.yScale,
|
|
44342
|
+
keys = _ref.keys,
|
|
44343
|
+
bars = _ref.bars,
|
|
44344
|
+
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
44345
|
+
xScale = _ref.xScale,
|
|
44346
|
+
height = _ref.height,
|
|
44347
|
+
width = _ref.width;
|
|
44348
|
+
var handleGetXValue = function handleGetXValue(d) {
|
|
44349
|
+
var xValue = d[xScaleKey];
|
|
44350
|
+
if (xScaleDataType === 'string') return String(xValue);
|
|
44351
|
+
if (xScaleDataType === 'date_time') {
|
|
44352
|
+
return new Date(xValue);
|
|
44353
|
+
}
|
|
44354
|
+
if (xScaleDataType === 'number') {
|
|
44355
|
+
return Number(xValue);
|
|
44356
|
+
}
|
|
44357
|
+
return String(xValue);
|
|
44358
|
+
};
|
|
44359
|
+
return jsx(BarStack$1, {
|
|
44360
|
+
x: handleGetXValue,
|
|
44361
|
+
xScale: xScale,
|
|
44362
|
+
yScale: yScale,
|
|
44363
|
+
data: data,
|
|
44364
|
+
keys: keys,
|
|
44365
|
+
color: function color() {
|
|
44366
|
+
return '';
|
|
44367
|
+
},
|
|
44368
|
+
height: height,
|
|
44369
|
+
width: width,
|
|
44370
|
+
offset: "none",
|
|
44371
|
+
children: function children(barStacks) {
|
|
44372
|
+
return barStacks.map(function (barStack) {
|
|
44373
|
+
return barStack.bars.map(function (bar) {
|
|
44374
|
+
return jsx(Bar, {
|
|
44375
|
+
bar: bar,
|
|
44376
|
+
barStack: barStack,
|
|
44377
|
+
bars: bars,
|
|
44378
|
+
conditionalFormattingRules: conditionalFormattingRules
|
|
44379
|
+
}, bar.key.toString());
|
|
44380
|
+
});
|
|
44381
|
+
});
|
|
44382
|
+
}
|
|
44383
|
+
});
|
|
44384
|
+
};
|
|
44385
|
+
var Bar = function Bar(_ref2) {
|
|
44386
|
+
var bar = _ref2.bar,
|
|
44387
|
+
barStack = _ref2.barStack,
|
|
44388
|
+
bars = _ref2.bars,
|
|
44389
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules;
|
|
44390
|
+
var BAR_PADDING = 1.5;
|
|
44391
|
+
if (bar.height < 3) return null;
|
|
44392
|
+
return jsx("rect", {
|
|
44393
|
+
x: bar.x,
|
|
44394
|
+
y: bar.y,
|
|
44395
|
+
width: bar.width,
|
|
44396
|
+
height: bar.height - BAR_PADDING,
|
|
44397
|
+
fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
|
|
44398
|
+
rx: BAR_RADIUS
|
|
44399
|
+
}, "bar-stack-" + barStack.index + "-" + bar.index);
|
|
44400
|
+
};
|
|
44401
|
+
|
|
44402
|
+
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)."; }
|
|
44403
|
+
function BarGroup(_ref) {
|
|
44404
|
+
var data = _ref.data,
|
|
44405
|
+
keys = _ref.keys,
|
|
44406
|
+
height = _ref.height,
|
|
44407
|
+
xKey = _ref.xKey,
|
|
44408
|
+
xScaleDataType = _ref.xScaleDataType,
|
|
44409
|
+
xScale = _ref.xScale,
|
|
44410
|
+
innerXScale = _ref.innerXScale,
|
|
44411
|
+
yScale = _ref.yScale,
|
|
44412
|
+
onClick = _ref.onClick,
|
|
44413
|
+
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
44414
|
+
bars = _ref.bars,
|
|
44415
|
+
enableHover = _ref.enableHover,
|
|
44416
|
+
yAxisLabels = _ref.yAxisLabels,
|
|
44417
|
+
yLabelPosition = _ref.yLabelPosition,
|
|
44418
|
+
showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
|
|
44419
|
+
labelStyle = _ref.labelStyle;
|
|
44420
|
+
var getGroupPosition = function getGroupPosition(d) {
|
|
44421
|
+
var xValue = d[xKey];
|
|
44422
|
+
if (xScaleDataType === 'string') return String(xValue);
|
|
44423
|
+
if (xScaleDataType === 'date_time') {
|
|
44424
|
+
return new Date(String(xValue));
|
|
44425
|
+
}
|
|
44426
|
+
if (xScaleDataType === 'number') {
|
|
44427
|
+
return Number(xValue);
|
|
44428
|
+
}
|
|
44429
|
+
return String(xValue);
|
|
44430
|
+
};
|
|
44431
|
+
return jsx(BarGroup$2, {
|
|
44432
|
+
data: data,
|
|
44433
|
+
keys: keys,
|
|
44434
|
+
height: height,
|
|
44435
|
+
x0: getGroupPosition
|
|
44436
|
+
// @ts-ignore
|
|
44437
|
+
,
|
|
44438
|
+
x0Scale: xScale
|
|
44439
|
+
// @ts-ignore
|
|
44440
|
+
,
|
|
44441
|
+
x1Scale: innerXScale,
|
|
44442
|
+
yScale: yScale,
|
|
44443
|
+
color: function color() {
|
|
44444
|
+
return '';
|
|
44445
|
+
},
|
|
44446
|
+
children: function children(barGroups) {
|
|
44447
|
+
return barGroups.map(function (barGroup) {
|
|
44448
|
+
return jsx(Group$2, {
|
|
44449
|
+
left: barGroup.x0,
|
|
44450
|
+
children: barGroup.bars.map(function (bar) {
|
|
44451
|
+
return jsx(Bar$1, {
|
|
44452
|
+
bar: bar,
|
|
44453
|
+
barGroup: barGroup,
|
|
44454
|
+
bars: bars,
|
|
44455
|
+
conditionalFormattingRules: conditionalFormattingRules,
|
|
44456
|
+
enableHover: enableHover,
|
|
44457
|
+
labelStyle: labelStyle,
|
|
44458
|
+
onClick: onClick,
|
|
44459
|
+
showDetailedSubGroupingLabels: showDetailedSubGroupingLabels,
|
|
44460
|
+
yAxisLabels: yAxisLabels,
|
|
44461
|
+
yLabelPosition: yLabelPosition
|
|
44462
|
+
}, "bar-" + bar.index + "-" + bar.x);
|
|
44463
|
+
})
|
|
44464
|
+
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
44465
|
+
});
|
|
44466
|
+
}
|
|
44467
|
+
});
|
|
44468
|
+
}
|
|
44469
|
+
var Bar$1 = function Bar(_ref2) {
|
|
44470
|
+
var bar = _ref2.bar,
|
|
44471
|
+
barGroup = _ref2.barGroup,
|
|
44472
|
+
bars = _ref2.bars,
|
|
44473
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules,
|
|
44474
|
+
enableHover = _ref2.enableHover,
|
|
44475
|
+
labelStyle = _ref2.labelStyle,
|
|
44476
|
+
_onClick = _ref2.onClick,
|
|
44477
|
+
showDetailedSubGroupingLabels = _ref2.showDetailedSubGroupingLabels,
|
|
44478
|
+
yAxisLabels = _ref2.yAxisLabels,
|
|
44479
|
+
yLabelPosition = _ref2.yLabelPosition;
|
|
44480
|
+
var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
|
|
44481
|
+
return jsxs(Fragment, {
|
|
44482
|
+
children: [showBar && jsx(BarRect, {
|
|
44483
|
+
x: bar.x,
|
|
44484
|
+
y: bar.y,
|
|
44485
|
+
width: bar.width,
|
|
44486
|
+
height: bar.height,
|
|
44487
|
+
fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
|
|
44488
|
+
onClick: function onClick(e) {
|
|
44489
|
+
return _onClick(e, barGroup, bar);
|
|
44490
|
+
},
|
|
44491
|
+
enableHover: enableHover
|
|
44492
|
+
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key)), jsx(BarLabel, {
|
|
44493
|
+
bar: bar,
|
|
44494
|
+
barGroup: barGroup,
|
|
44495
|
+
yLabelPosition: yLabelPosition,
|
|
44496
|
+
yAxisLabels: yAxisLabels,
|
|
44497
|
+
showDetailedSubGroupingLabels: showDetailedSubGroupingLabels,
|
|
44498
|
+
labelStyle: labelStyle
|
|
44499
|
+
})]
|
|
44500
|
+
});
|
|
44501
|
+
};
|
|
44502
|
+
var BarRect = function BarRect(_ref3) {
|
|
44503
|
+
var onClick = _ref3.onClick,
|
|
44504
|
+
fill = _ref3.fill,
|
|
44505
|
+
x = _ref3.x,
|
|
44506
|
+
y = _ref3.y,
|
|
44507
|
+
width = _ref3.width,
|
|
44508
|
+
height = _ref3.height,
|
|
44509
|
+
key = _ref3.key,
|
|
44510
|
+
enableHover = _ref3.enableHover;
|
|
44511
|
+
var _useState = useState(fill),
|
|
44512
|
+
fillColor = _useState[0],
|
|
44513
|
+
setFillColor = _useState[1];
|
|
44514
|
+
var classes = enableHover ? /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
|
|
44515
|
+
name: "e0dnmk",
|
|
44516
|
+
styles: "cursor:pointer"
|
|
44517
|
+
} : {
|
|
44518
|
+
name: "1ltmijl-classes",
|
|
44519
|
+
styles: "cursor:pointer;label:classes;",
|
|
44520
|
+
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}"]} */",
|
|
44521
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
44522
|
+
}) : '';
|
|
44523
|
+
var handleOnMouseEnter = function handleOnMouseEnter() {
|
|
44524
|
+
if (enableHover) {
|
|
44525
|
+
setFillColor(lightenColor$2(fill, 0.8));
|
|
44526
|
+
}
|
|
44527
|
+
};
|
|
44528
|
+
var handleOnMouseLeave = function handleOnMouseLeave() {
|
|
44529
|
+
if (enableHover) {
|
|
44530
|
+
setFillColor(fill);
|
|
44531
|
+
}
|
|
44532
|
+
};
|
|
44533
|
+
return jsx("rect", {
|
|
44534
|
+
x: x,
|
|
44535
|
+
y: y,
|
|
44536
|
+
width: width,
|
|
44537
|
+
height: height,
|
|
44538
|
+
fill: fillColor,
|
|
44539
|
+
rx: BAR_RADIUS,
|
|
44540
|
+
onClick: onClick,
|
|
44541
|
+
onMouseEnter: handleOnMouseEnter,
|
|
44542
|
+
onMouseLeave: handleOnMouseLeave,
|
|
44543
|
+
className: classes
|
|
44544
|
+
}, key);
|
|
44545
|
+
};
|
|
44546
|
+
var BarLabel = function BarLabel(_ref4) {
|
|
44547
|
+
var bar = _ref4.bar,
|
|
44548
|
+
barGroup = _ref4.barGroup,
|
|
44549
|
+
yLabelPosition = _ref4.yLabelPosition,
|
|
44550
|
+
yAxisLabels = _ref4.yAxisLabels,
|
|
44551
|
+
showDetailedSubGroupingLabels = _ref4.showDetailedSubGroupingLabels,
|
|
44552
|
+
labelStyle = _ref4.labelStyle;
|
|
44553
|
+
if (!showDetailedSubGroupingLabels || !yLabelPosition || !yAxisLabels) return null;
|
|
44554
|
+
var label = yAxisLabels[bar.index];
|
|
44555
|
+
var columnLabel = label.split('•')[0];
|
|
44556
|
+
var formattedColumnLabel;
|
|
44557
|
+
if (columnLabel.length >= 13) {
|
|
44558
|
+
formattedColumnLabel = columnLabel.slice(0, 10) + '...';
|
|
44559
|
+
} else {
|
|
44560
|
+
formattedColumnLabel = columnLabel.slice(0, 13);
|
|
44561
|
+
}
|
|
44562
|
+
var labelXGap = 4;
|
|
44563
|
+
var labelXPosition = bar.x + bar.width / 2 + labelXGap;
|
|
44564
|
+
var labelYGap = 15;
|
|
44565
|
+
var labelYPosition = yLabelPosition + labelYGap;
|
|
44566
|
+
var labelKey = "label-" + barGroup.index + "-" + bar.index + "-" + label;
|
|
44567
|
+
return jsx("text", {
|
|
44568
|
+
x: labelXPosition,
|
|
44569
|
+
y: labelYPosition,
|
|
44570
|
+
style: labelStyle,
|
|
44571
|
+
transform: "rotate(-70, " + labelXPosition + ", " + labelYPosition + ")",
|
|
44572
|
+
textAnchor: "end",
|
|
44573
|
+
children: formattedColumnLabel
|
|
44574
|
+
}, labelKey);
|
|
44575
|
+
};
|
|
44576
|
+
|
|
44314
44577
|
var BarChart$5 = function BarChart(_ref) {
|
|
44315
44578
|
var _theme$axis;
|
|
44316
44579
|
var chart = _ref.chart,
|
|
@@ -44319,7 +44582,8 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44319
44582
|
options = _ref.options,
|
|
44320
44583
|
theme = _ref.theme,
|
|
44321
44584
|
onClick = _ref.onClick,
|
|
44322
|
-
enableHover = _ref.enableHover
|
|
44585
|
+
enableHover = _ref.enableHover,
|
|
44586
|
+
numberOfDimensions = _ref.numberOfDimensions;
|
|
44323
44587
|
var _useTooltip = useTooltip$1(),
|
|
44324
44588
|
tooltipOpen = _useTooltip.tooltipOpen,
|
|
44325
44589
|
_useTooltip$tooltipLe = _useTooltip.tooltipLeft,
|
|
@@ -44331,18 +44595,34 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44331
44595
|
tooltipData = _useTooltip.tooltipData,
|
|
44332
44596
|
hideTooltip = _useTooltip.hideTooltip,
|
|
44333
44597
|
showTooltip = _useTooltip.showTooltip;
|
|
44334
|
-
var
|
|
44335
|
-
|
|
44336
|
-
|
|
44337
|
-
|
|
44598
|
+
var showDetailedSubGroupingLabels = numberOfDimensions === 2 && width > 450;
|
|
44599
|
+
var hasBottomTitle = chart.x.title != null;
|
|
44600
|
+
var hasLeftTitle = chart.y.title != null;
|
|
44601
|
+
var _useBottomAxisBaseLin = useBottomAxisBaseLineShift({
|
|
44602
|
+
hasBottomTitle: hasBottomTitle,
|
|
44603
|
+
hasLeftTitle: hasLeftTitle,
|
|
44604
|
+
showDetailedSubGroupingLabels: showDetailedSubGroupingLabels
|
|
44605
|
+
}),
|
|
44606
|
+
bottomAxisBaselineShift = _useBottomAxisBaseLin.bottomAxisBaselineShift,
|
|
44607
|
+
bottomOffset = _useBottomAxisBaseLin.bottomOffset,
|
|
44608
|
+
leftOffset = _useBottomAxisBaseLin.leftOffset;
|
|
44609
|
+
var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, hasLeftTitle, hasBottomTitle, showDetailedSubGroupingLabels);
|
|
44338
44610
|
var innerWidth = width - margin.left - margin.right;
|
|
44339
|
-
var innerHeight = height - margin.top - margin.bottom - (options.showLegend ?
|
|
44611
|
+
var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 50 : 0) - (showDetailedSubGroupingLabels ? 50 : 0);
|
|
44340
44612
|
var xKey = chart.x.key;
|
|
44341
44613
|
var xScaleKey = chart.x.scale.key;
|
|
44342
|
-
var yScaleKeys = chart.y.keys;
|
|
44343
44614
|
var xScaleDataType = chart.x.scale.dataType;
|
|
44344
44615
|
var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.data);
|
|
44616
|
+
var yScaleKeys = chart.y.keys;
|
|
44345
44617
|
var yScale = useYScale(innerHeight, chart.y.scale);
|
|
44618
|
+
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
44619
|
+
return Number(tick.value);
|
|
44620
|
+
});
|
|
44621
|
+
var yAxisLabels = chart.bars.map(function (legendItem) {
|
|
44622
|
+
var _chart$keys$legendIte, _chart$keys$legendIte2;
|
|
44623
|
+
return (_chart$keys$legendIte = (_chart$keys$legendIte2 = chart.keys[legendItem.yKey]) == null ? void 0 : _chart$keys$legendIte2.keyFormatted) != null ? _chart$keys$legendIte : '';
|
|
44624
|
+
});
|
|
44625
|
+
var ySubLabelPosition = yScale(yTickValues[0]) + margin.left + bottomAxisBaselineShift + bottomOffset + leftOffset;
|
|
44346
44626
|
var innerXScale = useMemo(function () {
|
|
44347
44627
|
if (!options.stacked && xScale && 'bandwidth' in xScale) {
|
|
44348
44628
|
return scaleBand({
|
|
@@ -44354,6 +44634,16 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44354
44634
|
return undefined;
|
|
44355
44635
|
}, [xScale, yScaleKeys, options.stacked, xScaleDataType]);
|
|
44356
44636
|
var dataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.data, chart.y.keys);
|
|
44637
|
+
var themeCSS = useMemo(function () {
|
|
44638
|
+
return getChartThemeCSS(theme);
|
|
44639
|
+
}, [theme]);
|
|
44640
|
+
var legendTooltipItems = [{
|
|
44641
|
+
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
44642
|
+
return legendItem.yKey;
|
|
44643
|
+
}),
|
|
44644
|
+
legendItems: chart.bars,
|
|
44645
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
44646
|
+
}];
|
|
44357
44647
|
var handleMouseMove = useCallback(function (event) {
|
|
44358
44648
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
44359
44649
|
var tooltipData = getTooltipData({
|
|
@@ -44393,19 +44683,6 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44393
44683
|
clickEvent: event
|
|
44394
44684
|
});
|
|
44395
44685
|
}, [onClick, chart.data, xKey]);
|
|
44396
|
-
var themeCSS = useMemo(function () {
|
|
44397
|
-
return getChartThemeCSS(theme);
|
|
44398
|
-
}, [theme]);
|
|
44399
|
-
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
44400
|
-
return Number(tick.value);
|
|
44401
|
-
});
|
|
44402
|
-
var legendTooltipItems = [{
|
|
44403
|
-
visibleYKeys: chart.bars.map(function (legendItem) {
|
|
44404
|
-
return legendItem.yKey;
|
|
44405
|
-
}),
|
|
44406
|
-
legendItems: chart.bars,
|
|
44407
|
-
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
44408
|
-
}];
|
|
44409
44686
|
return jsxs(Fragment, {
|
|
44410
44687
|
children: [jsxs(ChartWrapper$1, {
|
|
44411
44688
|
width: width,
|
|
@@ -44431,7 +44708,8 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44431
44708
|
removeStroke: options.removeStroke,
|
|
44432
44709
|
xScaleDataType: xScaleDataType,
|
|
44433
44710
|
xScale: xScale,
|
|
44434
|
-
height: innerHeight
|
|
44711
|
+
height: innerHeight,
|
|
44712
|
+
baselineShift: bottomAxisBaselineShift
|
|
44435
44713
|
}), jsx(AxisLeft, {
|
|
44436
44714
|
show: options.axis.showYAxisLabels,
|
|
44437
44715
|
y: chart.y,
|
|
@@ -44453,7 +44731,11 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44453
44731
|
onClick: handleOnBarClick,
|
|
44454
44732
|
conditionalFormattingRules: chart.conditionalFormattingRules,
|
|
44455
44733
|
bars: chart.bars,
|
|
44456
|
-
enableHover: enableHover
|
|
44734
|
+
enableHover: enableHover,
|
|
44735
|
+
showDetailedSubGroupingLabels: showDetailedSubGroupingLabels,
|
|
44736
|
+
yAxisLabels: yAxisLabels,
|
|
44737
|
+
yLabelPosition: ySubLabelPosition,
|
|
44738
|
+
labelStyle: themeCSS.labels
|
|
44457
44739
|
}), options.stacked && xScaleKey !== null && jsx(BarStacked, {
|
|
44458
44740
|
data: dataFlattened,
|
|
44459
44741
|
keys: chart.y.keys,
|
|
@@ -44483,7 +44765,6 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44483
44765
|
})]
|
|
44484
44766
|
}), options.showLegend && jsx(Legend$1, {
|
|
44485
44767
|
items: legendTooltipItems,
|
|
44486
|
-
setVisibleYKeys: function setVisibleYKeys() {},
|
|
44487
44768
|
keys: chart.keys,
|
|
44488
44769
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
44489
44770
|
}), tooltipOpen && tooltipData && xKey && jsx(Tooltip$1, {
|
|
@@ -44499,137 +44780,6 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44499
44780
|
})]
|
|
44500
44781
|
});
|
|
44501
44782
|
};
|
|
44502
|
-
function BarGroup(_ref2) {
|
|
44503
|
-
var data = _ref2.data,
|
|
44504
|
-
keys = _ref2.keys,
|
|
44505
|
-
height = _ref2.height,
|
|
44506
|
-
xKey = _ref2.xKey,
|
|
44507
|
-
xScaleDataType = _ref2.xScaleDataType,
|
|
44508
|
-
xScale = _ref2.xScale,
|
|
44509
|
-
innerXScale = _ref2.innerXScale,
|
|
44510
|
-
yScale = _ref2.yScale,
|
|
44511
|
-
_onClick = _ref2.onClick,
|
|
44512
|
-
conditionalFormattingRules = _ref2.conditionalFormattingRules,
|
|
44513
|
-
bars = _ref2.bars,
|
|
44514
|
-
enableHover = _ref2.enableHover;
|
|
44515
|
-
return jsx(BarGroup$2, {
|
|
44516
|
-
data: data,
|
|
44517
|
-
keys: keys,
|
|
44518
|
-
height: height,
|
|
44519
|
-
x0: function x0(d) {
|
|
44520
|
-
var xValue = d[xKey];
|
|
44521
|
-
if (xScaleDataType === 'string') return String(xValue);
|
|
44522
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(String(xValue)) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
44523
|
-
return xValueAdjusted;
|
|
44524
|
-
}
|
|
44525
|
-
// @ts-ignore
|
|
44526
|
-
,
|
|
44527
|
-
x0Scale: xScale
|
|
44528
|
-
// @ts-ignore
|
|
44529
|
-
,
|
|
44530
|
-
x1Scale: innerXScale,
|
|
44531
|
-
yScale: yScale,
|
|
44532
|
-
color: function color() {
|
|
44533
|
-
return '';
|
|
44534
|
-
},
|
|
44535
|
-
children: function children(barGroups) {
|
|
44536
|
-
return barGroups.map(function (barGroup) {
|
|
44537
|
-
return jsx(Group$2, {
|
|
44538
|
-
left: barGroup.x0,
|
|
44539
|
-
children: barGroup.bars.map(function (bar) {
|
|
44540
|
-
if (bar.value === null || bar.height < 0 || bar.width < 0) return null;
|
|
44541
|
-
return jsx(Bar, {
|
|
44542
|
-
x: bar.x,
|
|
44543
|
-
y: bar.y,
|
|
44544
|
-
width: bar.width,
|
|
44545
|
-
height: bar.height,
|
|
44546
|
-
fill: getBarFill(bars, conditionalFormattingRules, String(bar.key), bar.value),
|
|
44547
|
-
onClick: function onClick(e) {
|
|
44548
|
-
return _onClick(e, barGroup, bar);
|
|
44549
|
-
},
|
|
44550
|
-
enableHover: enableHover
|
|
44551
|
-
}, "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key));
|
|
44552
|
-
})
|
|
44553
|
-
}, "bar-group-" + barGroup.index + "-" + barGroup.x0);
|
|
44554
|
-
});
|
|
44555
|
-
}
|
|
44556
|
-
});
|
|
44557
|
-
}
|
|
44558
|
-
var BarStacked = function BarStacked(_ref3) {
|
|
44559
|
-
var xScaleDataType = _ref3.xScaleDataType,
|
|
44560
|
-
data = _ref3.data,
|
|
44561
|
-
xScaleKey = _ref3.xScaleKey,
|
|
44562
|
-
yScale = _ref3.yScale,
|
|
44563
|
-
keys = _ref3.keys,
|
|
44564
|
-
bars = _ref3.bars,
|
|
44565
|
-
conditionalFormattingRules = _ref3.conditionalFormattingRules,
|
|
44566
|
-
xScale = _ref3.xScale,
|
|
44567
|
-
height = _ref3.height,
|
|
44568
|
-
width = _ref3.width;
|
|
44569
|
-
return jsx(BarStack$1, {
|
|
44570
|
-
x: function x(d) {
|
|
44571
|
-
var xValue = d[xScaleKey];
|
|
44572
|
-
if (xScaleDataType === 'string') return xValue;
|
|
44573
|
-
var xValueAdjusted = xScaleDataType === 'date_time' ? new Date(xValue) : xScaleDataType === 'number' ? Number(xValue) : String(xValue);
|
|
44574
|
-
return xValueAdjusted;
|
|
44575
|
-
},
|
|
44576
|
-
xScale: xScale,
|
|
44577
|
-
yScale: yScale,
|
|
44578
|
-
data: data,
|
|
44579
|
-
keys: keys,
|
|
44580
|
-
color: function color() {
|
|
44581
|
-
return '';
|
|
44582
|
-
},
|
|
44583
|
-
height: height,
|
|
44584
|
-
width: width,
|
|
44585
|
-
offset: "none",
|
|
44586
|
-
children: function children(barStacks) {
|
|
44587
|
-
return barStacks.map(function (barStack) {
|
|
44588
|
-
return barStack.bars.map(function (bar) {
|
|
44589
|
-
if (bar.height < 3) return null;
|
|
44590
|
-
var BAR_PADDING = 1.5;
|
|
44591
|
-
return jsx("rect", {
|
|
44592
|
-
x: bar.x,
|
|
44593
|
-
y: bar.y,
|
|
44594
|
-
width: bar.width,
|
|
44595
|
-
height: bar.height - BAR_PADDING,
|
|
44596
|
-
fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
|
|
44597
|
-
rx: BAR_RADIUS
|
|
44598
|
-
}, "bar-stack-" + barStack.index + "-" + bar.index);
|
|
44599
|
-
});
|
|
44600
|
-
});
|
|
44601
|
-
}
|
|
44602
|
-
});
|
|
44603
|
-
};
|
|
44604
|
-
var Bar = function Bar(props) {
|
|
44605
|
-
var _useState = useState(props.fill),
|
|
44606
|
-
fillColor = _useState[0],
|
|
44607
|
-
setFillColor = _useState[1];
|
|
44608
|
-
return jsx("rect", {
|
|
44609
|
-
x: props.x,
|
|
44610
|
-
y: props.y,
|
|
44611
|
-
width: props.width,
|
|
44612
|
-
height: props.height,
|
|
44613
|
-
fill: fillColor,
|
|
44614
|
-
rx: BAR_RADIUS,
|
|
44615
|
-
onClick: props.onClick,
|
|
44616
|
-
onMouseEnter: function onMouseEnter() {
|
|
44617
|
-
return props.enableHover && setFillColor(lightenColor$2(props.fill, 0.8));
|
|
44618
|
-
},
|
|
44619
|
-
onMouseLeave: function onMouseLeave() {
|
|
44620
|
-
return props.enableHover && setFillColor(props.fill);
|
|
44621
|
-
},
|
|
44622
|
-
className: props.enableHover ? /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
|
|
44623
|
-
name: "e0dnmk",
|
|
44624
|
-
styles: "cursor:pointer"
|
|
44625
|
-
} : {
|
|
44626
|
-
name: "4nk3o1-Bar",
|
|
44627
|
-
styles: "cursor:pointer;label:Bar;",
|
|
44628
|
-
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"]} */",
|
|
44629
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
44630
|
-
}) : ''
|
|
44631
|
-
});
|
|
44632
|
-
};
|
|
44633
44783
|
|
|
44634
44784
|
var useableId = function useableId(key, prefix) {
|
|
44635
44785
|
var newKey = key.toLowerCase()
|
|
@@ -45330,7 +45480,7 @@ function getStyleDefinition(_ref) {
|
|
|
45330
45480
|
NOTES
|
|
45331
45481
|
-----
|
|
45332
45482
|
- Some logic will be needed here to determine trend and forecasts
|
|
45333
|
-
|
|
45483
|
+
- This will determine the strokeStyle, strokeDasharray, and strokeWidth
|
|
45334
45484
|
*/
|
|
45335
45485
|
|
|
45336
45486
|
return yKeys.map(function (yKey, index) {
|
|
@@ -45720,7 +45870,7 @@ var getTrendsAndForecastsData = function getTrendsAndForecastsData(_ref) {
|
|
|
45720
45870
|
var getGoalLines = function getGoalLines(_ref) {
|
|
45721
45871
|
var goalLineAttributes = _ref.goalLineAttributes,
|
|
45722
45872
|
formattingFunctionY = _ref.formattingFunctionY;
|
|
45723
|
-
return goalLineAttributes
|
|
45873
|
+
return goalLineAttributes.map(function (goalLine) {
|
|
45724
45874
|
return {
|
|
45725
45875
|
value: Number(goalLine.value),
|
|
45726
45876
|
formattedValue: "" + formattingFunctionY(Number(goalLine.value)),
|
|
@@ -45738,8 +45888,6 @@ var getConditionalFormatting = function getConditionalFormatting(_ref) {
|
|
|
45738
45888
|
var _rule$filters;
|
|
45739
45889
|
var firstFilterGroup = (_rule$filters = rule.filters) == null ? void 0 : _rule$filters[0];
|
|
45740
45890
|
var firstFilter = firstFilterGroup == null ? void 0 : firstFilterGroup[0];
|
|
45741
|
-
|
|
45742
|
-
// If either is missing, skip
|
|
45743
45891
|
if (!firstFilter) return;
|
|
45744
45892
|
conditionalFormattingRules.push({
|
|
45745
45893
|
operator: firstFilter.op,
|
|
@@ -45824,7 +45972,8 @@ var getStackedMinAndMax = function getStackedMinAndMax(_ref) {
|
|
|
45824
45972
|
max: Math.max.apply(Math, dataToAnalyse),
|
|
45825
45973
|
min: Math.min.apply(Math, dataToAnalyse)
|
|
45826
45974
|
};
|
|
45827
|
-
}
|
|
45975
|
+
}
|
|
45976
|
+
if (dataType === 'number') {
|
|
45828
45977
|
var _dataToAnalyse = [].concat(data.flatMap(function (dataItem) {
|
|
45829
45978
|
return keys.map(function (key) {
|
|
45830
45979
|
return dataItem[key] ? dataItem[key].value : 0;
|
|
@@ -45836,12 +45985,11 @@ var getStackedMinAndMax = function getStackedMinAndMax(_ref) {
|
|
|
45836
45985
|
max: Math.max.apply(Math, _dataToAnalyse),
|
|
45837
45986
|
min: Math.min.apply(Math, _dataToAnalyse)
|
|
45838
45987
|
};
|
|
45839
|
-
} else {
|
|
45840
|
-
return {
|
|
45841
|
-
max: null,
|
|
45842
|
-
min: null
|
|
45843
|
-
};
|
|
45844
45988
|
}
|
|
45989
|
+
return {
|
|
45990
|
+
max: null,
|
|
45991
|
+
min: null
|
|
45992
|
+
};
|
|
45845
45993
|
};
|
|
45846
45994
|
|
|
45847
45995
|
var DEFAULT_TICK_COUNT = 10;
|
|
@@ -45900,12 +46048,21 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
|
|
|
45900
46048
|
xTicks = data.map(function (dataItem) {
|
|
45901
46049
|
var _dataItem$xKey, _dataItem$xScale$key, _dataItem$xScale$key2;
|
|
45902
46050
|
var xValue = (_dataItem$xKey = dataItem[xKey]) != null && _dataItem$xKey.value ? dataItem[xKey].value : null;
|
|
45903
|
-
var
|
|
46051
|
+
var xFormattedValue = formattingFunctionX(xValue, nullValue);
|
|
45904
46052
|
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 : '';
|
|
45905
|
-
var xScaleValueAdjusted
|
|
46053
|
+
var xScaleValueAdjusted;
|
|
46054
|
+
if (xScale.dataType === 'date_time') {
|
|
46055
|
+
xScaleValueAdjusted = new Date(xScaleValue);
|
|
46056
|
+
} else if (xScale.dataType === 'string') {
|
|
46057
|
+
xScaleValueAdjusted = String(xScaleValue);
|
|
46058
|
+
} else if (xScale.dataType === 'number') {
|
|
46059
|
+
xScaleValueAdjusted = Number(xScaleValue);
|
|
46060
|
+
} else {
|
|
46061
|
+
xScaleValueAdjusted = xScaleValue;
|
|
46062
|
+
}
|
|
45906
46063
|
return {
|
|
45907
46064
|
value: xValue !== null ? xValue : '',
|
|
45908
|
-
formattedValue:
|
|
46065
|
+
formattedValue: xFormattedValue,
|
|
45909
46066
|
scaleValue: xScaleValueAdjusted
|
|
45910
46067
|
};
|
|
45911
46068
|
});
|
|
@@ -50179,6 +50336,7 @@ var BarChartV2View = function BarChartV2View(props) {
|
|
|
50179
50336
|
var theme = useTheme();
|
|
50180
50337
|
var BarChartV2Component = getComponentInterface(props.attributes.type);
|
|
50181
50338
|
var pivotConfig = init$d(props.attributes);
|
|
50339
|
+
var numberOfDimensions = props.attributes.dimension.length;
|
|
50182
50340
|
var chartRepresentation = useMemo(function () {
|
|
50183
50341
|
if (!isLoading(props.result) && !hasFailed(props.result) && !isEmpty(props.result) && BarChartV2Component.isRunnable(props.attributes)) {
|
|
50184
50342
|
var _theme$charts$colors, _theme$charts, _props$attributes$goa;
|
|
@@ -50315,7 +50473,8 @@ var BarChartV2View = function BarChartV2View(props) {
|
|
|
50315
50473
|
},
|
|
50316
50474
|
theme: theme == null ? void 0 : theme.charts,
|
|
50317
50475
|
onClick: handleOnClick,
|
|
50318
|
-
enableHover: drilldownEnabled(props.attributes.drilldownOptions) && !drilldownDepthReached(props.drilldownSelections)
|
|
50476
|
+
enableHover: drilldownEnabled(props.attributes.drilldownOptions) && !drilldownDepthReached(props.drilldownSelections),
|
|
50477
|
+
numberOfDimensions: numberOfDimensions
|
|
50319
50478
|
});
|
|
50320
50479
|
}
|
|
50321
50480
|
})
|
|
@@ -50860,7 +51019,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
50860
51019
|
return jsx(Group$2, {
|
|
50861
51020
|
left: barGroup.x0,
|
|
50862
51021
|
children: barGroup.bars.map(function (bar) {
|
|
50863
|
-
return jsx(Bar$
|
|
51022
|
+
return jsx(Bar$2, {
|
|
50864
51023
|
increaseColor: increaseColor,
|
|
50865
51024
|
decreaseColor: decreaseColor,
|
|
50866
51025
|
bar: bar,
|
|
@@ -50897,7 +51056,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
50897
51056
|
})]
|
|
50898
51057
|
});
|
|
50899
51058
|
};
|
|
50900
|
-
var Bar$
|
|
51059
|
+
var Bar$2 = function Bar(_ref4) {
|
|
50901
51060
|
var bar = _ref4.bar,
|
|
50902
51061
|
barGroup = _ref4.barGroup,
|
|
50903
51062
|
yScale = _ref4.yScale,
|
|
@@ -52214,17 +52373,21 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
52214
52373
|
showTooltip = _useTooltip.showTooltip,
|
|
52215
52374
|
_useTooltip$lineLeft = _useTooltip.lineLeft,
|
|
52216
52375
|
lineLeft = _useTooltip$lineLeft === void 0 ? 0 : _useTooltip$lineLeft;
|
|
52376
|
+
var themeCSS = useMemo(function () {
|
|
52377
|
+
return getChartThemeCSS(theme);
|
|
52378
|
+
}, [theme]);
|
|
52217
52379
|
var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);
|
|
52218
52380
|
var innerWidth = width - margin.left - margin.right;
|
|
52219
52381
|
var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 40 : 0);
|
|
52220
52382
|
var xKey = chart.x.key;
|
|
52221
52383
|
var xScaleKey = chart.x.scale.key;
|
|
52222
|
-
var yBarKeys = chart.y.barKeys;
|
|
52223
52384
|
var xScaleDataType = chart.x.scale.dataType;
|
|
52224
52385
|
var xScale = useBarXScale(xScaleDataType, innerWidth, xScaleKey, chart.bars.data);
|
|
52386
|
+
var yBarKeys = chart.y.barKeys;
|
|
52225
52387
|
var yScale = useYScale(innerHeight, chart.y.scale);
|
|
52226
|
-
var
|
|
52227
|
-
|
|
52388
|
+
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
52389
|
+
return Number(tick.value);
|
|
52390
|
+
});
|
|
52228
52391
|
var innerXScale = useMemo(function () {
|
|
52229
52392
|
if (!options.stacked && xScale && 'bandwidth' in xScale) {
|
|
52230
52393
|
return scaleBand({
|
|
@@ -52235,6 +52398,35 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
52235
52398
|
}
|
|
52236
52399
|
return undefined;
|
|
52237
52400
|
}, [options.stacked, xScale, yBarKeys, xScaleDataType]);
|
|
52401
|
+
var barDataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.bars.data, chart.y.barKeys);
|
|
52402
|
+
var lineDataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.lines.data, (_chart$y$lineKeys = chart.y.lineKeys) != null ? _chart$y$lineKeys : []);
|
|
52403
|
+
var lineOffset = useMemo(function () {
|
|
52404
|
+
var barWidths = chart.bars.data.flatMap(function (dataItem) {
|
|
52405
|
+
return yBarKeys.map(function (yKey) {
|
|
52406
|
+
var value = dataItem[yKey];
|
|
52407
|
+
if (value === null || xScale === null || !xScaleKey) return null;
|
|
52408
|
+
return xScale.bandwidth();
|
|
52409
|
+
});
|
|
52410
|
+
}).filter(function (width) {
|
|
52411
|
+
return width !== null;
|
|
52412
|
+
});
|
|
52413
|
+
var calulatedOffset = barWidths[0] / 2;
|
|
52414
|
+
return calulatedOffset;
|
|
52415
|
+
}, [chart.bars.data, yBarKeys, xScale, xScaleKey, xScaleDataType, innerXScale]);
|
|
52416
|
+
var getVisibleYKeys = function getVisibleYKeys(what) {
|
|
52417
|
+
return chart[what].definitions.map(function (legendItem) {
|
|
52418
|
+
return legendItem.yKey;
|
|
52419
|
+
});
|
|
52420
|
+
};
|
|
52421
|
+
var legendTooltipItems = [{
|
|
52422
|
+
visibleYKeys: getVisibleYKeys('bars'),
|
|
52423
|
+
conditionalFormattingRules: chart.bars.conditionalFormattingRules,
|
|
52424
|
+
legendItems: chart.bars.definitions
|
|
52425
|
+
}, {
|
|
52426
|
+
visibleYKeys: getVisibleYKeys('lines'),
|
|
52427
|
+
conditionalFormattingRules: chart.lines.conditionalFormattingRules,
|
|
52428
|
+
legendItems: chart.lines.definitions
|
|
52429
|
+
}];
|
|
52238
52430
|
var handleMouseMove = useCallback(function (event) {
|
|
52239
52431
|
if (!xKey || !xScaleKey || xScale === null) return;
|
|
52240
52432
|
var barTooltip = getTooltipData({
|
|
@@ -52267,39 +52459,6 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
52267
52459
|
var handleMouseLeave = useCallback(function () {
|
|
52268
52460
|
hideTooltip();
|
|
52269
52461
|
}, [hideTooltip]);
|
|
52270
|
-
var themeCSS = useMemo(function () {
|
|
52271
|
-
return getChartThemeCSS(theme);
|
|
52272
|
-
}, [theme]);
|
|
52273
|
-
var lineOffset = useMemo(function () {
|
|
52274
|
-
var barWidths = chart.bars.data.flatMap(function (dataItem) {
|
|
52275
|
-
return yBarKeys.map(function (yKey) {
|
|
52276
|
-
var value = dataItem[yKey];
|
|
52277
|
-
if (value === null || xScale === null || !xScaleKey) return null;
|
|
52278
|
-
return xScale.bandwidth();
|
|
52279
|
-
});
|
|
52280
|
-
}).filter(function (width) {
|
|
52281
|
-
return width !== null;
|
|
52282
|
-
});
|
|
52283
|
-
var calulatedOffset = barWidths[0] / 2;
|
|
52284
|
-
return calulatedOffset;
|
|
52285
|
-
}, [chart.bars.data, yBarKeys, xScale, xScaleKey, xScaleDataType, innerXScale]);
|
|
52286
|
-
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
52287
|
-
return Number(tick.value);
|
|
52288
|
-
});
|
|
52289
|
-
var visibleYKeys = function visibleYKeys(what) {
|
|
52290
|
-
return chart[what].definitions.map(function (legendItem) {
|
|
52291
|
-
return legendItem.yKey;
|
|
52292
|
-
});
|
|
52293
|
-
};
|
|
52294
|
-
var legendTooltipItems = [{
|
|
52295
|
-
visibleYKeys: visibleYKeys('bars'),
|
|
52296
|
-
conditionalFormattingRules: chart.bars.conditionalFormattingRules,
|
|
52297
|
-
legendItems: chart.bars.definitions
|
|
52298
|
-
}, {
|
|
52299
|
-
visibleYKeys: visibleYKeys('lines'),
|
|
52300
|
-
conditionalFormattingRules: chart.lines.conditionalFormattingRules,
|
|
52301
|
-
legendItems: chart.lines.definitions
|
|
52302
|
-
}];
|
|
52303
52462
|
return jsxs(Fragment, {
|
|
52304
52463
|
children: [jsxs(ChartWrapper$1, {
|
|
52305
52464
|
width: width,
|
|
@@ -52347,7 +52506,10 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
52347
52506
|
bars: chart.bars.definitions,
|
|
52348
52507
|
conditionalFormattingRules: chart.bars.conditionalFormattingRules,
|
|
52349
52508
|
xKey: xScaleKey,
|
|
52350
|
-
xScaleDataType: xScaleDataType
|
|
52509
|
+
xScaleDataType: xScaleDataType,
|
|
52510
|
+
showDetailedSubGroupingLabels: false,
|
|
52511
|
+
yAxisLabels: [],
|
|
52512
|
+
yLabelPosition: 0
|
|
52351
52513
|
}), options.stacked && xScaleKey !== null && jsx(BarStacked, {
|
|
52352
52514
|
data: barDataFlattened,
|
|
52353
52515
|
keys: yBarKeys,
|
|
@@ -52366,7 +52528,7 @@ var ComboChart$4 = function ComboChart(_ref) {
|
|
|
52366
52528
|
conditionalFormattingRules: chart.lines.conditionalFormattingRules,
|
|
52367
52529
|
curve: curveMonotoneX,
|
|
52368
52530
|
yKeys: chart.y.lineKeys,
|
|
52369
|
-
visibleYKeys:
|
|
52531
|
+
visibleYKeys: getVisibleYKeys('lines'),
|
|
52370
52532
|
data: lineDataFlattened,
|
|
52371
52533
|
xScaleKey: xScaleKey,
|
|
52372
52534
|
xScaleDataType: xScaleDataType,
|