@vizzly/dashboard 0.14.4-dev-dcdf669a67550a23017aa4648c565ad57c836104 → 0.14.4-dev-5f9d258f89c2ee8286ba7f049e91ade0dc1bdd18
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/Tooltip/Tooltip.d.ts +2 -2
- package/dist/charts/src/v2/components/hooks/useTooltip.d.ts +16 -0
- package/dist/charts/src/v2/utils/getTooltipData.d.ts +1 -2
- package/dist/dashboard.cjs.development.js +164 -87
- package/dist/dashboard.cjs.production.min.js +1 -1
- package/dist/dashboard.esm.js +167 -87
- package/package.json +1 -1
package/dist/dashboard.esm.js
CHANGED
|
@@ -40,7 +40,7 @@ import { feature } from 'topojson-client';
|
|
|
40
40
|
import ParentSize$1 from '@visx/responsive/lib/components/ParentSize';
|
|
41
41
|
import { Zoom } from '@visx/zoom';
|
|
42
42
|
import fetch$1 from 'cross-fetch';
|
|
43
|
-
import { useTooltip as useTooltip$
|
|
43
|
+
import { useTooltip as useTooltip$2, useTooltipInPortal, TooltipWithBounds } from '@visx/tooltip';
|
|
44
44
|
import { Group as Group$2 } from '@visx/group';
|
|
45
45
|
import Pie from '@visx/shape/lib/shapes/Pie';
|
|
46
46
|
import { useTransition as useTransition$1, animated, interpolate } from '@react-spring/web';
|
|
@@ -36473,7 +36473,7 @@ var useTopology = function useTopology(type) {
|
|
|
36473
36473
|
};
|
|
36474
36474
|
|
|
36475
36475
|
var useTooltip = function useTooltip(width, height) {
|
|
36476
|
-
var _useVisxTooltip = useTooltip$
|
|
36476
|
+
var _useVisxTooltip = useTooltip$2({
|
|
36477
36477
|
tooltipOpen: false,
|
|
36478
36478
|
tooltipLeft: width / 2,
|
|
36479
36479
|
tooltipTop: height,
|
|
@@ -36846,7 +36846,7 @@ var PieChartComponent = function PieChartComponent(props) {
|
|
|
36846
36846
|
var _useState = useState(false),
|
|
36847
36847
|
animating = _useState[0],
|
|
36848
36848
|
setAmimating = _useState[1];
|
|
36849
|
-
var _useTooltip = useTooltip$
|
|
36849
|
+
var _useTooltip = useTooltip$2({
|
|
36850
36850
|
tooltipOpen: false,
|
|
36851
36851
|
tooltipLeft: width / 2,
|
|
36852
36852
|
tooltipTop: height,
|
|
@@ -41946,8 +41946,7 @@ var getTooltipData = function getTooltipData(_ref) {
|
|
|
41946
41946
|
}
|
|
41947
41947
|
}
|
|
41948
41948
|
return {
|
|
41949
|
-
|
|
41950
|
-
tooltipTop: point.y,
|
|
41949
|
+
lineLeft: point.x,
|
|
41951
41950
|
tooltipData: tooltipData
|
|
41952
41951
|
};
|
|
41953
41952
|
};
|
|
@@ -42016,7 +42015,12 @@ var LegendItemTriangle = function LegendItemTriangle(_ref3) {
|
|
|
42016
42015
|
});
|
|
42017
42016
|
};
|
|
42018
42017
|
|
|
42018
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$5() { 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)."; }
|
|
42019
|
+
var MIN_TOOLTIP_WIDTH = 180;
|
|
42020
|
+
var TOOLTIP_OFFSET = 20;
|
|
42021
|
+
var SCROLLBAR_WIDTH = 40;
|
|
42019
42022
|
var Tooltip$1 = function Tooltip(_ref) {
|
|
42023
|
+
var _tooltipData$xKey$for;
|
|
42020
42024
|
var keys = _ref.keys,
|
|
42021
42025
|
legendItems = _ref.legendItems,
|
|
42022
42026
|
showRoundedTotal = _ref.showRoundedTotal,
|
|
@@ -42028,70 +42032,104 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
42028
42032
|
yKeys = _ref.yKeys,
|
|
42029
42033
|
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
42030
42034
|
theme = _ref.theme;
|
|
42031
|
-
|
|
42032
|
-
|
|
42033
|
-
|
|
42034
|
-
|
|
42035
|
+
var tooltipRef = useRef(null);
|
|
42036
|
+
var _useState = useState({
|
|
42037
|
+
left: tooltipLeft
|
|
42038
|
+
}),
|
|
42039
|
+
position = _useState[0],
|
|
42040
|
+
setPosition = _useState[1];
|
|
42041
|
+
useEffect(function () {
|
|
42042
|
+
var adjustTooltipPosition = function adjustTooltipPosition() {
|
|
42043
|
+
var tooltipElement = tooltipRef.current;
|
|
42044
|
+
if (tooltipElement) {
|
|
42045
|
+
var screenWidth = window.innerWidth;
|
|
42046
|
+
var rect = tooltipElement.getBoundingClientRect();
|
|
42047
|
+
var width = rect.width;
|
|
42048
|
+
if (width < MIN_TOOLTIP_WIDTH) {
|
|
42049
|
+
width = MIN_TOOLTIP_WIDTH;
|
|
42050
|
+
}
|
|
42051
|
+
var left = tooltipLeft + TOOLTIP_OFFSET;
|
|
42052
|
+
if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {
|
|
42053
|
+
left = tooltipLeft - width - TOOLTIP_OFFSET;
|
|
42054
|
+
}
|
|
42055
|
+
setPosition({
|
|
42056
|
+
left: left
|
|
42057
|
+
});
|
|
42058
|
+
}
|
|
42059
|
+
};
|
|
42060
|
+
adjustTooltipPosition();
|
|
42061
|
+
}, [tooltipLeft]);
|
|
42062
|
+
return /*#__PURE__*/createPortal(jsx("div", {
|
|
42063
|
+
ref: tooltipRef,
|
|
42064
|
+
style: _extends({
|
|
42065
|
+
position: 'absolute',
|
|
42066
|
+
left: position.left,
|
|
42067
|
+
top: tooltipTop,
|
|
42068
|
+
zIndex: 2147483647 * 10
|
|
42069
|
+
}, theme),
|
|
42035
42070
|
children: jsxs("div", {
|
|
42036
42071
|
style: {
|
|
42037
42072
|
wordBreak: 'break-all'
|
|
42038
42073
|
},
|
|
42039
42074
|
children: [jsx("div", {
|
|
42040
|
-
|
|
42075
|
+
className: /*#__PURE__*/css$1({
|
|
42041
42076
|
fontFamily: 'inherit',
|
|
42042
42077
|
lineHeight: 'inherit',
|
|
42043
42078
|
letterSpacing: 'inherit',
|
|
42044
42079
|
fontWeight: 'bold',
|
|
42045
42080
|
fontSize: '15px',
|
|
42046
|
-
width: '100%'
|
|
42047
|
-
|
|
42048
|
-
|
|
42081
|
+
width: '100%',
|
|
42082
|
+
minWidth: MIN_TOOLTIP_WIDTH
|
|
42083
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AAyF+B","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, 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 { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\ninterface TooltipProps<T> {\n    keys: { [key: string]: Key };\n    legendItems: Array<ShapeDefinition<T>>;\n    showRoundedTotal: boolean;\n    tooltipData: {\n        [keyId: string]: DataItem;\n    };\n    tooltipLeft: number;\n    tooltipTop: number;\n    visibleYKeys: string[];\n    xKey: string;\n    yKeys: string[];\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    theme: CSSProperties;\n}\n\nexport const Tooltip = ({\n    keys,\n    legendItems,\n    showRoundedTotal,\n    tooltipData,\n    tooltipLeft,\n    tooltipTop,\n    visibleYKeys,\n    xKey,\n    yKeys,\n    conditionalFormattingRules,\n    theme,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles>) => {\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                        {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                                visibleYKeys.includes(legendItem.yKey) && (\n                                    <tr key={legendItem.yKey}>\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,\n                                                })}\n                                                style={legendItem.style as LineStyles}\n                                                yKey={legendItem.yKey}\n                                            />\n                                        </td>\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                        )}\n                        {showRoundedTotal && (\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"]} */"),
|
|
42084
|
+
children: (_tooltipData$xKey$for = tooltipData[xKey].formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
|
|
42049
42085
|
}), jsx("table", {
|
|
42050
42086
|
cellPadding: 0,
|
|
42051
42087
|
cellSpacing: 0,
|
|
42052
|
-
|
|
42053
|
-
|
|
42054
|
-
|
|
42055
|
-
|
|
42056
|
-
|
|
42057
|
-
|
|
42088
|
+
className: /*#__PURE__*/css$1(process.env.NODE_ENV === "production" ? {
|
|
42089
|
+
name: "x8luwd",
|
|
42090
|
+
styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none"
|
|
42091
|
+
} : {
|
|
42092
|
+
name: "9a1sa-Tooltip",
|
|
42093
|
+
styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
|
|
42094
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tooltip.tsx"],"names":[],"mappings":"AAwG+B","file":"Tooltip.tsx","sourcesContent":["import React, { CSSProperties, 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 { css } from '@emotion/css';\n\nconst MIN_TOOLTIP_WIDTH = 180;\nconst TOOLTIP_OFFSET = 20;\nconst SCROLLBAR_WIDTH = 40;\ninterface TooltipProps<T> {\n    keys: { [key: string]: Key };\n    legendItems: Array<ShapeDefinition<T>>;\n    showRoundedTotal: boolean;\n    tooltipData: {\n        [keyId: string]: DataItem;\n    };\n    tooltipLeft: number;\n    tooltipTop: number;\n    visibleYKeys: string[];\n    xKey: string;\n    yKeys: string[];\n    conditionalFormattingRules: Array<ConditionalFormattingRule>;\n    theme: CSSProperties;\n}\n\nexport const Tooltip = ({\n    keys,\n    legendItems,\n    showRoundedTotal,\n    tooltipData,\n    tooltipLeft,\n    tooltipTop,\n    visibleYKeys,\n    xKey,\n    yKeys,\n    conditionalFormattingRules,\n    theme,\n}: TooltipProps<LineStyles | BarStyles | AreaStyles>) => {\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                        {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                                visibleYKeys.includes(legendItem.yKey) && (\n                                    <tr key={legendItem.yKey}>\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,\n                                                })}\n                                                style={legendItem.style as LineStyles}\n                                                yKey={legendItem.yKey}\n                                            />\n                                        </td>\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                        )}\n                        {showRoundedTotal && (\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"]} */",
|
|
42095
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
42096
|
+
}),
|
|
42058
42097
|
children: jsxs("tbody", {
|
|
42059
42098
|
children: [legendItems.map(function (legendItem, index) {
|
|
42060
42099
|
if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
|
|
42061
42100
|
// yKey could not be found in tooltipData
|
|
42062
42101
|
return null;
|
|
42063
|
-
} else {
|
|
42064
|
-
return visibleYKeys.includes(legendItem.yKey) && jsxs("tr", {
|
|
42065
|
-
children: [jsx("td", {
|
|
42066
|
-
style: {
|
|
42067
|
-
verticalAlign: 'middle',
|
|
42068
|
-
padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
|
|
42069
|
-
width: 'auto'
|
|
42070
|
-
},
|
|
42071
|
-
children: jsx(LegendItemBox, {
|
|
42072
|
-
color: getColor({
|
|
42073
|
-
defaultColor: legendItem.color,
|
|
42074
|
-
value: tooltipData[legendItem.yKey].value,
|
|
42075
|
-
yKey: legendItem.yKey,
|
|
42076
|
-
conditionalFormattingRules: conditionalFormattingRules
|
|
42077
|
-
}),
|
|
42078
|
-
style: legendItem.style,
|
|
42079
|
-
yKey: legendItem.yKey
|
|
42080
|
-
})
|
|
42081
|
-
}), jsx("td", {
|
|
42082
|
-
style: {
|
|
42083
|
-
padding: '8px 0 0 0'
|
|
42084
|
-
},
|
|
42085
|
-
children: keys[legendItem.yKey].keyFormatted
|
|
42086
|
-
}), jsx("td", {
|
|
42087
|
-
style: {
|
|
42088
|
-
fontWeight: 'bold',
|
|
42089
|
-
padding: '8px 0 0 16px'
|
|
42090
|
-
},
|
|
42091
|
-
children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
|
|
42092
|
-
})]
|
|
42093
|
-
}, legendItem.yKey);
|
|
42094
42102
|
}
|
|
42103
|
+
return visibleYKeys.includes(legendItem.yKey) && jsxs("tr", {
|
|
42104
|
+
children: [jsx("td", {
|
|
42105
|
+
style: {
|
|
42106
|
+
verticalAlign: 'middle',
|
|
42107
|
+
padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
|
|
42108
|
+
width: 'auto'
|
|
42109
|
+
},
|
|
42110
|
+
children: jsx(LegendItemBox, {
|
|
42111
|
+
color: getColor({
|
|
42112
|
+
defaultColor: legendItem.color,
|
|
42113
|
+
value: tooltipData[legendItem.yKey].value,
|
|
42114
|
+
yKey: legendItem.yKey,
|
|
42115
|
+
conditionalFormattingRules: conditionalFormattingRules
|
|
42116
|
+
}),
|
|
42117
|
+
style: legendItem.style,
|
|
42118
|
+
yKey: legendItem.yKey
|
|
42119
|
+
})
|
|
42120
|
+
}), jsx("td", {
|
|
42121
|
+
style: {
|
|
42122
|
+
padding: '8px 0 0 0'
|
|
42123
|
+
},
|
|
42124
|
+
children: keys[legendItem.yKey].keyFormatted
|
|
42125
|
+
}), jsx("td", {
|
|
42126
|
+
style: {
|
|
42127
|
+
fontWeight: 'bold',
|
|
42128
|
+
padding: '8px 0 0 16px'
|
|
42129
|
+
},
|
|
42130
|
+
children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
|
|
42131
|
+
})]
|
|
42132
|
+
}, legendItem.yKey);
|
|
42095
42133
|
}), showRoundedTotal && jsxs("tr", {
|
|
42096
42134
|
children: [jsx("td", {
|
|
42097
42135
|
colSpan: 2,
|
|
@@ -42112,10 +42150,10 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
42112
42150
|
})
|
|
42113
42151
|
})]
|
|
42114
42152
|
})
|
|
42115
|
-
},
|
|
42153
|
+
}), document.body);
|
|
42116
42154
|
};
|
|
42117
42155
|
|
|
42118
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42156
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { 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)."; }
|
|
42119
42157
|
var LegendItem = function LegendItem(_ref) {
|
|
42120
42158
|
var yKey = _ref.yKey,
|
|
42121
42159
|
yKeyFormatted = _ref.yKeyFormatted,
|
|
@@ -42151,7 +42189,7 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42151
42189
|
name: "mefz6m-LegendItem",
|
|
42152
42190
|
styles: "height:10px;display:flex;label:LegendItem;",
|
|
42153
42191
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStDeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
|
|
42154
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42192
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
42155
42193
|
}),
|
|
42156
42194
|
children: [jsx(LegendItemBox, {
|
|
42157
42195
|
color: color,
|
|
@@ -42172,7 +42210,7 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42172
42210
|
name: "pglbco-LegendItem",
|
|
42173
42211
|
styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
|
|
42174
42212
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
|
|
42175
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42213
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
42176
42214
|
}),
|
|
42177
42215
|
children: [jsx(LegendItemSquare, {
|
|
42178
42216
|
color: color
|
|
@@ -42189,7 +42227,7 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42189
42227
|
name: "pglbco-LegendItem",
|
|
42190
42228
|
styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
|
|
42191
42229
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9FeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
|
|
42192
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42230
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
42193
42231
|
}),
|
|
42194
42232
|
children: [jsx(LegendItemTriangle, {
|
|
42195
42233
|
color: color
|
|
@@ -42211,7 +42249,7 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42211
42249
|
}, "legend-" + yKey);
|
|
42212
42250
|
};
|
|
42213
42251
|
|
|
42214
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42252
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$7() { 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)."; }
|
|
42215
42253
|
var Legend$1 = function Legend(_ref) {
|
|
42216
42254
|
var keys = _ref.keys,
|
|
42217
42255
|
visibleYKeys = _ref.visibleYKeys,
|
|
@@ -42227,7 +42265,7 @@ var Legend$1 = function Legend(_ref) {
|
|
|
42227
42265
|
name: "qz6h7j-Legend",
|
|
42228
42266
|
styles: "height:40px;padding-top:8px;label:Legend;",
|
|
42229
42267
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
|
|
42230
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42268
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
42231
42269
|
}),
|
|
42232
42270
|
children: jsx(Scrollbar, {
|
|
42233
42271
|
className: /*#__PURE__*/css$1({
|
|
@@ -42605,7 +42643,7 @@ var GridRows = function GridRows(_ref) {
|
|
|
42605
42643
|
});
|
|
42606
42644
|
};
|
|
42607
42645
|
|
|
42608
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42646
|
+
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)."; }
|
|
42609
42647
|
var ChartWrapper$1 = function ChartWrapper(props) {
|
|
42610
42648
|
return jsx("svg", {
|
|
42611
42649
|
width: props.width,
|
|
@@ -42619,7 +42657,7 @@ var ChartWrapper$1 = function ChartWrapper(props) {
|
|
|
42619
42657
|
name: "fx4tbw-ChartWrapper",
|
|
42620
42658
|
styles: "display:block;label:ChartWrapper;",
|
|
42621
42659
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxuZXhwb3J0IGNvbnN0IENoYXJ0V3JhcHBlciA9IChwcm9wczoge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlO1xuICB3aWR0aDogbnVtYmVyO1xuICBoZWlnaHQ6IG51bWJlcjtcbiAgc2hvd0xlZ2VuZDogYm9vbGVhbjtcbiAgb25Nb3VzZU1vdmU/OiBSZWFjdC5Nb3VzZUV2ZW50SGFuZGxlcjxTVkdTVkdFbGVtZW50PjtcbiAgb25Nb3VzZUxlYXZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG59KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPHN2Z1xuICAgICAgd2lkdGg9e3Byb3BzLndpZHRofVxuICAgICAgaGVpZ2h0PXtwcm9wcy5oZWlnaHQgLSAocHJvcHMuc2hvd0xlZ2VuZCA/IDQwIDogMCl9XG4gICAgICBvbk1vdXNlTW92ZT17cHJvcHMub25Nb3VzZU1vdmV9XG4gICAgICBvbk1vdXNlTGVhdmU9e3Byb3BzLm9uTW91c2VMZWF2ZX1cbiAgICAgIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2Jsb2NrJyB9KX1cbiAgICA+XG4gICAgICB7cHJvcHMuY2hpbGRyZW59XG4gICAgPC9zdmc+XG4gICk7XG59O1xuIl19 */",
|
|
42622
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42660
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
|
|
42623
42661
|
}),
|
|
42624
42662
|
children: props.children
|
|
42625
42663
|
});
|
|
@@ -42687,6 +42725,48 @@ var Line = function Line(_ref) {
|
|
|
42687
42725
|
});
|
|
42688
42726
|
};
|
|
42689
42727
|
|
|
42728
|
+
var _excluded$g = ["tooltipOpen"];
|
|
42729
|
+
function useTooltip$1(initialTooltipState) {
|
|
42730
|
+
var _useState = useState(_extends({
|
|
42731
|
+
tooltipOpen: false
|
|
42732
|
+
}, initialTooltipState)),
|
|
42733
|
+
tooltipState = _useState[0],
|
|
42734
|
+
setTooltipState = _useState[1];
|
|
42735
|
+
var showTooltip = useCallback(function (showArgs) {
|
|
42736
|
+
return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
|
|
42737
|
+
var show = _objectWithoutPropertiesLoose(_ref, _excluded$g);
|
|
42738
|
+
return _extends({}, showArgs(show), {
|
|
42739
|
+
tooltipOpen: true
|
|
42740
|
+
});
|
|
42741
|
+
} : {
|
|
42742
|
+
tooltipOpen: true,
|
|
42743
|
+
tooltipLeft: showArgs.tooltipLeft,
|
|
42744
|
+
tooltipTop: showArgs.tooltipTop,
|
|
42745
|
+
lineLeft: showArgs.lineLeft,
|
|
42746
|
+
tooltipData: showArgs.tooltipData
|
|
42747
|
+
});
|
|
42748
|
+
}, [setTooltipState]);
|
|
42749
|
+
var hideTooltip = useCallback(function () {
|
|
42750
|
+
return setTooltipState({
|
|
42751
|
+
tooltipOpen: false,
|
|
42752
|
+
tooltipLeft: undefined,
|
|
42753
|
+
lineLeft: undefined,
|
|
42754
|
+
tooltipTop: undefined,
|
|
42755
|
+
tooltipData: undefined
|
|
42756
|
+
});
|
|
42757
|
+
}, [setTooltipState]);
|
|
42758
|
+
return {
|
|
42759
|
+
tooltipOpen: tooltipState.tooltipOpen,
|
|
42760
|
+
tooltipLeft: tooltipState.tooltipLeft,
|
|
42761
|
+
tooltipTop: tooltipState.tooltipTop,
|
|
42762
|
+
lineLeft: tooltipState.lineLeft,
|
|
42763
|
+
tooltipData: tooltipState.tooltipData,
|
|
42764
|
+
updateTooltip: setTooltipState,
|
|
42765
|
+
showTooltip: showTooltip,
|
|
42766
|
+
hideTooltip: hideTooltip
|
|
42767
|
+
};
|
|
42768
|
+
}
|
|
42769
|
+
|
|
42690
42770
|
var LineChart$5 = function LineChart(_ref) {
|
|
42691
42771
|
var _theme$axis;
|
|
42692
42772
|
var chart = _ref.chart,
|
|
@@ -42700,6 +42780,8 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42700
42780
|
tooltipLeft = _useTooltip$tooltipLe === void 0 ? 0 : _useTooltip$tooltipLe,
|
|
42701
42781
|
_useTooltip$tooltipTo = _useTooltip.tooltipTop,
|
|
42702
42782
|
tooltipTop = _useTooltip$tooltipTo === void 0 ? 0 : _useTooltip$tooltipTo,
|
|
42783
|
+
_useTooltip$lineLeft = _useTooltip.lineLeft,
|
|
42784
|
+
lineLeft = _useTooltip$lineLeft === void 0 ? 0 : _useTooltip$lineLeft,
|
|
42703
42785
|
tooltipData = _useTooltip.tooltipData,
|
|
42704
42786
|
hideTooltip = _useTooltip.hideTooltip,
|
|
42705
42787
|
showTooltip = _useTooltip.showTooltip;
|
|
@@ -42771,8 +42853,9 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42771
42853
|
chartType: 'lines'
|
|
42772
42854
|
});
|
|
42773
42855
|
showTooltip({
|
|
42774
|
-
|
|
42775
|
-
|
|
42856
|
+
lineLeft: tooltipData == null ? void 0 : tooltipData.lineLeft,
|
|
42857
|
+
tooltipLeft: event.pageX,
|
|
42858
|
+
tooltipTop: event.pageY,
|
|
42776
42859
|
tooltipData: tooltipData == null ? void 0 : tooltipData.tooltipData
|
|
42777
42860
|
});
|
|
42778
42861
|
}, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]);
|
|
@@ -42907,7 +42990,7 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42907
42990
|
})]
|
|
42908
42991
|
}), tooltipData && jsxs("g", {
|
|
42909
42992
|
children: [jsx(Line, {
|
|
42910
|
-
x:
|
|
42993
|
+
x: lineLeft,
|
|
42911
42994
|
margin: margin,
|
|
42912
42995
|
height: innerHeight
|
|
42913
42996
|
}), jsx(CrosshairCircle, {
|
|
@@ -42981,7 +43064,7 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
|
42981
43064
|
return fill;
|
|
42982
43065
|
}
|
|
42983
43066
|
|
|
42984
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
43067
|
+
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)."; }
|
|
42985
43068
|
var BAR_RADIUS = 2;
|
|
42986
43069
|
var PADDING = {
|
|
42987
43070
|
paddingOuter: 0.05,
|
|
@@ -43002,6 +43085,8 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43002
43085
|
tooltipLeft = _useTooltip$tooltipLe === void 0 ? 0 : _useTooltip$tooltipLe,
|
|
43003
43086
|
_useTooltip$tooltipTo = _useTooltip.tooltipTop,
|
|
43004
43087
|
tooltipTop = _useTooltip$tooltipTo === void 0 ? 0 : _useTooltip$tooltipTo,
|
|
43088
|
+
_useTooltip$lineLeft = _useTooltip.lineLeft,
|
|
43089
|
+
lineLeft = _useTooltip$lineLeft === void 0 ? 0 : _useTooltip$lineLeft,
|
|
43005
43090
|
tooltipData = _useTooltip.tooltipData,
|
|
43006
43091
|
hideTooltip = _useTooltip.hideTooltip,
|
|
43007
43092
|
showTooltip = _useTooltip.showTooltip;
|
|
@@ -43074,8 +43159,9 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43074
43159
|
chartType: 'bar'
|
|
43075
43160
|
});
|
|
43076
43161
|
showTooltip({
|
|
43077
|
-
|
|
43078
|
-
|
|
43162
|
+
lineLeft: tooltipData == null ? void 0 : tooltipData.lineLeft,
|
|
43163
|
+
tooltipLeft: event.pageX,
|
|
43164
|
+
tooltipTop: event.pageY,
|
|
43079
43165
|
tooltipData: tooltipData == null ? void 0 : tooltipData.tooltipData
|
|
43080
43166
|
});
|
|
43081
43167
|
}, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]);
|
|
@@ -43225,7 +43311,7 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43225
43311
|
})]
|
|
43226
43312
|
}), tooltipData && jsx("g", {
|
|
43227
43313
|
children: jsx(Line, {
|
|
43228
|
-
x:
|
|
43314
|
+
x: lineLeft,
|
|
43229
43315
|
margin: margin,
|
|
43230
43316
|
height: innerHeight
|
|
43231
43317
|
})
|
|
@@ -43287,8 +43373,8 @@ var Bar = function Bar(props) {
|
|
|
43287
43373
|
} : {
|
|
43288
43374
|
name: "4nk3o1-Bar",
|
|
43289
43375
|
styles: "cursor:pointer;label:Bar;",
|
|
43290
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AAiYqC","file":"BarChart.tsx","sourcesContent":["import { BarChartRepresentation } from 'shared-logic/src/BarChartV2/types';\nimport { ChartTheme } from '../../../types';\nimport { Group } from '@visx/group';\nimport { getChartThemeCSS, getTooltipData } from '../../utils';\nimport { Fragment, useCallback, useMemo, useState } from 'react';\nimport { Tooltip } from '../Tooltip';\nimport { useTooltip } from '@visx/tooltip';\nimport { Legend } from '../Legend';\nimport { BarGroup, BarStack } from '@visx/shape';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { scaleLinear, scaleBand } from '@visx/scale';\nimport { getBarFill } from './getBarFill';\nimport { buildMargin } from '../../utils/buildMargin';\nimport { ChartOnViewClick, ChartDataDefinition, DataItem } from 'shared-logic/src/ChartsV2/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { css } from '@emotion/css';\nimport { BarGroupBar, BarGroup as BarGroupType } from '@visx/shape/lib/types';\nimport { useFlattenedData } from '../hooks/useFlattenedData';\nimport GoalLines from '../GoalLine/GoalLines';\nimport { AxisBottom } from '../Axis/AxisBottom';\nimport { AxisLeft } from '../Axis/AxisLeft';\nimport { GridRows } from '../GridRows/GridRows';\nimport { ChartWrapper } from '../ChartWrapper/ChartWrapper';\nimport { Line } from '../Tooltip/Line';\n\n// Need to look at updating BarChart to use this type method of rendering - https://codesandbox.io/p/sandbox/visx-bar-chart-j9smpj?file=%2FExample.tsx\n// Currently it's using Stacked Chart which isn't technically correct\n\nexport type BarChartProps = {\n  width: number;\n  height: number;\n  theme?: ChartTheme;\n  chart: BarChartRepresentation;\n  options: {\n    stacked: boolean;\n    showRoundedTotal: boolean;\n    showLegend: boolean;\n    removeStroke: boolean;\n    axis: {\n      showXAxisLabels: boolean;\n      showYAxisLabels: boolean;\n    };\n  };\n  onClick: (params: ChartOnViewClick) => void;\n  enableHover?: boolean;\n};\n\nconst BAR_RADIUS = 2;\n\nconst PADDING = {\n  paddingOuter: 0.05,\n  paddingInner: 0.3,\n};\n\nexport const BarChart = ({ chart, width, height, options, theme, onClick, enableHover }: BarChartProps) => {\n  const { tooltipOpen, tooltipLeft = 0, tooltipTop = 0, tooltipData, hideTooltip, showTooltip } = useTooltip<{\n    [keyId: string]: DataItem;\n  } | null>();\n\n  const margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);\n\n  // const [visibleYKeys, setVisibleYKeys] = useState(chart.bars.map((legendItem) => legendItem.yKey));\n\n  const innerWidth = width - margin.left - margin.right;\n  const innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 40 : 0);\n  const xKey = chart.x.key;\n  const xScaleKey = chart.x.scale.key;\n  const yScaleKeys = chart.y.keys;\n  const xScaleDataType: DataType = chart.x.scale.dataType;\n\n  const xScale = useMemo(() => {\n    if (xScaleDataType === 'string') {\n      return scaleBand<string>({\n        range: [0, innerWidth],\n        domain: xScaleKey\n          ? [...chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : ''))]\n          : [],\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'date_time' && xScaleKey) {\n      return scaleBand<Date>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => new Date(d[xScaleKey].value as string)),\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'number' && xScaleKey) {\n      return scaleBand<number>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0)),\n        ...PADDING,\n      });\n    }\n\n    return null;\n  }, [innerWidth, chart.x, chart.data]);\n\n  const yScale = useMemo(\n    () =>\n      scaleLinear<number>({\n        range: [innerHeight, 0],\n        domain:\n          chart.y.scale.ordering === 'asc'\n            ? [chart.y.scale.min as number, chart.y.scale.max as number]\n            : [chart.y.scale.max as number, chart.y.scale.min as number],\n        nice: true,\n        round: true,\n      }),\n    [innerHeight, chart.y]\n  );\n\n  const innerXScale = useMemo(() => {\n    if (!options.stacked && xScale && 'bandwidth' in xScale) {\n      return scaleBand<string>({\n        range: [0, xScale?.bandwidth()],\n        domain: yScaleKeys,\n        padding: 0.1,\n      });\n    }\n\n    return undefined;\n  }, [xScale, yScaleKeys, options.stacked, xScaleDataType]);\n\n  const dataFlattened = useFlattenedData<BarChartRepresentation, ChartDataDefinition>(xScaleKey, xScaleDataType, chart);\n\n  const handleMouseMove = useCallback(\n    (event: React.MouseEvent<SVGElement>) => {\n      if (!xKey || !xScaleKey || xScale === null) return;\n\n      const tooltipData = getTooltipData({\n        data: chart.data,\n        event,\n        margin,\n        xScaleKey,\n        xScaleDataType,\n        xOrdering: chart.x.scale.ordering,\n        xScale,\n        chartType: 'bar',\n      });\n\n      showTooltip({\n        tooltipLeft: tooltipData?.tooltipLeft,\n        tooltipTop: tooltipData?.tooltipTop,\n        tooltipData: tooltipData?.tooltipData,\n      });\n    },\n    [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]\n  );\n\n  const handleMouseLeave = useCallback(() => {\n    hideTooltip();\n  }, [hideTooltip]);\n\n  const handleOnBarClick = useCallback(\n    (event: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: BarGroupType<string>, bar: BarGroupBar<string>) => {\n      onClick({\n        clickedValue: {\n          index: barGroup.index,\n          y: {\n            key: bar.key,\n            value: bar.value,\n          },\n          x: {\n            ...chart.x.ticks[barGroup.index],\n            value: chart.data[barGroup.index][xKey].value ?? '',\n            key: xKey,\n          },\n        },\n        clickEvent: event,\n      });\n    },\n    [onClick, chart.data, xKey]\n  );\n\n  const themeCSS = useMemo(() => getChartThemeCSS(theme), [theme]);\n\n  const yTickValues = chart.y.ticks.map(tick => Number(tick.value));\n\n  return (\n    <Fragment>\n      {/* width/height 100% required or useParentSize() continuously scales as parent element has no specified height */}\n      <ChartWrapper\n        width={width}\n        height={height}\n        onMouseMove={handleMouseMove}\n        onMouseLeave={handleMouseLeave}\n        showLegend={options.showLegend}\n      >\n        <Group left={margin.left} top={margin.top}>\n          <GridRows\n            ticks={yTickValues}\n            yScale={yScale}\n            width={innerWidth}\n            height={innerHeight}\n            removeStroke={options.removeStroke}\n            themeCSS={themeCSS}\n          />\n          <AxisBottom\n            x={chart.x}\n            margin={margin}\n            themeCSS={themeCSS}\n            show={options.axis.showXAxisLabels}\n            removeStroke={options.removeStroke}\n            xScaleDataType={xScaleDataType}\n            xScale={xScale}\n            height={innerHeight}\n          />\n          <AxisLeft\n            show={options.axis.showYAxisLabels}\n            y={chart.y}\n            margin={margin}\n            themeCSS={themeCSS}\n            yScale={yScale}\n            ticks={yTickValues}\n            stroke={theme?.axis?.stroke}\n          />\n          <Group>\n            {!options.stacked && (\n              <BarGroup\n                data={dataFlattened}\n                keys={yScaleKeys}\n                height={innerHeight}\n                x0={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                x0Scale={xScale}\n                // @ts-ignore\n                x1Scale={innerXScale}\n                yScale={yScale}\n                color={() => ''}\n              >\n                {barGroups => {\n                  return barGroups.map(barGroup => (\n                    <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n                      {barGroup.bars.map(bar => {\n                        if (bar.value === null) return null;\n                        if (bar.height < 0 || bar.width < 0) return null;\n                        return (\n                          <Bar\n                            key={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${bar.key}`}\n                            x={bar.x}\n                            y={bar.y}\n                            width={bar.width}\n                            height={bar.height}\n                            fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.value)}\n                            onClick={e => handleOnBarClick(e, barGroup, bar)}\n                            enableHover={enableHover}\n                          />\n                        );\n                      })}\n                    </Group>\n                  ));\n                }}\n              </BarGroup>\n            )}\n\n            {/* How to we get 'scaleValue' here? Will we need to start storing scaleKey as well as xKey? */}\n            {options.stacked && (\n              <BarStack\n                x={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                xScale={xScale}\n                yScale={yScale}\n                data={dataFlattened}\n                keys={chart.y.keys}\n                color={() => ''}\n                height={innerHeight}\n                width={innerWidth}\n                offset=\"none\"\n              >\n                {barStacks =>\n                  barStacks.map(barStack =>\n                    barStack.bars.map(bar => {\n                      if (bar.height < 3) return null;\n                      const BAR_PADDING = 1.5;\n                      return (\n                        <rect\n                          key={`bar-stack-${barStack.index}-${bar.index}`}\n                          x={bar.x}\n                          y={bar.y}\n                          width={bar.width}\n                          height={bar.height - BAR_PADDING}\n                          fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.bar.data)}\n                          rx={BAR_RADIUS}\n                        />\n                      );\n                    })\n                  )\n                }\n              </BarStack>\n            )}\n          </Group>\n        </Group>\n        {/* ----- TOOLTIP CROSSHAIR ----- */}\n        {tooltipData && (\n          <g>\n            <Line x={tooltipLeft} margin={margin} height={innerHeight} />\n          </g>\n        )}\n        {/* ----- GOAL LINES ------ */}\n        <GoalLines goalLines={chart.goalLines} y={d => yScale(d)} margin={margin} width={innerWidth} />\n      </ChartWrapper>\n      {/* ----- LEGEND ----- */}\n      {options.showLegend && (\n        <Legend\n          legendItems={chart.bars}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          setVisibleYKeys={() => {}}\n          keys={chart.keys}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          marginLeft={margin.left - margin.leftTitleOffset}\n        />\n      )}\n      {/* ----- TOOLTIP ----- */}\n      {tooltipOpen && tooltipData && xKey && (\n        <Tooltip\n          tooltipData={tooltipData}\n          tooltipLeft={tooltipLeft}\n          tooltipTop={tooltipTop}\n          xKey={xKey}\n          keys={chart.keys}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          yKeys={chart.y.keys}\n          legendItems={chart.bars}\n          showRoundedTotal={options.showRoundedTotal}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          theme={themeCSS.popoverMenus}\n        />\n      )}\n    </Fragment>\n  );\n};\n\nconst Bar = (props: {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  key: string;\n  enableHover?: boolean;\n}) => {\n  const [fillColor, setFillColor] = useState(props.fill);\n  return (\n    <rect\n      key={props.key}\n      x={props.x}\n      y={props.y}\n      width={props.width}\n      height={props.height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={props.onClick}\n      onMouseEnter={() => props.enableHover && setFillColor(lightenColor(props.fill, 0.8))}\n      onMouseLeave={() => props.enableHover && setFillColor(props.fill)}\n      className={props.enableHover ? css({ cursor: 'pointer' }) : ''}\n    />\n  );\n};\n"]} */",
|
|
43291
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
43376
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["BarChart.tsx"],"names":[],"mappings":"AA0YqC","file":"BarChart.tsx","sourcesContent":["import { BarChartRepresentation } from 'shared-logic/src/BarChartV2/types';\nimport { ChartTheme } from '../../../types';\nimport { Group } from '@visx/group';\nimport { getChartThemeCSS, getTooltipData } from '../../utils';\nimport { Fragment, useCallback, useMemo, useState } from 'react';\nimport { Tooltip } from '../Tooltip';\nimport { Legend } from '../Legend';\nimport { BarGroup, BarStack } from '@visx/shape';\nimport { DataType } from 'shared-logic/src/Field/types';\nimport { scaleLinear, scaleBand } from '@visx/scale';\nimport { getBarFill } from './getBarFill';\nimport { buildMargin } from '../../utils/buildMargin';\nimport { ChartOnViewClick, ChartDataDefinition, DataItem } from 'shared-logic/src/ChartsV2/types';\nimport { lightenColor } from '../../../styles/color.functions';\nimport { css } from '@emotion/css';\nimport { BarGroupBar, BarGroup as BarGroupType } from '@visx/shape/lib/types';\nimport { useFlattenedData } from '../hooks/useFlattenedData';\nimport GoalLines from '../GoalLine/GoalLines';\nimport { AxisBottom } from '../Axis/AxisBottom';\nimport { AxisLeft } from '../Axis/AxisLeft';\nimport { GridRows } from '../GridRows/GridRows';\nimport { ChartWrapper } from '../ChartWrapper/ChartWrapper';\nimport { Line } from '../Tooltip/Line';\nimport useTooltip from '../hooks/useTooltip';\n\n// Need to look at updating BarChart to use this type method of rendering - https://codesandbox.io/p/sandbox/visx-bar-chart-j9smpj?file=%2FExample.tsx\n// Currently it's using Stacked Chart which isn't technically correct\n\nexport type BarChartProps = {\n  width: number;\n  height: number;\n  theme?: ChartTheme;\n  chart: BarChartRepresentation;\n  options: {\n    stacked: boolean;\n    showRoundedTotal: boolean;\n    showLegend: boolean;\n    removeStroke: boolean;\n    axis: {\n      showXAxisLabels: boolean;\n      showYAxisLabels: boolean;\n    };\n  };\n  onClick: (params: ChartOnViewClick) => void;\n  enableHover?: boolean;\n};\n\nconst BAR_RADIUS = 2;\n\nconst PADDING = {\n  paddingOuter: 0.05,\n  paddingInner: 0.3,\n};\n\nexport const BarChart = ({ chart, width, height, options, theme, onClick, enableHover }: BarChartProps) => {\n  const {\n    tooltipOpen,\n    tooltipLeft = 0,\n    tooltipTop = 0,\n    lineLeft = 0,\n    tooltipData,\n    hideTooltip,\n    showTooltip,\n  } = useTooltip<{\n    [keyId: string]: DataItem;\n  } | null>();\n\n  const margin = buildMargin(chart.y.ticks, options.axis.showYAxisLabels, chart.y.title != null, chart.x.title != null);\n\n  // const [visibleYKeys, setVisibleYKeys] = useState(chart.bars.map((legendItem) => legendItem.yKey));\n\n  const innerWidth = width - margin.left - margin.right;\n  const innerHeight = height - margin.top - margin.bottom - (options.showLegend ? 40 : 0);\n  const xKey = chart.x.key;\n  const xScaleKey = chart.x.scale.key;\n  const yScaleKeys = chart.y.keys;\n  const xScaleDataType: DataType = chart.x.scale.dataType;\n\n  const xScale = useMemo(() => {\n    if (xScaleDataType === 'string') {\n      return scaleBand<string>({\n        range: [0, innerWidth],\n        domain: xScaleKey\n          ? [...chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? String(d[xScaleKey].value) : ''))]\n          : [],\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'date_time' && xScaleKey) {\n      return scaleBand<Date>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => new Date(d[xScaleKey].value as string)),\n        ...PADDING,\n      });\n    }\n\n    if (xScaleDataType === 'number' && xScaleKey) {\n      return scaleBand<number>({\n        range: [0, innerWidth],\n        domain: chart.data.map(d => (d[xScaleKey] && d[xScaleKey].value !== null ? Number(d[xScaleKey].value) : 0)),\n        ...PADDING,\n      });\n    }\n\n    return null;\n  }, [innerWidth, chart.x, chart.data]);\n\n  const yScale = useMemo(\n    () =>\n      scaleLinear<number>({\n        range: [innerHeight, 0],\n        domain:\n          chart.y.scale.ordering === 'asc'\n            ? [chart.y.scale.min as number, chart.y.scale.max as number]\n            : [chart.y.scale.max as number, chart.y.scale.min as number],\n        nice: true,\n        round: true,\n      }),\n    [innerHeight, chart.y]\n  );\n\n  const innerXScale = useMemo(() => {\n    if (!options.stacked && xScale && 'bandwidth' in xScale) {\n      return scaleBand<string>({\n        range: [0, xScale?.bandwidth()],\n        domain: yScaleKeys,\n        padding: 0.1,\n      });\n    }\n\n    return undefined;\n  }, [xScale, yScaleKeys, options.stacked, xScaleDataType]);\n\n  const dataFlattened = useFlattenedData<BarChartRepresentation, ChartDataDefinition>(xScaleKey, xScaleDataType, chart);\n\n  const handleMouseMove = useCallback(\n    (event: React.MouseEvent<SVGElement>) => {\n      if (!xKey || !xScaleKey || xScale === null) return;\n\n      const tooltipData = getTooltipData({\n        data: chart.data,\n        event,\n        margin,\n        xScaleKey,\n        xScaleDataType,\n        xOrdering: chart.x.scale.ordering,\n        xScale,\n        chartType: 'bar',\n      });\n\n      showTooltip({\n        lineLeft: tooltipData?.lineLeft,\n        tooltipLeft: event.pageX,\n        tooltipTop: event.pageY,\n        tooltipData: tooltipData?.tooltipData,\n      });\n    },\n    [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]\n  );\n\n  const handleMouseLeave = useCallback(() => {\n    hideTooltip();\n  }, [hideTooltip]);\n\n  const handleOnBarClick = useCallback(\n    (event: React.MouseEvent<SVGRectElement, MouseEvent>, barGroup: BarGroupType<string>, bar: BarGroupBar<string>) => {\n      onClick({\n        clickedValue: {\n          index: barGroup.index,\n          y: {\n            key: bar.key,\n            value: bar.value,\n          },\n          x: {\n            ...chart.x.ticks[barGroup.index],\n            value: chart.data[barGroup.index][xKey].value ?? '',\n            key: xKey,\n          },\n        },\n        clickEvent: event,\n      });\n    },\n    [onClick, chart.data, xKey]\n  );\n\n  const themeCSS = useMemo(() => getChartThemeCSS(theme), [theme]);\n\n  const yTickValues = chart.y.ticks.map(tick => Number(tick.value));\n\n  return (\n    <Fragment>\n      {/* width/height 100% required or useParentSize() continuously scales as parent element has no specified height */}\n      <ChartWrapper\n        width={width}\n        height={height}\n        onMouseMove={handleMouseMove}\n        onMouseLeave={handleMouseLeave}\n        showLegend={options.showLegend}\n      >\n        <Group left={margin.left} top={margin.top}>\n          <GridRows\n            ticks={yTickValues}\n            yScale={yScale}\n            width={innerWidth}\n            height={innerHeight}\n            removeStroke={options.removeStroke}\n            themeCSS={themeCSS}\n          />\n          <AxisBottom\n            x={chart.x}\n            margin={margin}\n            themeCSS={themeCSS}\n            show={options.axis.showXAxisLabels}\n            removeStroke={options.removeStroke}\n            xScaleDataType={xScaleDataType}\n            xScale={xScale}\n            height={innerHeight}\n          />\n          <AxisLeft\n            show={options.axis.showYAxisLabels}\n            y={chart.y}\n            margin={margin}\n            themeCSS={themeCSS}\n            yScale={yScale}\n            ticks={yTickValues}\n            stroke={theme?.axis?.stroke}\n          />\n          <Group>\n            {!options.stacked && (\n              <BarGroup\n                data={dataFlattened}\n                keys={yScaleKeys}\n                height={innerHeight}\n                x0={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                x0Scale={xScale}\n                // @ts-ignore\n                x1Scale={innerXScale}\n                yScale={yScale}\n                color={() => ''}\n              >\n                {barGroups => {\n                  return barGroups.map(barGroup => (\n                    <Group key={`bar-group-${barGroup.index}-${barGroup.x0}`} left={barGroup.x0}>\n                      {barGroup.bars.map(bar => {\n                        if (bar.value === null) return null;\n                        if (bar.height < 0 || bar.width < 0) return null;\n                        return (\n                          <Bar\n                            key={`bar-group-bar-${barGroup.index}-${bar.index}-${bar.value}-${bar.key}`}\n                            x={bar.x}\n                            y={bar.y}\n                            width={bar.width}\n                            height={bar.height}\n                            fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.value)}\n                            onClick={e => handleOnBarClick(e, barGroup, bar)}\n                            enableHover={enableHover}\n                          />\n                        );\n                      })}\n                    </Group>\n                  ));\n                }}\n              </BarGroup>\n            )}\n\n            {/* How to we get 'scaleValue' here? Will we need to start storing scaleKey as well as xKey? */}\n            {options.stacked && (\n              <BarStack\n                x={d => {\n                  // @ts-ignore\n                  const xValue = d[xScaleKey];\n                  if (xScaleDataType === 'string') return xValue;\n\n                  const xValueAdjusted =\n                    xScaleDataType === 'date_time'\n                      ? new Date(xValue)\n                      : xScaleDataType === 'number'\n                      ? Number(xValue)\n                      : String(xValue);\n                  // @ts-ignore\n                  return xValueAdjusted;\n                }}\n                // @ts-ignore\n                xScale={xScale}\n                yScale={yScale}\n                data={dataFlattened}\n                keys={chart.y.keys}\n                color={() => ''}\n                height={innerHeight}\n                width={innerWidth}\n                offset=\"none\"\n              >\n                {barStacks =>\n                  barStacks.map(barStack =>\n                    barStack.bars.map(bar => {\n                      if (bar.height < 3) return null;\n                      const BAR_PADDING = 1.5;\n                      return (\n                        <rect\n                          key={`bar-stack-${barStack.index}-${bar.index}`}\n                          x={bar.x}\n                          y={bar.y}\n                          width={bar.width}\n                          height={bar.height - BAR_PADDING}\n                          fill={getBarFill(chart.bars, chart.conditionalFormattingRules, bar.key, bar.bar.data)}\n                          rx={BAR_RADIUS}\n                        />\n                      );\n                    })\n                  )\n                }\n              </BarStack>\n            )}\n          </Group>\n        </Group>\n        {/* ----- TOOLTIP CROSSHAIR ----- */}\n        {tooltipData && (\n          <g>\n            <Line x={lineLeft} margin={margin} height={innerHeight} />\n          </g>\n        )}\n        {/* ----- GOAL LINES ------ */}\n        <GoalLines goalLines={chart.goalLines} y={d => yScale(d)} margin={margin} width={innerWidth} />\n      </ChartWrapper>\n      {/* ----- LEGEND ----- */}\n      {options.showLegend && (\n        <Legend\n          legendItems={chart.bars}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          setVisibleYKeys={() => {}}\n          keys={chart.keys}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          marginLeft={margin.left - margin.leftTitleOffset}\n        />\n      )}\n      {/* ----- TOOLTIP ----- */}\n      {tooltipOpen && tooltipData && xKey && (\n        <Tooltip\n          tooltipData={tooltipData}\n          tooltipLeft={tooltipLeft}\n          tooltipTop={tooltipTop}\n          xKey={xKey}\n          keys={chart.keys}\n          visibleYKeys={chart.bars.map(legendItem => legendItem.yKey)}\n          yKeys={chart.y.keys}\n          legendItems={chart.bars}\n          showRoundedTotal={options.showRoundedTotal}\n          conditionalFormattingRules={chart.conditionalFormattingRules}\n          theme={themeCSS.popoverMenus}\n        />\n      )}\n    </Fragment>\n  );\n};\n\nconst Bar = (props: {\n  onClick: (e: React.MouseEvent<SVGRectElement, MouseEvent>) => void;\n  fill?: string;\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n  key: string;\n  enableHover?: boolean;\n}) => {\n  const [fillColor, setFillColor] = useState(props.fill);\n  return (\n    <rect\n      key={props.key}\n      x={props.x}\n      y={props.y}\n      width={props.width}\n      height={props.height}\n      fill={fillColor}\n      rx={BAR_RADIUS}\n      onClick={props.onClick}\n      onMouseEnter={() => props.enableHover && setFillColor(lightenColor(props.fill, 0.8))}\n      onMouseLeave={() => props.enableHover && setFillColor(props.fill)}\n      className={props.enableHover ? css({ cursor: 'pointer' }) : ''}\n    />\n  );\n};\n"]} */",
|
|
43377
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
43292
43378
|
}) : ''
|
|
43293
43379
|
}, props.key);
|
|
43294
43380
|
};
|
|
@@ -48241,7 +48327,7 @@ var Legend$2 = function Legend(_ref) {
|
|
|
48241
48327
|
});
|
|
48242
48328
|
};
|
|
48243
48329
|
|
|
48244
|
-
var _excluded$
|
|
48330
|
+
var _excluded$h = ["formattedValue"],
|
|
48245
48331
|
_excluded2$4 = ["formattedValue"];
|
|
48246
48332
|
var AXIS_TITLE_STYLES$1 = {
|
|
48247
48333
|
opacity: '0.75',
|
|
@@ -48265,6 +48351,8 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
48265
48351
|
tooltipLeft = _useTooltip$tooltipLe === void 0 ? 0 : _useTooltip$tooltipLe,
|
|
48266
48352
|
_useTooltip$tooltipTo = _useTooltip.tooltipTop,
|
|
48267
48353
|
tooltipTop = _useTooltip$tooltipTo === void 0 ? 0 : _useTooltip$tooltipTo,
|
|
48354
|
+
_useTooltip$lineLeft = _useTooltip.lineLeft,
|
|
48355
|
+
lineLeft = _useTooltip$lineLeft === void 0 ? 0 : _useTooltip$lineLeft,
|
|
48268
48356
|
tooltipData = _useTooltip.tooltipData,
|
|
48269
48357
|
hideTooltip = _useTooltip.hideTooltip,
|
|
48270
48358
|
showTooltip = _useTooltip.showTooltip;
|
|
@@ -48363,8 +48451,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
48363
48451
|
chartType: 'bar'
|
|
48364
48452
|
});
|
|
48365
48453
|
showTooltip({
|
|
48366
|
-
|
|
48367
|
-
|
|
48454
|
+
lineLeft: tooltipData == null ? void 0 : tooltipData.lineLeft,
|
|
48455
|
+
tooltipLeft: event.pageX,
|
|
48456
|
+
tooltipTop: event.pageY,
|
|
48368
48457
|
tooltipData: tooltipData == null ? void 0 : tooltipData.tooltipData
|
|
48369
48458
|
});
|
|
48370
48459
|
}, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, formattedChartDataForBarChart.x.scale.ordering, formattedChartDataForBarChart.data]);
|
|
@@ -48446,7 +48535,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
48446
48535
|
tickValues: xTickValues,
|
|
48447
48536
|
tickComponent: function tickComponent(_ref2) {
|
|
48448
48537
|
var formattedValue = _ref2.formattedValue,
|
|
48449
|
-
tickProps = _objectWithoutPropertiesLoose(_ref2, _excluded$
|
|
48538
|
+
tickProps = _objectWithoutPropertiesLoose(_ref2, _excluded$h);
|
|
48450
48539
|
return jsx(Text, _extends({
|
|
48451
48540
|
style: themeCSS.labels
|
|
48452
48541
|
}, tickProps, {
|
|
@@ -48512,19 +48601,10 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
48512
48601
|
})
|
|
48513
48602
|
})]
|
|
48514
48603
|
}), tooltipData && jsx("g", {
|
|
48515
|
-
children: jsx(Line
|
|
48516
|
-
|
|
48517
|
-
|
|
48518
|
-
|
|
48519
|
-
},
|
|
48520
|
-
to: {
|
|
48521
|
-
x: tooltipLeft,
|
|
48522
|
-
y: innerHeight + margin.top
|
|
48523
|
-
},
|
|
48524
|
-
stroke: '#aaa',
|
|
48525
|
-
strokeWidth: 2,
|
|
48526
|
-
pointerEvents: "none",
|
|
48527
|
-
opacity: 0.8
|
|
48604
|
+
children: jsx(Line, {
|
|
48605
|
+
x: lineLeft,
|
|
48606
|
+
margin: margin,
|
|
48607
|
+
height: innerHeight
|
|
48528
48608
|
})
|
|
48529
48609
|
})]
|
|
48530
48610
|
}), jsx(Legend$2, {
|
|
@@ -70928,7 +71008,7 @@ var GlobalProviderContents = function GlobalProviderContents(props) {
|
|
|
70928
71008
|
});
|
|
70929
71009
|
};
|
|
70930
71010
|
|
|
70931
|
-
var _excluded$
|
|
71011
|
+
var _excluded$i = ["view"];
|
|
70932
71012
|
var Dashboard$2 = function Dashboard(props) {
|
|
70933
71013
|
var handleOnError = function handleOnError(error, errorInfo) {
|
|
70934
71014
|
return (props == null ? void 0 : props.onError) && (props == null ? void 0 : props.onError(error, errorInfo));
|
|
@@ -70949,7 +71029,7 @@ var Editor$1 = function Editor(props) {
|
|
|
70949
71029
|
var handleOnError = function handleOnError(error, errorInfo) {
|
|
70950
71030
|
return (props == null ? void 0 : props.onError) && (props == null ? void 0 : props.onError(error, errorInfo));
|
|
70951
71031
|
};
|
|
70952
|
-
var resetProps = _objectWithoutPropertiesLoose(props, _excluded$
|
|
71032
|
+
var resetProps = _objectWithoutPropertiesLoose(props, _excluded$i);
|
|
70953
71033
|
return jsxs(ErrorBoundary, {
|
|
70954
71034
|
renderOnError: function renderOnError() {
|
|
70955
71035
|
return jsx("p", {
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@vizzly/dashboard",
|
|
3
3
|
"author": "james@vizzly.co",
|
|
4
|
-
"version": "0.14.4-dev-
|
|
4
|
+
"version": "0.14.4-dev-5f9d258f89c2ee8286ba7f049e91ade0dc1bdd18",
|
|
5
5
|
"source": "src/index.tsx",
|
|
6
6
|
"types": "./dist/dashboard/src/index.d.ts",
|
|
7
7
|
"module": "./dist/dashboard.esm.js",
|