@vizzly/dashboard 0.15.0-dev-ec22f31a049b4f844d3ea606a85bd487c4553b03 → 0.15.0-dev-eee3e3fd0a4936db9e65592ae2ac639fc993b559
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/charts/src/v2/components/Axis/AxisBottom.d.ts +1 -1
- package/dist/charts/src/v2/components/BarChart/BarChart.d.ts +2 -2
- package/dist/charts/src/v2/components/ChartWrapper/ChartWrapper.d.ts +4 -2
- package/dist/charts/src/v2/components/Tooltip/Tooltip.d.ts +2 -1
- package/dist/charts/src/v2/utils/components/BarGroup.d.ts +4 -4
- package/dist/charts/src/v2/utils/components/BarStacked.d.ts +4 -4
- package/dist/dashboard.cjs.development.js +388 -533
- package/dist/dashboard.cjs.production.min.js +1 -1
- package/dist/dashboard.esm.js +389 -534
- package/dist/shared-logic/src/BubbleChart/types.d.ts +7 -0
- package/dist/shared-logic/src/BubbleChartV2/buildBubbleChartRepresentation.d.ts +4 -7
- package/dist/shared-logic/src/BubbleChartV2/getScaleAndTicks.d.ts +4 -3
- package/dist/shared-logic/src/BubbleChartV2/types.d.ts +8 -0
- package/dist/shared-logic/src/PivotConfigForMetricAxis/index.d.ts +3 -0
- package/dist/shared-logic/src/Result/formattedResultToSeriesForMetricAxis.d.ts +25 -0
- package/dist/shared-ui/src/components/BarChartV2/BarChartV2View.d.ts +3 -3
- package/package.json +1 -1
|
@@ -14557,7 +14557,7 @@ var buildDefaults = function buildDefaults(partialFeatureToggles) {
|
|
|
14557
14557
|
};
|
|
14558
14558
|
};
|
|
14559
14559
|
|
|
14560
|
-
var ALL_COMPONENT_TYPES = ['barChart', '
|
|
14560
|
+
var ALL_COMPONENT_TYPES = ['barChart', 'barChartV2', 'horizontalBarChart', 'funnelChart', 'areaChart', 'areaChartV2', 'lineChart', 'lineChartV2', 'comboChartV2', 'scatterChart', 'bubbleChart', 'bubbleChartV2', 'pieChart', 'sunburstChart', 'singleStat', 'dataTable', 'basicTable', 'comboChart', 'mercatorMap', 'progress', 'richText', 'custom', 'waterfallChart', 'radarChart'];
|
|
14561
14561
|
var ALL_VIZZLY_COMPONENT_TYPES = /*#__PURE__*/[].concat(ALL_COMPONENT_TYPES).filter(function (type) {
|
|
14562
14562
|
return type != 'custom';
|
|
14563
14563
|
});
|
|
@@ -43338,7 +43338,9 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
43338
43338
|
xKey = _ref.xKey,
|
|
43339
43339
|
yKeys = _ref.yKeys,
|
|
43340
43340
|
theme = _ref.theme,
|
|
43341
|
-
items = _ref.items
|
|
43341
|
+
items = _ref.items,
|
|
43342
|
+
_ref$shouldShowColorL = _ref.shouldShowColorLegend,
|
|
43343
|
+
shouldShowColorLegend = _ref$shouldShowColorL === void 0 ? true : _ref$shouldShowColorL;
|
|
43342
43344
|
var tooltipRef = React.useRef(null);
|
|
43343
43345
|
var _useState = React.useState({
|
|
43344
43346
|
left: tooltipLeft
|
|
@@ -43387,7 +43389,7 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
43387
43389
|
fontSize: '15px',
|
|
43388
43390
|
width: '100%',
|
|
43389
43391
|
minWidth: MIN_TOOLTIP_WIDTH
|
|
43390
|
-
}, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
43392
|
+
}, ";label:Tooltip;", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA6FqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {tooltipData[legendItem.yKey].formattedValue\n                              ? tooltipData[legendItem.yKey].formattedValue\n                              : tooltipData[legendItem.yKey].value}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */"),
|
|
43391
43393
|
children: (_tooltipData$xKey$for = (_tooltipData$xKey = tooltipData[xKey]) == null ? void 0 : _tooltipData$xKey.formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
|
|
43392
43394
|
}), jsxRuntime.jsx("table", {
|
|
43393
43395
|
cellPadding: 0,
|
|
@@ -43395,7 +43397,7 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
43395
43397
|
className: /*#__PURE__*/css$1.css( {
|
|
43396
43398
|
name: "9a1sa-Tooltip",
|
|
43397
43399
|
styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
|
|
43398
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
43400
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AA4GqB","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, Fragment, useEffect, useRef, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { getColor } from '../../utils';\nimport { LegendItemBox } from '../Legend/LegendItemBox';\nimport { ShapeDefinition, ConditionalFormattingRule, DataItem, Key } from 'shared-logic/src/ChartsV2/types';\nimport { LineStyles } from 'shared-logic/src/LineChartV2/types';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { AreaStyles } from 'shared-logic/src/AreaChartV2/types';\nimport { BubbleStyles } from 'shared-logic/src/BubbleChartV2/types';\nimport { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\n\ninterface TooltipProps<T> {\n  keys: { [key: string]: Key };\n  showRoundedTotal: boolean;\n  tooltipData: {\n    [keyId: string]: DataItem;\n  };\n  tooltipLeft: number;\n  tooltipTop: number;\n  xKey: string;\n  yKeys?: string[];\n  items: {\n    legendItems: Array<ShapeDefinition<T>>;\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    visibleYKeys: string[];\n  }[];\n  theme: CSSProperties;\n  shouldShowColorLegend?: boolean;\n}\n\nexport const Tooltip = ({\n  keys,\n  showRoundedTotal,\n  tooltipData,\n  tooltipLeft,\n  tooltipTop,\n  xKey,\n  yKeys,\n  theme,\n  items,\n  shouldShowColorLegend = true,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles | BubbleStyles>) => {\n  const tooltipRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<{ left: number }>({\n    left: tooltipLeft,\n  });\n\n  useEffect(() => {\n    const adjustTooltipPosition = () => {\n      const tooltipElement = tooltipRef.current;\n\n      if (tooltipElement) {\n        const screenWidth = window.innerWidth;\n\n        const rect = tooltipElement.getBoundingClientRect();\n\n        let width = rect.width;\n\n        if (width < MIN_TOOLTIP_WIDTH) {\n          width = MIN_TOOLTIP_WIDTH;\n        }\n\n        let left = tooltipLeft + TOOLTIP_OFFSET;\n\n        if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {\n          left = tooltipLeft - width - TOOLTIP_OFFSET;\n        }\n\n        setPosition({ left });\n      }\n    };\n\n    adjustTooltipPosition();\n  }, [tooltipLeft]);\n\n  return createPortal(\n    <div\n      ref={tooltipRef}\n      style={{\n        position: 'absolute',\n        left: position.left,\n        top: tooltipTop,\n        zIndex: 2147483647 * 10,\n        ...theme,\n      }}\n    >\n      <div style={{ wordBreak: 'break-all' }}>\n        <div\n          className={css({\n            fontFamily: 'inherit',\n            lineHeight: 'inherit',\n            letterSpacing: 'inherit',\n            fontWeight: 'bold',\n            fontSize: '15px',\n            width: '100%',\n            minWidth: MIN_TOOLTIP_WIDTH,\n          })}\n        >\n          {tooltipData[xKey]?.formattedValue ?? tooltipData[xKey].value}\n        </div>\n        <table\n          cellPadding={0}\n          cellSpacing={0}\n          className={css({\n            margin: '0',\n            borderSpacing: '0',\n            borderCollapse: 'inherit',\n            border: 'none',\n          })}\n        >\n          <tbody>\n            {items.map((item, index) => {\n              return (\n                <Fragment key={index}>\n                  {item.legendItems?.map((legendItem, index) => {\n                    if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {\n                      // yKey could not be found in tooltipData\n                      return null;\n                    }\n                    return (\n                      item.visibleYKeys?.includes(legendItem.yKey) && (\n                        <tr key={`${legendItem.yKey}-${index}-${tooltipData[legendItem.yKey].value}`}>\n                          {shouldShowColorLegend && (\n                            <td\n                              style={{\n                                verticalAlign: 'middle',\n                                padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',\n                                width: 'auto',\n                              }}\n                            >\n                              <LegendItemBox\n                                color={getColor({\n                                  defaultColor: legendItem.color,\n                                  value: tooltipData[legendItem.yKey].value,\n                                  yKey: legendItem.yKey,\n                                  conditionalFormattingRules: item.conditionalFormattingRules ?? [],\n                                })}\n                                style={legendItem.style as LineStyles}\n                                yKey={legendItem.yKey}\n                              />\n                            </td>\n                          )}\n                          <td style={{ padding: '8px 0 0 0' }}>{keys[legendItem.yKey].keyFormatted}</td>\n                          <td style={{ fontWeight: 'bold', padding: '8px 0 0 16px' }}>\n                            {tooltipData[legendItem.yKey].formattedValue\n                              ? tooltipData[legendItem.yKey].formattedValue\n                              : tooltipData[legendItem.yKey].value}\n                          </td>\n                        </tr>\n                      )\n                    );\n                  })}\n                </Fragment>\n              );\n            })}\n\n            {showRoundedTotal && yKeys && (\n              <tr>\n                <td colSpan={2} style={{ padding: '12px 0 0 0' }}>\n                  Rounded Total\n                </td>\n                <td style={{ fontWeight: 'bold', padding: '12px 0 0 16px' }}>\n                  {yKeys.reduce((total, key) => {\n                    return total + Math.round(tooltipData[key].value as number);\n                  }, 0)}\n                </td>\n              </tr>\n            )}\n          </tbody>\n        </table>\n      </div>\n    </div>,\n    document.body,\n  );\n};\n"]} */",
|
|
43399
43401
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
43400
43402
|
}),
|
|
43401
43403
|
children: jsxRuntime.jsxs("tbody", {
|
|
@@ -43409,7 +43411,7 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
43409
43411
|
return null;
|
|
43410
43412
|
}
|
|
43411
43413
|
return ((_item$visibleYKeys = item.visibleYKeys) == null ? void 0 : _item$visibleYKeys.includes(legendItem.yKey)) && jsxRuntime.jsxs("tr", {
|
|
43412
|
-
children: [jsxRuntime.jsx("td", {
|
|
43414
|
+
children: [shouldShowColorLegend && jsxRuntime.jsx("td", {
|
|
43413
43415
|
style: {
|
|
43414
43416
|
verticalAlign: 'middle',
|
|
43415
43417
|
padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
|
|
@@ -43437,7 +43439,7 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
43437
43439
|
},
|
|
43438
43440
|
children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
|
|
43439
43441
|
})]
|
|
43440
|
-
}, legendItem.yKey);
|
|
43442
|
+
}, legendItem.yKey + "-" + index + "-" + tooltipData[legendItem.yKey].value);
|
|
43441
43443
|
})
|
|
43442
43444
|
}, index);
|
|
43443
43445
|
}), showRoundedTotal && yKeys && jsxRuntime.jsxs("tr", {
|
|
@@ -44051,21 +44053,30 @@ var GridRows = function GridRows(_ref) {
|
|
|
44051
44053
|
});
|
|
44052
44054
|
};
|
|
44053
44055
|
|
|
44056
|
+
var _excluded$g = ["children", "width", "height", "showLegend", "onMouseMove", "onMouseLeave"];
|
|
44054
44057
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$8() { 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)."; }
|
|
44055
|
-
var ChartWrapper$1 = function ChartWrapper(
|
|
44056
|
-
|
|
44057
|
-
width
|
|
44058
|
-
height
|
|
44059
|
-
|
|
44060
|
-
|
|
44058
|
+
var ChartWrapper$1 = function ChartWrapper(_ref) {
|
|
44059
|
+
var children = _ref.children,
|
|
44060
|
+
width = _ref.width,
|
|
44061
|
+
height = _ref.height,
|
|
44062
|
+
showLegend = _ref.showLegend,
|
|
44063
|
+
onMouseMove = _ref.onMouseMove,
|
|
44064
|
+
onMouseLeave = _ref.onMouseLeave,
|
|
44065
|
+
svgProps = _objectWithoutPropertiesLoose(_ref, _excluded$g);
|
|
44066
|
+
return jsxRuntime.jsx("svg", _extends({
|
|
44067
|
+
width: width,
|
|
44068
|
+
height: height - (showLegend ? 40 : 0),
|
|
44069
|
+
onMouseMove: onMouseMove,
|
|
44070
|
+
onMouseLeave: onMouseLeave,
|
|
44061
44071
|
className: /*#__PURE__*/css$1.css( {
|
|
44062
44072
|
name: "fx4tbw-ChartWrapper",
|
|
44063
44073
|
styles: "display:block;label:ChartWrapper;",
|
|
44064
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
44074
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxudHlwZSBDaGFydFdyYXBwZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG4gIHNob3dMZWdlbmQ6IGJvb2xlYW47XG4gIG9uTW91c2VNb3ZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG4gIG9uTW91c2VMZWF2ZT86IFJlYWN0Lk1vdXNlRXZlbnRIYW5kbGVyPFNWR1NWR0VsZW1lbnQ+O1xufSAmIFJlYWN0LlNWR1Byb3BzPFNWR1NWR0VsZW1lbnQ+O1xuXG5leHBvcnQgY29uc3QgQ2hhcnRXcmFwcGVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIHNob3dMZWdlbmQsXG4gIG9uTW91c2VNb3ZlLFxuICBvbk1vdXNlTGVhdmUsXG4gIC4uLnN2Z1Byb3BzXG59OiBDaGFydFdyYXBwZXJQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxzdmdcbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIGhlaWdodD17aGVpZ2h0IC0gKHNob3dMZWdlbmQgPyA0MCA6IDApfVxuICAgICAgb25Nb3VzZU1vdmU9e29uTW91c2VNb3ZlfVxuICAgICAgb25Nb3VzZUxlYXZlPXtvbk1vdXNlTGVhdmV9XG4gICAgICBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdibG9jaycgfSl9XG4gICAgICB7Li4uc3ZnUHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvc3ZnPlxuICApO1xufTtcbiJdfQ== */",
|
|
44065
44075
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
|
|
44066
|
-
})
|
|
44067
|
-
|
|
44068
|
-
|
|
44076
|
+
})
|
|
44077
|
+
}, svgProps, {
|
|
44078
|
+
children: children
|
|
44079
|
+
}));
|
|
44069
44080
|
};
|
|
44070
44081
|
|
|
44071
44082
|
var CrosshairCircle = function CrosshairCircle(_ref) {
|
|
@@ -44130,7 +44141,7 @@ var Line = function Line(_ref) {
|
|
|
44130
44141
|
});
|
|
44131
44142
|
};
|
|
44132
44143
|
|
|
44133
|
-
var _excluded$
|
|
44144
|
+
var _excluded$h = ["tooltipOpen"];
|
|
44134
44145
|
function useTooltip$1(initialTooltipState) {
|
|
44135
44146
|
var _useState = React.useState(_extends({
|
|
44136
44147
|
tooltipOpen: false
|
|
@@ -44139,7 +44150,7 @@ function useTooltip$1(initialTooltipState) {
|
|
|
44139
44150
|
setTooltipState = _useState[1];
|
|
44140
44151
|
var showTooltip = React.useCallback(function (showArgs) {
|
|
44141
44152
|
return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
|
|
44142
|
-
var show = _objectWithoutPropertiesLoose(_ref, _excluded$
|
|
44153
|
+
var show = _objectWithoutPropertiesLoose(_ref, _excluded$h);
|
|
44143
44154
|
return _extends({}, showArgs(show), {
|
|
44144
44155
|
tooltipOpen: true
|
|
44145
44156
|
});
|
|
@@ -44471,58 +44482,7 @@ function Lines(_ref2) {
|
|
|
44471
44482
|
});
|
|
44472
44483
|
}
|
|
44473
44484
|
|
|
44474
|
-
var
|
|
44475
|
-
paddingOuter: 0.05,
|
|
44476
|
-
paddingInner: 0.3
|
|
44477
|
-
};
|
|
44478
|
-
|
|
44479
|
-
function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
|
|
44480
|
-
return React.useMemo(function () {
|
|
44481
|
-
if (xScaleDataType === 'string') {
|
|
44482
|
-
return scale.scaleBand(_extends({
|
|
44483
|
-
range: [0, innerWidth],
|
|
44484
|
-
domain: xScaleKey ? [].concat(data.map(function (d) {
|
|
44485
|
-
return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
|
|
44486
|
-
})) : []
|
|
44487
|
-
}, PADDING));
|
|
44488
|
-
}
|
|
44489
|
-
if (xScaleDataType === 'date_time' && xScaleKey) {
|
|
44490
|
-
return scale.scaleBand(_extends({
|
|
44491
|
-
range: [0, innerWidth],
|
|
44492
|
-
domain: data.map(function (d) {
|
|
44493
|
-
return new Date(d[xScaleKey].value);
|
|
44494
|
-
})
|
|
44495
|
-
}, PADDING));
|
|
44496
|
-
}
|
|
44497
|
-
if (xScaleDataType === 'number' && xScaleKey) {
|
|
44498
|
-
return scale.scaleBand(_extends({
|
|
44499
|
-
range: [0, innerWidth],
|
|
44500
|
-
domain: data.map(function (d) {
|
|
44501
|
-
return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
|
|
44502
|
-
})
|
|
44503
|
-
}, PADDING));
|
|
44504
|
-
}
|
|
44505
|
-
return null;
|
|
44506
|
-
}, [innerWidth, data]);
|
|
44507
|
-
}
|
|
44508
|
-
|
|
44509
|
-
var useBottomAxisBaseLineShift = function useBottomAxisBaseLineShift(_ref) {
|
|
44510
|
-
var showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
|
|
44511
|
-
hasBottomTitle = _ref.hasBottomTitle,
|
|
44512
|
-
hasLeftTitle = _ref.hasLeftTitle;
|
|
44513
|
-
if (!showDetailedSubGroupingLabels) {
|
|
44514
|
-
return {
|
|
44515
|
-
bottomAxisBaselineShift: 0,
|
|
44516
|
-
bottomOffset: 0,
|
|
44517
|
-
leftOffset: 0
|
|
44518
|
-
};
|
|
44519
|
-
}
|
|
44520
|
-
return {
|
|
44521
|
-
bottomAxisBaselineShift: hasBottomTitle ? -65 : -60,
|
|
44522
|
-
bottomOffset: hasBottomTitle ? -15 : 10,
|
|
44523
|
-
leftOffset: hasLeftTitle ? -10 : 0
|
|
44524
|
-
};
|
|
44525
|
-
};
|
|
44485
|
+
var BAR_RADIUS = 2;
|
|
44526
44486
|
|
|
44527
44487
|
function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
44528
44488
|
var _bars$find;
|
|
@@ -44548,73 +44508,6 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
|
44548
44508
|
return fill;
|
|
44549
44509
|
}
|
|
44550
44510
|
|
|
44551
|
-
var BAR_RADIUS = 2;
|
|
44552
|
-
|
|
44553
|
-
var BarStacked = function BarStacked(_ref) {
|
|
44554
|
-
var xScaleDataType = _ref.xScaleDataType,
|
|
44555
|
-
data = _ref.data,
|
|
44556
|
-
xScaleKey = _ref.xScaleKey,
|
|
44557
|
-
yScale = _ref.yScale,
|
|
44558
|
-
keys = _ref.keys,
|
|
44559
|
-
bars = _ref.bars,
|
|
44560
|
-
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
44561
|
-
xScale = _ref.xScale,
|
|
44562
|
-
height = _ref.height,
|
|
44563
|
-
width = _ref.width;
|
|
44564
|
-
var handleGetXValue = function handleGetXValue(d) {
|
|
44565
|
-
var xValue = d[xScaleKey];
|
|
44566
|
-
if (xScaleDataType === 'string') return String(xValue);
|
|
44567
|
-
if (xScaleDataType === 'date_time') {
|
|
44568
|
-
return new Date(xValue);
|
|
44569
|
-
}
|
|
44570
|
-
if (xScaleDataType === 'number') {
|
|
44571
|
-
return Number(xValue);
|
|
44572
|
-
}
|
|
44573
|
-
return String(xValue);
|
|
44574
|
-
};
|
|
44575
|
-
return jsxRuntime.jsx(shape.BarStack, {
|
|
44576
|
-
x: handleGetXValue,
|
|
44577
|
-
xScale: xScale,
|
|
44578
|
-
yScale: yScale,
|
|
44579
|
-
data: data,
|
|
44580
|
-
keys: keys,
|
|
44581
|
-
color: function color() {
|
|
44582
|
-
return '';
|
|
44583
|
-
},
|
|
44584
|
-
height: height,
|
|
44585
|
-
width: width,
|
|
44586
|
-
offset: "none",
|
|
44587
|
-
children: function children(barStacks) {
|
|
44588
|
-
return barStacks.map(function (barStack) {
|
|
44589
|
-
return barStack.bars.map(function (bar) {
|
|
44590
|
-
return jsxRuntime.jsx(Bar, {
|
|
44591
|
-
bar: bar,
|
|
44592
|
-
barStack: barStack,
|
|
44593
|
-
bars: bars,
|
|
44594
|
-
conditionalFormattingRules: conditionalFormattingRules
|
|
44595
|
-
}, bar.key.toString());
|
|
44596
|
-
});
|
|
44597
|
-
});
|
|
44598
|
-
}
|
|
44599
|
-
});
|
|
44600
|
-
};
|
|
44601
|
-
var Bar = function Bar(_ref2) {
|
|
44602
|
-
var bar = _ref2.bar,
|
|
44603
|
-
barStack = _ref2.barStack,
|
|
44604
|
-
bars = _ref2.bars,
|
|
44605
|
-
conditionalFormattingRules = _ref2.conditionalFormattingRules;
|
|
44606
|
-
var BAR_PADDING = 1.5;
|
|
44607
|
-
if (bar.height < 3) return null;
|
|
44608
|
-
return jsxRuntime.jsx("rect", {
|
|
44609
|
-
x: bar.x,
|
|
44610
|
-
y: bar.y,
|
|
44611
|
-
width: bar.width,
|
|
44612
|
-
height: bar.height - BAR_PADDING,
|
|
44613
|
-
fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
|
|
44614
|
-
rx: BAR_RADIUS
|
|
44615
|
-
}, "bar-stack-" + barStack.index + "-" + bar.index);
|
|
44616
|
-
};
|
|
44617
|
-
|
|
44618
44511
|
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)."; }
|
|
44619
44512
|
function BarGroup(_ref) {
|
|
44620
44513
|
var data = _ref.data,
|
|
@@ -44664,7 +44557,7 @@ function BarGroup(_ref) {
|
|
|
44664
44557
|
return jsxRuntime.jsx(group.Group, {
|
|
44665
44558
|
left: barGroup.x0,
|
|
44666
44559
|
children: barGroup.bars.map(function (bar) {
|
|
44667
|
-
return jsxRuntime.jsx(Bar
|
|
44560
|
+
return jsxRuntime.jsx(Bar, {
|
|
44668
44561
|
bar: bar,
|
|
44669
44562
|
barGroup: barGroup,
|
|
44670
44563
|
bars: bars,
|
|
@@ -44682,7 +44575,7 @@ function BarGroup(_ref) {
|
|
|
44682
44575
|
}
|
|
44683
44576
|
});
|
|
44684
44577
|
}
|
|
44685
|
-
var Bar
|
|
44578
|
+
var Bar = function Bar(_ref2) {
|
|
44686
44579
|
var bar = _ref2.bar,
|
|
44687
44580
|
barGroup = _ref2.barGroup,
|
|
44688
44581
|
bars = _ref2.bars,
|
|
@@ -44696,6 +44589,7 @@ var Bar$1 = function Bar(_ref2) {
|
|
|
44696
44589
|
var showBar = bar.value !== null && bar.height > 0 && bar.width > 0;
|
|
44697
44590
|
return jsxRuntime.jsxs(React.Fragment, {
|
|
44698
44591
|
children: [showBar && jsxRuntime.jsx(BarRect, {
|
|
44592
|
+
barRectKey: "bar-group-bar-" + barGroup.index + "-" + bar.index + "-" + bar.value + "-" + String(bar.key),
|
|
44699
44593
|
x: bar.x,
|
|
44700
44594
|
y: bar.y,
|
|
44701
44595
|
width: bar.width,
|
|
@@ -44705,7 +44599,7 @@ var Bar$1 = function Bar(_ref2) {
|
|
|
44705
44599
|
return _onClick(e, barGroup, bar);
|
|
44706
44600
|
},
|
|
44707
44601
|
enableHover: enableHover
|
|
44708
|
-
}
|
|
44602
|
+
}), jsxRuntime.jsx(BarLabel, {
|
|
44709
44603
|
bar: bar,
|
|
44710
44604
|
barGroup: barGroup,
|
|
44711
44605
|
yLabelPosition: yLabelPosition,
|
|
@@ -44722,7 +44616,7 @@ var BarRect = function BarRect(_ref3) {
|
|
|
44722
44616
|
y = _ref3.y,
|
|
44723
44617
|
width = _ref3.width,
|
|
44724
44618
|
height = _ref3.height,
|
|
44725
|
-
|
|
44619
|
+
barRectKey = _ref3.barRectKey,
|
|
44726
44620
|
enableHover = _ref3.enableHover;
|
|
44727
44621
|
var _useState = React.useState(fill),
|
|
44728
44622
|
fillColor = _useState[0],
|
|
@@ -44730,7 +44624,7 @@ var BarRect = function BarRect(_ref3) {
|
|
|
44730
44624
|
var classes = enableHover ? /*#__PURE__*/css$1.css( {
|
|
44731
44625
|
name: "1ltmijl-classes",
|
|
44732
44626
|
styles: "cursor:pointer;label:classes;",
|
|
44733
|
-
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}"]} */",
|
|
44627
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarGroup.tsx"],"names":[],"mappings":"AA4KgC","file":"BarGroup.tsx","sourcesContent":["import { css } from '@emotion/css';\nimport { Group } from '@visx/group';\nimport { BarGroup as VisxBarGroup } from '@visx/shape';\nimport { DatumObject } from '@visx/shape/lib/types';\nimport { ScaleBand, ScaleLinear } from '@visx/vendor/d3-scale';\nimport { Fragment, useState } from 'react';\nimport { BarStyles } from 'shared-logic/src/BarChartV2/types';\nimport { ChartDataDefinition, ConditionalFormattingRule, ShapeDefinition } from 'shared-logic/src/ChartsV2/types';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { BAR_RADIUS } from '../../constants/BORDER_RADIUS';\nimport { getBarFill } from '../getBarFill';\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 && (\n        <BarRect\n          barRectKey={`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      <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  barRectKey: string;\n  enableHover?: boolean;\n};\n\nconst BarRect = ({ onClick, fill, x, y, width, height, barRectKey, enableHover }: 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={barRectKey}\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 (\n    <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  );\n};\n"]} */",
|
|
44734
44628
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
44735
44629
|
}) : '';
|
|
44736
44630
|
var handleOnMouseEnter = function handleOnMouseEnter() {
|
|
@@ -44754,7 +44648,7 @@ var BarRect = function BarRect(_ref3) {
|
|
|
44754
44648
|
onMouseEnter: handleOnMouseEnter,
|
|
44755
44649
|
onMouseLeave: handleOnMouseLeave,
|
|
44756
44650
|
className: classes
|
|
44757
|
-
},
|
|
44651
|
+
}, barRectKey);
|
|
44758
44652
|
};
|
|
44759
44653
|
var BarLabel = function BarLabel(_ref4) {
|
|
44760
44654
|
var bar = _ref4.bar,
|
|
@@ -44787,6 +44681,124 @@ var BarLabel = function BarLabel(_ref4) {
|
|
|
44787
44681
|
}, labelKey);
|
|
44788
44682
|
};
|
|
44789
44683
|
|
|
44684
|
+
var BarStacked = function BarStacked(_ref) {
|
|
44685
|
+
var xScaleDataType = _ref.xScaleDataType,
|
|
44686
|
+
data = _ref.data,
|
|
44687
|
+
xScaleKey = _ref.xScaleKey,
|
|
44688
|
+
yScale = _ref.yScale,
|
|
44689
|
+
keys = _ref.keys,
|
|
44690
|
+
bars = _ref.bars,
|
|
44691
|
+
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
44692
|
+
xScale = _ref.xScale,
|
|
44693
|
+
height = _ref.height,
|
|
44694
|
+
width = _ref.width;
|
|
44695
|
+
var handleGetXValue = function handleGetXValue(d) {
|
|
44696
|
+
var xValue = d[xScaleKey];
|
|
44697
|
+
if (xScaleDataType === 'string') return String(xValue);
|
|
44698
|
+
if (xScaleDataType === 'date_time') {
|
|
44699
|
+
return new Date(xValue);
|
|
44700
|
+
}
|
|
44701
|
+
if (xScaleDataType === 'number') {
|
|
44702
|
+
return Number(xValue);
|
|
44703
|
+
}
|
|
44704
|
+
return String(xValue);
|
|
44705
|
+
};
|
|
44706
|
+
return jsxRuntime.jsx(shape.BarStack, {
|
|
44707
|
+
x: handleGetXValue,
|
|
44708
|
+
xScale: xScale,
|
|
44709
|
+
yScale: yScale,
|
|
44710
|
+
data: data,
|
|
44711
|
+
keys: keys,
|
|
44712
|
+
color: function color() {
|
|
44713
|
+
return '';
|
|
44714
|
+
},
|
|
44715
|
+
height: height,
|
|
44716
|
+
width: width,
|
|
44717
|
+
offset: "none",
|
|
44718
|
+
children: function children(barStacks) {
|
|
44719
|
+
return barStacks.map(function (barStack) {
|
|
44720
|
+
return barStack.bars.map(function (bar) {
|
|
44721
|
+
return jsxRuntime.jsx(Bar$1, {
|
|
44722
|
+
bar: bar,
|
|
44723
|
+
barStack: barStack,
|
|
44724
|
+
bars: bars,
|
|
44725
|
+
conditionalFormattingRules: conditionalFormattingRules
|
|
44726
|
+
}, bar.key.toString() + "-" + bar.index + "-" + bar.x);
|
|
44727
|
+
});
|
|
44728
|
+
});
|
|
44729
|
+
}
|
|
44730
|
+
});
|
|
44731
|
+
};
|
|
44732
|
+
var Bar$1 = function Bar(_ref2) {
|
|
44733
|
+
var bar = _ref2.bar,
|
|
44734
|
+
barStack = _ref2.barStack,
|
|
44735
|
+
bars = _ref2.bars,
|
|
44736
|
+
conditionalFormattingRules = _ref2.conditionalFormattingRules;
|
|
44737
|
+
var BAR_PADDING = 1.5;
|
|
44738
|
+
if (bar.height < 3) return null;
|
|
44739
|
+
return jsxRuntime.jsx("rect", {
|
|
44740
|
+
x: bar.x,
|
|
44741
|
+
y: bar.y,
|
|
44742
|
+
width: bar.width,
|
|
44743
|
+
height: bar.height - BAR_PADDING,
|
|
44744
|
+
fill: getBarFill(bars, conditionalFormattingRules, bar.key, bar.bar.data),
|
|
44745
|
+
rx: BAR_RADIUS
|
|
44746
|
+
}, "bar-stack-" + barStack.index + "-" + bar.index);
|
|
44747
|
+
};
|
|
44748
|
+
|
|
44749
|
+
var useBottomAxisBaseLineShift = function useBottomAxisBaseLineShift(_ref) {
|
|
44750
|
+
var showDetailedSubGroupingLabels = _ref.showDetailedSubGroupingLabels,
|
|
44751
|
+
hasBottomTitle = _ref.hasBottomTitle,
|
|
44752
|
+
hasLeftTitle = _ref.hasLeftTitle;
|
|
44753
|
+
if (!showDetailedSubGroupingLabels) {
|
|
44754
|
+
return {
|
|
44755
|
+
bottomAxisBaselineShift: 0,
|
|
44756
|
+
bottomOffset: 0,
|
|
44757
|
+
leftOffset: 0
|
|
44758
|
+
};
|
|
44759
|
+
}
|
|
44760
|
+
return {
|
|
44761
|
+
bottomAxisBaselineShift: hasBottomTitle ? -65 : -60,
|
|
44762
|
+
bottomOffset: hasBottomTitle ? -15 : 10,
|
|
44763
|
+
leftOffset: hasLeftTitle ? -10 : 0
|
|
44764
|
+
};
|
|
44765
|
+
};
|
|
44766
|
+
|
|
44767
|
+
var PADDING = {
|
|
44768
|
+
paddingOuter: 0.05,
|
|
44769
|
+
paddingInner: 0.3
|
|
44770
|
+
};
|
|
44771
|
+
|
|
44772
|
+
function useBarXScale(xScaleDataType, innerWidth, xScaleKey, data) {
|
|
44773
|
+
return React.useMemo(function () {
|
|
44774
|
+
if (xScaleDataType === 'string') {
|
|
44775
|
+
return scale.scaleBand(_extends({
|
|
44776
|
+
range: [0, innerWidth],
|
|
44777
|
+
domain: xScaleKey ? [].concat(data.map(function (d) {
|
|
44778
|
+
return d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : '';
|
|
44779
|
+
})) : []
|
|
44780
|
+
}, PADDING));
|
|
44781
|
+
}
|
|
44782
|
+
if (xScaleDataType === 'date_time' && xScaleKey) {
|
|
44783
|
+
return scale.scaleBand(_extends({
|
|
44784
|
+
range: [0, innerWidth],
|
|
44785
|
+
domain: data.map(function (d) {
|
|
44786
|
+
return new Date(d[xScaleKey].value);
|
|
44787
|
+
})
|
|
44788
|
+
}, PADDING));
|
|
44789
|
+
}
|
|
44790
|
+
if (xScaleDataType === 'number' && xScaleKey) {
|
|
44791
|
+
return scale.scaleBand(_extends({
|
|
44792
|
+
range: [0, innerWidth],
|
|
44793
|
+
domain: data.map(function (d) {
|
|
44794
|
+
return d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0;
|
|
44795
|
+
})
|
|
44796
|
+
}, PADDING));
|
|
44797
|
+
}
|
|
44798
|
+
return null;
|
|
44799
|
+
}, [innerWidth, data]);
|
|
44800
|
+
}
|
|
44801
|
+
|
|
44790
44802
|
var BarChart$5 = function BarChart(_ref) {
|
|
44791
44803
|
var _theme$axis;
|
|
44792
44804
|
var chart = _ref.chart,
|
|
@@ -44808,7 +44820,7 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44808
44820
|
tooltipData = _useTooltip.tooltipData,
|
|
44809
44821
|
hideTooltip = _useTooltip.hideTooltip,
|
|
44810
44822
|
showTooltip = _useTooltip.showTooltip;
|
|
44811
|
-
var showDetailedSubGroupingLabels = numberOfDimensions === 2 && width > 450;
|
|
44823
|
+
var showDetailedSubGroupingLabels = !options.stacked && numberOfDimensions === 2 && width > 450;
|
|
44812
44824
|
var hasBottomTitle = chart.x.title != null;
|
|
44813
44825
|
var hasLeftTitle = chart.y.title != null;
|
|
44814
44826
|
var _useBottomAxisBaseLin = useBottomAxisBaseLineShift({
|
|
@@ -44821,7 +44833,7 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
44821
44833
|
leftOffset = _useBottomAxisBaseLin.leftOffset;
|
|
44822
44834
|
var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, hasLeftTitle, hasBottomTitle, showDetailedSubGroupingLabels);
|
|
44823
44835
|
var innerWidth = width - margin.left - margin.right;
|
|
44824
|
-
var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 50 : 0) - (showDetailedSubGroupingLabels ? 50 : 0);
|
|
44836
|
+
var innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 50 : 0) - (showDetailedSubGroupingLabels ? 50 : 0) + (options.axis.showXAxisLabels ? 0 : 25);
|
|
44825
44837
|
var xKey = chart.x.key;
|
|
44826
44838
|
var xScaleKey = chart.x.scale.key;
|
|
44827
44839
|
var xScaleDataType = chart.x.scale.dataType;
|
|
@@ -45415,6 +45427,7 @@ function Area(_ref3) {
|
|
|
45415
45427
|
});
|
|
45416
45428
|
}
|
|
45417
45429
|
|
|
45430
|
+
var MAX_BUBBLE_RADIUS = 30;
|
|
45418
45431
|
var BubbleChart$4 = function BubbleChart(_ref) {
|
|
45419
45432
|
var _theme$axis;
|
|
45420
45433
|
var chart = _ref.chart,
|
|
@@ -45436,25 +45449,34 @@ var BubbleChart$4 = function BubbleChart(_ref) {
|
|
|
45436
45449
|
var zValues = chart.z ? chart.data.map(function (d) {
|
|
45437
45450
|
return d[chart.z];
|
|
45438
45451
|
}).map(function (d) {
|
|
45439
|
-
return d.value;
|
|
45452
|
+
return d == null ? void 0 : d.value;
|
|
45440
45453
|
}) : [];
|
|
45441
45454
|
var normaliseArray = function normaliseArray(array, min, max) {
|
|
45442
45455
|
var arrayMin = Math.min.apply(Math, array);
|
|
45443
45456
|
var arrayMax = Math.max.apply(Math, array);
|
|
45457
|
+
if (arrayMin === arrayMax) {
|
|
45458
|
+
return array.map(function () {
|
|
45459
|
+
return min;
|
|
45460
|
+
});
|
|
45461
|
+
}
|
|
45444
45462
|
return array.map(function (value) {
|
|
45445
45463
|
return (value - arrayMin) / (arrayMax - arrayMin) * (max - min) + min;
|
|
45446
45464
|
});
|
|
45447
45465
|
};
|
|
45448
|
-
var scaledSizeValues = normaliseArray(zValues, 5,
|
|
45466
|
+
var scaledSizeValues = normaliseArray(zValues, 5, MAX_BUBBLE_RADIUS);
|
|
45449
45467
|
var margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);
|
|
45450
45468
|
var _useState = React.useState(chart.lines.map(function (legendItem) {
|
|
45451
45469
|
return legendItem.yKey;
|
|
45470
|
+
}).filter(function (yKey) {
|
|
45471
|
+
return yKey !== chart.groupByKey;
|
|
45452
45472
|
})),
|
|
45453
45473
|
visibleYKeys = _useState[0],
|
|
45454
45474
|
setVisibleYKeys = _useState[1];
|
|
45455
45475
|
React.useEffect(function () {
|
|
45456
45476
|
setVisibleYKeys(chart.lines.map(function (legendItem) {
|
|
45457
45477
|
return legendItem.yKey;
|
|
45478
|
+
}).filter(function (yKey) {
|
|
45479
|
+
return yKey !== chart.groupByKey;
|
|
45458
45480
|
}));
|
|
45459
45481
|
return function () {
|
|
45460
45482
|
setVisibleYKeys([]);
|
|
@@ -45480,13 +45502,13 @@ var BubbleChart$4 = function BubbleChart(_ref) {
|
|
|
45480
45502
|
if (xScaleDataType === 'date_time') {
|
|
45481
45503
|
return scale.scaleTime({
|
|
45482
45504
|
range: [0, innerWidth],
|
|
45483
|
-
domain: chart.x.scale.ordering === '
|
|
45505
|
+
domain: chart.x.scale.ordering === 'desc' ? [chart.x.scale.max, chart.x.scale.min] : [chart.x.scale.min, chart.x.scale.max]
|
|
45484
45506
|
});
|
|
45485
45507
|
}
|
|
45486
45508
|
if (xScaleDataType === 'number') {
|
|
45487
45509
|
return scale.scaleLinear({
|
|
45488
45510
|
range: [0, innerWidth],
|
|
45489
|
-
domain: chart.x.scale.ordering === '
|
|
45511
|
+
domain: chart.x.scale.ordering === 'desc' ? [chart.x.scale.max, chart.x.scale.min] : [chart.x.scale.min, chart.x.scale.max],
|
|
45490
45512
|
nice: true
|
|
45491
45513
|
});
|
|
45492
45514
|
}
|
|
@@ -45525,11 +45547,18 @@ var BubbleChart$4 = function BubbleChart(_ref) {
|
|
|
45525
45547
|
var yTickValues = chart.y.ticks.map(function (tick) {
|
|
45526
45548
|
return Number(tick.value);
|
|
45527
45549
|
});
|
|
45528
|
-
var
|
|
45550
|
+
var tooltipItems = [{
|
|
45529
45551
|
legendItems: chart.lines,
|
|
45530
45552
|
visibleYKeys: visibleYKeys,
|
|
45531
45553
|
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
45532
45554
|
}];
|
|
45555
|
+
var legendItems = chart.legend.items.map(function (legendItem) {
|
|
45556
|
+
return {
|
|
45557
|
+
legendItems: [legendItem],
|
|
45558
|
+
visibleYKeys: [legendItem.yKey],
|
|
45559
|
+
conditionalFormattingRules: chart.conditionalFormattingRules
|
|
45560
|
+
};
|
|
45561
|
+
});
|
|
45533
45562
|
return jsxRuntime.jsxs(React__default.Fragment, {
|
|
45534
45563
|
children: [jsxRuntime.jsxs(ChartWrapper$1, {
|
|
45535
45564
|
width: width,
|
|
@@ -45607,20 +45636,20 @@ var BubbleChart$4 = function BubbleChart(_ref) {
|
|
|
45607
45636
|
width: innerWidth
|
|
45608
45637
|
})]
|
|
45609
45638
|
}), options.showLegend && jsxRuntime.jsx(Legend$1, {
|
|
45610
|
-
items:
|
|
45611
|
-
|
|
45612
|
-
keys: chart.keys,
|
|
45639
|
+
items: legendItems,
|
|
45640
|
+
keys: chart.legend.keys,
|
|
45613
45641
|
marginLeft: margin.left - margin.leftTitleOffset
|
|
45614
45642
|
}), tooltipOpen && tooltipData && xKey && jsxRuntime.jsx(Tooltip$1, {
|
|
45615
|
-
items:
|
|
45643
|
+
items: tooltipItems,
|
|
45616
45644
|
tooltipData: tooltipData,
|
|
45617
45645
|
tooltipLeft: tooltipLeft,
|
|
45618
45646
|
tooltipTop: tooltipTop,
|
|
45619
|
-
xKey:
|
|
45647
|
+
xKey: chart.groupByKey,
|
|
45620
45648
|
keys: chart.keys,
|
|
45621
45649
|
yKeys: chart.y.keys,
|
|
45622
45650
|
showRoundedTotal: options.showRoundedTotal,
|
|
45623
|
-
theme: themeCSS.popoverMenus
|
|
45651
|
+
theme: themeCSS.popoverMenus,
|
|
45652
|
+
shouldShowColorLegend: false
|
|
45624
45653
|
})]
|
|
45625
45654
|
});
|
|
45626
45655
|
};
|
|
@@ -45631,6 +45660,9 @@ function Bubbles(_ref2) {
|
|
|
45631
45660
|
xScale = _ref2.xScale,
|
|
45632
45661
|
yScale = _ref2.yScale,
|
|
45633
45662
|
chart = _ref2.chart;
|
|
45663
|
+
var getBubbleColor = function getBubbleColor(index) {
|
|
45664
|
+
return chart.legend.items[index % chart.legend.items.length].color;
|
|
45665
|
+
};
|
|
45634
45666
|
return jsxRuntime.jsx(React.Fragment, {
|
|
45635
45667
|
children: data.map(function (d, index) {
|
|
45636
45668
|
var _ref3, _yScale2;
|
|
@@ -45638,10 +45670,7 @@ function Bubbles(_ref2) {
|
|
|
45638
45670
|
r: d.bubbleSize,
|
|
45639
45671
|
cx: (_ref3 = xScale(d[xScaleKey])) != null ? _ref3 : 0,
|
|
45640
45672
|
cy: (_yScale2 = yScale(d[yKeys[0]])) != null ? _yScale2 : 0,
|
|
45641
|
-
fill:
|
|
45642
|
-
style: {
|
|
45643
|
-
zIndex: -d.bubbleSize
|
|
45644
|
-
}
|
|
45673
|
+
fill: getBubbleColor(index)
|
|
45645
45674
|
}, "bubble_chart_" + index);
|
|
45646
45675
|
})
|
|
45647
45676
|
});
|
|
@@ -45916,6 +45945,21 @@ var RadarChart$2 = function RadarChart(_ref) {
|
|
|
45916
45945
|
});
|
|
45917
45946
|
};
|
|
45918
45947
|
|
|
45948
|
+
var init$d = function init(xMeasure, yMeasure) {
|
|
45949
|
+
return {
|
|
45950
|
+
x: xMeasure.map(function (measure) {
|
|
45951
|
+
return id(measure);
|
|
45952
|
+
}),
|
|
45953
|
+
y: yMeasure.map(function (measure) {
|
|
45954
|
+
return id(measure);
|
|
45955
|
+
}),
|
|
45956
|
+
detailed: {
|
|
45957
|
+
x: xMeasure,
|
|
45958
|
+
y: yMeasure
|
|
45959
|
+
}
|
|
45960
|
+
};
|
|
45961
|
+
};
|
|
45962
|
+
|
|
45919
45963
|
var getStyleDefinition = function getStyleDefinition(_ref) {
|
|
45920
45964
|
var colors = _ref.colors,
|
|
45921
45965
|
yKeys = _ref.yKeys;
|
|
@@ -45994,7 +46038,7 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
|
|
|
45994
46038
|
yKeys = _ref.yKeys,
|
|
45995
46039
|
xScaleDataType = _ref.xScaleDataType,
|
|
45996
46040
|
nullValue = _ref.nullValue,
|
|
45997
|
-
|
|
46041
|
+
approxYAxisLabelCount = _ref.approxYAxisLabelCount,
|
|
45998
46042
|
formattingFunctionX = _ref.formattingFunctionX,
|
|
45999
46043
|
formattingFunctionY = _ref.formattingFunctionY,
|
|
46000
46044
|
order = _ref.order,
|
|
@@ -46011,32 +46055,18 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
|
|
|
46011
46055
|
keys: xScale.key === null ? [] : [xScale.key],
|
|
46012
46056
|
dataType: xScale.dataType
|
|
46013
46057
|
});
|
|
46014
|
-
if (xKey) {
|
|
46015
|
-
xTicks = data.map(function (dataItem) {
|
|
46016
|
-
var _dataItem$xKey, _dataItem$xScale$key, _dataItem$xScale$key2;
|
|
46017
|
-
var xValue = (_dataItem$xKey = dataItem[xKey]) != null && _dataItem$xKey.value ? dataItem[xKey].value : null;
|
|
46018
|
-
var xformattedValue = formattingFunctionX(xValue, nullValue);
|
|
46019
|
-
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 : '';
|
|
46020
|
-
var xScaleValueAdjusted = xScale.dataType === 'date_time' ? new Date(xScaleValue) : xScale.dataType === 'string' ? String(xScaleValue) : xScale.dataType === 'number' ? Number(xScaleValue) : xScaleValue;
|
|
46021
|
-
return {
|
|
46022
|
-
value: xValue !== null ? xValue : '',
|
|
46023
|
-
formattedValue: xformattedValue !== null ? "" + xformattedValue : null,
|
|
46024
|
-
scaleValue: xScaleValueAdjusted
|
|
46025
|
-
};
|
|
46026
|
-
});
|
|
46027
|
-
}
|
|
46028
|
-
// ----- Y Axis ("number") -----
|
|
46029
|
-
|
|
46030
46058
|
var y = getMinAndMax({
|
|
46031
46059
|
data: data,
|
|
46032
46060
|
keys: yKeys,
|
|
46033
46061
|
dataType: 'number',
|
|
46034
46062
|
goalLines: goalLines
|
|
46035
46063
|
});
|
|
46036
|
-
var maxY = y.max ||
|
|
46064
|
+
var maxY = y.max ? y.max * 1.1 : y.max || 1;
|
|
46037
46065
|
var minY = Math.min(y.min || 0, 0);
|
|
46066
|
+
var tickCountYAxis = approxYAxisLabelCount === 'auto' ? 10 : approxYAxisLabelCount;
|
|
46038
46067
|
var yTickInterval = getNiceInterval((maxY - minY) / (tickCountYAxis - 1));
|
|
46039
|
-
|
|
46068
|
+
var i = 0;
|
|
46069
|
+
while (yTickInterval * i <= maxY + yTickInterval) {
|
|
46040
46070
|
var _value = yTickInterval * i;
|
|
46041
46071
|
var formattedValue = formattingFunctionY(_value, nullValue);
|
|
46042
46072
|
yTicks.push({
|
|
@@ -46044,14 +46074,29 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
|
|
|
46044
46074
|
formattedValue: formattedValue,
|
|
46045
46075
|
scaleValue: _value
|
|
46046
46076
|
});
|
|
46077
|
+
i++;
|
|
46078
|
+
}
|
|
46079
|
+
var maxX = x.max ? x.max * 1.05 : x.max || 1;
|
|
46080
|
+
var minX = Math.min(x.min || 0, 0);
|
|
46081
|
+
var xTickInterval = getNiceInterval((maxX - minX) / (10 - 1));
|
|
46082
|
+
i = 0;
|
|
46083
|
+
while (xTickInterval * i <= maxX + xTickInterval) {
|
|
46084
|
+
var _value2 = xTickInterval * i;
|
|
46085
|
+
var _formattedValue = formattingFunctionX(_value2, nullValue);
|
|
46086
|
+
xTicks.push({
|
|
46087
|
+
value: _value2,
|
|
46088
|
+
formattedValue: _formattedValue,
|
|
46089
|
+
scaleValue: _value2
|
|
46090
|
+
});
|
|
46091
|
+
i++;
|
|
46047
46092
|
}
|
|
46048
46093
|
return {
|
|
46049
46094
|
x: {
|
|
46050
46095
|
ticks: xTicks,
|
|
46051
46096
|
scale: {
|
|
46052
46097
|
dataType: xScale.dataType,
|
|
46053
|
-
max:
|
|
46054
|
-
min:
|
|
46098
|
+
max: maxX,
|
|
46099
|
+
min: minX,
|
|
46055
46100
|
key: xScale.key,
|
|
46056
46101
|
ordering: xScale.ordering
|
|
46057
46102
|
}
|
|
@@ -46060,7 +46105,7 @@ var getScaleAndTicks = function getScaleAndTicks(_ref) {
|
|
|
46060
46105
|
ticks: yTicks,
|
|
46061
46106
|
scale: {
|
|
46062
46107
|
dataType: 'number',
|
|
46063
|
-
key:
|
|
46108
|
+
key: yKeys[0],
|
|
46064
46109
|
ordering: 'asc',
|
|
46065
46110
|
max: maxY,
|
|
46066
46111
|
min: minY
|
|
@@ -46098,223 +46143,6 @@ var getGoalLines = function getGoalLines(_ref) {
|
|
|
46098
46143
|
});
|
|
46099
46144
|
};
|
|
46100
46145
|
|
|
46101
|
-
var buildTrendAndForecast = function buildTrendAndForecast(_ref) {
|
|
46102
|
-
var data = _ref.data,
|
|
46103
|
-
forecastUnits = _ref.forecastUnits,
|
|
46104
|
-
xKey = _ref.xKey,
|
|
46105
|
-
yKey = _ref.yKey,
|
|
46106
|
-
timeUnit = _ref.timeUnit,
|
|
46107
|
-
includeForecast = _ref.includeForecast;
|
|
46108
|
-
var forecastKey = yKey + "_forecast";
|
|
46109
|
-
var trendKey = yKey + "_trend";
|
|
46110
|
-
var trendData = [];
|
|
46111
|
-
var forecastData = [];
|
|
46112
|
-
var values = data.map(function (point) {
|
|
46113
|
-
return Number(point[yKey].value);
|
|
46114
|
-
});
|
|
46115
|
-
var dates = data.map(function (point) {
|
|
46116
|
-
return new Date(point[xKey].value);
|
|
46117
|
-
});
|
|
46118
|
-
var n = values.length;
|
|
46119
|
-
var daysSinceStart = dates.map(function (date) {
|
|
46120
|
-
return (date.getTime() - dates[0].getTime()) / 86400000;
|
|
46121
|
-
});
|
|
46122
|
-
var meanX = daysSinceStart.reduce(function (a, b) {
|
|
46123
|
-
return a + b;
|
|
46124
|
-
}, 0) / n;
|
|
46125
|
-
var meanY = values.reduce(function (a, b) {
|
|
46126
|
-
return a + b;
|
|
46127
|
-
}, 0) / n;
|
|
46128
|
-
var numerator = 0,
|
|
46129
|
-
denominator = 0;
|
|
46130
|
-
for (var i = 0; i < n; i++) {
|
|
46131
|
-
numerator += (daysSinceStart[i] - meanX) * (values[i] - meanY);
|
|
46132
|
-
denominator += Math.pow(daysSinceStart[i] - meanX, 2);
|
|
46133
|
-
}
|
|
46134
|
-
var slope = numerator / denominator;
|
|
46135
|
-
var intercept = meanY - slope * meanX;
|
|
46136
|
-
var forecastDate = new Date(dates[n - 1]); // Start from the last date in the data
|
|
46137
|
-
|
|
46138
|
-
for (var _i = 0; _i < n + (includeForecast ? forecastUnits : 0); _i++) {
|
|
46139
|
-
var x = void 0;
|
|
46140
|
-
if (_i < n) {
|
|
46141
|
-
// Use existing dates for current trend values
|
|
46142
|
-
x = dates[_i];
|
|
46143
|
-
} else if (includeForecast) {
|
|
46144
|
-
// Generate future dates for forecast values if includeForecast is true
|
|
46145
|
-
switch (timeUnit) {
|
|
46146
|
-
case 'week':
|
|
46147
|
-
forecastDate.setDate(forecastDate.getDate() + 7);
|
|
46148
|
-
break;
|
|
46149
|
-
case 'month':
|
|
46150
|
-
forecastDate.setMonth(forecastDate.getMonth() + 1);
|
|
46151
|
-
break;
|
|
46152
|
-
case 'quarter':
|
|
46153
|
-
forecastDate.setMonth(forecastDate.getMonth() + 3);
|
|
46154
|
-
break;
|
|
46155
|
-
case 'year':
|
|
46156
|
-
forecastDate.setFullYear(forecastDate.getFullYear() + 1);
|
|
46157
|
-
break;
|
|
46158
|
-
}
|
|
46159
|
-
x = new Date(forecastDate);
|
|
46160
|
-
} else {
|
|
46161
|
-
continue; // Skip this iteration if forecasting is not included
|
|
46162
|
-
}
|
|
46163
|
-
var dayCount = (x.getTime() - dates[0].getTime()) / 86400000; // 1 day in milliseconds
|
|
46164
|
-
var forecastedValue = slope * dayCount + intercept;
|
|
46165
|
-
var currentValue = slope * dayCount + intercept;
|
|
46166
|
-
if (_i >= n - 1) {
|
|
46167
|
-
if (_i === n - 1) {
|
|
46168
|
-
trendData.push({
|
|
46169
|
-
date: x.toISOString(),
|
|
46170
|
-
value: parseFloat(currentValue.toFixed(2))
|
|
46171
|
-
});
|
|
46172
|
-
}
|
|
46173
|
-
if (includeForecast) {
|
|
46174
|
-
forecastData.push({
|
|
46175
|
-
date: x.toISOString(),
|
|
46176
|
-
value: parseFloat(forecastedValue.toFixed(2))
|
|
46177
|
-
});
|
|
46178
|
-
}
|
|
46179
|
-
} else {
|
|
46180
|
-
trendData.push({
|
|
46181
|
-
date: x.toISOString(),
|
|
46182
|
-
value: parseFloat(currentValue.toFixed(2))
|
|
46183
|
-
});
|
|
46184
|
-
}
|
|
46185
|
-
}
|
|
46186
|
-
return {
|
|
46187
|
-
trendData: trendData,
|
|
46188
|
-
trendKey: trendKey,
|
|
46189
|
-
forecastData: forecastData,
|
|
46190
|
-
forecastKey: forecastKey
|
|
46191
|
-
};
|
|
46192
|
-
};
|
|
46193
|
-
|
|
46194
|
-
var getTrendsAndForecastsData = function getTrendsAndForecastsData(_ref) {
|
|
46195
|
-
var _trendsAndForecasts$;
|
|
46196
|
-
var chartData = _ref.chartData,
|
|
46197
|
-
formattingFunctionX = _ref.formattingFunctionX,
|
|
46198
|
-
formattingFunctionY = _ref.formattingFunctionY,
|
|
46199
|
-
keys = _ref.keys,
|
|
46200
|
-
nullValue = _ref.nullValue,
|
|
46201
|
-
orderFunction = _ref.orderFunction,
|
|
46202
|
-
trendsAndForecasts = _ref.trendsAndForecasts,
|
|
46203
|
-
xAxisPostfix = _ref.xAxisPostfix,
|
|
46204
|
-
xAxisPrefix = _ref.xAxisPrefix,
|
|
46205
|
-
xKey = _ref.xKey,
|
|
46206
|
-
xScaleDataType = _ref.xScaleDataType,
|
|
46207
|
-
yAxisPostfix = _ref.yAxisPostfix,
|
|
46208
|
-
yAxisPrefix = _ref.yAxisPrefix,
|
|
46209
|
-
yKeys = _ref.yKeys;
|
|
46210
|
-
if (!trendsAndForecasts || trendsAndForecasts.length === 0 || xScaleDataType !== 'date_time') return {
|
|
46211
|
-
chartData: chartData
|
|
46212
|
-
};
|
|
46213
|
-
if (!orderFunction || !['week', 'month', 'quarter', 'year'].includes(orderFunction)) return {
|
|
46214
|
-
chartData: chartData
|
|
46215
|
-
};
|
|
46216
|
-
|
|
46217
|
-
// ----- Technically we should do a loop here but at the moment we'll only have one trend/forecast so use trendsAndForecasts[0] -----
|
|
46218
|
-
|
|
46219
|
-
var includeForecast = trendsAndForecasts[0].type === 'Forecast';
|
|
46220
|
-
var forecastUnits = trendsAndForecasts[0].type === 'Forecast' ? (_trendsAndForecasts$ = trendsAndForecasts[0].value) != null ? _trendsAndForecasts$ : 0 : 0;
|
|
46221
|
-
var yKey = yKeys[0];
|
|
46222
|
-
var newKeys = _.cloneDeep(keys);
|
|
46223
|
-
var _buildTrendAndForecas = buildTrendAndForecast({
|
|
46224
|
-
data: chartData,
|
|
46225
|
-
forecastUnits: forecastUnits,
|
|
46226
|
-
xKey: xKey,
|
|
46227
|
-
yKey: yKey,
|
|
46228
|
-
timeUnit: orderFunction,
|
|
46229
|
-
includeForecast: includeForecast
|
|
46230
|
-
}),
|
|
46231
|
-
trendData = _buildTrendAndForecas.trendData,
|
|
46232
|
-
trendKey = _buildTrendAndForecas.trendKey,
|
|
46233
|
-
forecastData = _buildTrendAndForecas.forecastData,
|
|
46234
|
-
forecastKey = _buildTrendAndForecas.forecastKey;
|
|
46235
|
-
|
|
46236
|
-
// ----- Add Trend To Existing Data Array And Trend Key -----
|
|
46237
|
-
|
|
46238
|
-
var newData = chartData.map(function (dataItem) {
|
|
46239
|
-
var date = dataItem[xKey].value;
|
|
46240
|
-
var trend = trendData.find(function (trendItem) {
|
|
46241
|
-
return trendItem.date === date;
|
|
46242
|
-
});
|
|
46243
|
-
if (trend) {
|
|
46244
|
-
var trendDataItem = {
|
|
46245
|
-
value: trend.value,
|
|
46246
|
-
formattedValue: "" + yAxisPrefix + formattingFunctionY(trend.value, nullValue) + yAxisPostfix
|
|
46247
|
-
};
|
|
46248
|
-
if (includeForecast && forecastData.length > 0) {
|
|
46249
|
-
var _extends2;
|
|
46250
|
-
return _extends({}, dataItem, (_extends2 = {}, _extends2[trendKey] = trendDataItem, _extends2[forecastKey] = {
|
|
46251
|
-
value: null,
|
|
46252
|
-
formattedValue: null
|
|
46253
|
-
}, _extends2));
|
|
46254
|
-
} else {
|
|
46255
|
-
var _extends3;
|
|
46256
|
-
return _extends({}, dataItem, (_extends3 = {}, _extends3[trendKey] = trendDataItem, _extends3));
|
|
46257
|
-
}
|
|
46258
|
-
}
|
|
46259
|
-
return null;
|
|
46260
|
-
});
|
|
46261
|
-
|
|
46262
|
-
// ----- Add New Array Items For Forecast & Forecast Key -----
|
|
46263
|
-
|
|
46264
|
-
if (includeForecast && forecastData.length > 0) {
|
|
46265
|
-
var _loop = function _loop() {
|
|
46266
|
-
var _forecastIncrement;
|
|
46267
|
-
var forecastDataItem = forecastData[index];
|
|
46268
|
-
var forecastIncrement = (_forecastIncrement = {}, _forecastIncrement[xKey] = {
|
|
46269
|
-
value: forecastDataItem.date,
|
|
46270
|
-
formattedValue: "" + xAxisPrefix + formattingFunctionX(forecastDataItem.date, nullValue) + xAxisPostfix
|
|
46271
|
-
}, _forecastIncrement[trendKey] = {
|
|
46272
|
-
value: null,
|
|
46273
|
-
formattedValue: null
|
|
46274
|
-
}, _forecastIncrement[forecastKey] = {
|
|
46275
|
-
value: forecastDataItem.value,
|
|
46276
|
-
formattedValue: "" + yAxisPrefix + formattingFunctionY(forecastDataItem.value, nullValue) + yAxisPostfix
|
|
46277
|
-
}, _forecastIncrement);
|
|
46278
|
-
yKeys.forEach(function (key) {
|
|
46279
|
-
forecastIncrement[key] = {
|
|
46280
|
-
value: null,
|
|
46281
|
-
formattedValue: null
|
|
46282
|
-
};
|
|
46283
|
-
});
|
|
46284
|
-
newData.push(forecastIncrement);
|
|
46285
|
-
};
|
|
46286
|
-
for (var index = 0; index < forecastUnits; index++) {
|
|
46287
|
-
_loop();
|
|
46288
|
-
}
|
|
46289
|
-
}
|
|
46290
|
-
|
|
46291
|
-
// ----- Update Keys -----
|
|
46292
|
-
|
|
46293
|
-
var newYKeys = includeForecast && forecastData.length > 0 ? [].concat(yKeys, [trendKey, forecastKey]) : [].concat(yKeys, [trendKey]);
|
|
46294
|
-
newKeys[trendKey] = {
|
|
46295
|
-
key: trendKey,
|
|
46296
|
-
keyFormatted: newKeys[yKey].keyFormatted + " \u2022 Trend",
|
|
46297
|
-
dataType: 'number'
|
|
46298
|
-
};
|
|
46299
|
-
if (includeForecast && forecastData.length > 0) {
|
|
46300
|
-
newKeys[forecastKey] = {
|
|
46301
|
-
key: forecastKey,
|
|
46302
|
-
keyFormatted: newKeys[yKey].keyFormatted + " \u2022 Forecast",
|
|
46303
|
-
dataType: 'number'
|
|
46304
|
-
};
|
|
46305
|
-
}
|
|
46306
|
-
|
|
46307
|
-
// ----- Create style definitions for trend and forecast in the form of legend items to append to getStyleDefinition() -----
|
|
46308
|
-
|
|
46309
|
-
// TODO
|
|
46310
|
-
|
|
46311
|
-
return {
|
|
46312
|
-
newChartData: newData,
|
|
46313
|
-
newYKeys: newYKeys,
|
|
46314
|
-
newKeys: newKeys
|
|
46315
|
-
};
|
|
46316
|
-
};
|
|
46317
|
-
|
|
46318
46146
|
/**
|
|
46319
46147
|
* When provided with a result, and formatting parameters, it returns a
|
|
46320
46148
|
* populated result including the formatted value to show.
|
|
@@ -46411,77 +46239,28 @@ var formatResult = function formatResult(result, params) {
|
|
|
46411
46239
|
};
|
|
46412
46240
|
};
|
|
46413
46241
|
|
|
46414
|
-
var formattedResultToSeries = function formattedResultToSeries(formattedResult, pivotConfig,
|
|
46415
|
-
var _formattedResult$fiel, _formattedResult$fiel2;
|
|
46242
|
+
var formattedResultToSeries = function formattedResultToSeries(formattedResult, pivotConfig, zFieldId) {
|
|
46416
46243
|
var keys = {};
|
|
46417
|
-
|
|
46418
|
-
|
|
46419
|
-
|
|
46420
|
-
|
|
46421
|
-
|
|
46422
|
-
|
|
46423
|
-
|
|
46424
|
-
var xPivotFields = formattedResult.fields.filter(function (resultField) {
|
|
46425
|
-
return pivotConfig.x.includes(resultField.id);
|
|
46426
|
-
});
|
|
46427
|
-
var yPivotFields = formattedResult.fields.filter(function (resultField) {
|
|
46428
|
-
return pivotConfig.y.includes(resultField.id);
|
|
46429
|
-
});
|
|
46430
|
-
var pivotedData = {};
|
|
46431
|
-
var xKeyOrdering = [];
|
|
46432
|
-
var yKeys = {};
|
|
46433
|
-
formattedResult.contentMapped.forEach(function (row) {
|
|
46434
|
-
xPivotFields.forEach(function (xPivotField) {
|
|
46435
|
-
var _extends2;
|
|
46436
|
-
var uniqueXValue = xPivotField.id + ":" + row[xPivotField.id].value;
|
|
46437
|
-
xKeyOrdering.push(uniqueXValue);
|
|
46438
|
-
|
|
46439
|
-
// Add any existing values, and the x key itself
|
|
46440
|
-
|
|
46441
|
-
var yPivotPrefix = yPivotFields.map(function (yPivotField) {
|
|
46442
|
-
return yPivotField.id + ":" + row[yPivotField.id].value;
|
|
46443
|
-
}).join('_');
|
|
46444
|
-
pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends2 = {}, _extends2[xPivotField.id] = row[xPivotField.id], _extends2));
|
|
46445
|
-
yResultFields.forEach(function (yResultField) {
|
|
46446
|
-
var _extends3;
|
|
46447
|
-
var key = yPivotFields.length > 0 ? [yPivotPrefix, yResultField.id].join('_') : yResultField.id;
|
|
46448
|
-
yKeys[key] = true;
|
|
46449
|
-
keys[key] = {
|
|
46450
|
-
key: key,
|
|
46451
|
-
dataType: yResultField.dataType,
|
|
46452
|
-
outputDataType: yResultField.outputDataType,
|
|
46453
|
-
keyFormatted: seriesLabelFormatter({
|
|
46454
|
-
yResultField: yResultField,
|
|
46455
|
-
yPivotFields: yPivotFields,
|
|
46456
|
-
row: row
|
|
46457
|
-
})
|
|
46458
|
-
};
|
|
46459
|
-
pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends3 = {}, _extends3[key] = row[yResultField.id], _extends3));
|
|
46460
|
-
});
|
|
46461
|
-
});
|
|
46462
|
-
});
|
|
46463
|
-
var seriesDataFlattened = _.uniq(xKeyOrdering).map(function (xKey) {
|
|
46464
|
-
return pivotedData[xKey];
|
|
46465
|
-
});
|
|
46466
|
-
var mappedXKeys = xPivotFields.map(function (r) {
|
|
46467
|
-
return r.id;
|
|
46244
|
+
formattedResult.fields.forEach(function (field) {
|
|
46245
|
+
keys[field.id] = {
|
|
46246
|
+
key: field.id,
|
|
46247
|
+
dataType: field.dataType,
|
|
46248
|
+
outputDataType: field.outputDataType,
|
|
46249
|
+
keyFormatted: field["function"] === 'none' ? field.publicName : field.publicName + " (" + field["function"] + ")"
|
|
46250
|
+
};
|
|
46468
46251
|
});
|
|
46469
|
-
var mappedYKeys = Object.keys(yKeys);
|
|
46470
|
-
var mappedZKey = (_formattedResult$fiel = (_formattedResult$fiel2 = formattedResult.fields.find(function (resultField) {
|
|
46471
|
-
return resultField.fieldId === zFieldId;
|
|
46472
|
-
})) == null ? void 0 : _formattedResult$fiel2.id) != null ? _formattedResult$fiel : '';
|
|
46473
46252
|
var formattedResultReturn = {
|
|
46474
|
-
xKeys:
|
|
46475
|
-
yKeys:
|
|
46476
|
-
zKey:
|
|
46253
|
+
xKeys: pivotConfig.x,
|
|
46254
|
+
yKeys: pivotConfig.y,
|
|
46255
|
+
zKey: zFieldId,
|
|
46477
46256
|
keys: keys,
|
|
46478
|
-
seriesData:
|
|
46257
|
+
seriesData: formattedResult.contentMapped
|
|
46479
46258
|
};
|
|
46480
46259
|
return formattedResultReturn;
|
|
46481
46260
|
};
|
|
46482
46261
|
|
|
46483
46262
|
var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_ref) {
|
|
46484
|
-
var _pivotConfig$x$, _xKeys$, _axisTitles$x, _axisTitles$y;
|
|
46263
|
+
var _pivotConfig$x$, _xKeys$, _formattedResult$fiel, _formattedResult$fiel2, _axisTitles$x, _axisTitles$y;
|
|
46485
46264
|
var axisTitles = _ref.axisTitles,
|
|
46486
46265
|
colors = _ref.colors,
|
|
46487
46266
|
conditionalFormattingAttributes = _ref.conditionalFormattingAttributes,
|
|
@@ -46493,7 +46272,6 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
|
|
|
46493
46272
|
order = _ref.order,
|
|
46494
46273
|
pivotConfig = _ref.pivotConfig,
|
|
46495
46274
|
result = _ref.result,
|
|
46496
|
-
trendsAndForecasts = _ref.trendsAndForecasts,
|
|
46497
46275
|
xAxisFormat = _ref.xAxisFormat,
|
|
46498
46276
|
xAxisPostfix = _ref.xAxisPostfix,
|
|
46499
46277
|
xAxisPrefix = _ref.xAxisPrefix,
|
|
@@ -46501,7 +46279,6 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
|
|
|
46501
46279
|
yAxisPostfix = _ref.yAxisPostfix,
|
|
46502
46280
|
yAxisPrefix = _ref.yAxisPrefix,
|
|
46503
46281
|
approxYAxisLabelCount = _ref.approxYAxisLabelCount,
|
|
46504
|
-
seriesLabelFormatter = _ref.seriesLabelFormatter,
|
|
46505
46282
|
_valueAlias = _ref.valueAlias,
|
|
46506
46283
|
zFieldId = _ref.zFieldId;
|
|
46507
46284
|
var allPrefixes = {};
|
|
@@ -46584,7 +46361,6 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
|
|
|
46584
46361
|
var xKeyField = result.fields.find(function (field) {
|
|
46585
46362
|
return field.id === xKeyTemp;
|
|
46586
46363
|
});
|
|
46587
|
-
var orderFunction = order.length > 0 ? order[0]["function"] : undefined;
|
|
46588
46364
|
|
|
46589
46365
|
// ----- Formatting -----
|
|
46590
46366
|
|
|
@@ -46601,7 +46377,7 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
|
|
|
46601
46377
|
var formattingFunctionY = function formattingFunctionY(value) {
|
|
46602
46378
|
// Use any y axis field as they are all formatted in the same way (for now...);
|
|
46603
46379
|
var nonPivotField = formattedResult.fields.find(function (resultField) {
|
|
46604
|
-
return
|
|
46380
|
+
return pivotConfig.y.includes(resultField.id);
|
|
46605
46381
|
});
|
|
46606
46382
|
if (!nonPivotField) return '';
|
|
46607
46383
|
return formattedResult.formatterFunc(value, {
|
|
@@ -46613,32 +46389,22 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
|
|
|
46613
46389
|
|
|
46614
46390
|
// ----- Keys & Prep -----
|
|
46615
46391
|
var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
|
|
46616
|
-
var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig,
|
|
46392
|
+
var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, zFieldId),
|
|
46617
46393
|
keys = _formattedResultToSer.keys,
|
|
46618
46394
|
yKeys = _formattedResultToSer.yKeys,
|
|
46619
46395
|
xKeys = _formattedResultToSer.xKeys,
|
|
46620
46396
|
zKey = _formattedResultToSer.zKey,
|
|
46621
46397
|
chartData = _formattedResultToSer.seriesData;
|
|
46622
|
-
var
|
|
46623
|
-
|
|
46624
|
-
|
|
46625
|
-
|
|
46626
|
-
|
|
46627
|
-
|
|
46628
|
-
|
|
46629
|
-
|
|
46630
|
-
keys: keys,
|
|
46631
|
-
nullValue: nullValue,
|
|
46632
|
-
trendsAndForecasts: trendsAndForecasts,
|
|
46633
|
-
xAxisPostfix: xAxisPostfix,
|
|
46634
|
-
xKey: xKey,
|
|
46635
|
-
yKeys: yKeys,
|
|
46636
|
-
xAxisPrefix: xAxisPrefix,
|
|
46637
|
-
xScaleDataType: xScaleDataType,
|
|
46638
|
-
yAxisPostfix: yAxisPostfix,
|
|
46639
|
-
yAxisPrefix: yAxisPrefix,
|
|
46640
|
-
orderFunction: orderFunction
|
|
46398
|
+
var sortedChartData = chartData.sort(function (a, b) {
|
|
46399
|
+
var _order$, _a$pivotConfig$x$, _b$pivotConfig$x$;
|
|
46400
|
+
var isDescending = ((_order$ = order[0]) == null ? void 0 : _order$.direction) === 'desc';
|
|
46401
|
+
var xValueA = (_a$pivotConfig$x$ = a[pivotConfig.x[0]]) == null ? void 0 : _a$pivotConfig$x$.value;
|
|
46402
|
+
var xValueB = (_b$pivotConfig$x$ = b[pivotConfig.x[0]]) == null ? void 0 : _b$pivotConfig$x$.value;
|
|
46403
|
+
if (xValueA < xValueB) return isDescending ? 1 : -1;
|
|
46404
|
+
if (xValueA > xValueB) return isDescending ? -1 : 1;
|
|
46405
|
+
return 0;
|
|
46641
46406
|
});
|
|
46407
|
+
var xKey = (_xKeys$ = xKeys[0]) != null ? _xKeys$ : null;
|
|
46642
46408
|
|
|
46643
46409
|
// ----- Goal Lines -----
|
|
46644
46410
|
|
|
@@ -46650,11 +46416,11 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
|
|
|
46650
46416
|
// ----- Ticks -----
|
|
46651
46417
|
|
|
46652
46418
|
var ticks = getScaleAndTicks({
|
|
46653
|
-
data:
|
|
46419
|
+
data: sortedChartData,
|
|
46654
46420
|
xKey: xKey,
|
|
46655
46421
|
xScaleDataType: xScaleDataType,
|
|
46656
46422
|
yKeys: yKeys,
|
|
46657
|
-
|
|
46423
|
+
approxYAxisLabelCount: approxYAxisLabelCount,
|
|
46658
46424
|
formattingFunctionX: formattingFunctionX,
|
|
46659
46425
|
formattingFunctionY: formattingFunctionY,
|
|
46660
46426
|
nullValue: nullValue,
|
|
@@ -46664,9 +46430,36 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
|
|
|
46664
46430
|
|
|
46665
46431
|
// ----- Lines -----
|
|
46666
46432
|
|
|
46433
|
+
var groupByKey = (_formattedResult$fiel = (_formattedResult$fiel2 = formattedResult.fields.find(function (field) {
|
|
46434
|
+
return field["function"] === 'none';
|
|
46435
|
+
})) == null ? void 0 : _formattedResult$fiel2.id) != null ? _formattedResult$fiel : '';
|
|
46667
46436
|
var styleDefinition = getStyleDefinition({
|
|
46668
|
-
colors: colors
|
|
46669
|
-
yKeys: yKeys
|
|
46437
|
+
colors: colors,
|
|
46438
|
+
yKeys: [].concat(yKeys, [xKey, zKey])
|
|
46439
|
+
});
|
|
46440
|
+
|
|
46441
|
+
// ----- Legend -----
|
|
46442
|
+
var colorScale = themeToColorScale(colors, sortedChartData.length);
|
|
46443
|
+
var legendItems = sortedChartData.map(function (d, index) {
|
|
46444
|
+
var _d$groupByKey, _colorScale;
|
|
46445
|
+
return {
|
|
46446
|
+
yKey: (_d$groupByKey = d[groupByKey]) == null ? void 0 : _d$groupByKey.value,
|
|
46447
|
+
color: (_colorScale = colorScale[index % colorScale.length]) != null ? _colorScale : '',
|
|
46448
|
+
style: {
|
|
46449
|
+
strokeWidth: 3,
|
|
46450
|
+
strokeDasharray: null,
|
|
46451
|
+
type: 'line'
|
|
46452
|
+
}
|
|
46453
|
+
};
|
|
46454
|
+
});
|
|
46455
|
+
var legendKeys = {};
|
|
46456
|
+
sortedChartData.forEach(function (row) {
|
|
46457
|
+
var _row$groupByKey, _row$groupByKey$value, _row$groupByKey2, _row$groupByKey$forma, _row$groupByKey3;
|
|
46458
|
+
legendKeys[(_row$groupByKey = row[groupByKey]) == null ? void 0 : _row$groupByKey.value] = {
|
|
46459
|
+
key: (_row$groupByKey$value = (_row$groupByKey2 = row[groupByKey]) == null ? void 0 : _row$groupByKey2.value) != null ? _row$groupByKey$value : '',
|
|
46460
|
+
dataType: 'string',
|
|
46461
|
+
keyFormatted: (_row$groupByKey$forma = (_row$groupByKey3 = row[groupByKey]) == null ? void 0 : _row$groupByKey3.formattedValue) != null ? _row$groupByKey$forma : ''
|
|
46462
|
+
};
|
|
46670
46463
|
});
|
|
46671
46464
|
|
|
46672
46465
|
// ----- Conditional Formatting -----
|
|
@@ -46705,21 +46498,24 @@ var buildBubbleChartRepresentation = function buildBubbleChartRepresentation(_re
|
|
|
46705
46498
|
title: (_axisTitles$y = axisTitles == null ? void 0 : axisTitles.y) != null ? _axisTitles$y : null
|
|
46706
46499
|
},
|
|
46707
46500
|
z: zKey,
|
|
46708
|
-
data:
|
|
46501
|
+
data: sortedChartData,
|
|
46709
46502
|
lines: styleDefinition,
|
|
46710
46503
|
conditionalFormattingRules: conditionalFormattingRules,
|
|
46711
|
-
goalLines: goalLines
|
|
46504
|
+
goalLines: goalLines,
|
|
46505
|
+
groupByKey: groupByKey,
|
|
46506
|
+
legend: {
|
|
46507
|
+
keys: legendKeys,
|
|
46508
|
+
items: legendItems
|
|
46509
|
+
}
|
|
46712
46510
|
};
|
|
46713
46511
|
return chart;
|
|
46714
46512
|
};
|
|
46715
46513
|
|
|
46716
46514
|
var BubbleChartV2View = function BubbleChartV2View(props) {
|
|
46717
|
-
var _props$library, _props$attributes$vie;
|
|
46515
|
+
var _props$library, _props$attributes$vie, _props$result, _props$result2, _props$result3;
|
|
46718
46516
|
var _useDashboardBehaviou = useDashboardBehaviourContext(),
|
|
46719
46517
|
textOverride = _useDashboardBehaviou.textOverride,
|
|
46720
|
-
valueAlias = _useDashboardBehaviou.valueAlias
|
|
46721
|
-
labelFormat = _useDashboardBehaviou.labelFormat,
|
|
46722
|
-
queryEngineConfig = _useDashboardBehaviou.queryEngineConfig;
|
|
46518
|
+
valueAlias = _useDashboardBehaviou.valueAlias;
|
|
46723
46519
|
var headerProps = {
|
|
46724
46520
|
displayTitle: props.attributes.displayTitle,
|
|
46725
46521
|
displaySubject: props.attributes.displaySubject,
|
|
@@ -46740,12 +46536,12 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
|
|
|
46740
46536
|
var showHeadline = headlineAvailable(props.attributes.order, props.attributes.headline, null);
|
|
46741
46537
|
var theme = useTheme();
|
|
46742
46538
|
var BubbleChartV2Component = getComponentInterface(props.attributes.type);
|
|
46743
|
-
var pivotConfig = init$
|
|
46539
|
+
var pivotConfig = init$d(props.attributes.xMeasure, props.attributes.measure);
|
|
46744
46540
|
var chartRepresentation = null;
|
|
46745
46541
|
if (!isLoading(props.result) && !hasFailed(props.result) && !isEmpty(props.result) && BubbleChartV2Component.isRunnable(props.attributes)) {
|
|
46746
46542
|
var _theme$charts$colors, _theme$charts, _props$attributes$goa;
|
|
46747
46543
|
chartRepresentation = buildBubbleChartRepresentation({
|
|
46748
|
-
zFieldId: props.attributes.zMeasure[0]
|
|
46544
|
+
zFieldId: id(props.attributes.zMeasure[0]),
|
|
46749
46545
|
axisTitles: props.attributes.axisTitles,
|
|
46750
46546
|
xAxisPostfix: props.attributes.xAxisPostfix,
|
|
46751
46547
|
xAxisPrefix: props.attributes.xAxisPrefix,
|
|
@@ -46753,7 +46549,7 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
|
|
|
46753
46549
|
yAxisPrefix: props.attributes.yAxisPrefix,
|
|
46754
46550
|
yAxisFormat: props.attributes.yAxisFormat,
|
|
46755
46551
|
xAxisFormat: props.attributes.xAxisFormat,
|
|
46756
|
-
approxYAxisLabelCount: props.attributes.approxYAxisLabelCount
|
|
46552
|
+
approxYAxisLabelCount: props.attributes.approxYAxisLabelCount,
|
|
46757
46553
|
colors: (_theme$charts$colors = theme == null || (_theme$charts = theme.charts) == null ? void 0 : _theme$charts.colors) != null ? _theme$charts$colors : DEFAULT_CHART_COLORS,
|
|
46758
46554
|
valueAlias: valueAlias,
|
|
46759
46555
|
nullValue: checkForNullValue(props.attributes.dataSetId, props.attributes.dimension, props.attributes.timeDimension, textOverride, valueAlias),
|
|
@@ -46764,27 +46560,7 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
|
|
|
46764
46560
|
dateTimeFormatOptions: props.dateTimeFormatOptions,
|
|
46765
46561
|
goalLineAttributes: (_props$attributes$goa = props.attributes.goalLines) != null ? _props$attributes$goa : [],
|
|
46766
46562
|
conditionalFormattingAttributes: props.attributes.conditionalFormattingRules,
|
|
46767
|
-
|
|
46768
|
-
defaultFormats: props.defaultFormats,
|
|
46769
|
-
seriesLabelFormatter: function seriesLabelFormatter(labelFormatParams) {
|
|
46770
|
-
var _queryEngineConfig$su, _queryEngineConfig$su2, _queryEngineConfig$su3;
|
|
46771
|
-
var yResultField = labelFormatParams.yResultField,
|
|
46772
|
-
yPivotFields = labelFormatParams.yPivotFields,
|
|
46773
|
-
row = labelFormatParams.row;
|
|
46774
|
-
var formattedFunctionName = ((_queryEngineConfig$su = queryEngineConfig.supportedAggregates[yResultField["function"]]) == null ? void 0 : _queryEngineConfig$su.publicName) || ((_queryEngineConfig$su2 = queryEngineConfig.supportedTimeTruncFunctions[yResultField["function"]]) == null ? void 0 : _queryEngineConfig$su2.publicName) || ((_queryEngineConfig$su3 = queryEngineConfig.supportedTransformationFunctions[yResultField["function"]]) == null ? void 0 : _queryEngineConfig$su3.publicName);
|
|
46775
|
-
var formattedFunction = yResultField["function"] === 'none' ? '' : " \u2022 " + formattedFunctionName;
|
|
46776
|
-
var defaultLabelFormat = "" + yPivotFields.map(function (field) {
|
|
46777
|
-
return row[field.id].formattedValue;
|
|
46778
|
-
}).join(' • ') + (yPivotFields.length === 0 ? '' : ' • ') + yResultField.publicName + formattedFunction;
|
|
46779
|
-
if (!labelFormat) return defaultLabelFormat;
|
|
46780
|
-
return labelFormat({
|
|
46781
|
-
viewId: props.attributes.viewId,
|
|
46782
|
-
fieldId: yResultField.fieldId,
|
|
46783
|
-
func: yResultField["function"],
|
|
46784
|
-
type: 'bubbleChartV2',
|
|
46785
|
-
defaultLabel: defaultLabelFormat
|
|
46786
|
-
}) || defaultLabelFormat;
|
|
46787
|
-
}
|
|
46563
|
+
defaultFormats: props.defaultFormats
|
|
46788
46564
|
});
|
|
46789
46565
|
}
|
|
46790
46566
|
|
|
@@ -46794,6 +46570,16 @@ var BubbleChartV2View = function BubbleChartV2View(props) {
|
|
|
46794
46570
|
title: "Missing parameters"
|
|
46795
46571
|
});
|
|
46796
46572
|
}
|
|
46573
|
+
if (((_props$result = props.result) == null ? void 0 : _props$result.fields.filter(function (r) {
|
|
46574
|
+
return pivotConfig.x.includes(r.id);
|
|
46575
|
+
}).length) === 0) return jsxRuntime.jsx(LoadingComponent, {});
|
|
46576
|
+
if (((_props$result2 = props.result) == null ? void 0 : _props$result2.fields.filter(function (r) {
|
|
46577
|
+
return pivotConfig.y.includes(r.id);
|
|
46578
|
+
}).length) === 0) return jsxRuntime.jsx(LoadingComponent, {});
|
|
46579
|
+
if (((_props$result3 = props.result) == null ? void 0 : _props$result3.fields.filter(function (r) {
|
|
46580
|
+
var _Field$id;
|
|
46581
|
+
return (_Field$id = id(props.attributes.zMeasure[0])) == null ? void 0 : _Field$id.includes(r.id);
|
|
46582
|
+
}).length) === 0) return jsxRuntime.jsx(LoadingComponent, {});
|
|
46797
46583
|
if (isLoading(props.result)) return jsxRuntime.jsx(LoadingComponent, {});
|
|
46798
46584
|
if (hasFailed(props.result)) return jsxRuntime.jsx(FailedToLoadDataNotice, {});
|
|
46799
46585
|
if (isEmpty(props.result)) return jsxRuntime.jsx(NoResultContentToShowNotice, _extends({}, headerProps));
|
|
@@ -47005,7 +46791,76 @@ function getStyleDefinition$1(_ref) {
|
|
|
47005
46791
|
});
|
|
47006
46792
|
}
|
|
47007
46793
|
|
|
47008
|
-
var
|
|
46794
|
+
var formattedResultToSeries$1 = function formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter, zFieldId) {
|
|
46795
|
+
var _formattedResult$fiel, _formattedResult$fiel2;
|
|
46796
|
+
var keys = {};
|
|
46797
|
+
|
|
46798
|
+
// Collect the result fields which are going to be used on the Y axis.
|
|
46799
|
+
var yResultFields = formattedResult.fields.filter(function (resultField) {
|
|
46800
|
+
var isNotXPivot = !pivotConfig.x.includes(resultField.id);
|
|
46801
|
+
var isNotYPivot = !pivotConfig.y.includes(resultField.id);
|
|
46802
|
+
return isNotXPivot && isNotYPivot;
|
|
46803
|
+
});
|
|
46804
|
+
var xPivotFields = formattedResult.fields.filter(function (resultField) {
|
|
46805
|
+
return pivotConfig.x.includes(resultField.id);
|
|
46806
|
+
});
|
|
46807
|
+
var yPivotFields = formattedResult.fields.filter(function (resultField) {
|
|
46808
|
+
return pivotConfig.y.includes(resultField.id);
|
|
46809
|
+
});
|
|
46810
|
+
var pivotedData = {};
|
|
46811
|
+
var xKeyOrdering = [];
|
|
46812
|
+
var yKeys = {};
|
|
46813
|
+
formattedResult.contentMapped.forEach(function (row) {
|
|
46814
|
+
xPivotFields.forEach(function (xPivotField) {
|
|
46815
|
+
var _extends2;
|
|
46816
|
+
var uniqueXValue = xPivotField.id + ":" + row[xPivotField.id].value;
|
|
46817
|
+
xKeyOrdering.push(uniqueXValue);
|
|
46818
|
+
|
|
46819
|
+
// Add any existing values, and the x key itself
|
|
46820
|
+
|
|
46821
|
+
var yPivotPrefix = yPivotFields.map(function (yPivotField) {
|
|
46822
|
+
return yPivotField.id + ":" + row[yPivotField.id].value;
|
|
46823
|
+
}).join('_');
|
|
46824
|
+
pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends2 = {}, _extends2[xPivotField.id] = row[xPivotField.id], _extends2));
|
|
46825
|
+
yResultFields.forEach(function (yResultField) {
|
|
46826
|
+
var _extends3;
|
|
46827
|
+
var key = yPivotFields.length > 0 ? [yPivotPrefix, yResultField.id].join('_') : yResultField.id;
|
|
46828
|
+
yKeys[key] = true;
|
|
46829
|
+
keys[key] = {
|
|
46830
|
+
key: key,
|
|
46831
|
+
dataType: yResultField.dataType,
|
|
46832
|
+
outputDataType: yResultField.outputDataType,
|
|
46833
|
+
keyFormatted: seriesLabelFormatter({
|
|
46834
|
+
yResultField: yResultField,
|
|
46835
|
+
yPivotFields: yPivotFields,
|
|
46836
|
+
row: row
|
|
46837
|
+
})
|
|
46838
|
+
};
|
|
46839
|
+
pivotedData[uniqueXValue] = _extends({}, pivotedData[uniqueXValue] || {}, (_extends3 = {}, _extends3[key] = row[yResultField.id], _extends3));
|
|
46840
|
+
});
|
|
46841
|
+
});
|
|
46842
|
+
});
|
|
46843
|
+
var seriesDataFlattened = _.uniq(xKeyOrdering).map(function (xKey) {
|
|
46844
|
+
return pivotedData[xKey];
|
|
46845
|
+
});
|
|
46846
|
+
var mappedXKeys = xPivotFields.map(function (r) {
|
|
46847
|
+
return r.id;
|
|
46848
|
+
});
|
|
46849
|
+
var mappedYKeys = Object.keys(yKeys);
|
|
46850
|
+
var mappedZKey = (_formattedResult$fiel = (_formattedResult$fiel2 = formattedResult.fields.find(function (resultField) {
|
|
46851
|
+
return resultField.fieldId === zFieldId;
|
|
46852
|
+
})) == null ? void 0 : _formattedResult$fiel2.id) != null ? _formattedResult$fiel : '';
|
|
46853
|
+
var formattedResultReturn = {
|
|
46854
|
+
xKeys: mappedXKeys,
|
|
46855
|
+
yKeys: mappedYKeys,
|
|
46856
|
+
zKey: mappedZKey,
|
|
46857
|
+
keys: keys,
|
|
46858
|
+
seriesData: seriesDataFlattened
|
|
46859
|
+
};
|
|
46860
|
+
return formattedResultReturn;
|
|
46861
|
+
};
|
|
46862
|
+
|
|
46863
|
+
var buildTrendAndForecast = function buildTrendAndForecast(_ref) {
|
|
47009
46864
|
var data = _ref.data,
|
|
47010
46865
|
forecastUnits = _ref.forecastUnits,
|
|
47011
46866
|
xKey = _ref.xKey,
|
|
@@ -47098,7 +46953,7 @@ var buildTrendAndForecast$1 = function buildTrendAndForecast(_ref) {
|
|
|
47098
46953
|
};
|
|
47099
46954
|
};
|
|
47100
46955
|
|
|
47101
|
-
var getTrendsAndForecastsData
|
|
46956
|
+
var getTrendsAndForecastsData = function getTrendsAndForecastsData(_ref) {
|
|
47102
46957
|
var _trendsAndForecasts$;
|
|
47103
46958
|
var chartData = _ref.chartData,
|
|
47104
46959
|
formattingFunctionX = _ref.formattingFunctionX,
|
|
@@ -47127,7 +46982,7 @@ var getTrendsAndForecastsData$1 = function getTrendsAndForecastsData(_ref) {
|
|
|
47127
46982
|
var forecastUnits = trendsAndForecasts[0].type === 'Forecast' ? (_trendsAndForecasts$ = trendsAndForecasts[0].value) != null ? _trendsAndForecasts$ : 0 : 0;
|
|
47128
46983
|
var yKey = yKeys[0];
|
|
47129
46984
|
var newKeys = _.cloneDeep(keys);
|
|
47130
|
-
var _buildTrendAndForecas = buildTrendAndForecast
|
|
46985
|
+
var _buildTrendAndForecas = buildTrendAndForecast({
|
|
47131
46986
|
data: chartData,
|
|
47132
46987
|
forecastUnits: forecastUnits,
|
|
47133
46988
|
xKey: xKey,
|
|
@@ -47566,7 +47421,7 @@ var buildLineChartRepresentation = function buildLineChartRepresentation(_ref) {
|
|
|
47566
47421
|
|
|
47567
47422
|
// ----- Keys & Prep -----
|
|
47568
47423
|
var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
|
|
47569
|
-
var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
|
|
47424
|
+
var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
|
|
47570
47425
|
keys = _formattedResultToSer.keys,
|
|
47571
47426
|
yKeys = _formattedResultToSer.yKeys,
|
|
47572
47427
|
xKeys = _formattedResultToSer.xKeys,
|
|
@@ -47576,7 +47431,7 @@ var buildLineChartRepresentation = function buildLineChartRepresentation(_ref) {
|
|
|
47576
47431
|
// ----- Trends & Forecasts -----
|
|
47577
47432
|
|
|
47578
47433
|
var orderFunction = order.length > 0 ? order[0]["function"] : undefined;
|
|
47579
|
-
var trendsAndForecastData = getTrendsAndForecastsData
|
|
47434
|
+
var trendsAndForecastData = getTrendsAndForecastsData({
|
|
47580
47435
|
chartData: chartData,
|
|
47581
47436
|
formattingFunctionX: function formattingFunctionX$1(value) {
|
|
47582
47437
|
return formattingFunctionX(value, formattedResult, xKeyField);
|
|
@@ -47945,7 +47800,7 @@ var buildAreaChartRepresentation = function buildAreaChartRepresentation(_ref) {
|
|
|
47945
47800
|
|
|
47946
47801
|
// ----- Keys & Prep -----
|
|
47947
47802
|
var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
|
|
47948
|
-
var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
|
|
47803
|
+
var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
|
|
47949
47804
|
keys = _formattedResultToSer.keys,
|
|
47950
47805
|
yKeys = _formattedResultToSer.yKeys,
|
|
47951
47806
|
xKeys = _formattedResultToSer.xKeys,
|
|
@@ -48297,7 +48152,7 @@ var buildBarChartRepresentation = function buildBarChartRepresentation(_ref) {
|
|
|
48297
48152
|
|
|
48298
48153
|
// ----- Keys & Prep -----
|
|
48299
48154
|
var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
|
|
48300
|
-
var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
|
|
48155
|
+
var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
|
|
48301
48156
|
keys = _formattedResultToSer.keys,
|
|
48302
48157
|
yKeys = _formattedResultToSer.yKeys,
|
|
48303
48158
|
xKeys = _formattedResultToSer.xKeys,
|
|
@@ -52523,7 +52378,7 @@ var buildRadarChartRepresentation = function buildRadarChartRepresentation(_ref)
|
|
|
52523
52378
|
}).formattedValue;
|
|
52524
52379
|
};
|
|
52525
52380
|
var xScaleDataType = (xKeyField == null ? void 0 : xKeyField.outputDataType) || 'string';
|
|
52526
|
-
var _formattedResultToSer = formattedResultToSeries(formattedResult, pivotConfig, seriesLabelFormatter),
|
|
52381
|
+
var _formattedResultToSer = formattedResultToSeries$1(formattedResult, pivotConfig, seriesLabelFormatter),
|
|
52527
52382
|
keys = _formattedResultToSer.keys,
|
|
52528
52383
|
yKeys = _formattedResultToSer.yKeys,
|
|
52529
52384
|
xKeys = _formattedResultToSer.xKeys,
|
|
@@ -53518,7 +53373,7 @@ var Legend$2 = function Legend(_ref) {
|
|
|
53518
53373
|
});
|
|
53519
53374
|
};
|
|
53520
53375
|
|
|
53521
|
-
var _excluded$
|
|
53376
|
+
var _excluded$i = ["formattedValue"],
|
|
53522
53377
|
_excluded2$4 = ["formattedValue"];
|
|
53523
53378
|
var AXIS_TITLE_STYLES$1 = {
|
|
53524
53379
|
opacity: '0.75',
|
|
@@ -53728,7 +53583,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
53728
53583
|
tickValues: xTickValues,
|
|
53729
53584
|
tickComponent: function tickComponent(_ref2) {
|
|
53730
53585
|
var formattedValue = _ref2.formattedValue,
|
|
53731
|
-
tickProps = _objectWithoutPropertiesLoose(_ref2, _excluded$
|
|
53586
|
+
tickProps = _objectWithoutPropertiesLoose(_ref2, _excluded$i);
|
|
53732
53587
|
return jsxRuntime.jsx(text$3.Text, _extends({
|
|
53733
53588
|
style: themeCSS.labels
|
|
53734
53589
|
}, tickProps, {
|
|
@@ -70266,7 +70121,7 @@ var fromToken = function fromToken(token) {
|
|
|
70266
70121
|
});
|
|
70267
70122
|
};
|
|
70268
70123
|
|
|
70269
|
-
var init$
|
|
70124
|
+
var init$e = function init(dashboardSessionToken, dataAccessToken, queryEngineAccessToken, dashboardAdminOverrideToken) {
|
|
70270
70125
|
var dashboardAccessContent = fromToken(dashboardSessionToken);
|
|
70271
70126
|
if (!('scope' in dashboardAccessContent)) {
|
|
70272
70127
|
dashboardAccessContent.scope = 'read_write';
|
|
@@ -70332,7 +70187,7 @@ var fetchIdentityConfig = /*#__PURE__*/function () {
|
|
|
70332
70187
|
throw new FailedToLoadIdentity('Failed to fetch identity config.');
|
|
70333
70188
|
case 6:
|
|
70334
70189
|
dashboardAdminOverride = isClientSide() ? getDashboardAdminOverride(window.location.href) : null;
|
|
70335
|
-
identityConfig = init$
|
|
70190
|
+
identityConfig = init$e(tokens.dashboardAccessToken, tokens.dataAccessToken, tokens.queryEngineAccessToken, dashboardAdminOverride);
|
|
70336
70191
|
return _context.abrupt("return", {
|
|
70337
70192
|
identityConfig: identityConfig,
|
|
70338
70193
|
tokens: tokens
|
|
@@ -76284,7 +76139,7 @@ var GlobalProviderContents = function GlobalProviderContents(props) {
|
|
|
76284
76139
|
});
|
|
76285
76140
|
};
|
|
76286
76141
|
|
|
76287
|
-
var _excluded$
|
|
76142
|
+
var _excluded$j = ["view"];
|
|
76288
76143
|
var Dashboard$2 = function Dashboard(props) {
|
|
76289
76144
|
var handleOnError = function handleOnError(error, errorInfo) {
|
|
76290
76145
|
return (props == null ? void 0 : props.onError) && (props == null ? void 0 : props.onError(error, errorInfo));
|
|
@@ -76305,7 +76160,7 @@ var Editor$1 = function Editor(props) {
|
|
|
76305
76160
|
var handleOnError = function handleOnError(error, errorInfo) {
|
|
76306
76161
|
return (props == null ? void 0 : props.onError) && (props == null ? void 0 : props.onError(error, errorInfo));
|
|
76307
76162
|
};
|
|
76308
|
-
var resetProps = _objectWithoutPropertiesLoose(props, _excluded$
|
|
76163
|
+
var resetProps = _objectWithoutPropertiesLoose(props, _excluded$j);
|
|
76309
76164
|
return jsxRuntime.jsxs(ErrorBoundary, {
|
|
76310
76165
|
renderOnError: function renderOnError() {
|
|
76311
76166
|
return jsxRuntime.jsx("p", {
|