@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
|
@@ -41909,8 +41909,7 @@ var getTooltipData = function getTooltipData(_ref) {
|
|
|
41909
41909
|
}
|
|
41910
41910
|
}
|
|
41911
41911
|
return {
|
|
41912
|
-
|
|
41913
|
-
tooltipTop: point.y,
|
|
41912
|
+
lineLeft: point.x,
|
|
41914
41913
|
tooltipData: tooltipData
|
|
41915
41914
|
};
|
|
41916
41915
|
};
|
|
@@ -41979,7 +41978,12 @@ var LegendItemTriangle = function LegendItemTriangle(_ref3) {
|
|
|
41979
41978
|
});
|
|
41980
41979
|
};
|
|
41981
41980
|
|
|
41981
|
+
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)."; }
|
|
41982
|
+
var MIN_TOOLTIP_WIDTH = 180;
|
|
41983
|
+
var TOOLTIP_OFFSET = 20;
|
|
41984
|
+
var SCROLLBAR_WIDTH = 40;
|
|
41982
41985
|
var Tooltip$1 = function Tooltip(_ref) {
|
|
41986
|
+
var _tooltipData$xKey$for;
|
|
41983
41987
|
var keys = _ref.keys,
|
|
41984
41988
|
legendItems = _ref.legendItems,
|
|
41985
41989
|
showRoundedTotal = _ref.showRoundedTotal,
|
|
@@ -41991,70 +41995,101 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
41991
41995
|
yKeys = _ref.yKeys,
|
|
41992
41996
|
conditionalFormattingRules = _ref.conditionalFormattingRules,
|
|
41993
41997
|
theme = _ref.theme;
|
|
41994
|
-
|
|
41995
|
-
|
|
41996
|
-
|
|
41997
|
-
|
|
41998
|
+
var tooltipRef = React.useRef(null);
|
|
41999
|
+
var _useState = React.useState({
|
|
42000
|
+
left: tooltipLeft
|
|
42001
|
+
}),
|
|
42002
|
+
position = _useState[0],
|
|
42003
|
+
setPosition = _useState[1];
|
|
42004
|
+
React.useEffect(function () {
|
|
42005
|
+
var adjustTooltipPosition = function adjustTooltipPosition() {
|
|
42006
|
+
var tooltipElement = tooltipRef.current;
|
|
42007
|
+
if (tooltipElement) {
|
|
42008
|
+
var screenWidth = window.innerWidth;
|
|
42009
|
+
var rect = tooltipElement.getBoundingClientRect();
|
|
42010
|
+
var width = rect.width;
|
|
42011
|
+
if (width < MIN_TOOLTIP_WIDTH) {
|
|
42012
|
+
width = MIN_TOOLTIP_WIDTH;
|
|
42013
|
+
}
|
|
42014
|
+
var left = tooltipLeft + TOOLTIP_OFFSET;
|
|
42015
|
+
if (tooltipLeft + width > screenWidth - SCROLLBAR_WIDTH) {
|
|
42016
|
+
left = tooltipLeft - width - TOOLTIP_OFFSET;
|
|
42017
|
+
}
|
|
42018
|
+
setPosition({
|
|
42019
|
+
left: left
|
|
42020
|
+
});
|
|
42021
|
+
}
|
|
42022
|
+
};
|
|
42023
|
+
adjustTooltipPosition();
|
|
42024
|
+
}, [tooltipLeft]);
|
|
42025
|
+
return /*#__PURE__*/ReactDOM.createPortal(jsxRuntime.jsx("div", {
|
|
42026
|
+
ref: tooltipRef,
|
|
42027
|
+
style: _extends({
|
|
42028
|
+
position: 'absolute',
|
|
42029
|
+
left: position.left,
|
|
42030
|
+
top: tooltipTop,
|
|
42031
|
+
zIndex: 2147483647 * 10
|
|
42032
|
+
}, theme),
|
|
41998
42033
|
children: jsxRuntime.jsxs("div", {
|
|
41999
42034
|
style: {
|
|
42000
42035
|
wordBreak: 'break-all'
|
|
42001
42036
|
},
|
|
42002
42037
|
children: [jsxRuntime.jsx("div", {
|
|
42003
|
-
|
|
42038
|
+
className: /*#__PURE__*/css$1.css({
|
|
42004
42039
|
fontFamily: 'inherit',
|
|
42005
42040
|
lineHeight: 'inherit',
|
|
42006
42041
|
letterSpacing: 'inherit',
|
|
42007
42042
|
fontWeight: 'bold',
|
|
42008
42043
|
fontSize: '15px',
|
|
42009
|
-
width: '100%'
|
|
42010
|
-
|
|
42011
|
-
|
|
42044
|
+
width: '100%',
|
|
42045
|
+
minWidth: MIN_TOOLTIP_WIDTH
|
|
42046
|
+
}, ";label:Tooltip;", "/*# 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"]} */"),
|
|
42047
|
+
children: (_tooltipData$xKey$for = tooltipData[xKey].formattedValue) != null ? _tooltipData$xKey$for : tooltipData[xKey].value
|
|
42012
42048
|
}), jsxRuntime.jsx("table", {
|
|
42013
42049
|
cellPadding: 0,
|
|
42014
42050
|
cellSpacing: 0,
|
|
42015
|
-
|
|
42016
|
-
|
|
42017
|
-
|
|
42018
|
-
|
|
42019
|
-
|
|
42020
|
-
},
|
|
42051
|
+
className: /*#__PURE__*/css$1.css( {
|
|
42052
|
+
name: "9a1sa-Tooltip",
|
|
42053
|
+
styles: "margin:0;border-spacing:0;border-collapse:inherit;border:none;label:Tooltip;",
|
|
42054
|
+
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"]} */",
|
|
42055
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
|
|
42056
|
+
}),
|
|
42021
42057
|
children: jsxRuntime.jsxs("tbody", {
|
|
42022
42058
|
children: [legendItems.map(function (legendItem, index) {
|
|
42023
42059
|
if (!tooltipData[legendItem.yKey] || tooltipData[legendItem.yKey].value === null) {
|
|
42024
42060
|
// yKey could not be found in tooltipData
|
|
42025
42061
|
return null;
|
|
42026
|
-
} else {
|
|
42027
|
-
return visibleYKeys.includes(legendItem.yKey) && jsxRuntime.jsxs("tr", {
|
|
42028
|
-
children: [jsxRuntime.jsx("td", {
|
|
42029
|
-
style: {
|
|
42030
|
-
verticalAlign: 'middle',
|
|
42031
|
-
padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
|
|
42032
|
-
width: 'auto'
|
|
42033
|
-
},
|
|
42034
|
-
children: jsxRuntime.jsx(LegendItemBox, {
|
|
42035
|
-
color: getColor({
|
|
42036
|
-
defaultColor: legendItem.color,
|
|
42037
|
-
value: tooltipData[legendItem.yKey].value,
|
|
42038
|
-
yKey: legendItem.yKey,
|
|
42039
|
-
conditionalFormattingRules: conditionalFormattingRules
|
|
42040
|
-
}),
|
|
42041
|
-
style: legendItem.style,
|
|
42042
|
-
yKey: legendItem.yKey
|
|
42043
|
-
})
|
|
42044
|
-
}), jsxRuntime.jsx("td", {
|
|
42045
|
-
style: {
|
|
42046
|
-
padding: '8px 0 0 0'
|
|
42047
|
-
},
|
|
42048
|
-
children: keys[legendItem.yKey].keyFormatted
|
|
42049
|
-
}), jsxRuntime.jsx("td", {
|
|
42050
|
-
style: {
|
|
42051
|
-
fontWeight: 'bold',
|
|
42052
|
-
padding: '8px 0 0 16px'
|
|
42053
|
-
},
|
|
42054
|
-
children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
|
|
42055
|
-
})]
|
|
42056
|
-
}, legendItem.yKey);
|
|
42057
42062
|
}
|
|
42063
|
+
return visibleYKeys.includes(legendItem.yKey) && jsxRuntime.jsxs("tr", {
|
|
42064
|
+
children: [jsxRuntime.jsx("td", {
|
|
42065
|
+
style: {
|
|
42066
|
+
verticalAlign: 'middle',
|
|
42067
|
+
padding: index === 0 ? '12px 8px 0 0' : '8px 8px 0 0',
|
|
42068
|
+
width: 'auto'
|
|
42069
|
+
},
|
|
42070
|
+
children: jsxRuntime.jsx(LegendItemBox, {
|
|
42071
|
+
color: getColor({
|
|
42072
|
+
defaultColor: legendItem.color,
|
|
42073
|
+
value: tooltipData[legendItem.yKey].value,
|
|
42074
|
+
yKey: legendItem.yKey,
|
|
42075
|
+
conditionalFormattingRules: conditionalFormattingRules
|
|
42076
|
+
}),
|
|
42077
|
+
style: legendItem.style,
|
|
42078
|
+
yKey: legendItem.yKey
|
|
42079
|
+
})
|
|
42080
|
+
}), jsxRuntime.jsx("td", {
|
|
42081
|
+
style: {
|
|
42082
|
+
padding: '8px 0 0 0'
|
|
42083
|
+
},
|
|
42084
|
+
children: keys[legendItem.yKey].keyFormatted
|
|
42085
|
+
}), jsxRuntime.jsx("td", {
|
|
42086
|
+
style: {
|
|
42087
|
+
fontWeight: 'bold',
|
|
42088
|
+
padding: '8px 0 0 16px'
|
|
42089
|
+
},
|
|
42090
|
+
children: tooltipData[legendItem.yKey].formattedValue ? tooltipData[legendItem.yKey].formattedValue : tooltipData[legendItem.yKey].value
|
|
42091
|
+
})]
|
|
42092
|
+
}, legendItem.yKey);
|
|
42058
42093
|
}), showRoundedTotal && jsxRuntime.jsxs("tr", {
|
|
42059
42094
|
children: [jsxRuntime.jsx("td", {
|
|
42060
42095
|
colSpan: 2,
|
|
@@ -42075,10 +42110,10 @@ var Tooltip$1 = function Tooltip(_ref) {
|
|
|
42075
42110
|
})
|
|
42076
42111
|
})]
|
|
42077
42112
|
})
|
|
42078
|
-
},
|
|
42113
|
+
}), document.body);
|
|
42079
42114
|
};
|
|
42080
42115
|
|
|
42081
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42116
|
+
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)."; }
|
|
42082
42117
|
var LegendItem = function LegendItem(_ref) {
|
|
42083
42118
|
var yKey = _ref.yKey,
|
|
42084
42119
|
yKeyFormatted = _ref.yKeyFormatted,
|
|
@@ -42111,7 +42146,7 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42111
42146
|
name: "mefz6m-LegendItem",
|
|
42112
42147
|
styles: "height:10px;display:flex;label:LegendItem;",
|
|
42113
42148
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStDeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
|
|
42114
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42149
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
42115
42150
|
}),
|
|
42116
42151
|
children: [jsxRuntime.jsx(LegendItemBox, {
|
|
42117
42152
|
color: color,
|
|
@@ -42129,7 +42164,7 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42129
42164
|
name: "pglbco-LegendItem",
|
|
42130
42165
|
styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
|
|
42131
42166
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZEeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
|
|
42132
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42167
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
42133
42168
|
}),
|
|
42134
42169
|
children: [jsxRuntime.jsx(LegendItemSquare, {
|
|
42135
42170
|
color: color
|
|
@@ -42143,7 +42178,7 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42143
42178
|
name: "pglbco-LegendItem",
|
|
42144
42179
|
styles: "display:flex;flex-direction:row;align-items:center;gap:2px;label:LegendItem;",
|
|
42145
42180
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9FeUIiLCJmaWxlIjoiTGVnZW5kSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExlZ2VuZEl0ZW1Cb3ggfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtU3F1YXJlLCBMZWdlbmRJdGVtVHJpYW5nbGUgfSBmcm9tICcuLi9MZWdlbmRJdGVtQm94L0xlZ2VuZEl0ZW1Cb3gnO1xuaW1wb3J0IHsgU2hhcGVEZWZpbml0aW9uLCBDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9DaGFydHNWMi90eXBlcyc7XG5pbXBvcnQgeyBMaW5lU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9MaW5lQ2hhcnRWMi90eXBlcyc7XG5pbXBvcnQgeyBCYXJTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0JhckNoYXJ0VjIvdHlwZXMnO1xuaW1wb3J0IHsgQXJlYVN0eWxlcyB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQXJlYUNoYXJ0VjIvdHlwZXMnO1xuXG5pbnRlcmZhY2UgTGVnZW5kSXRlbVByb3BzPFQ+IGV4dGVuZHMgU2hhcGVEZWZpbml0aW9uPFQ+IHtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgdmlzaWJsZTogYm9vbGVhbjtcbiAgeUtleUZvcm1hdHRlZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlczogQXJyYXk8Q29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZT47XG59XG5cbmV4cG9ydCBjb25zdCBMZWdlbmRJdGVtID0gKHtcbiAgeUtleSxcbiAgeUtleUZvcm1hdHRlZCxcbiAgY29sb3IsXG4gIHN0eWxlLFxuICBvbkNsaWNrLFxuICB2aXNpYmxlLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbn06IExlZ2VuZEl0ZW1Qcm9wczxCYXJTdHlsZXMgfCBMaW5lU3R5bGVzIHwgQXJlYVN0eWxlcz4pID0+IHtcbiAgY29uc3QgcmVsZXZhbnRSdWxlcyA9IHVzZU1lbW8oKCkgPT4gY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXMuZmlsdGVyKHJ1bGUgPT4gcnVsZS55S2V5ID09PSB5S2V5KSwgW1xuICAgIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzLFxuICBdKTtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGtleT17YGxlZ2VuZC0ke3lLZXl9YH1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgc3R5bGU9e3tcbiAgICAgICAgYWxsOiAndW5zZXQnLFxuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIG91dGxpbmU6ICdyZXZlcnQnLFxuICAgICAgICBnYXA6ICc0cHgnLFxuICAgICAgICBwYWRkaW5nOiAnNHB4JyxcbiAgICAgICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgICAgIG1hcmdpblJpZ2h0OiAnMTBweCcsXG4gICAgICB9fVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7c3R5bGUudHlwZSA9PT0gJ2xpbmUnICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDEwLCBkaXNwbGF5OiAnZmxleCcgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtQm94IGNvbG9yPXtjb2xvcn0gc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9IHlLZXk9e3lLZXl9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiAoXG4gICAgICAgICAgICAgIDxMZWdlbmRJdGVtQm94XG4gICAgICAgICAgICAgICAgY29sb3I9e3J1bGUuY29sb3J9XG4gICAgICAgICAgICAgICAga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9XG4gICAgICAgICAgICAgICAgc3R5bGU9e3N0eWxlIGFzIExpbmVTdHlsZXN9XG4gICAgICAgICAgICAgICAgeUtleT17eUtleX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L3NwYW4+XG4gICAgICApfVxuICAgICAge3N0eWxlLnR5cGUgPT09ICdiYXInICYmIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtjc3MoeyBkaXNwbGF5OiAnZmxleCcsIGZsZXhEaXJlY3Rpb246ICdyb3cnLCBhbGlnbkl0ZW1zOiAnY2VudGVyJywgZ2FwOiAyIH0pfT5cbiAgICAgICAgICA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAge3JlbGV2YW50UnVsZXMubGVuZ3RoID4gMCAmJlxuICAgICAgICAgICAgcmVsZXZhbnRSdWxlcy5tYXAocnVsZSA9PiA8TGVnZW5kSXRlbVNxdWFyZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIHtzdHlsZS50eXBlID09PSAnYXJlYScgJiYgKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2Nzcyh7IGRpc3BsYXk6ICdmbGV4JywgZmxleERpcmVjdGlvbjogJ3JvdycsIGFsaWduSXRlbXM6ICdjZW50ZXInLCBnYXA6IDIgfSl9PlxuICAgICAgICAgIDxMZWdlbmRJdGVtVHJpYW5nbGUgY29sb3I9e2NvbG9yfSAvPlxuICAgICAgICAgIHtyZWxldmFudFJ1bGVzLmxlbmd0aCA+IDAgJiZcbiAgICAgICAgICAgIHJlbGV2YW50UnVsZXMubWFwKHJ1bGUgPT4gPExlZ2VuZEl0ZW1UcmlhbmdsZSBjb2xvcj17cnVsZS5jb2xvcn0ga2V5PXtgcnVsZS0ke0pTT04uc3RyaW5naWZ5KHJ1bGUpfWB9IC8+KX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKX1cbiAgICAgIDxzcGFuXG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgZm9udFNpemU6ICcxMnB4JyxcbiAgICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgICAgZGlzcGxheTogJ2Jsb2NrJyxcbiAgICAgICAgICB0ZXh0RGVjb3JhdGlvbjogdmlzaWJsZSA/ICdub25lJyA6ICdsaW5lLXRocm91Z2gnLFxuICAgICAgICAgIHRleHRXcmFwOiAnbm93cmFwJyxcbiAgICAgICAgfX1cbiAgICAgID5cbiAgICAgICAge3lLZXlGb3JtYXR0ZWQgPyB5S2V5Rm9ybWF0dGVkIDogeUtleX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgKTtcbn07XG4iXX0= */",
|
|
42146
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42181
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$6
|
|
42147
42182
|
}),
|
|
42148
42183
|
children: [jsxRuntime.jsx(LegendItemTriangle, {
|
|
42149
42184
|
color: color
|
|
@@ -42165,7 +42200,7 @@ var LegendItem = function LegendItem(_ref) {
|
|
|
42165
42200
|
}, "legend-" + yKey);
|
|
42166
42201
|
};
|
|
42167
42202
|
|
|
42168
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42203
|
+
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)."; }
|
|
42169
42204
|
var Legend$1 = function Legend(_ref) {
|
|
42170
42205
|
var keys = _ref.keys,
|
|
42171
42206
|
visibleYKeys = _ref.visibleYKeys,
|
|
@@ -42178,7 +42213,7 @@ var Legend$1 = function Legend(_ref) {
|
|
|
42178
42213
|
name: "qz6h7j-Legend",
|
|
42179
42214
|
styles: "height:40px;padding-top:8px;label:Legend;",
|
|
42180
42215
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxlZ2VuZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJvQiIsImZpbGUiOiJMZWdlbmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgTGVnZW5kSXRlbSB9IGZyb20gJy4vTGVnZW5kSXRlbSc7XG5pbXBvcnQgeyBTaGFwZURlZmluaXRpb24sIENvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGUsIEtleSB9IGZyb20gJ3NoYXJlZC1sb2dpYy9zcmMvQ2hhcnRzVjIvdHlwZXMnO1xuaW1wb3J0IHsgU2Nyb2xsYmFyIH0gZnJvbSAnLi4vLi4vLi4vU2Nyb2xsYmFyL1Njcm9sbGJhcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsgQmFyU3R5bGVzIH0gZnJvbSAnc2hhcmVkLWxvZ2ljL3NyYy9CYXJDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IExpbmVTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0xpbmVDaGFydFYyL3R5cGVzJztcbmltcG9ydCB7IEFyZWFTdHlsZXMgfSBmcm9tICdzaGFyZWQtbG9naWMvc3JjL0FyZWFDaGFydFYyL3R5cGVzJztcblxuaW50ZXJmYWNlIExlZ2VuZFByb3BzPFQ+IHtcbiAgc2V0VmlzaWJsZVlLZXlzOiBSZWFjdC5EaXNwYXRjaDxSZWFjdC5TZXRTdGF0ZUFjdGlvbjxBcnJheTxzdHJpbmc+Pj47XG4gIHZpc2libGVZS2V5czogQXJyYXk8c3RyaW5nPjtcbiAga2V5czogeyBba2V5OiBzdHJpbmddOiBLZXkgfTtcbiAgbGVnZW5kSXRlbXM6IEFycmF5PFNoYXBlRGVmaW5pdGlvbjxUPj47XG4gIGNvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzOiBBcnJheTxDb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlPjtcbiAgbWFyZ2luTGVmdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgTGVnZW5kID0gKHtcbiAga2V5cyxcbiAgdmlzaWJsZVlLZXlzLFxuICBsZWdlbmRJdGVtcyxcbiAgc2V0VmlzaWJsZVlLZXlzLFxuICBjb25kaXRpb25hbEZvcm1hdHRpbmdSdWxlcyxcbiAgbWFyZ2luTGVmdCxcbn06IExlZ2VuZFByb3BzPEJhclN0eWxlcyB8IExpbmVTdHlsZXMgfCBBcmVhU3R5bGVzPikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjc3MoeyBoZWlnaHQ6IDQwLCBwYWRkaW5nVG9wOiA4IH0pfT5cbiAgICAgIDxTY3JvbGxiYXJcbiAgICAgICAgY2xhc3NOYW1lPXtjc3Moe1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgICBmbGV4V3JhcDogJ25vd3JhcCcsXG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgICAgbWFyZ2luTGVmdDogbWFyZ2luTGVmdCA/IGAke21hcmdpbkxlZnR9cHhgIDogdW5kZWZpbmVkLFxuICAgICAgICB9KX1cbiAgICAgICAgeD17dHJ1ZX1cbiAgICAgID5cbiAgICAgICAge2xlZ2VuZEl0ZW1zLm1hcChcbiAgICAgICAgICBsZWdlbmRJdGVtID0+XG4gICAgICAgICAgICBrZXlzW2xlZ2VuZEl0ZW0ueUtleV0gJiYgKFxuICAgICAgICAgICAgICA8TGVnZW5kSXRlbVxuICAgICAgICAgICAgICAgIHsuLi5sZWdlbmRJdGVtfVxuICAgICAgICAgICAgICAgIGtleT17YGxlZ2VuZC0ke2xlZ2VuZEl0ZW0ueUtleX1gfVxuICAgICAgICAgICAgICAgIHlLZXlGb3JtYXR0ZWQ9e2tleXNbbGVnZW5kSXRlbS55S2V5XS5rZXlGb3JtYXR0ZWR9XG4gICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT5cbiAgICAgICAgICAgICAgICAgIHNldFZpc2libGVZS2V5cyhwcmV2ID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IG5ld1Zpc2libGVMZWdlbmRJdGVtczogQXJyYXk8c3RyaW5nPiA9IFtdO1xuXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcmV2Lmxlbmd0aCA9PT0gbGVnZW5kSXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gW2xlZ2VuZEl0ZW0ueUtleV07XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgaWYgKHByZXYuaW5jbHVkZXMobGVnZW5kSXRlbS55S2V5KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zID0gcHJldi5maWx0ZXIocHJldkxlZ2VuZEl0ZW1JZCA9PiBwcmV2TGVnZW5kSXRlbUlkICE9PSBsZWdlbmRJdGVtLnlLZXkpO1xuICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBuZXdWaXNpYmxlTGVnZW5kSXRlbXMgPSBbLi4ucHJldiwgbGVnZW5kSXRlbS55S2V5XTtcbiAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zLmxlbmd0aCA9PT0gMFxuICAgICAgICAgICAgICAgICAgICAgID8gbGVnZW5kSXRlbXMubWFwKGxlZ2VuZEl0ZW0gPT4gbGVnZW5kSXRlbS55S2V5KVxuICAgICAgICAgICAgICAgICAgICAgIDogbmV3VmlzaWJsZUxlZ2VuZEl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgdmlzaWJsZT17dmlzaWJsZVlLZXlzLmluY2x1ZGVzKGxlZ2VuZEl0ZW0ueUtleSl9XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uYWxGb3JtYXR0aW5nUnVsZXM9e2NvbmRpdGlvbmFsRm9ybWF0dGluZ1J1bGVzfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKVxuICAgICAgICApfVxuICAgICAgPC9TY3JvbGxiYXI+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuIl19 */",
|
|
42181
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42216
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$7
|
|
42182
42217
|
}),
|
|
42183
42218
|
children: jsxRuntime.jsx(Scrollbar, {
|
|
42184
42219
|
className: /*#__PURE__*/css$1.css({
|
|
@@ -42556,7 +42591,7 @@ var GridRows = function GridRows(_ref) {
|
|
|
42556
42591
|
});
|
|
42557
42592
|
};
|
|
42558
42593
|
|
|
42559
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42594
|
+
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)."; }
|
|
42560
42595
|
var ChartWrapper$1 = function ChartWrapper(props) {
|
|
42561
42596
|
return jsxRuntime.jsx("svg", {
|
|
42562
42597
|
width: props.width,
|
|
@@ -42567,7 +42602,7 @@ var ChartWrapper$1 = function ChartWrapper(props) {
|
|
|
42567
42602
|
name: "fx4tbw-ChartWrapper",
|
|
42568
42603
|
styles: "display:block;label:ChartWrapper;",
|
|
42569
42604
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoYXJ0V3JhcHBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JpQiIsImZpbGUiOiJDaGFydFdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY3NzJztcblxuZXhwb3J0IGNvbnN0IENoYXJ0V3JhcHBlciA9IChwcm9wczoge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlO1xuICB3aWR0aDogbnVtYmVyO1xuICBoZWlnaHQ6IG51bWJlcjtcbiAgc2hvd0xlZ2VuZDogYm9vbGVhbjtcbiAgb25Nb3VzZU1vdmU/OiBSZWFjdC5Nb3VzZUV2ZW50SGFuZGxlcjxTVkdTVkdFbGVtZW50PjtcbiAgb25Nb3VzZUxlYXZlPzogUmVhY3QuTW91c2VFdmVudEhhbmRsZXI8U1ZHU1ZHRWxlbWVudD47XG59KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPHN2Z1xuICAgICAgd2lkdGg9e3Byb3BzLndpZHRofVxuICAgICAgaGVpZ2h0PXtwcm9wcy5oZWlnaHQgLSAocHJvcHMuc2hvd0xlZ2VuZCA/IDQwIDogMCl9XG4gICAgICBvbk1vdXNlTW92ZT17cHJvcHMub25Nb3VzZU1vdmV9XG4gICAgICBvbk1vdXNlTGVhdmU9e3Byb3BzLm9uTW91c2VMZWF2ZX1cbiAgICAgIGNsYXNzTmFtZT17Y3NzKHsgZGlzcGxheTogJ2Jsb2NrJyB9KX1cbiAgICA+XG4gICAgICB7cHJvcHMuY2hpbGRyZW59XG4gICAgPC9zdmc+XG4gICk7XG59O1xuIl19 */",
|
|
42570
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
42605
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
|
|
42571
42606
|
}),
|
|
42572
42607
|
children: props.children
|
|
42573
42608
|
});
|
|
@@ -42635,6 +42670,48 @@ var Line = function Line(_ref) {
|
|
|
42635
42670
|
});
|
|
42636
42671
|
};
|
|
42637
42672
|
|
|
42673
|
+
var _excluded$g = ["tooltipOpen"];
|
|
42674
|
+
function useTooltip$1(initialTooltipState) {
|
|
42675
|
+
var _useState = React.useState(_extends({
|
|
42676
|
+
tooltipOpen: false
|
|
42677
|
+
}, initialTooltipState)),
|
|
42678
|
+
tooltipState = _useState[0],
|
|
42679
|
+
setTooltipState = _useState[1];
|
|
42680
|
+
var showTooltip = React.useCallback(function (showArgs) {
|
|
42681
|
+
return setTooltipState(typeof showArgs === 'function' ? function (_ref) {
|
|
42682
|
+
var show = _objectWithoutPropertiesLoose(_ref, _excluded$g);
|
|
42683
|
+
return _extends({}, showArgs(show), {
|
|
42684
|
+
tooltipOpen: true
|
|
42685
|
+
});
|
|
42686
|
+
} : {
|
|
42687
|
+
tooltipOpen: true,
|
|
42688
|
+
tooltipLeft: showArgs.tooltipLeft,
|
|
42689
|
+
tooltipTop: showArgs.tooltipTop,
|
|
42690
|
+
lineLeft: showArgs.lineLeft,
|
|
42691
|
+
tooltipData: showArgs.tooltipData
|
|
42692
|
+
});
|
|
42693
|
+
}, [setTooltipState]);
|
|
42694
|
+
var hideTooltip = React.useCallback(function () {
|
|
42695
|
+
return setTooltipState({
|
|
42696
|
+
tooltipOpen: false,
|
|
42697
|
+
tooltipLeft: undefined,
|
|
42698
|
+
lineLeft: undefined,
|
|
42699
|
+
tooltipTop: undefined,
|
|
42700
|
+
tooltipData: undefined
|
|
42701
|
+
});
|
|
42702
|
+
}, [setTooltipState]);
|
|
42703
|
+
return {
|
|
42704
|
+
tooltipOpen: tooltipState.tooltipOpen,
|
|
42705
|
+
tooltipLeft: tooltipState.tooltipLeft,
|
|
42706
|
+
tooltipTop: tooltipState.tooltipTop,
|
|
42707
|
+
lineLeft: tooltipState.lineLeft,
|
|
42708
|
+
tooltipData: tooltipState.tooltipData,
|
|
42709
|
+
updateTooltip: setTooltipState,
|
|
42710
|
+
showTooltip: showTooltip,
|
|
42711
|
+
hideTooltip: hideTooltip
|
|
42712
|
+
};
|
|
42713
|
+
}
|
|
42714
|
+
|
|
42638
42715
|
var LineChart$5 = function LineChart(_ref) {
|
|
42639
42716
|
var _theme$axis;
|
|
42640
42717
|
var chart = _ref.chart,
|
|
@@ -42642,12 +42719,14 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42642
42719
|
theme = _ref.theme,
|
|
42643
42720
|
width = _ref.width,
|
|
42644
42721
|
height = _ref.height;
|
|
42645
|
-
var _useTooltip =
|
|
42722
|
+
var _useTooltip = useTooltip$1(),
|
|
42646
42723
|
tooltipOpen = _useTooltip.tooltipOpen,
|
|
42647
42724
|
_useTooltip$tooltipLe = _useTooltip.tooltipLeft,
|
|
42648
42725
|
tooltipLeft = _useTooltip$tooltipLe === void 0 ? 0 : _useTooltip$tooltipLe,
|
|
42649
42726
|
_useTooltip$tooltipTo = _useTooltip.tooltipTop,
|
|
42650
42727
|
tooltipTop = _useTooltip$tooltipTo === void 0 ? 0 : _useTooltip$tooltipTo,
|
|
42728
|
+
_useTooltip$lineLeft = _useTooltip.lineLeft,
|
|
42729
|
+
lineLeft = _useTooltip$lineLeft === void 0 ? 0 : _useTooltip$lineLeft,
|
|
42651
42730
|
tooltipData = _useTooltip.tooltipData,
|
|
42652
42731
|
hideTooltip = _useTooltip.hideTooltip,
|
|
42653
42732
|
showTooltip = _useTooltip.showTooltip;
|
|
@@ -42719,8 +42798,9 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42719
42798
|
chartType: 'lines'
|
|
42720
42799
|
});
|
|
42721
42800
|
showTooltip({
|
|
42722
|
-
|
|
42723
|
-
|
|
42801
|
+
lineLeft: tooltipData == null ? void 0 : tooltipData.lineLeft,
|
|
42802
|
+
tooltipLeft: event.pageX,
|
|
42803
|
+
tooltipTop: event.pageY,
|
|
42724
42804
|
tooltipData: tooltipData == null ? void 0 : tooltipData.tooltipData
|
|
42725
42805
|
});
|
|
42726
42806
|
}, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]);
|
|
@@ -42855,7 +42935,7 @@ var LineChart$5 = function LineChart(_ref) {
|
|
|
42855
42935
|
})]
|
|
42856
42936
|
}), tooltipData && jsxRuntime.jsxs("g", {
|
|
42857
42937
|
children: [jsxRuntime.jsx(Line, {
|
|
42858
|
-
x:
|
|
42938
|
+
x: lineLeft,
|
|
42859
42939
|
margin: margin,
|
|
42860
42940
|
height: innerHeight
|
|
42861
42941
|
}), jsxRuntime.jsx(CrosshairCircle, {
|
|
@@ -42929,7 +43009,7 @@ function getBarFill(bars, conditionalFormattingRules, barKey, barValues) {
|
|
|
42929
43009
|
return fill;
|
|
42930
43010
|
}
|
|
42931
43011
|
|
|
42932
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
43012
|
+
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)."; }
|
|
42933
43013
|
var BAR_RADIUS = 2;
|
|
42934
43014
|
var PADDING = {
|
|
42935
43015
|
paddingOuter: 0.05,
|
|
@@ -42944,12 +43024,14 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
42944
43024
|
theme = _ref.theme,
|
|
42945
43025
|
onClick = _ref.onClick,
|
|
42946
43026
|
enableHover = _ref.enableHover;
|
|
42947
|
-
var _useTooltip =
|
|
43027
|
+
var _useTooltip = useTooltip$1(),
|
|
42948
43028
|
tooltipOpen = _useTooltip.tooltipOpen,
|
|
42949
43029
|
_useTooltip$tooltipLe = _useTooltip.tooltipLeft,
|
|
42950
43030
|
tooltipLeft = _useTooltip$tooltipLe === void 0 ? 0 : _useTooltip$tooltipLe,
|
|
42951
43031
|
_useTooltip$tooltipTo = _useTooltip.tooltipTop,
|
|
42952
43032
|
tooltipTop = _useTooltip$tooltipTo === void 0 ? 0 : _useTooltip$tooltipTo,
|
|
43033
|
+
_useTooltip$lineLeft = _useTooltip.lineLeft,
|
|
43034
|
+
lineLeft = _useTooltip$lineLeft === void 0 ? 0 : _useTooltip$lineLeft,
|
|
42953
43035
|
tooltipData = _useTooltip.tooltipData,
|
|
42954
43036
|
hideTooltip = _useTooltip.hideTooltip,
|
|
42955
43037
|
showTooltip = _useTooltip.showTooltip;
|
|
@@ -43022,8 +43104,9 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43022
43104
|
chartType: 'bar'
|
|
43023
43105
|
});
|
|
43024
43106
|
showTooltip({
|
|
43025
|
-
|
|
43026
|
-
|
|
43107
|
+
lineLeft: tooltipData == null ? void 0 : tooltipData.lineLeft,
|
|
43108
|
+
tooltipLeft: event.pageX,
|
|
43109
|
+
tooltipTop: event.pageY,
|
|
43027
43110
|
tooltipData: tooltipData == null ? void 0 : tooltipData.tooltipData
|
|
43028
43111
|
});
|
|
43029
43112
|
}, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, chart.x.scale.ordering, chart.data]);
|
|
@@ -43173,7 +43256,7 @@ var BarChart$5 = function BarChart(_ref) {
|
|
|
43173
43256
|
})]
|
|
43174
43257
|
}), tooltipData && jsxRuntime.jsx("g", {
|
|
43175
43258
|
children: jsxRuntime.jsx(Line, {
|
|
43176
|
-
x:
|
|
43259
|
+
x: lineLeft,
|
|
43177
43260
|
margin: margin,
|
|
43178
43261
|
height: innerHeight
|
|
43179
43262
|
})
|
|
@@ -43232,8 +43315,8 @@ var Bar = function Bar(props) {
|
|
|
43232
43315
|
className: props.enableHover ? /*#__PURE__*/css$1.css( {
|
|
43233
43316
|
name: "4nk3o1-Bar",
|
|
43234
43317
|
styles: "cursor:pointer;label:Bar;",
|
|
43235
|
-
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"]} */",
|
|
43236
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
43318
|
+
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"]} */",
|
|
43319
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
43237
43320
|
}) : ''
|
|
43238
43321
|
}, props.key);
|
|
43239
43322
|
};
|
|
@@ -48186,7 +48269,7 @@ var Legend$2 = function Legend(_ref) {
|
|
|
48186
48269
|
});
|
|
48187
48270
|
};
|
|
48188
48271
|
|
|
48189
|
-
var _excluded$
|
|
48272
|
+
var _excluded$h = ["formattedValue"],
|
|
48190
48273
|
_excluded2$4 = ["formattedValue"];
|
|
48191
48274
|
var AXIS_TITLE_STYLES$1 = {
|
|
48192
48275
|
opacity: '0.75',
|
|
@@ -48204,12 +48287,14 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
48204
48287
|
if (chart.x.scale.dataType === 'date_time' || chart.x.scale.dataType === 'number') {
|
|
48205
48288
|
return null;
|
|
48206
48289
|
}
|
|
48207
|
-
var _useTooltip =
|
|
48290
|
+
var _useTooltip = useTooltip$1(),
|
|
48208
48291
|
tooltipOpen = _useTooltip.tooltipOpen,
|
|
48209
48292
|
_useTooltip$tooltipLe = _useTooltip.tooltipLeft,
|
|
48210
48293
|
tooltipLeft = _useTooltip$tooltipLe === void 0 ? 0 : _useTooltip$tooltipLe,
|
|
48211
48294
|
_useTooltip$tooltipTo = _useTooltip.tooltipTop,
|
|
48212
48295
|
tooltipTop = _useTooltip$tooltipTo === void 0 ? 0 : _useTooltip$tooltipTo,
|
|
48296
|
+
_useTooltip$lineLeft = _useTooltip.lineLeft,
|
|
48297
|
+
lineLeft = _useTooltip$lineLeft === void 0 ? 0 : _useTooltip$lineLeft,
|
|
48213
48298
|
tooltipData = _useTooltip.tooltipData,
|
|
48214
48299
|
hideTooltip = _useTooltip.hideTooltip,
|
|
48215
48300
|
showTooltip = _useTooltip.showTooltip;
|
|
@@ -48308,8 +48393,9 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
48308
48393
|
chartType: 'bar'
|
|
48309
48394
|
});
|
|
48310
48395
|
showTooltip({
|
|
48311
|
-
|
|
48312
|
-
|
|
48396
|
+
lineLeft: tooltipData == null ? void 0 : tooltipData.lineLeft,
|
|
48397
|
+
tooltipLeft: event.pageX,
|
|
48398
|
+
tooltipTop: event.pageY,
|
|
48313
48399
|
tooltipData: tooltipData == null ? void 0 : tooltipData.tooltipData
|
|
48314
48400
|
});
|
|
48315
48401
|
}, [showTooltip, xScale, margin, xKey, xScaleKey, xScaleDataType, formattedChartDataForBarChart.x.scale.ordering, formattedChartDataForBarChart.data]);
|
|
@@ -48391,7 +48477,7 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
48391
48477
|
tickValues: xTickValues,
|
|
48392
48478
|
tickComponent: function tickComponent(_ref2) {
|
|
48393
48479
|
var formattedValue = _ref2.formattedValue,
|
|
48394
|
-
tickProps = _objectWithoutPropertiesLoose(_ref2, _excluded$
|
|
48480
|
+
tickProps = _objectWithoutPropertiesLoose(_ref2, _excluded$h);
|
|
48395
48481
|
return jsxRuntime.jsx(text$3.Text, _extends({
|
|
48396
48482
|
style: themeCSS.labels
|
|
48397
48483
|
}, tickProps, {
|
|
@@ -48457,19 +48543,10 @@ var WaterfallChart$2 = function WaterfallChart(_ref) {
|
|
|
48457
48543
|
})
|
|
48458
48544
|
})]
|
|
48459
48545
|
}), tooltipData && jsxRuntime.jsx("g", {
|
|
48460
|
-
children: jsxRuntime.jsx(
|
|
48461
|
-
|
|
48462
|
-
|
|
48463
|
-
|
|
48464
|
-
},
|
|
48465
|
-
to: {
|
|
48466
|
-
x: tooltipLeft,
|
|
48467
|
-
y: innerHeight + margin.top
|
|
48468
|
-
},
|
|
48469
|
-
stroke: '#aaa',
|
|
48470
|
-
strokeWidth: 2,
|
|
48471
|
-
pointerEvents: "none",
|
|
48472
|
-
opacity: 0.8
|
|
48546
|
+
children: jsxRuntime.jsx(Line, {
|
|
48547
|
+
x: lineLeft,
|
|
48548
|
+
margin: margin,
|
|
48549
|
+
height: innerHeight
|
|
48473
48550
|
})
|
|
48474
48551
|
})]
|
|
48475
48552
|
}), jsxRuntime.jsx(Legend$2, {
|
|
@@ -70873,7 +70950,7 @@ var GlobalProviderContents = function GlobalProviderContents(props) {
|
|
|
70873
70950
|
});
|
|
70874
70951
|
};
|
|
70875
70952
|
|
|
70876
|
-
var _excluded$
|
|
70953
|
+
var _excluded$i = ["view"];
|
|
70877
70954
|
var Dashboard$2 = function Dashboard(props) {
|
|
70878
70955
|
var handleOnError = function handleOnError(error, errorInfo) {
|
|
70879
70956
|
return (props == null ? void 0 : props.onError) && (props == null ? void 0 : props.onError(error, errorInfo));
|
|
@@ -70894,7 +70971,7 @@ var Editor$1 = function Editor(props) {
|
|
|
70894
70971
|
var handleOnError = function handleOnError(error, errorInfo) {
|
|
70895
70972
|
return (props == null ? void 0 : props.onError) && (props == null ? void 0 : props.onError(error, errorInfo));
|
|
70896
70973
|
};
|
|
70897
|
-
var resetProps = _objectWithoutPropertiesLoose(props, _excluded$
|
|
70974
|
+
var resetProps = _objectWithoutPropertiesLoose(props, _excluded$i);
|
|
70898
70975
|
return jsxRuntime.jsxs(ErrorBoundary, {
|
|
70899
70976
|
renderOnError: function renderOnError() {
|
|
70900
70977
|
return jsxRuntime.jsx("p", {
|