@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.
@@ -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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
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 == null ? void 0 : items.map(function (item, index) {
43397
- var _item$legendItems;
43415
+ children: items.map(function (item, index) {
43398
43416
  return jsxRuntime.jsx(React.Fragment, {
43399
- children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem) {
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
- return setVisibleYKeys && setVisibleYKeys(function (prev) {
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 = 8.8;
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: 20,
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
- var AxisBottom = function AxisBottom(_ref) {
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
- 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)."; }
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 margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);
44280
-
44281
- // const [visibleYKeys, setVisibleYKeys] = useState(chart.bars.map((legendItem) => legendItem.yKey));
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 ? 40 : 0);
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
- - This will determind the strokeStyle, strokeDasharray, and strokeWidth
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 == null ? void 0 : goalLineAttributes.map(function (goalLine) {
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
- } else if (dataType === 'number') {
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 xformattedValue = formattingFunctionX(xValue, nullValue);
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 = xScale.dataType === 'date_time' ? new Date(xScaleValue) : xScale.dataType === 'string' ? String(xScaleValue) : xScale.dataType === 'number' ? Number(xScaleValue) : xScaleValue;
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: xformattedValue !== null ? "" + xformattedValue : null,
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$1, {
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$1 = function Bar(_ref4) {
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 barDataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.bars.data, chart.y.barKeys);
52169
- var lineDataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.lines.data, (_chart$y$lineKeys = chart.y.lineKeys) != null ? _chart$y$lineKeys : []);
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: visibleYKeys('lines'),
52473
+ visibleYKeys: getVisibleYKeys('lines'),
52312
52474
  data: lineDataFlattened,
52313
52475
  xScaleKey: xScaleKey,
52314
52476
  xScaleDataType: xScaleDataType,