@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.
@@ -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, BarGroup as BarGroup$2, BarStack as BarStack$1, AreaStack as AreaStack$1, AreaClosed, LineRadial } from '@visx/shape';
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJtQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBMZWdlbmRJdGVtIH0gZnJvbSAnLi9MZWdlbmRJdGVtJztcbmltcG9ydCB7IFNoYXBlRGVmaW5pdGlvbiwgQ29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZSwgS2V5IH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBTY3JvbGxiYXIgfSBmcm9tICcuLi8uLi8uLi9TY3JvbGxiYXIvU2Nyb2xsYmFyJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgTGluZVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvTGluZUNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kUHJvcHM8VD4ge1xuICBzZXRWaXNpYmxlWUtleXM/OiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIGtleXM6IHsgW2tleTogc3RyaW5nXTogS2V5IH07XG4gIG1hcmdpbkxlZnQ6IG51bWJlcjtcbiAgaXRlbXM/OiB7XG4gICAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gICAgdmlzaWJsZVlLZXlzOiBBcnJheTxzdHJpbmc+O1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgfVtdO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBtYXJnaW5MZWZ0LFxuICBpdGVtcyxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2l0ZW1zPy5tYXAoKGl0ZW0sIGluZGV4KSA9PiAoXG4gICAgICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICAgICAge2l0ZW0ubGVnZW5kSXRlbXM/Lm1hcChcbiAgICAgICAgICAgICAgbGVnZW5kSXRlbSA9PlxuICAgICAgICAgICAgICAgIGtleXNbbGVnZW5kSXRlbS55S2V5XSAmJiAoXG4gICAgICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgICAgICB7Li4ubGVnZW5kSXRlbX1cbiAgICAgICAgICAgICAgICAgICAga2V5PXtgbGVnZW5kLSR7bGVnZW5kSXRlbS55S2V5fWB9XG4gICAgICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+XG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzICYmXG4gICAgICAgICAgICAgICAgICAgICAgc2V0VmlzaWJsZVlLZXlzKHByZXYgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAocHJldi5sZW5ndGggPT09IGl0ZW0ubGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFtsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IHByZXYuZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXlcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5ld1Zpc2libGVMZWdlbmRJdGVtcyA9IFsuLi5wcmV2LCBsZWdlbmRJdGVtLnlLZXldO1xuICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBuZXdWaXNpYmxlTGVnZW5kSXRlbXMubGVuZ3RoID09PSAwXG4gICAgICAgICAgICAgICAgICAgICAgICAgID8gaXRlbS5sZWdlbmRJdGVtcy5tYXAobGVnZW5kSXRlbSA9PiBsZWdlbmRJdGVtLnlLZXkpXG4gICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdmlzaWJsZT17c2V0VmlzaWJsZVlLZXlzID8gaXRlbS52aXNpYmxlWUtleXMuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSA6IHRydWV9XG4gICAgICAgICAgICAgICAgICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzPXtpdGVtLmNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICAgICkpfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */"),
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 == null ? void 0 : items.map(function (item, index) {
43449
- var _item$legendItems;
43467
+ children: items.map(function (item, index) {
43450
43468
  return jsx(Fragment, {
43451
- children: (_item$legendItems = item.legendItems) == null ? void 0 : _item$legendItems.map(function (legendItem) {
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
- return setVisibleYKeys && setVisibleYKeys(function (prev) {
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 = 8.8;
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: 20,
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
- var AxisBottom = function AxisBottom(_ref) {
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
- 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)."; }
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 margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);
44335
-
44336
- // const [visibleYKeys, setVisibleYKeys] = useState(chart.bars.map((legendItem) => legendItem.yKey));
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 ? 40 : 0);
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
- - This will determind the strokeStyle, strokeDasharray, and strokeWidth
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 == null ? void 0 : goalLineAttributes.map(function (goalLine) {
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
- } else if (dataType === 'number') {
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 xformattedValue = formattingFunctionX(xValue, nullValue);
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 = xScale.dataType === 'date_time' ? new Date(xScaleValue) : xScale.dataType === 'string' ? String(xScaleValue) : xScale.dataType === 'number' ? Number(xScaleValue) : xScaleValue;
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: xformattedValue !== null ? "" + xformattedValue : null,
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$1, {
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$1 = function Bar(_ref4) {
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 barDataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.bars.data, chart.y.barKeys);
52227
- var lineDataFlattened = useFlattenedData(xScaleKey, xScaleDataType, chart.lines.data, (_chart$y$lineKeys = chart.y.lineKeys) != null ? _chart$y$lineKeys : []);
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: visibleYKeys('lines'),
52531
+ visibleYKeys: getVisibleYKeys('lines'),
52370
52532
  data: lineDataFlattened,
52371
52533
  xScaleKey: xScaleKey,
52372
52534
  xScaleDataType: xScaleDataType,