@undp/data-viz 2.1.3 → 2.1.4
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/AreaChart.cjs +1 -1
- package/dist/AreaChart.cjs.map +1 -1
- package/dist/AreaChart.js +279 -272
- package/dist/AreaChart.js.map +1 -1
- package/dist/BarGraph.cjs +1 -1
- package/dist/BarGraph.cjs.map +1 -1
- package/dist/BarGraph.d.ts +2 -0
- package/dist/BarGraph.js +1795 -1724
- package/dist/BarGraph.js.map +1 -1
- package/dist/BeeSwarmChart.cjs +1 -1
- package/dist/BeeSwarmChart.cjs.map +1 -1
- package/dist/BeeSwarmChart.js +312 -305
- package/dist/BeeSwarmChart.js.map +1 -1
- package/dist/BulletChart.cjs +1 -1
- package/dist/BulletChart.cjs.map +1 -1
- package/dist/BulletChart.js +298 -287
- package/dist/BulletChart.js.map +1 -1
- package/dist/ButterflyChart.cjs +1 -1
- package/dist/ButterflyChart.cjs.map +1 -1
- package/dist/ButterflyChart.js +224 -217
- package/dist/ButterflyChart.js.map +1 -1
- package/dist/CirclePackingGraph.cjs +1 -1
- package/dist/CirclePackingGraph.js +2 -2
- package/dist/DifferenceLineChart.cjs +1 -1
- package/dist/DifferenceLineChart.cjs.map +1 -1
- package/dist/DifferenceLineChart.js +404 -397
- package/dist/DifferenceLineChart.js.map +1 -1
- package/dist/DonutChart.cjs +1 -1
- package/dist/DonutChart.cjs.map +1 -1
- package/dist/DonutChart.js +42 -39
- package/dist/DonutChart.js.map +1 -1
- package/dist/DualAxisLineChart.cjs +1 -1
- package/dist/DualAxisLineChart.cjs.map +1 -1
- package/dist/DualAxisLineChart.js +320 -313
- package/dist/DualAxisLineChart.js.map +1 -1
- package/dist/DumbbellChart.cjs +1 -1
- package/dist/DumbbellChart.cjs.map +1 -1
- package/dist/DumbbellChart.js +298 -291
- package/dist/DumbbellChart.js.map +1 -1
- package/dist/{EmptyState-BZo1BbAn.js → EmptyState-C7ZXkZWd.js} +4 -4
- package/dist/EmptyState-C7ZXkZWd.js.map +1 -0
- package/dist/EmptyState-gLDRXBHm.cjs +2 -0
- package/dist/EmptyState-gLDRXBHm.cjs.map +1 -0
- package/dist/GraphEl-C2Fgg8PA.cjs +2 -0
- package/dist/GraphEl-C2Fgg8PA.cjs.map +1 -0
- package/dist/{GraphEl-CRrAlbcr.js → GraphEl-oZwZiTHI.js} +3 -2
- package/dist/GraphEl-oZwZiTHI.js.map +1 -0
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.js +1 -1
- package/dist/HeatMap.cjs +1 -1
- package/dist/HeatMap.cjs.map +1 -1
- package/dist/HeatMap.js +179 -172
- package/dist/HeatMap.js.map +1 -1
- package/dist/Histogram.cjs +1 -1
- package/dist/Histogram.js +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs.map +1 -1
- package/dist/LineChartWithConfidenceInterval.js +368 -361
- package/dist/LineChartWithConfidenceInterval.js.map +1 -1
- package/dist/MultiLineAltChart.cjs +1 -1
- package/dist/MultiLineAltChart.cjs.map +1 -1
- package/dist/MultiLineAltChart.js +327 -320
- package/dist/MultiLineAltChart.js.map +1 -1
- package/dist/MultiLineChart.cjs +1 -1
- package/dist/MultiLineChart.cjs.map +1 -1
- package/dist/MultiLineChart.js +374 -367
- package/dist/MultiLineChart.js.map +1 -1
- package/dist/ParetoChart.cjs +1 -1
- package/dist/ParetoChart.cjs.map +1 -1
- package/dist/ParetoChart.js +385 -378
- package/dist/ParetoChart.js.map +1 -1
- package/dist/RadarChart.cjs +1 -1
- package/dist/RadarChart.cjs.map +1 -1
- package/dist/RadarChart.js +34 -33
- package/dist/RadarChart.js.map +1 -1
- package/dist/SankeyChart.cjs +1 -1
- package/dist/SankeyChart.cjs.map +1 -1
- package/dist/SankeyChart.js +176 -169
- package/dist/SankeyChart.js.map +1 -1
- package/dist/ScatterPlot.cjs +1 -1
- package/dist/ScatterPlot.cjs.map +1 -1
- package/dist/ScatterPlot.js +366 -359
- package/dist/ScatterPlot.js.map +1 -1
- package/dist/SimpleLineChart.cjs +1 -1
- package/dist/SimpleLineChart.cjs.map +1 -1
- package/dist/SimpleLineChart.js +285 -278
- package/dist/SimpleLineChart.js.map +1 -1
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.js +1 -1
- package/dist/SlopeChart.cjs +1 -1
- package/dist/SlopeChart.cjs.map +1 -1
- package/dist/SlopeChart.js +243 -236
- package/dist/SlopeChart.js.map +1 -1
- package/dist/StripChart.cjs +1 -1
- package/dist/StripChart.cjs.map +1 -1
- package/dist/StripChart.js +293 -286
- package/dist/StripChart.js.map +1 -1
- package/dist/TreeMapGraph.cjs +1 -1
- package/dist/TreeMapGraph.cjs.map +1 -1
- package/dist/TreeMapGraph.js +222 -215
- package/dist/TreeMapGraph.js.map +1 -1
- package/dist/index-Blvf-Q3U.cjs +2 -0
- package/dist/{index-CF5hnGvG.cjs.map → index-Blvf-Q3U.cjs.map} +1 -1
- package/dist/index-D1RrKgK6.js +337 -0
- package/dist/index-D1RrKgK6.js.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.js +1 -1
- package/package.json +1 -1
- package/dist/EmptyState-BZo1BbAn.js.map +0 -1
- package/dist/EmptyState-sAEZ_5rU.cjs +0 -2
- package/dist/EmptyState-sAEZ_5rU.cjs.map +0 -1
- package/dist/GraphEl-BLMih7RN.cjs +0 -2
- package/dist/GraphEl-BLMih7RN.cjs.map +0 -1
- package/dist/GraphEl-CRrAlbcr.js.map +0 -1
- package/dist/index-CF5hnGvG.cjs +0 -2
- package/dist/index-DPGq3eIL.js +0 -330
- package/dist/index-DPGq3eIL.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index-CF5hnGvG.cjs","sources":["../node_modules/d3-array/src/extent.js","../src/Components/Graphs/CirclePackingGraph/Graph.tsx","../src/Components/Graphs/CirclePackingGraph/getMaxCircleRadius.ts","../src/Components/Graphs/CirclePackingGraph/index.tsx"],"sourcesContent":["export default function extent(values, valueof) {\n let min;\n let max;\n if (valueof === undefined) {\n for (const value of values) {\n if (value != null) {\n if (min === undefined) {\n if (value >= value) min = max = value;\n } else {\n if (min > value) min = value;\n if (max < value) max = value;\n }\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null) {\n if (min === undefined) {\n if (value >= value) min = max = value;\n } else {\n if (min > value) min = value;\n if (max < value) max = value;\n }\n }\n }\n }\n return [min, max];\n}\n","import { useEffect, useState, useRef } from 'react';\r\nimport { forceCollide, forceManyBody, forceSimulation, forceX, forceY } from 'd3-force';\r\nimport orderBy from 'lodash.orderby';\r\nimport { scaleSqrt } from 'd3-scale';\r\nimport { extent } from 'd3-array';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Spinner } from '@undp/design-system-react/Spinner';\r\nimport { P } from '@undp/design-system-react/Typography';\r\n\r\nimport { ClassNameObject, StyleObject, TreeMapDataType } from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { getTextColorBasedOnBgColor } from '@/Utils/getTextColorBasedOnBgColor';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n data: TreeMapDataType[];\r\n colors: string[];\r\n colorDomain: string[];\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n showLabels: boolean;\r\n showValues: boolean;\r\n width: number;\r\n height: number;\r\n suffix: string;\r\n prefix: string;\r\n selectedColor?: string;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n highlightedDataPoints: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n theme: 'light' | 'dark';\r\n maxRadiusValue?: number;\r\n radius: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n dimmedOpacity: number;\r\n precision: number;\r\n}\r\n\r\ninterface TreeMapDataTypeForBubbleChart extends TreeMapDataType {\r\n x: number;\r\n y: number;\r\n vx: number;\r\n vy: number;\r\n}\r\n\r\nexport const Graph = (props: Props) => {\r\n const {\r\n data,\r\n colors,\r\n leftMargin,\r\n width,\r\n height,\r\n colorDomain,\r\n selectedColor,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n showValues,\r\n suffix,\r\n prefix,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n maxRadiusValue,\r\n radius,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n dimmedOpacity,\r\n precision,\r\n } = props;\r\n const svgRef = useRef(null);\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [viewPortDimensions, setViewPortDimensions] = useState<\r\n [number, number, number, number] | undefined\r\n >(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const [finalData, setFinalData] = useState<TreeMapDataTypeForBubbleChart[] | null>(null);\r\n\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n // Memoize data ordering and radius scale\r\n const dataOrdered =\r\n data.filter(d => !checkIfNullOrUndefined(d.size)).length === 0\r\n ? data\r\n : orderBy(\r\n data.filter(d => !checkIfNullOrUndefined(d.size)),\r\n 'radius',\r\n 'asc',\r\n );\r\n\r\n const radiusScale =\r\n data.filter(d => d.size === undefined || d.size === null).length !== data.length\r\n ? scaleSqrt()\r\n .domain([\r\n 0,\r\n checkIfNullOrUndefined(maxRadiusValue)\r\n ? Math.max(...data.map(d => d.size).filter(d => d !== undefined && d !== null))\r\n : (maxRadiusValue as number),\r\n ])\r\n .range([0.25, radius])\r\n .nice()\r\n : undefined;\r\n\r\n // Memoize simulation setup\r\n useEffect(() => {\r\n const setupSimulation = () => {\r\n const dataTemp = dataOrdered.map(d => ({ ...d, ...(d.data && { data: { ...d.data } }) }));\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const simulation = forceSimulation(dataTemp as any)\r\n .force('y', forceY(_d => graphHeight / 2).strength(1))\r\n .force('x', forceX(_d => graphWidth / 2).strength(1))\r\n .force(\r\n 'collide',\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n forceCollide((d: any) => (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1)),\r\n )\r\n .force('charge', forceManyBody().strength(-15))\r\n .alphaDecay(0.05)\r\n .tick(10000);\r\n\r\n simulation\r\n .on('tick', () => {\r\n setFinalData(dataTemp as TreeMapDataTypeForBubbleChart[]);\r\n })\r\n .on('end', () => {\r\n setFinalData(dataTemp as TreeMapDataTypeForBubbleChart[]);\r\n const xMinExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.x - (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[0] || 0;\r\n const yMinExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.y - (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[0] || 0;\r\n const xMaxExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.x + (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[1] || 0;\r\n const yMaxExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.y + (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[1] || 0;\r\n setViewPortDimensions([\r\n xMinExtent,\r\n yMinExtent,\r\n xMinExtent < 0 ? xMaxExtent - xMinExtent : xMaxExtent,\r\n yMinExtent < 0 ? yMaxExtent - yMinExtent : yMaxExtent,\r\n ]);\r\n });\r\n };\r\n\r\n setupSimulation();\r\n }, [data, radius, graphHeight, graphWidth, maxRadiusValue, dataOrdered, radiusScale]);\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleMouseEnter = (event: any, d: any) => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleMouseMove = (event: any, d: any) => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleClick = (d: any) => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (mouseClickData === d.label && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d.label);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n };\r\n\r\n const handleMouseLeave = () => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const getCircleColor = (d: any) =>\r\n data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)];\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const getOpacity = (d: any) =>\r\n selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85;\r\n\r\n // Render loading state\r\n if (!finalData) {\r\n return (\r\n <div style={{ width: `${width}px`, height: `${height}px` }}>\r\n <div className='flex m-auto items-center justify-center p-0 leading-none text-base h-40'>\r\n <Spinner />\r\n </div>\r\n </div>\r\n );\r\n }\r\n if (viewPortDimensions) {\r\n return (\r\n <>\r\n <svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`${viewPortDimensions[0] > 0 ? 0 : viewPortDimensions[0]} ${\r\n viewPortDimensions[1] > 0 ? 0 : viewPortDimensions[1]\r\n } ${width < viewPortDimensions[2] ? viewPortDimensions[2] : width} ${\r\n height < viewPortDimensions[3] ? viewPortDimensions[3] : height\r\n }`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {finalData.map(d => {\r\n const circleColor = getCircleColor(d);\r\n const opacity = getOpacity(d);\r\n const bubbleRadius = radiusScale ? radiusScale(d.size || 0) : radius;\r\n const showLabel = bubbleRadius > 20 && (showLabels || showValues);\r\n return (\r\n <g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n opacity={opacity}\r\n transform={`translate(${d.x},${d.y})`}\r\n onMouseEnter={event => handleMouseEnter(event, d)}\r\n onMouseMove={event => handleMouseMove(event, d)}\r\n onClick={() => handleClick(d)}\r\n onMouseLeave={handleMouseLeave}\r\n >\r\n <circle cx={0} cy={0} r={bubbleRadius} fill={circleColor} />\r\n {(showLabel || showValues) &&\r\n d.size !== undefined &&\r\n d.size !== null &&\r\n bubbleRadius >= 15 && (\r\n <g>\r\n <foreignObject\r\n y={0 - bubbleRadius}\r\n x={0 - bubbleRadius}\r\n width={2 * bubbleRadius}\r\n height={2 * bubbleRadius}\r\n >\r\n <div\r\n className='flex flex-col justify-center items-center h-full py-0 px-3'\r\n style={{\r\n display: 'flex',\r\n flexDirection: 'column',\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n height: '100%',\r\n padding: '0 0.75rem',\r\n }}\r\n >\r\n {showLabels && (\r\n <P\r\n className={cn(\r\n 'text-center leading-[1.25] overflow-hidden m-0 circle-packing-label',\r\n classNames?.graphObjectValues,\r\n )}\r\n marginBottom='none'\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(Math.round(bubbleRadius / 4), 12),\r\n Math.max(\r\n Math.round((bubbleRadius * 12) / `${d.label}`.length),\r\n 12,\r\n ),\r\n 14,\r\n )}px`,\r\n WebkitLineClamp:\r\n bubbleRadius * 2 < 60\r\n ? 1\r\n : bubbleRadius * 2 < 75\r\n ? 2\r\n : bubbleRadius * 2 < 100\r\n ? 3\r\n : undefined,\r\n display: '-webkit-box',\r\n WebkitBoxOrient: 'vertical',\r\n color: getTextColorBasedOnBgColor(circleColor),\r\n hyphens: 'auto',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n >\r\n {d.label}\r\n </P>\r\n )}\r\n {showValues && (\r\n <P\r\n className='text-center font-bold leading-[1.25] w-full m-0 circle-packing-value'\r\n marginBottom='none'\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(Math.round(bubbleRadius / 4), 14),\r\n 14,\r\n )}px`,\r\n color: getTextColorBasedOnBgColor(circleColor),\r\n }}\r\n >\r\n {numberFormattingFunction(d.size, 'NA', precision, prefix, suffix)}\r\n </P>\r\n )}\r\n </div>\r\n </foreignObject>\r\n </g>\r\n )}\r\n </g>\r\n );\r\n })}\r\n </g>\r\n </svg>\r\n {mouseOverData && tooltip && eventX && eventY && (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n )}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n }\r\n return null;\r\n};\r\n","export function getMaxCircleRadius(\r\n values: (number | undefined | null)[],\r\n width: number,\r\n height: number,\r\n) {\r\n const filteredValues = values.filter(d => d !== undefined && d !== null);\r\n const containerRadius = Math.min(width, height) / 2;\r\n const totalValue = filteredValues.reduce((sum, v) => sum + v, 0);\r\n const maxValue = Math.max(...filteredValues);\r\n const getPackingEfficiency = (n: number) => {\r\n if (n <= 5) return 0.9;\r\n if (n <= 10) return 0.85;\r\n if (n <= 20) return 0.8;\r\n return 0.7;\r\n };\r\n const getEfficiencyBecauseOfContainerRadius = (r: number) => {\r\n if (r <= 200) return 0.85;\r\n if (r <= 250) return 0.95;\r\n return 1;\r\n };\r\n return (\r\n containerRadius *\r\n Math.sqrt(maxValue / totalValue) *\r\n getEfficiencyBecauseOfContainerRadius(containerRadius) *\r\n getPackingEfficiency(filteredValues.length)\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\nimport { getMaxCircleRadius } from './getMaxCircleRadius';\r\n\r\nimport { Languages, SourcesDataType, StyleObject, ClassNameObject, TreeMapDataType } from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: TreeMapDataType[];\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Color or array of colors for circle */\r\n colors?: string | string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value mapped to the radius chart */\r\n maxRadiusValue?: number;\r\n\r\n // Graph Parameters\r\n /** Maximum radius of the circle */\r\n radius?: number;\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Toggle visibility of NA color in the color scale. This is only applicable if the data props hae color parameter and showColorScale prop is true */\r\n showNAColor?: boolean;\r\n /** Data points to highlight. Use the label value from data to highlight the data point */\r\n highlightedDataPoints?: (string | number)[];\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function CirclePackingGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n suffix = '',\r\n sources,\r\n prefix = '',\r\n graphDescription,\r\n leftMargin = 0,\r\n rightMargin = 0,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n backgroundColor = false,\r\n topMargin = 0,\r\n bottomMargin = 0,\r\n showLabels = true,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n showValues,\r\n graphID,\r\n highlightedDataPoints = [],\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n showNAColor,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n radius,\r\n maxRadiusValue,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n } = props;\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale && data.filter(el => el.color).length !== 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={(colors as string[] | undefined) || Colors[theme].categoricalColors.colors}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor === undefined || showNAColor === null ? true : showNAColor}\r\n isCenter\r\n className={classNames?.colorLegend}\r\n />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {svgWidth && svgHeight ? (\r\n <Graph\r\n data={data}\r\n colors={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={\r\n data.filter(el => el.color).length === 0\r\n ? []\r\n : colorDomain || (uniqBy(data, 'color', true) as string[])\r\n }\r\n width={svgWidth}\r\n height={svgHeight}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n showLabels={showLabels}\r\n showValues={\r\n showValues !== false\r\n ? data.filter(el => el.size).length !== 0\r\n : (showValues as boolean)\r\n }\r\n selectedColor={selectedColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n theme={theme}\r\n radius={\r\n !radius\r\n ? getMaxCircleRadius(\r\n data.map(d => d.size),\r\n svgWidth,\r\n svgHeight,\r\n )\r\n : radius\r\n }\r\n maxRadiusValue={maxRadiusValue}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n />\r\n ) : null}\r\n </GraphArea>\r\n </>\r\n )}\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["extent","values","valueof","min","max","value","index","Graph","props","$","_c","data","colors","leftMargin","width","height","colorDomain","selectedColor","rightMargin","topMargin","bottomMargin","showLabels","tooltip","onSeriesMouseOver","showValues","suffix","prefix","highlightedDataPoints","onSeriesMouseClick","maxRadiusValue","radius","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","dimmedOpacity","precision","svgRef","useRef","mouseOverData","setMouseOverData","useState","undefined","mouseClickData","setMouseClickData","viewPortDimensions","setViewPortDimensions","eventX","setEventX","eventY","setEventY","finalData","setFinalData","t0","top","bottom","left","right","margin","graphWidth","graphHeight","t1","filter","_temp","length","orderBy","_temp2","dataOrdered","t2","_temp3","scaleSqrt","domain","checkIfNullOrUndefined","Math","map","_temp4","_temp5","range","nice","radiusScale","t3","setupSimulation","dataTemp","_temp6","forceSimulation","force","forceY","_d","strength","forceX","_d_0","forceCollide","d_5","d","size","forceManyBody","alphaDecay","tick","on","xMinExtent","d_6","x","yMinExtent","d_7","y","xMaxExtent","d_8","yMaxExtent","d_9","t4","useEffect","t5","event","d_10","clientY","clientX","handleMouseEnter","t6","Symbol","for","event_0","d_11","handleMouseMove","t7","d_12","label","handleClick","t8","handleMouseLeave","t9","d_13","_temp7","color","indexOf","Colors","gray","getCircleColor","t10","d_14","getOpacity","t11","t12","t13","t14","jsx","Spinner","t15","graphObjectValues","t16","d_15","circleColor","opacity","bubbleRadius","showLabel","jsxs","event_1","event_2","display","flexDirection","justifyContent","alignItems","padding","P","cn","fontSize","round","WebkitLineClamp","WebkitBoxOrient","getTextColorBasedOnBgColor","hyphens","numberFormattingFunction","t17","t18","Tooltip","t19","modal","DetailsModal","t20","Fragment","d_0","d_3","d_1","d_2","d_4","el","getMaxCircleRadius","filteredValues","containerRadius","totalValue","reduce","sum","v","maxValue","getPackingEfficiency","n","getEfficiencyBecauseOfContainerRadius","r","sqrt","CirclePackingGraph","graphTitle","sources","graphDescription","footNote","colorLegendTitle","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","language","showNAColor","minHeight","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","current","observe","disconnect","t21","graphContainer","t22","t23","description","title","GraphHeader","t24","EmptyState","ColorLegendWithMouseOver","categoricalColors","uniqBy","colorLegend","GraphArea","primaryColors","_temp8","_temp9","_temp0","t25","footnote","source","GraphFooter","t26","GraphContainer","el_2","el_1","el_0"],"mappings":"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","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"index-Blvf-Q3U.cjs","sources":["../node_modules/d3-array/src/extent.js","../src/Components/Graphs/CirclePackingGraph/Graph.tsx","../src/Components/Graphs/CirclePackingGraph/getMaxCircleRadius.ts","../src/Components/Graphs/CirclePackingGraph/index.tsx"],"sourcesContent":["export default function extent(values, valueof) {\n let min;\n let max;\n if (valueof === undefined) {\n for (const value of values) {\n if (value != null) {\n if (min === undefined) {\n if (value >= value) min = max = value;\n } else {\n if (min > value) min = value;\n if (max < value) max = value;\n }\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null) {\n if (min === undefined) {\n if (value >= value) min = max = value;\n } else {\n if (min > value) min = value;\n if (max < value) max = value;\n }\n }\n }\n }\n return [min, max];\n}\n","import { useEffect, useState, useRef } from 'react';\r\nimport { forceCollide, forceManyBody, forceSimulation, forceX, forceY } from 'd3-force';\r\nimport orderBy from 'lodash.orderby';\r\nimport { scaleSqrt } from 'd3-scale';\r\nimport { extent } from 'd3-array';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { Spinner } from '@undp/design-system-react/Spinner';\r\nimport { P } from '@undp/design-system-react/Typography';\r\n\r\nimport { ClassNameObject, StyleObject, TreeMapDataType } from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { getTextColorBasedOnBgColor } from '@/Utils/getTextColorBasedOnBgColor';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n data: TreeMapDataType[];\r\n colors: string[];\r\n colorDomain: string[];\r\n leftMargin: number;\r\n rightMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n showLabels: boolean;\r\n showValues: boolean;\r\n width: number;\r\n height: number;\r\n suffix: string;\r\n prefix: string;\r\n selectedColor?: string;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n highlightedDataPoints: (string | number)[];\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n theme: 'light' | 'dark';\r\n maxRadiusValue?: number;\r\n radius: number;\r\n resetSelectionOnDoubleClick: boolean;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n dimmedOpacity: number;\r\n precision: number;\r\n}\r\n\r\ninterface TreeMapDataTypeForBubbleChart extends TreeMapDataType {\r\n x: number;\r\n y: number;\r\n vx: number;\r\n vy: number;\r\n}\r\n\r\nexport const Graph = (props: Props) => {\r\n const {\r\n data,\r\n colors,\r\n leftMargin,\r\n width,\r\n height,\r\n colorDomain,\r\n selectedColor,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n showLabels,\r\n tooltip,\r\n onSeriesMouseOver,\r\n showValues,\r\n suffix,\r\n prefix,\r\n highlightedDataPoints,\r\n onSeriesMouseClick,\r\n maxRadiusValue,\r\n radius,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n dimmedOpacity,\r\n precision,\r\n } = props;\r\n const svgRef = useRef(null);\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [viewPortDimensions, setViewPortDimensions] = useState<\r\n [number, number, number, number] | undefined\r\n >(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const [finalData, setFinalData] = useState<TreeMapDataTypeForBubbleChart[] | null>(null);\r\n\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n\r\n // Memoize data ordering and radius scale\r\n const dataOrdered =\r\n data.filter(d => !checkIfNullOrUndefined(d.size)).length === 0\r\n ? data\r\n : orderBy(\r\n data.filter(d => !checkIfNullOrUndefined(d.size)),\r\n 'radius',\r\n 'asc',\r\n );\r\n\r\n const radiusScale =\r\n data.filter(d => d.size === undefined || d.size === null).length !== data.length\r\n ? scaleSqrt()\r\n .domain([\r\n 0,\r\n checkIfNullOrUndefined(maxRadiusValue)\r\n ? Math.max(...data.map(d => d.size).filter(d => d !== undefined && d !== null))\r\n : (maxRadiusValue as number),\r\n ])\r\n .range([0.25, radius])\r\n .nice()\r\n : undefined;\r\n\r\n // Memoize simulation setup\r\n useEffect(() => {\r\n const setupSimulation = () => {\r\n const dataTemp = dataOrdered.map(d => ({ ...d, ...(d.data && { data: { ...d.data } }) }));\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const simulation = forceSimulation(dataTemp as any)\r\n .force('y', forceY(_d => graphHeight / 2).strength(1))\r\n .force('x', forceX(_d => graphWidth / 2).strength(1))\r\n .force(\r\n 'collide',\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n forceCollide((d: any) => (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1)),\r\n )\r\n .force('charge', forceManyBody().strength(-15))\r\n .alphaDecay(0.05)\r\n .tick(10000);\r\n\r\n simulation\r\n .on('tick', () => {\r\n setFinalData(dataTemp as TreeMapDataTypeForBubbleChart[]);\r\n })\r\n .on('end', () => {\r\n setFinalData(dataTemp as TreeMapDataTypeForBubbleChart[]);\r\n const xMinExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.x - (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[0] || 0;\r\n const yMinExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.y - (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[0] || 0;\r\n const xMaxExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.x + (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[1] || 0;\r\n const yMaxExtent =\r\n extent(\r\n dataTemp as TreeMapDataTypeForBubbleChart[],\r\n d => d.y + (radiusScale ? radiusScale(d.size || 0) + 1 : radius + 1),\r\n )[1] || 0;\r\n setViewPortDimensions([\r\n xMinExtent,\r\n yMinExtent,\r\n xMinExtent < 0 ? xMaxExtent - xMinExtent : xMaxExtent,\r\n yMinExtent < 0 ? yMaxExtent - yMinExtent : yMaxExtent,\r\n ]);\r\n });\r\n };\r\n\r\n setupSimulation();\r\n }, [data, radius, graphHeight, graphWidth, maxRadiusValue, dataOrdered, radiusScale]);\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleMouseEnter = (event: any, d: any) => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleMouseMove = (event: any, d: any) => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleClick = (d: any) => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (mouseClickData === d.label && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d.label);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n };\r\n\r\n const handleMouseLeave = () => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const getCircleColor = (d: any) =>\r\n data.filter(el => el.color).length === 0\r\n ? colors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : colors[colorDomain.indexOf(d.color)];\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const getOpacity = (d: any) =>\r\n selectedColor\r\n ? d.color\r\n ? colors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedDataPoints.length !== 0\r\n ? highlightedDataPoints.indexOf(d.label) !== -1\r\n ? 0.85\r\n : dimmedOpacity\r\n : 0.85;\r\n\r\n // Render loading state\r\n if (!finalData) {\r\n return (\r\n <div style={{ width: `${width}px`, height: `${height}px` }}>\r\n <div className='flex m-auto items-center justify-center p-0 leading-none text-base h-40'>\r\n <Spinner />\r\n </div>\r\n </div>\r\n );\r\n }\r\n if (viewPortDimensions) {\r\n return (\r\n <>\r\n <svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`${viewPortDimensions[0] > 0 ? 0 : viewPortDimensions[0]} ${\r\n viewPortDimensions[1] > 0 ? 0 : viewPortDimensions[1]\r\n } ${width < viewPortDimensions[2] ? viewPortDimensions[2] : width} ${\r\n height < viewPortDimensions[3] ? viewPortDimensions[3] : height\r\n }`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {finalData.map(d => {\r\n const circleColor = getCircleColor(d);\r\n const opacity = getOpacity(d);\r\n const bubbleRadius = radiusScale ? radiusScale(d.size || 0) : radius;\r\n const showLabel = bubbleRadius > 20 && (showLabels || showValues);\r\n return (\r\n <g\r\n className='undp-viz-g-with-hover'\r\n key={d.label}\r\n opacity={opacity}\r\n transform={`translate(${d.x},${d.y})`}\r\n onMouseEnter={event => handleMouseEnter(event, d)}\r\n onMouseMove={event => handleMouseMove(event, d)}\r\n onClick={() => handleClick(d)}\r\n onMouseLeave={handleMouseLeave}\r\n >\r\n <circle cx={0} cy={0} r={bubbleRadius} fill={circleColor} />\r\n {(showLabel || showValues) &&\r\n d.size !== undefined &&\r\n d.size !== null &&\r\n bubbleRadius >= 15 && (\r\n <g>\r\n <foreignObject\r\n y={0 - bubbleRadius}\r\n x={0 - bubbleRadius}\r\n width={2 * bubbleRadius}\r\n height={2 * bubbleRadius}\r\n >\r\n <div\r\n className='flex flex-col justify-center items-center h-full py-0 px-3'\r\n style={{\r\n display: 'flex',\r\n flexDirection: 'column',\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n height: '100%',\r\n padding: '0 0.75rem',\r\n }}\r\n >\r\n {showLabels && (\r\n <P\r\n className={cn(\r\n 'text-center leading-[1.25] overflow-hidden m-0 circle-packing-label',\r\n classNames?.graphObjectValues,\r\n )}\r\n marginBottom='none'\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(Math.round(bubbleRadius / 4), 12),\r\n Math.max(\r\n Math.round((bubbleRadius * 12) / `${d.label}`.length),\r\n 12,\r\n ),\r\n 14,\r\n )}px`,\r\n WebkitLineClamp:\r\n bubbleRadius * 2 < 60\r\n ? 1\r\n : bubbleRadius * 2 < 75\r\n ? 2\r\n : bubbleRadius * 2 < 100\r\n ? 3\r\n : undefined,\r\n display: '-webkit-box',\r\n WebkitBoxOrient: 'vertical',\r\n color: getTextColorBasedOnBgColor(circleColor),\r\n hyphens: 'auto',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n >\r\n {d.label}\r\n </P>\r\n )}\r\n {showValues && (\r\n <P\r\n className='text-center font-bold leading-[1.25] w-full m-0 circle-packing-value'\r\n marginBottom='none'\r\n style={{\r\n fontSize: `${Math.min(\r\n Math.max(Math.round(bubbleRadius / 4), 14),\r\n 14,\r\n )}px`,\r\n color: getTextColorBasedOnBgColor(circleColor),\r\n }}\r\n >\r\n {numberFormattingFunction(d.size, 'NA', precision, prefix, suffix)}\r\n </P>\r\n )}\r\n </div>\r\n </foreignObject>\r\n </g>\r\n )}\r\n </g>\r\n );\r\n })}\r\n </g>\r\n </svg>\r\n {mouseOverData && tooltip && eventX && eventY && (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n )}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n }\r\n return null;\r\n};\r\n","export function getMaxCircleRadius(\r\n values: (number | undefined | null)[],\r\n width: number,\r\n height: number,\r\n) {\r\n const filteredValues = values.filter(d => d !== undefined && d !== null);\r\n const containerRadius = Math.min(width, height) / 2;\r\n const totalValue = filteredValues.reduce((sum, v) => sum + v, 0);\r\n const maxValue = Math.max(...filteredValues);\r\n const getPackingEfficiency = (n: number) => {\r\n if (n <= 5) return 0.9;\r\n if (n <= 10) return 0.85;\r\n if (n <= 20) return 0.8;\r\n return 0.7;\r\n };\r\n const getEfficiencyBecauseOfContainerRadius = (r: number) => {\r\n if (r <= 200) return 0.85;\r\n if (r <= 250) return 0.95;\r\n return 1;\r\n };\r\n return (\r\n containerRadius *\r\n Math.sqrt(maxValue / totalValue) *\r\n getEfficiencyBecauseOfContainerRadius(containerRadius) *\r\n getPackingEfficiency(filteredValues.length)\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\nimport { getMaxCircleRadius } from './getMaxCircleRadius';\r\n\r\nimport { Languages, SourcesDataType, StyleObject, ClassNameObject, TreeMapDataType } from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { uniqBy } from '@/Utils/uniqBy';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: TreeMapDataType[];\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Color or array of colors for circle */\r\n colors?: string | string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value mapped to the radius chart */\r\n maxRadiusValue?: number;\r\n\r\n // Graph Parameters\r\n /** Maximum radius of the circle */\r\n radius?: number;\r\n /** Toggle visibility of labels */\r\n showLabels?: boolean;\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Toggle visibility of NA color in the color scale. This is only applicable if the data props hae color parameter and showColorScale prop is true */\r\n showNAColor?: boolean;\r\n /** Data points to highlight. Use the label value from data to highlight the data point */\r\n highlightedDataPoints?: (string | number)[];\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function CirclePackingGraph(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n colors,\r\n suffix = '',\r\n sources,\r\n prefix = '',\r\n graphDescription,\r\n leftMargin = 0,\r\n rightMargin = 0,\r\n height,\r\n width,\r\n footNote,\r\n colorDomain,\r\n colorLegendTitle,\r\n padding,\r\n backgroundColor = false,\r\n topMargin = 0,\r\n bottomMargin = 0,\r\n showLabels = true,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n showColorScale = true,\r\n showValues,\r\n graphID,\r\n highlightedDataPoints = [],\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n language = 'en',\r\n showNAColor,\r\n minHeight = 0,\r\n theme = 'light',\r\n ariaLabel,\r\n radius,\r\n maxRadiusValue,\r\n resetSelectionOnDoubleClick = true,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n } = props;\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {showColorScale && data.filter(el => el.color).length !== 0 && data.length > 0 ? (\r\n <ColorLegendWithMouseOver\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={(colors as string[] | undefined) || Colors[theme].categoricalColors.colors}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n setSelectedColor={setSelectedColor}\r\n showNAColor={showNAColor === undefined || showNAColor === null ? true : showNAColor}\r\n isCenter\r\n className={classNames?.colorLegend}\r\n />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {data.length === 0 && <EmptyState />}\r\n {svgWidth && svgHeight && data.length > 0 ? (\r\n <Graph\r\n data={data}\r\n colors={\r\n data.filter(el => el.color).length === 0\r\n ? colors\r\n ? [colors as string]\r\n : [Colors.primaryColors['blue-600']]\r\n : (colors as string[] | undefined) || Colors[theme].categoricalColors.colors\r\n }\r\n colorDomain={\r\n data.filter(el => el.color).length === 0\r\n ? []\r\n : colorDomain || (uniqBy(data, 'color', true) as string[])\r\n }\r\n width={svgWidth}\r\n height={svgHeight}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n showLabels={showLabels}\r\n showValues={\r\n showValues !== false\r\n ? data.filter(el => el.size).length !== 0\r\n : (showValues as boolean)\r\n }\r\n selectedColor={selectedColor}\r\n suffix={suffix}\r\n prefix={prefix}\r\n tooltip={tooltip}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n highlightedDataPoints={highlightedDataPoints}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n theme={theme}\r\n radius={\r\n !radius\r\n ? getMaxCircleRadius(\r\n data.map(d => d.size),\r\n svgWidth,\r\n svgHeight,\r\n )\r\n : radius\r\n }\r\n maxRadiusValue={maxRadiusValue}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n detailsOnClick={detailsOnClick}\r\n styles={styles}\r\n classNames={classNames}\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n />\r\n ) : null}\r\n </GraphArea>\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["extent","values","valueof","min","max","value","index","Graph","props","$","_c","data","colors","leftMargin","width","height","colorDomain","selectedColor","rightMargin","topMargin","bottomMargin","showLabels","tooltip","onSeriesMouseOver","showValues","suffix","prefix","highlightedDataPoints","onSeriesMouseClick","maxRadiusValue","radius","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","dimmedOpacity","precision","svgRef","useRef","mouseOverData","setMouseOverData","useState","undefined","mouseClickData","setMouseClickData","viewPortDimensions","setViewPortDimensions","eventX","setEventX","eventY","setEventY","finalData","setFinalData","t0","top","bottom","left","right","margin","graphWidth","graphHeight","t1","filter","_temp","length","orderBy","_temp2","dataOrdered","t2","_temp3","scaleSqrt","domain","checkIfNullOrUndefined","Math","map","_temp4","_temp5","range","nice","radiusScale","t3","setupSimulation","dataTemp","_temp6","forceSimulation","force","forceY","_d","strength","forceX","_d_0","forceCollide","d_5","d","size","forceManyBody","alphaDecay","tick","on","xMinExtent","d_6","x","yMinExtent","d_7","y","xMaxExtent","d_8","yMaxExtent","d_9","t4","useEffect","t5","event","d_10","clientY","clientX","handleMouseEnter","t6","Symbol","for","event_0","d_11","handleMouseMove","t7","d_12","label","handleClick","t8","handleMouseLeave","t9","d_13","_temp7","color","indexOf","Colors","gray","getCircleColor","t10","d_14","getOpacity","t11","t12","t13","t14","jsx","Spinner","t15","graphObjectValues","t16","d_15","circleColor","opacity","bubbleRadius","showLabel","jsxs","event_1","event_2","display","flexDirection","justifyContent","alignItems","padding","P","cn","fontSize","round","WebkitLineClamp","WebkitBoxOrient","getTextColorBasedOnBgColor","hyphens","numberFormattingFunction","t17","t18","Tooltip","t19","modal","DetailsModal","t20","Fragment","d_0","d_3","d_1","d_2","d_4","el","getMaxCircleRadius","filteredValues","containerRadius","totalValue","reduce","sum","v","maxValue","getPackingEfficiency","n","getEfficiencyBecauseOfContainerRadius","r","sqrt","CirclePackingGraph","graphTitle","sources","graphDescription","footNote","colorLegendTitle","backgroundColor","relativeHeight","showColorScale","graphID","graphDownload","dataDownload","language","showNAColor","minHeight","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","setSelectedColor","graphDiv","graphParentDiv","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","current","observe","disconnect","t21","graphContainer","t22","t23","description","title","GraphHeader","t24","colorLegend","ColorLegendWithMouseOver","categoricalColors","uniqBy","t25","EmptyState","t26","primaryColors","_temp8","_temp9","_temp0","t27","GraphArea","t28","footnote","source","GraphFooter","t29","GraphContainer","el_2","el_1","el_0"],"mappings":"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","x_google_ignoreList":[0]}
|
|
@@ -0,0 +1,337 @@
|
|
|
1
|
+
import { c as Ge, j as a, m as Te } from "./index-CHPV5EwG-Curnpaqc.js";
|
|
2
|
+
import { useRef as Ne, useState as te, useEffect as We } from "react";
|
|
3
|
+
import { o as Fe } from "./index-BZQYSqar.js";
|
|
4
|
+
import { w as Xe } from "./Spinner-D7rnnwnA.js";
|
|
5
|
+
import { j as Be } from "./Typography-PxtFcnJb.js";
|
|
6
|
+
import { T as Ye } from "./Tooltip-Dj5eVppQ.js";
|
|
7
|
+
import { n as Ae } from "./numberFormattingFunction-14YCbkN2.js";
|
|
8
|
+
import { g as Pe } from "./getTextColorBasedOnBgColor-CDY808zi.js";
|
|
9
|
+
import { Colors as Ve } from "./Colors.js";
|
|
10
|
+
import { c as Ee } from "./checkIfNullOrUndefined-DmfiKkNw.js";
|
|
11
|
+
import { D as qe } from "./DetailsModal-0Ry5nXiC.js";
|
|
12
|
+
import { s as Ie } from "./pow-CM2aze4M.js";
|
|
13
|
+
import { f as Ue, b as Je, a as Ke, c as Qe, d as Ze } from "./y-BqfogMAB.js";
|
|
14
|
+
import { GraphFooter as _e } from "./GraphFooter.js";
|
|
15
|
+
import { GraphHeader as et } from "./GraphHeader.js";
|
|
16
|
+
import { ColorLegendWithMouseOver as tt } from "./ColorLegendWithMouseOver.js";
|
|
17
|
+
import { E as ot } from "./EmptyState-C7ZXkZWd.js";
|
|
18
|
+
import { u as He } from "./uniqBy-BHy4I8PK.js";
|
|
19
|
+
import { a as it, G as nt } from "./GraphContainer-CRqzdKu2.js";
|
|
20
|
+
function ze(o, e) {
|
|
21
|
+
let t, s;
|
|
22
|
+
if (e === void 0)
|
|
23
|
+
for (const n of o)
|
|
24
|
+
n != null && (t === void 0 ? n >= n && (t = s = n) : (t > n && (t = n), s < n && (s = n)));
|
|
25
|
+
else {
|
|
26
|
+
let n = -1;
|
|
27
|
+
for (let d of o)
|
|
28
|
+
(d = e(d, ++n, o)) != null && (t === void 0 ? d >= d && (t = s = d) : (t > d && (t = d), s < d && (s = d)));
|
|
29
|
+
}
|
|
30
|
+
return [t, s];
|
|
31
|
+
}
|
|
32
|
+
const lt = (o) => {
|
|
33
|
+
const e = Ge.c(105), {
|
|
34
|
+
data: t,
|
|
35
|
+
colors: s,
|
|
36
|
+
leftMargin: n,
|
|
37
|
+
width: d,
|
|
38
|
+
height: D,
|
|
39
|
+
colorDomain: k,
|
|
40
|
+
selectedColor: S,
|
|
41
|
+
rightMargin: x,
|
|
42
|
+
topMargin: oe,
|
|
43
|
+
bottomMargin: be,
|
|
44
|
+
showLabels: h,
|
|
45
|
+
tooltip: F,
|
|
46
|
+
onSeriesMouseOver: j,
|
|
47
|
+
showValues: $,
|
|
48
|
+
suffix: X,
|
|
49
|
+
prefix: ie,
|
|
50
|
+
highlightedDataPoints: ye,
|
|
51
|
+
onSeriesMouseClick: ne,
|
|
52
|
+
maxRadiusValue: L,
|
|
53
|
+
radius: c,
|
|
54
|
+
resetSelectionOnDoubleClick: Me,
|
|
55
|
+
detailsOnClick: z,
|
|
56
|
+
styles: V,
|
|
57
|
+
classNames: M,
|
|
58
|
+
dimmedOpacity: Y,
|
|
59
|
+
precision: R
|
|
60
|
+
} = o, we = Ne(null), [Ce, je] = te(void 0), [B, A] = te(void 0), [w, Se] = te(void 0), [le, se] = te(void 0), [re, Oe] = te(void 0), [ae, g] = te(null);
|
|
61
|
+
let r;
|
|
62
|
+
e[0] !== be || e[1] !== n || e[2] !== x || e[3] !== oe ? (r = {
|
|
63
|
+
top: oe,
|
|
64
|
+
bottom: be,
|
|
65
|
+
left: n,
|
|
66
|
+
right: x
|
|
67
|
+
}, e[0] = be, e[1] = n, e[2] = x, e[3] = oe, e[4] = r) : r = e[4];
|
|
68
|
+
const q = r, I = d - q.left - q.right, P = D - q.top - q.bottom;
|
|
69
|
+
let ce;
|
|
70
|
+
e[5] !== t ? (ce = t.filter(st).length === 0 ? t : Fe(t.filter(rt), "radius", "asc"), e[5] = t, e[6] = ce) : ce = e[6];
|
|
71
|
+
const H = ce;
|
|
72
|
+
let fe;
|
|
73
|
+
e[7] !== t || e[8] !== L || e[9] !== c ? (fe = t.filter(at).length !== t.length ? Ie().domain([0, Ee(L) ? Math.max(...t.map(ct).filter(ft)) : L]).range([0.25, c]).nice() : void 0, e[7] = t, e[8] = L, e[9] = c, e[10] = fe) : fe = e[10];
|
|
74
|
+
const l = fe;
|
|
75
|
+
let ue;
|
|
76
|
+
e[11] !== H || e[12] !== P || e[13] !== I || e[14] !== c || e[15] !== l ? (ue = () => {
|
|
77
|
+
(() => {
|
|
78
|
+
const f = H.map(ut);
|
|
79
|
+
Ue(f).force("y", Je((v) => P / 2).strength(1)).force("x", Ke((v) => I / 2).strength(1)).force("collide", Qe((v) => l ? l(v.size || 0) + 1 : c + 1)).force("charge", Ze().strength(-15)).alphaDecay(0.05).tick(1e4).on("tick", () => {
|
|
80
|
+
g(f);
|
|
81
|
+
}).on("end", () => {
|
|
82
|
+
g(f);
|
|
83
|
+
const v = ze(f, (u) => u.x - (l ? l(u.size || 0) + 1 : c + 1))[0] || 0, p = ze(f, (u) => u.y - (l ? l(u.size || 0) + 1 : c + 1))[0] || 0, N = ze(f, (u) => u.x + (l ? l(u.size || 0) + 1 : c + 1))[1] || 0, O = ze(f, (u) => u.y + (l ? l(u.size || 0) + 1 : c + 1))[1] || 0;
|
|
84
|
+
Se([v, p, v < 0 ? N - v : N, p < 0 ? O - p : O]);
|
|
85
|
+
});
|
|
86
|
+
})();
|
|
87
|
+
}, e[11] = H, e[12] = P, e[13] = I, e[14] = c, e[15] = l, e[16] = ue) : ue = e[16];
|
|
88
|
+
let de;
|
|
89
|
+
e[17] !== t || e[18] !== H || e[19] !== P || e[20] !== I || e[21] !== L || e[22] !== c || e[23] !== l ? (de = [t, c, P, I, L, H, l], e[17] = t, e[18] = H, e[19] = P, e[20] = I, e[21] = L, e[22] = c, e[23] = l, e[24] = de) : de = e[24], We(ue, de);
|
|
90
|
+
let me;
|
|
91
|
+
e[25] !== j ? (me = (i, f) => {
|
|
92
|
+
je(f), Oe(i.clientY), se(i.clientX), j?.(f);
|
|
93
|
+
}, e[25] = j, e[26] = me) : me = e[26];
|
|
94
|
+
const U = me;
|
|
95
|
+
let J;
|
|
96
|
+
e[27] === Symbol.for("react.memo_cache_sentinel") ? (J = (i, f) => {
|
|
97
|
+
je(f), Oe(i.clientY), se(i.clientX);
|
|
98
|
+
}, e[27] = J) : J = e[27];
|
|
99
|
+
const ke = J;
|
|
100
|
+
let K;
|
|
101
|
+
e[28] !== z || e[29] !== B || e[30] !== ne || e[31] !== Me ? (K = (i) => {
|
|
102
|
+
(ne || z) && (B === i.label && Me ? (A(void 0), ne?.(void 0)) : (A(i.label), ne?.(i)));
|
|
103
|
+
}, e[28] = z, e[29] = B, e[30] = ne, e[31] = Me, e[32] = K) : K = e[32];
|
|
104
|
+
const G = K;
|
|
105
|
+
let he;
|
|
106
|
+
e[33] !== j ? (he = () => {
|
|
107
|
+
je(void 0), se(void 0), Oe(void 0), j?.(void 0);
|
|
108
|
+
}, e[33] = j, e[34] = he) : he = e[34];
|
|
109
|
+
const Q = he;
|
|
110
|
+
let C;
|
|
111
|
+
e[35] !== k || e[36] !== s || e[37] !== t ? (C = (i) => t.filter(dt).length === 0 ? s[0] : i.color ? s[k.indexOf(i.color)] : Ve.gray, e[35] = k, e[36] = s, e[37] = t, e[38] = C) : C = e[38];
|
|
112
|
+
const Z = C;
|
|
113
|
+
let ge;
|
|
114
|
+
e[39] !== k || e[40] !== s || e[41] !== Y || e[42] !== ye || e[43] !== S ? (ge = (i) => S ? i.color && s[k.indexOf(i.color)] === S ? 1 : Y : ye.length !== 0 ? ye.indexOf(i.label) !== -1 ? 0.85 : Y : 0.85, e[39] = k, e[40] = s, e[41] = Y, e[42] = ye, e[43] = S, e[44] = ge) : ge = e[44];
|
|
115
|
+
const _ = ge;
|
|
116
|
+
if (!ae) {
|
|
117
|
+
const i = `${d}px`, f = `${D}px`;
|
|
118
|
+
let y;
|
|
119
|
+
e[45] !== i || e[46] !== f ? (y = {
|
|
120
|
+
width: i,
|
|
121
|
+
height: f
|
|
122
|
+
}, e[45] = i, e[46] = f, e[47] = y) : y = e[47];
|
|
123
|
+
let v;
|
|
124
|
+
e[48] === Symbol.for("react.memo_cache_sentinel") ? (v = /* @__PURE__ */ a.jsx("div", { className: "flex m-auto items-center justify-center p-0 leading-none text-base h-40", children: /* @__PURE__ */ a.jsx(Xe, {}) }), e[48] = v) : v = e[48];
|
|
125
|
+
let p;
|
|
126
|
+
return e[49] !== y ? (p = /* @__PURE__ */ a.jsx("div", { style: y, children: v }), e[49] = y, e[50] = p) : p = e[50], p;
|
|
127
|
+
}
|
|
128
|
+
if (w) {
|
|
129
|
+
const i = `${d}px`, f = `${D}px`, y = `${w[0] > 0 ? 0 : w[0]} ${w[1] > 0 ? 0 : w[1]} ${d < w[2] ? w[2] : d} ${D < w[3] ? w[3] : D}`, v = `translate(${q.left},${q.top})`;
|
|
130
|
+
let p;
|
|
131
|
+
if (e[51] !== M?.graphObjectValues || e[52] !== ae || e[53] !== Z || e[54] !== _ || e[55] !== G || e[56] !== U || e[57] !== Q || e[58] !== R || e[59] !== ie || e[60] !== c || e[61] !== l || e[62] !== h || e[63] !== $ || e[64] !== V?.graphObjectValues || e[65] !== X) {
|
|
132
|
+
let pe;
|
|
133
|
+
e[67] !== M?.graphObjectValues || e[68] !== Z || e[69] !== _ || e[70] !== G || e[71] !== U || e[72] !== Q || e[73] !== R || e[74] !== ie || e[75] !== c || e[76] !== l || e[77] !== h || e[78] !== $ || e[79] !== V?.graphObjectValues || e[80] !== X ? (pe = (b) => {
|
|
134
|
+
const W = Z(b), xe = _(b), m = l ? l(b.size || 0) : c, ve = m > 20 && (h || $);
|
|
135
|
+
return /* @__PURE__ */ a.jsxs("g", { className: "undp-viz-g-with-hover", opacity: xe, transform: `translate(${b.x},${b.y})`, onMouseEnter: (T) => U(T, b), onMouseMove: (T) => ke(T, b), onClick: () => G(b), onMouseLeave: Q, children: [
|
|
136
|
+
/* @__PURE__ */ a.jsx("circle", { cx: 0, cy: 0, r: m, fill: W }),
|
|
137
|
+
(ve || $) && b.size !== void 0 && b.size !== null && m >= 15 && /* @__PURE__ */ a.jsx("g", { children: /* @__PURE__ */ a.jsx("foreignObject", { y: 0 - m, x: 0 - m, width: 2 * m, height: 2 * m, children: /* @__PURE__ */ a.jsxs("div", { className: "flex flex-col justify-center items-center h-full py-0 px-3", style: {
|
|
138
|
+
display: "flex",
|
|
139
|
+
flexDirection: "column",
|
|
140
|
+
justifyContent: "center",
|
|
141
|
+
alignItems: "center",
|
|
142
|
+
height: "100%",
|
|
143
|
+
padding: "0 0.75rem"
|
|
144
|
+
}, children: [
|
|
145
|
+
h && /* @__PURE__ */ a.jsx(Be, { className: Te("text-center leading-[1.25] overflow-hidden m-0 circle-packing-label", M?.graphObjectValues), marginBottom: "none", style: {
|
|
146
|
+
fontSize: `${Math.min(Math.max(Math.round(m / 4), 12), Math.max(Math.round(m * 12 / `${b.label}`.length), 12), 14)}px`,
|
|
147
|
+
WebkitLineClamp: m * 2 < 60 ? 1 : m * 2 < 75 ? 2 : m * 2 < 100 ? 3 : void 0,
|
|
148
|
+
display: "-webkit-box",
|
|
149
|
+
WebkitBoxOrient: "vertical",
|
|
150
|
+
color: Pe(W),
|
|
151
|
+
hyphens: "auto",
|
|
152
|
+
...V?.graphObjectValues || {}
|
|
153
|
+
}, children: b.label }),
|
|
154
|
+
$ && /* @__PURE__ */ a.jsx(Be, { className: "text-center font-bold leading-[1.25] w-full m-0 circle-packing-value", marginBottom: "none", style: {
|
|
155
|
+
fontSize: `${Math.min(Math.max(Math.round(m / 4), 14), 14)}px`,
|
|
156
|
+
color: Pe(W)
|
|
157
|
+
}, children: Ae(b.size, "NA", R, ie, X) })
|
|
158
|
+
] }) }) })
|
|
159
|
+
] }, b.label);
|
|
160
|
+
}, e[67] = M?.graphObjectValues, e[68] = Z, e[69] = _, e[70] = G, e[71] = U, e[72] = Q, e[73] = R, e[74] = ie, e[75] = c, e[76] = l, e[77] = h, e[78] = $, e[79] = V?.graphObjectValues, e[80] = X, e[81] = pe) : pe = e[81], p = ae.map(pe), e[51] = M?.graphObjectValues, e[52] = ae, e[53] = Z, e[54] = _, e[55] = G, e[56] = U, e[57] = Q, e[58] = R, e[59] = ie, e[60] = c, e[61] = l, e[62] = h, e[63] = $, e[64] = V?.graphObjectValues, e[65] = X, e[66] = p;
|
|
161
|
+
} else
|
|
162
|
+
p = e[66];
|
|
163
|
+
let N;
|
|
164
|
+
e[82] !== v || e[83] !== p ? (N = /* @__PURE__ */ a.jsx("g", { transform: v, children: p }), e[82] = v, e[83] = p, e[84] = N) : N = e[84];
|
|
165
|
+
let O;
|
|
166
|
+
e[85] !== i || e[86] !== f || e[87] !== y || e[88] !== N ? (O = /* @__PURE__ */ a.jsx("svg", { width: i, height: f, viewBox: y, direction: "ltr", ref: we, children: N }), e[85] = i, e[86] = f, e[87] = y, e[88] = N, e[89] = O) : O = e[89];
|
|
167
|
+
let u;
|
|
168
|
+
e[90] !== M?.tooltip || e[91] !== le || e[92] !== re || e[93] !== Ce || e[94] !== V?.tooltip || e[95] !== F ? (u = Ce && F && le && re && /* @__PURE__ */ a.jsx(Ye, { data: Ce, body: F, xPos: le, yPos: re, backgroundStyle: V?.tooltip, className: M?.tooltip }), e[90] = M?.tooltip, e[91] = le, e[92] = re, e[93] = Ce, e[94] = V?.tooltip, e[95] = F, e[96] = u) : u = e[96];
|
|
169
|
+
let E;
|
|
170
|
+
e[97] !== M?.modal || e[98] !== z || e[99] !== B ? (E = z && B !== void 0 ? /* @__PURE__ */ a.jsx(qe, { body: z, data: B, setData: A, className: M?.modal }) : null, e[97] = M?.modal, e[98] = z, e[99] = B, e[100] = E) : E = e[100];
|
|
171
|
+
let ee;
|
|
172
|
+
return e[101] !== O || e[102] !== u || e[103] !== E ? (ee = /* @__PURE__ */ a.jsxs(a.Fragment, { children: [
|
|
173
|
+
O,
|
|
174
|
+
u,
|
|
175
|
+
E
|
|
176
|
+
] }), e[101] = O, e[102] = u, e[103] = E, e[104] = ee) : ee = e[104], ee;
|
|
177
|
+
}
|
|
178
|
+
return null;
|
|
179
|
+
};
|
|
180
|
+
function st(o) {
|
|
181
|
+
return !Ee(o.size);
|
|
182
|
+
}
|
|
183
|
+
function rt(o) {
|
|
184
|
+
return !Ee(o.size);
|
|
185
|
+
}
|
|
186
|
+
function at(o) {
|
|
187
|
+
return o.size === void 0 || o.size === null;
|
|
188
|
+
}
|
|
189
|
+
function ct(o) {
|
|
190
|
+
return o.size;
|
|
191
|
+
}
|
|
192
|
+
function ft(o) {
|
|
193
|
+
return o != null;
|
|
194
|
+
}
|
|
195
|
+
function ut(o) {
|
|
196
|
+
return {
|
|
197
|
+
...o,
|
|
198
|
+
...o.data && {
|
|
199
|
+
data: {
|
|
200
|
+
...o.data
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
};
|
|
204
|
+
}
|
|
205
|
+
function dt(o) {
|
|
206
|
+
return o.color;
|
|
207
|
+
}
|
|
208
|
+
function mt(o, e, t) {
|
|
209
|
+
const s = o.filter((x) => x != null), n = Math.min(e, t) / 2, d = s.reduce((x, oe) => x + oe, 0), D = Math.max(...s), k = (x) => x <= 5 ? 0.9 : x <= 10 ? 0.85 : x <= 20 ? 0.8 : 0.7, S = (x) => x <= 200 ? 0.85 : x <= 250 ? 0.95 : 1;
|
|
210
|
+
return n * Math.sqrt(D / d) * S(n) * k(s.length);
|
|
211
|
+
}
|
|
212
|
+
function Xt(o) {
|
|
213
|
+
const e = Ge.c(83), {
|
|
214
|
+
data: t,
|
|
215
|
+
graphTitle: s,
|
|
216
|
+
colors: n,
|
|
217
|
+
suffix: d,
|
|
218
|
+
sources: D,
|
|
219
|
+
prefix: k,
|
|
220
|
+
graphDescription: S,
|
|
221
|
+
leftMargin: x,
|
|
222
|
+
rightMargin: oe,
|
|
223
|
+
height: be,
|
|
224
|
+
width: h,
|
|
225
|
+
footNote: F,
|
|
226
|
+
colorDomain: j,
|
|
227
|
+
colorLegendTitle: $,
|
|
228
|
+
padding: X,
|
|
229
|
+
backgroundColor: ie,
|
|
230
|
+
topMargin: ye,
|
|
231
|
+
bottomMargin: ne,
|
|
232
|
+
showLabels: L,
|
|
233
|
+
relativeHeight: c,
|
|
234
|
+
tooltip: Me,
|
|
235
|
+
onSeriesMouseOver: z,
|
|
236
|
+
showColorScale: V,
|
|
237
|
+
showValues: M,
|
|
238
|
+
graphID: Y,
|
|
239
|
+
highlightedDataPoints: R,
|
|
240
|
+
onSeriesMouseClick: we,
|
|
241
|
+
graphDownload: Ce,
|
|
242
|
+
dataDownload: je,
|
|
243
|
+
language: B,
|
|
244
|
+
showNAColor: A,
|
|
245
|
+
minHeight: w,
|
|
246
|
+
theme: Se,
|
|
247
|
+
ariaLabel: le,
|
|
248
|
+
radius: se,
|
|
249
|
+
maxRadiusValue: re,
|
|
250
|
+
resetSelectionOnDoubleClick: Oe,
|
|
251
|
+
detailsOnClick: ae,
|
|
252
|
+
styles: g,
|
|
253
|
+
classNames: r,
|
|
254
|
+
dimmedOpacity: q,
|
|
255
|
+
precision: I
|
|
256
|
+
} = o, P = d === void 0 ? "" : d, ce = k === void 0 ? "" : k, H = x === void 0 ? 0 : x, fe = oe === void 0 ? 0 : oe, l = ie === void 0 ? !1 : ie, ue = ye === void 0 ? 0 : ye, de = ne === void 0 ? 0 : ne, me = L === void 0 ? !0 : L, U = V === void 0 ? !0 : V;
|
|
257
|
+
let J;
|
|
258
|
+
e[0] !== R ? (J = R === void 0 ? [] : R, e[0] = R, e[1] = J) : J = e[1];
|
|
259
|
+
const ke = J, K = Ce === void 0 ? !1 : Ce, G = je === void 0 ? !1 : je, he = B === void 0 ? "en" : B, Q = w === void 0 ? 0 : w, C = Se === void 0 ? "light" : Se, Z = Oe === void 0 ? !0 : Oe, ge = q === void 0 ? 0.3 : q, _ = I === void 0 ? 2 : I, [i, f] = te(0), [y, v] = te(0), [p, N] = te(void 0), O = Ne(null), u = Ne(null);
|
|
260
|
+
let E, ee;
|
|
261
|
+
e[2] === Symbol.for("react.memo_cache_sentinel") ? (E = () => {
|
|
262
|
+
const Le = new ResizeObserver((Re) => {
|
|
263
|
+
f(Re[0].target.clientWidth || 620), v(Re[0].target.clientHeight || 480);
|
|
264
|
+
});
|
|
265
|
+
return O.current && Le.observe(O.current), () => Le.disconnect();
|
|
266
|
+
}, ee = [], e[2] = E, e[3] = ee) : (E = e[2], ee = e[3]), We(E, ee);
|
|
267
|
+
const pe = r?.graphContainer, b = g?.graphContainer;
|
|
268
|
+
let W;
|
|
269
|
+
e[4] !== r?.description || e[5] !== r?.title || e[6] !== t || e[7] !== G || e[8] !== S || e[9] !== K || e[10] !== s || e[11] !== g?.description || e[12] !== g?.title || e[13] !== h ? (W = s || S || K || G ? /* @__PURE__ */ a.jsx(et, { styles: {
|
|
270
|
+
title: g?.title,
|
|
271
|
+
description: g?.description
|
|
272
|
+
}, classNames: {
|
|
273
|
+
title: r?.title,
|
|
274
|
+
description: r?.description
|
|
275
|
+
}, graphTitle: s, graphDescription: S, width: h, graphDownload: K ? u : void 0, dataDownload: G ? t.map(jt).filter(Ct).length > 0 ? t.map(Mt).filter(yt) : t.filter(bt) : null }) : null, e[4] = r?.description, e[5] = r?.title, e[6] = t, e[7] = G, e[8] = S, e[9] = K, e[10] = s, e[11] = g?.description, e[12] = g?.title, e[13] = h, e[14] = W) : W = e[14];
|
|
276
|
+
let xe;
|
|
277
|
+
e[15] !== r?.colorLegend || e[16] !== j || e[17] !== $ || e[18] !== n || e[19] !== t || e[20] !== U || e[21] !== A || e[22] !== C || e[23] !== h ? (xe = U && t.filter(vt).length !== 0 && t.length > 0 ? /* @__PURE__ */ a.jsx(tt, { width: h, colorLegendTitle: $, colors: n || Ve[C].categoricalColors.colors, colorDomain: j || He(t, "color", !0), setSelectedColor: N, showNAColor: A ?? !0, isCenter: !0, className: r?.colorLegend }) : null, e[15] = r?.colorLegend, e[16] = j, e[17] = $, e[18] = n, e[19] = t, e[20] = U, e[21] = A, e[22] = C, e[23] = h, e[24] = xe) : xe = e[24];
|
|
278
|
+
let m;
|
|
279
|
+
e[25] !== t.length ? (m = t.length === 0 && /* @__PURE__ */ a.jsx(ot, {}), e[25] = t.length, e[26] = m) : m = e[26];
|
|
280
|
+
let ve;
|
|
281
|
+
e[27] !== de || e[28] !== r || e[29] !== j || e[30] !== n || e[31] !== t || e[32] !== ae || e[33] !== ge || e[34] !== ke || e[35] !== H || e[36] !== re || e[37] !== we || e[38] !== z || e[39] !== _ || e[40] !== ce || e[41] !== se || e[42] !== Z || e[43] !== fe || e[44] !== p || e[45] !== me || e[46] !== M || e[47] !== g || e[48] !== P || e[49] !== y || e[50] !== i || e[51] !== C || e[52] !== Me || e[53] !== ue ? (ve = i && y && t.length > 0 ? /* @__PURE__ */ a.jsx(lt, { data: t, colors: t.filter(xt).length === 0 ? n ? [n] : [Ve.primaryColors["blue-600"]] : n || Ve[C].categoricalColors.colors, colorDomain: t.filter(pt).length === 0 ? [] : j || He(t, "color", !0), width: i, height: y, leftMargin: H, rightMargin: fe, topMargin: ue, bottomMargin: de, showLabels: me, showValues: M !== !1 ? t.filter(gt).length !== 0 : M, selectedColor: p, suffix: P, prefix: ce, tooltip: Me, onSeriesMouseOver: z, highlightedDataPoints: ke, onSeriesMouseClick: we, theme: C, radius: se || mt(t.map(ht), i, y), maxRadiusValue: re, resetSelectionOnDoubleClick: Z, detailsOnClick: ae, styles: g, classNames: r, dimmedOpacity: ge, precision: _ }) : null, e[27] = de, e[28] = r, e[29] = j, e[30] = n, e[31] = t, e[32] = ae, e[33] = ge, e[34] = ke, e[35] = H, e[36] = re, e[37] = we, e[38] = z, e[39] = _, e[40] = ce, e[41] = se, e[42] = Z, e[43] = fe, e[44] = p, e[45] = me, e[46] = M, e[47] = g, e[48] = P, e[49] = y, e[50] = i, e[51] = C, e[52] = Me, e[53] = ue, e[54] = ve) : ve = e[54];
|
|
282
|
+
let T;
|
|
283
|
+
e[55] !== m || e[56] !== ve ? (T = /* @__PURE__ */ a.jsxs(it, { ref: O, children: [
|
|
284
|
+
m,
|
|
285
|
+
ve
|
|
286
|
+
] }), e[55] = m, e[56] = ve, e[57] = T) : T = e[57];
|
|
287
|
+
let De;
|
|
288
|
+
e[58] !== r?.footnote || e[59] !== r?.source || e[60] !== F || e[61] !== D || e[62] !== g?.footnote || e[63] !== g?.source || e[64] !== h ? (De = D || F ? /* @__PURE__ */ a.jsx(_e, { styles: {
|
|
289
|
+
footnote: g?.footnote,
|
|
290
|
+
source: g?.source
|
|
291
|
+
}, classNames: {
|
|
292
|
+
footnote: r?.footnote,
|
|
293
|
+
source: r?.source
|
|
294
|
+
}, sources: D, footNote: F, width: h }) : null, e[58] = r?.footnote, e[59] = r?.source, e[60] = F, e[61] = D, e[62] = g?.footnote, e[63] = g?.source, e[64] = h, e[65] = De) : De = e[65];
|
|
295
|
+
let $e;
|
|
296
|
+
return e[66] !== le || e[67] !== l || e[68] !== Y || e[69] !== be || e[70] !== he || e[71] !== Q || e[72] !== X || e[73] !== c || e[74] !== pe || e[75] !== b || e[76] !== W || e[77] !== xe || e[78] !== T || e[79] !== De || e[80] !== C || e[81] !== h ? ($e = /* @__PURE__ */ a.jsxs(nt, { className: pe, style: b, id: Y, ref: u, "aria-label": le, backgroundColor: l, theme: C, language: he, minHeight: Q, width: h, height: be, relativeHeight: c, padding: X, children: [
|
|
297
|
+
W,
|
|
298
|
+
xe,
|
|
299
|
+
T,
|
|
300
|
+
De
|
|
301
|
+
] }), e[66] = le, e[67] = l, e[68] = Y, e[69] = be, e[70] = he, e[71] = Q, e[72] = X, e[73] = c, e[74] = pe, e[75] = b, e[76] = W, e[77] = xe, e[78] = T, e[79] = De, e[80] = C, e[81] = h, e[82] = $e) : $e = e[82], $e;
|
|
302
|
+
}
|
|
303
|
+
function ht(o) {
|
|
304
|
+
return o.size;
|
|
305
|
+
}
|
|
306
|
+
function gt(o) {
|
|
307
|
+
return o.size;
|
|
308
|
+
}
|
|
309
|
+
function pt(o) {
|
|
310
|
+
return o.color;
|
|
311
|
+
}
|
|
312
|
+
function xt(o) {
|
|
313
|
+
return o.color;
|
|
314
|
+
}
|
|
315
|
+
function vt(o) {
|
|
316
|
+
return o.color;
|
|
317
|
+
}
|
|
318
|
+
function bt(o) {
|
|
319
|
+
return o !== void 0;
|
|
320
|
+
}
|
|
321
|
+
function yt(o) {
|
|
322
|
+
return o !== void 0;
|
|
323
|
+
}
|
|
324
|
+
function Mt(o) {
|
|
325
|
+
return o.data;
|
|
326
|
+
}
|
|
327
|
+
function Ct(o) {
|
|
328
|
+
return o !== void 0;
|
|
329
|
+
}
|
|
330
|
+
function jt(o) {
|
|
331
|
+
return o.data;
|
|
332
|
+
}
|
|
333
|
+
export {
|
|
334
|
+
Xt as C,
|
|
335
|
+
ze as e
|
|
336
|
+
};
|
|
337
|
+
//# sourceMappingURL=index-D1RrKgK6.js.map
|