@undp/data-viz 2.1.2 → 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 +281 -274
- 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 +367 -356
- 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 +406 -399
- package/dist/DifferenceLineChart.js.map +1 -1
- package/dist/DonutChart.cjs +1 -1
- package/dist/DonutChart.cjs.map +1 -1
- package/dist/DonutChart.d.ts +10 -0
- package/dist/DonutChart.js +232 -263
- 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-sVZvlyWe.js → GraphEl-oZwZiTHI.js} +6 -3
- package/dist/GraphEl-oZwZiTHI.js.map +1 -0
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.d.ts +1 -0
- package/dist/GriddedGraphs.js +1 -1
- package/dist/GriddedGraphsFromConfig.d.ts +1 -0
- 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 +370 -363
- package/dist/LineChartWithConfidenceInterval.js.map +1 -1
- package/dist/MultiGraphDashboard.d.ts +1 -0
- package/dist/MultiGraphDashboardFromConfig.d.ts +1 -0
- package/dist/MultiLineAltChart.cjs +1 -1
- package/dist/MultiLineAltChart.cjs.map +1 -1
- package/dist/MultiLineAltChart.js +328 -321
- package/dist/MultiLineAltChart.js.map +1 -1
- package/dist/MultiLineChart.cjs +1 -1
- package/dist/MultiLineChart.cjs.map +1 -1
- package/dist/MultiLineChart.js +375 -368
- 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/PerformanceIntensiveMultiGraphDashboard.d.ts +1 -0
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.d.ts +1 -0
- package/dist/PerformanceIntensiveScrollStory.d.ts +1 -0
- package/dist/RadarChart.cjs +1 -1
- package/dist/RadarChart.cjs.map +1 -1
- package/dist/RadarChart.js +35 -34
- 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 +367 -360
- package/dist/ScatterPlot.js.map +1 -1
- package/dist/ScrollStory.d.ts +1 -0
- package/dist/SimpleLineChart.cjs +1 -1
- package/dist/SimpleLineChart.cjs.map +1 -1
- package/dist/SimpleLineChart.js +286 -279
- package/dist/SimpleLineChart.js.map +1 -1
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.d.ts +1 -0
- package/dist/SingleGraphDashboard.js +1 -1
- package/dist/SingleGraphDashboardFromConfig.d.ts +1 -0
- package/dist/SingleGraphDashboardGeoHubMaps.d.ts +1 -0
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.d.ts +1 -0
- package/dist/SingleGraphDashboardThreeDGraphs.d.ts +1 -0
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.d.ts +1 -0
- 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/SparkLine.cjs +1 -1
- package/dist/SparkLine.js +2 -2
- 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/Types.d.ts +1 -0
- package/dist/{area-BE2wo7fv.js → area-B6r7cv2o.js} +5 -5
- package/dist/{area-BE2wo7fv.js.map → area-B6r7cv2o.js.map} +1 -1
- package/dist/area-C1gxfNGD.cjs +2 -0
- package/dist/{area-D3Qx7k7K.cjs.map → area-C1gxfNGD.cjs.map} +1 -1
- package/dist/array-DMyR1sql.cjs +2 -0
- package/dist/array-DMyR1sql.cjs.map +1 -0
- package/dist/array-USo-Szhp.js +13 -0
- package/dist/array-USo-Szhp.js.map +1 -0
- package/dist/{ensureCompleteData-DS7gCvVd.js → ensureCompleteData-DH5c52Ub.js} +6 -6
- package/dist/{ensureCompleteData-DS7gCvVd.js.map → ensureCompleteData-DH5c52Ub.js.map} +1 -1
- package/dist/{ensureCompleteData-Oib-vGb0.cjs → ensureCompleteData-pZ9QO6kB.cjs} +2 -2
- package/dist/{ensureCompleteData-Oib-vGb0.cjs.map → ensureCompleteData-pZ9QO6kB.cjs.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 +7 -0
- package/dist/index.js +1 -1
- package/dist/line-DFlZsxI1.js +144 -0
- package/dist/line-DFlZsxI1.js.map +1 -0
- package/dist/line-DaEMhXmx.cjs +2 -0
- package/dist/line-DaEMhXmx.cjs.map +1 -0
- package/dist/style.css +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-YKUlz-37.cjs +0 -2
- package/dist/GraphEl-YKUlz-37.cjs.map +0 -1
- package/dist/GraphEl-sVZvlyWe.js.map +0 -1
- package/dist/area-D3Qx7k7K.cjs +0 -2
- package/dist/array-B7TkkRH0.js +0 -89
- package/dist/array-B7TkkRH0.js.map +0 -1
- package/dist/array-DKbXV8lR.cjs +0 -2
- package/dist/array-DKbXV8lR.cjs.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
- package/dist/line-CPfhohvF.js +0 -68
- package/dist/line-CPfhohvF.js.map +0 -1
- package/dist/line-DHV4JwCR.cjs +0 -2
- package/dist/line-DHV4JwCR.cjs.map +0 -1
package/dist/RadarChart.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RadarChart.js","sources":["../node_modules/d3-shape/src/curve/radial.js","../node_modules/d3-shape/src/lineRadial.js","../node_modules/d3-shape/src/noop.js","../node_modules/d3-shape/src/curve/cardinal.js","../node_modules/d3-shape/src/curve/cardinalClosed.js","../node_modules/d3-shape/src/curve/linearClosed.js","../src/Components/Graphs/RadarChart/Graph.tsx","../src/Components/Graphs/RadarChart/index.tsx"],"sourcesContent":["import curveLinear from \"./linear.js\";\n\nexport var curveRadialLinear = curveRadial(curveLinear);\n\nfunction Radial(curve) {\n this._curve = curve;\n}\n\nRadial.prototype = {\n areaStart: function() {\n this._curve.areaStart();\n },\n areaEnd: function() {\n this._curve.areaEnd();\n },\n lineStart: function() {\n this._curve.lineStart();\n },\n lineEnd: function() {\n this._curve.lineEnd();\n },\n point: function(a, r) {\n this._curve.point(r * Math.sin(a), r * -Math.cos(a));\n }\n};\n\nexport default function curveRadial(curve) {\n\n function radial(context) {\n return new Radial(curve(context));\n }\n\n radial._curve = curve;\n\n return radial;\n}\n","import curveRadial, {curveRadialLinear} from \"./curve/radial.js\";\nimport line from \"./line.js\";\n\nexport function lineRadial(l) {\n var c = l.curve;\n\n l.angle = l.x, delete l.x;\n l.radius = l.y, delete l.y;\n\n l.curve = function(_) {\n return arguments.length ? c(curveRadial(_)) : c()._curve;\n };\n\n return l;\n}\n\nexport default function() {\n return lineRadial(line().curve(curveRadialLinear));\n}\n","export default function() {}\n","export function point(that, x, y) {\n that._context.bezierCurveTo(\n that._x1 + that._k * (that._x2 - that._x0),\n that._y1 + that._k * (that._y2 - that._y0),\n that._x2 + that._k * (that._x1 - x),\n that._y2 + that._k * (that._y1 - y),\n that._x2,\n that._y2\n );\n}\n\nexport function Cardinal(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinal.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: point(this, this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; this._x1 = x, this._y1 = y; break;\n case 2: this._point = 3; // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new Cardinal(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import noop from \"../noop.js\";\nimport {point} from \"./cardinal.js\";\n\nexport function CardinalClosed(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinalClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalClosed(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import noop from \"../noop.js\";\n\nfunction LinearClosed(context) {\n this._context = context;\n}\n\nLinearClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._point) this._context.closePath();\n },\n point: function(x, y) {\n x = +x, y = +y;\n if (this._point) this._context.lineTo(x, y);\n else this._point = 1, this._context.moveTo(x, y);\n }\n};\n\nexport default function(context) {\n return new LinearClosed(context);\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport isEqual from 'fast-deep-equal';\r\nimport { lineRadial, curveLinearClosed, curveCardinalClosed } from 'd3-shape';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { scaleLinear } from 'd3-scale';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n RadarChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n radius: number;\r\n lineColors: string[];\r\n axisLabels: (string | number)[];\r\n data: RadarChartDataType[];\r\n\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n selectedColor?: string;\r\n onSeriesMouseOver?: (_d: any) => void;\r\n onSeriesMouseClick?: (_d: any) => void;\r\n colorDomain: string[];\r\n\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n strokeWidth: number;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n showValues: boolean;\r\n showDots: boolean;\r\n topMargin: number;\r\n bottomMargin: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n curveType: 'linear' | 'curve';\r\n noOfTicks: number;\r\n maxValue?: number;\r\n minValue?: number;\r\n fillShape: boolean;\r\n resetSelectionOnDoubleClick: boolean;\r\n highlightedLines: (string | number)[];\r\n animate: AnimateDataType;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n radius,\r\n lineColors,\r\n tooltip,\r\n onSeriesMouseOver,\r\n onSeriesMouseClick,\r\n colorDomain,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n selectedColor,\r\n axisLabels,\r\n strokeWidth,\r\n showValues,\r\n showDots,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n leftMargin,\r\n curveType,\r\n noOfTicks,\r\n minValue,\r\n maxValue,\r\n resetSelectionOnDoubleClick,\r\n fillShape,\r\n highlightedLines,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const curve = curveType === 'linear' ? curveLinearClosed : curveCardinalClosed;\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n const radiusWithoutMargin = Math.min(\r\n (2 * radius - leftMargin - rightMargin) / 2,\r\n (2 * radius - topMargin - bottomMargin) / 2,\r\n );\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const angleScale = scaleLinear()\r\n .domain([0, data[0].values.length])\r\n .range([0, 2 * Math.PI]);\r\n\r\n const maxVal = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n );\r\n\r\n const minVal = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n );\r\n const scale = scaleLinear().domain([minVal, maxVal]).range([0, radiusWithoutMargin]).nice();\r\n const ticksArray = scale.ticks(noOfTicks);\r\n const lineShape = lineRadial<number>()\r\n .radius(d => scale(d))\r\n .angle((_, i) => angleScale(i))\r\n .curve(curve);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${radius * 2}px`}\r\n height={`${radius * 2}px`}\r\n viewBox={`0 0 ${radius * 2} ${radius * 2}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n className='mx-auto'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <g transform={`translate(${radiusWithoutMargin},${radiusWithoutMargin})`}>\r\n {axisLabels.map((d, i) => (\r\n <g key={i}>\r\n <line\r\n x1={0}\r\n y1={0}\r\n x2={Math.cos(angleScale(i) - Math.PI / 2) * radiusWithoutMargin}\r\n y2={Math.sin(angleScale(i) - Math.PI / 2) * radiusWithoutMargin}\r\n key={i}\r\n className={cn(\r\n 'stroke-1 stroke-primary-gray-500 dark:stroke-primary-gray-550',\r\n classNames?.xAxis?.axis,\r\n )}\r\n style={styles?.xAxis?.axis}\r\n />\r\n <text\r\n x={Math.cos(angleScale(i) - Math.PI / 2) * (radiusWithoutMargin + 6)}\r\n y={Math.sin(angleScale(i) - Math.PI / 2) * (radiusWithoutMargin + 6)}\r\n style={{\r\n textAnchor:\r\n Math.cos(angleScale(i) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(i) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n ...(styles?.xAxis?.labels || ''),\r\n }}\r\n dy={\r\n Math.sin(angleScale(i) - Math.PI / 2) < 0\r\n ? 0\r\n : Math.sin(angleScale(i) - Math.PI / 2) < 0.00001\r\n ? 5\r\n : 10\r\n }\r\n className={cn(\r\n 'fill-primary-gray-700 dark:fill-primary-gray-300 text-xs',\r\n classNames?.xAxis?.labels,\r\n )}\r\n >\r\n {d}\r\n </text>\r\n </g>\r\n ))}\r\n {ticksArray.map((d, i) => (\r\n <g key={i}>\r\n <path\r\n d={lineShape(Array(axisLabels.length).fill(d)) || ''}\r\n className={cn(\r\n 'stroke-primary-gray-500 dark:stroke-primary-gray-550',\r\n classNames?.xAxis?.gridLines,\r\n )}\r\n style={{\r\n ...styles?.xAxis?.gridLines,\r\n fill: 'none',\r\n }}\r\n />\r\n <foreignObject\r\n x={-25}\r\n y={\r\n Math.sin(-Math.PI / 2) * scale(d) > -0.0001\r\n ? Math.sin(-Math.PI / 2) * scale(d) - 7\r\n : Math.sin(-Math.PI / 2) * scale(d) - 5\r\n }\r\n width={50}\r\n height={12}\r\n >\r\n <div className='flex justify-center'>\r\n <p\r\n className={cn(\r\n 'fill-primary-gray-500 dark:fill-primary-gray-550 text-xs m-0 py-0 px-1.5 text-center leading-none bg-primary-white dark:bg-primary-gray-700',\r\n classNames?.xAxis?.labels,\r\n )}\r\n style={styles?.xAxis?.labels}\r\n >\r\n {numberFormattingFunction(d, 'NA', precision)}\r\n </p>\r\n </div>\r\n </foreignObject>\r\n </g>\r\n ))}\r\n <AnimatePresence>\r\n {data.map((d, i) => (\r\n <motion.g\r\n key={d.label || i}\r\n variants={{\r\n initial: {\r\n opacity: mouseOverData\r\n ? d.label === mouseOverData.label\r\n ? 1\r\n : dimmedOpacity\r\n : selectedColor\r\n ? d.color\r\n ? lineColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedLines.length !== 0\r\n ? d.label\r\n ? highlightedLines.indexOf(d.label) !== -1\r\n ? 1\r\n : 0.3\r\n : 0.3\r\n : 1,\r\n },\r\n whileInView: {\r\n opacity: mouseOverData\r\n ? d.label === mouseOverData.label\r\n ? 1\r\n : dimmedOpacity\r\n : selectedColor\r\n ? d.color\r\n ? lineColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedLines.length !== 0\r\n ? d.label\r\n ? highlightedLines.indexOf(d.label) !== -1\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n >\r\n <motion.path\r\n d={lineShape(d.values) || ''}\r\n variants={{\r\n initial: {\r\n d: lineShape(d.values.map(_el => 0)) || '',\r\n stroke:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n fill: fillShape\r\n ? data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)]\r\n : 'none',\r\n strokeWidth,\r\n },\r\n whileInView: {\r\n d: lineShape(d.values) || '',\r\n transition: { duration: animate.duration },\r\n stroke:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n fill: fillShape\r\n ? data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)]\r\n : 'none',\r\n strokeWidth,\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n fillOpacity: 0.1,\r\n }}\r\n />\r\n <g>\r\n {d.values.map((el, j) => (\r\n <g key={j}>\r\n {!checkIfNullOrUndefined(el) ? (\r\n <>\r\n {showDots ? (\r\n <motion.circle\r\n r={4}\r\n variants={{\r\n initial: {\r\n cx: 0,\r\n cy: 0,\r\n opacity: 0,\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n cx: Math.cos(angleScale(j) - Math.PI / 2) * scale(el),\r\n cy: Math.sin(angleScale(j) - Math.PI / 2) * scale(el),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n style={{\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n dy={\r\n Math.sin(angleScale(j) - Math.PI / 2) < 0\r\n ? 10\r\n : Math.sin(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 0\r\n : 0\r\n }\r\n className={cn(\r\n 'graph-value text-xs font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: Math.cos(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n y: Math.sin(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n fill: lineColors[i],\r\n textAnchor:\r\n Math.cos(angleScale(j) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: Math.cos(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n y: Math.sin(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n fill: lineColors[i],\r\n textAnchor:\r\n Math.cos(angleScale(j) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {numberFormattingFunction(el, 'NA', precision)}\r\n </motion.text>\r\n ) : null}\r\n </>\r\n ) : null}\r\n </g>\r\n ))}\r\n </g>\r\n </motion.g>\r\n ))}\r\n </AnimatePresence>\r\n </g>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.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 ) : null}\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","import { useEffect, useRef, useState } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n RadarChartDataType,\r\n Languages,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\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: RadarChartDataType[];\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 each line */\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 /** Radius of the radar chart */\r\n radius?: number;\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 /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Toggle visibility of dots on the line */\r\n showDots?: boolean;\r\n /** Stroke width of the line */\r\n strokeWidth?: number;\r\n /** Toggle is the shape is filled or not */\r\n fillShape?: boolean;\r\n /** No. of ticks on the x-axis */\r\n noOfTicks?: number;\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 highlightedLines?: (string | number)[];\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Labels for the axes */\r\n axisLabels: (string | number)[];\r\n /** Curve type for the line */\r\n curveType?: 'linear' | 'curve';\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\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\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 RadarChart(props: Props) {\r\n const {\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n footNote,\r\n radius,\r\n data,\r\n showColorScale = true,\r\n padding,\r\n backgroundColor = false,\r\n tooltip,\r\n onSeriesMouseOver,\r\n graphID,\r\n onSeriesMouseClick,\r\n topMargin = 75,\r\n bottomMargin = 75,\r\n leftMargin = 75,\r\n rightMargin = 75,\r\n graphDownload = false,\r\n dataDownload = false,\r\n colorDomain,\r\n language = 'en',\r\n theme = 'light',\r\n highlightedLines = [],\r\n width,\r\n height,\r\n minHeight = 0,\r\n strokeWidth = 2,\r\n relativeHeight,\r\n ariaLabel,\r\n colorLegendTitle,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n showNAColor = true,\r\n axisLabels,\r\n showDots = true,\r\n showValues = false,\r\n curveType = 'curve',\r\n noOfTicks = 5,\r\n minValue,\r\n maxValue,\r\n fillShape = false,\r\n resetSelectionOnDoubleClick = true,\r\n animate = false,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const [graphRadius, setGraphRadius] = useState(0);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setGraphRadius(\r\n (Math.min(\r\n ...[\r\n entries[0].target.clientWidth || 620,\r\n entries[0].target.clientHeight || 480,\r\n radius || Infinity,\r\n ],\r\n ) || 420) / 2,\r\n );\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [radius]);\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}\r\n className={classNames?.colorLegend}\r\n isCenter\r\n />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {graphRadius ? (\r\n <Graph\r\n data={data}\r\n lineColors={\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 radius={graphRadius}\r\n tooltip={tooltip}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n selectedColor={selectedColor}\r\n axisLabels={axisLabels}\r\n strokeWidth={strokeWidth}\r\n showValues={showValues}\r\n showDots={showDots}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n curveType={curveType}\r\n noOfTicks={noOfTicks}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n fillShape={fillShape}\r\n highlightedLines={highlightedLines}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\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":["curveRadialLinear","curveRadial","curveLinear","Radial","curve","a","r","radial","context","lineRadial","l","c","_","lineRadial$1","line","noop","point","that","x","y","Cardinal","tension","custom","cardinal","CardinalClosed","curveCardinalClosed","LinearClosed","curveLinearClosed","Graph","props","$","_c","data","radius","lineColors","tooltip","onSeriesMouseOver","onSeriesMouseClick","colorDomain","detailsOnClick","styles","classNames","selectedColor","axisLabels","strokeWidth","showValues","showDots","rightMargin","topMargin","bottomMargin","leftMargin","curveType","noOfTicks","minValue","maxValue","resetSelectionOnDoubleClick","fillShape","highlightedLines","animate","dimmedOpacity","precision","customLayers","svgRef","useRef","t0","amount","once","isInView","useInView","t1","top","bottom","left","right","margin","radiusWithoutMargin","Math","min","mouseOverData","setMouseOverData","useState","undefined","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","T0","T1","t10","t11","t12","t13","t2","t3","t4","t5","t6","t7","t8","t9","duration","graphObjectValues","xAxis","axis","gridLines","labels","angleScale","scaleLinear","domain","values","length","range","PI","t14","checkIfNullOrUndefined","max","map","_temp2","_temp4","maxVal","t15","_temp6","_temp8","minVal","scale","nice","ticksArray","ticks","lineShape","d_3","d","angle","i","motion","svg","filter","_temp9","_temp0","d_6","i_0","jsx","cos","sin","cn","textAnchor","d_7","i_1","Array","fill","numberFormattingFunction","AnimatePresence","d_8","i_2","jsxs","initial","opacity","label","color","indexOf","whileInView","transition","event","clientY","clientX","event_0","isEqual","_temp1","stroke","_temp10","Colors","gray","_temp11","_temp12","_temp13","fillOpacity","el_3","j","el","Fragment","cx","cy","_temp14","_temp15","t16","_temp16","_temp17","t17","t18","t19","Tooltip","t20","modal","DetailsModal","t21","d_10","layer","d_9","position","el_5","el_4","el_2","el_1","el_0","_el","d_5","d_4","d_1","_temp7","l_1","d_2","_temp5","l_2","_temp3","d_0","_temp","l_0","RadarChart","graphTitle","colors","sources","graphDescription","footNote","showColorScale","padding","backgroundColor","graphID","graphDownload","dataDownload","language","theme","width","height","minHeight","relativeHeight","ariaLabel","colorLegendTitle","showNAColor","graphRadius","setGraphRadius","setSelectedColor","graphDiv","graphParentDiv","useEffect","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","Infinity","current","observe","disconnect","GraphContainer","graphContainer","GraphHeader","title","description","EmptyState","ColorLegendWithMouseOver","categoricalColors","uniqBy","colorLegend","GraphArea","primaryColors","GraphFooter","footnote","source"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5]}
|
|
1
|
+
{"version":3,"file":"RadarChart.js","sources":["../node_modules/d3-shape/src/curve/radial.js","../node_modules/d3-shape/src/lineRadial.js","../node_modules/d3-shape/src/noop.js","../node_modules/d3-shape/src/curve/cardinal.js","../node_modules/d3-shape/src/curve/cardinalClosed.js","../node_modules/d3-shape/src/curve/linearClosed.js","../src/Components/Graphs/RadarChart/Graph.tsx","../src/Components/Graphs/RadarChart/index.tsx"],"sourcesContent":["import curveLinear from \"./linear.js\";\n\nexport var curveRadialLinear = curveRadial(curveLinear);\n\nfunction Radial(curve) {\n this._curve = curve;\n}\n\nRadial.prototype = {\n areaStart: function() {\n this._curve.areaStart();\n },\n areaEnd: function() {\n this._curve.areaEnd();\n },\n lineStart: function() {\n this._curve.lineStart();\n },\n lineEnd: function() {\n this._curve.lineEnd();\n },\n point: function(a, r) {\n this._curve.point(r * Math.sin(a), r * -Math.cos(a));\n }\n};\n\nexport default function curveRadial(curve) {\n\n function radial(context) {\n return new Radial(curve(context));\n }\n\n radial._curve = curve;\n\n return radial;\n}\n","import curveRadial, {curveRadialLinear} from \"./curve/radial.js\";\nimport line from \"./line.js\";\n\nexport function lineRadial(l) {\n var c = l.curve;\n\n l.angle = l.x, delete l.x;\n l.radius = l.y, delete l.y;\n\n l.curve = function(_) {\n return arguments.length ? c(curveRadial(_)) : c()._curve;\n };\n\n return l;\n}\n\nexport default function() {\n return lineRadial(line().curve(curveRadialLinear));\n}\n","export default function() {}\n","export function point(that, x, y) {\n that._context.bezierCurveTo(\n that._x1 + that._k * (that._x2 - that._x0),\n that._y1 + that._k * (that._y2 - that._y0),\n that._x2 + that._k * (that._x1 - x),\n that._y2 + that._k * (that._y1 - y),\n that._x2,\n that._y2\n );\n}\n\nexport function Cardinal(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinal.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: point(this, this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; this._x1 = x, this._y1 = y; break;\n case 2: this._point = 3; // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new Cardinal(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import noop from \"../noop.js\";\nimport {point} from \"./cardinal.js\";\n\nexport function CardinalClosed(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinalClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalClosed(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import noop from \"../noop.js\";\n\nfunction LinearClosed(context) {\n this._context = context;\n}\n\nLinearClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._point) this._context.closePath();\n },\n point: function(x, y) {\n x = +x, y = +y;\n if (this._point) this._context.lineTo(x, y);\n else this._point = 1, this._context.moveTo(x, y);\n }\n};\n\nexport default function(context) {\n return new LinearClosed(context);\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport isEqual from 'fast-deep-equal';\r\nimport { lineRadial, curveLinearClosed, curveCardinalClosed } from 'd3-shape';\r\nimport { useRef, useState } from 'react';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { scaleLinear } from 'd3-scale';\r\nimport { AnimatePresence, motion, useInView } from 'motion/react';\r\n\r\nimport {\r\n AnimateDataType,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n RadarChartDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n radius: number;\r\n lineColors: string[];\r\n axisLabels: (string | number)[];\r\n data: RadarChartDataType[];\r\n\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n selectedColor?: string;\r\n onSeriesMouseOver?: (_d: any) => void;\r\n onSeriesMouseClick?: (_d: any) => void;\r\n colorDomain: string[];\r\n\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n strokeWidth: number;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n showValues: boolean;\r\n showDots: boolean;\r\n topMargin: number;\r\n bottomMargin: number;\r\n leftMargin: number;\r\n rightMargin: number;\r\n curveType: 'linear' | 'curve';\r\n noOfTicks: number;\r\n maxValue?: number;\r\n minValue?: number;\r\n fillShape: boolean;\r\n resetSelectionOnDoubleClick: boolean;\r\n highlightedLines: (string | number)[];\r\n animate: AnimateDataType;\r\n dimmedOpacity: number;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n radius,\r\n lineColors,\r\n tooltip,\r\n onSeriesMouseOver,\r\n onSeriesMouseClick,\r\n colorDomain,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n selectedColor,\r\n axisLabels,\r\n strokeWidth,\r\n showValues,\r\n showDots,\r\n rightMargin,\r\n topMargin,\r\n bottomMargin,\r\n leftMargin,\r\n curveType,\r\n noOfTicks,\r\n minValue,\r\n maxValue,\r\n resetSelectionOnDoubleClick,\r\n fillShape,\r\n highlightedLines,\r\n animate,\r\n dimmedOpacity,\r\n precision,\r\n customLayers,\r\n } = props;\r\n const svgRef = useRef(null);\r\n const isInView = useInView(svgRef, {\r\n once: animate.once,\r\n amount: animate.amount,\r\n });\r\n const curve = curveType === 'linear' ? curveLinearClosed : curveCardinalClosed;\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: leftMargin,\r\n right: rightMargin,\r\n };\r\n const radiusWithoutMargin = Math.min(\r\n (2 * radius - leftMargin - rightMargin) / 2,\r\n (2 * radius - topMargin - bottomMargin) / 2,\r\n );\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const angleScale = scaleLinear()\r\n .domain([0, data[0].values.length])\r\n .range([0, 2 * Math.PI]);\r\n\r\n const maxVal = !checkIfNullOrUndefined(maxValue)\r\n ? (maxValue as number)\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n ) < 0\r\n ? 0\r\n : Math.max(\r\n ...data.map(d =>\r\n Math.max(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n );\r\n\r\n const minVal = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n ) >= 0\r\n ? 0\r\n : Math.min(\r\n ...data.map(d =>\r\n Math.min(...(d.values.filter(l => !checkIfNullOrUndefined(l)) as number[])),\r\n ),\r\n );\r\n const scale = scaleLinear().domain([minVal, maxVal]).range([0, radiusWithoutMargin]).nice();\r\n const ticksArray = scale.ticks(noOfTicks);\r\n const lineShape = lineRadial<number>()\r\n .radius(d => scale(d))\r\n .angle((_, i) => angleScale(i))\r\n .curve(curve);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${radius * 2}px`}\r\n height={`${radius * 2}px`}\r\n viewBox={`0 0 ${radius * 2} ${radius * 2}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n className='mx-auto'\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <g transform={`translate(${radiusWithoutMargin},${radiusWithoutMargin})`}>\r\n {axisLabels.map((d, i) => (\r\n <g key={i}>\r\n <line\r\n x1={0}\r\n y1={0}\r\n x2={Math.cos(angleScale(i) - Math.PI / 2) * radiusWithoutMargin}\r\n y2={Math.sin(angleScale(i) - Math.PI / 2) * radiusWithoutMargin}\r\n key={i}\r\n className={cn(\r\n 'stroke-1 stroke-primary-gray-500 dark:stroke-primary-gray-550',\r\n classNames?.xAxis?.axis,\r\n )}\r\n style={styles?.xAxis?.axis}\r\n />\r\n <text\r\n x={Math.cos(angleScale(i) - Math.PI / 2) * (radiusWithoutMargin + 6)}\r\n y={Math.sin(angleScale(i) - Math.PI / 2) * (radiusWithoutMargin + 6)}\r\n style={{\r\n textAnchor:\r\n Math.cos(angleScale(i) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(i) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n ...(styles?.xAxis?.labels || ''),\r\n }}\r\n dy={\r\n Math.sin(angleScale(i) - Math.PI / 2) < 0\r\n ? 0\r\n : Math.sin(angleScale(i) - Math.PI / 2) < 0.00001\r\n ? 5\r\n : 10\r\n }\r\n className={cn(\r\n 'fill-primary-gray-700 dark:fill-primary-gray-300 text-xs',\r\n classNames?.xAxis?.labels,\r\n )}\r\n >\r\n {d}\r\n </text>\r\n </g>\r\n ))}\r\n {ticksArray.map((d, i) => (\r\n <g key={i}>\r\n <path\r\n d={lineShape(Array(axisLabels.length).fill(d)) || ''}\r\n className={cn(\r\n 'stroke-primary-gray-500 dark:stroke-primary-gray-550',\r\n classNames?.xAxis?.gridLines,\r\n )}\r\n style={{\r\n ...styles?.xAxis?.gridLines,\r\n fill: 'none',\r\n }}\r\n />\r\n <foreignObject\r\n x={-25}\r\n y={\r\n Math.sin(-Math.PI / 2) * scale(d) > -0.0001\r\n ? Math.sin(-Math.PI / 2) * scale(d) - 7\r\n : Math.sin(-Math.PI / 2) * scale(d) - 5\r\n }\r\n width={50}\r\n height={12}\r\n >\r\n <div className='flex justify-center'>\r\n <p\r\n className={cn(\r\n 'fill-primary-gray-500 dark:fill-primary-gray-550 text-xs m-0 py-0 px-1.5 text-center leading-none bg-primary-white dark:bg-primary-gray-700',\r\n classNames?.xAxis?.labels,\r\n )}\r\n style={styles?.xAxis?.labels}\r\n >\r\n {numberFormattingFunction(d, 'NA', precision)}\r\n </p>\r\n </div>\r\n </foreignObject>\r\n </g>\r\n ))}\r\n <AnimatePresence>\r\n {data.map((d, i) => (\r\n <motion.g\r\n key={d.label || i}\r\n variants={{\r\n initial: {\r\n opacity: mouseOverData\r\n ? d.label === mouseOverData.label\r\n ? 1\r\n : dimmedOpacity\r\n : selectedColor\r\n ? d.color\r\n ? lineColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedLines.length !== 0\r\n ? d.label\r\n ? highlightedLines.indexOf(d.label) !== -1\r\n ? 1\r\n : 0.3\r\n : 0.3\r\n : 1,\r\n },\r\n whileInView: {\r\n opacity: mouseOverData\r\n ? d.label === mouseOverData.label\r\n ? 1\r\n : dimmedOpacity\r\n : selectedColor\r\n ? d.color\r\n ? lineColors[colorDomain.indexOf(d.color)] === selectedColor\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : highlightedLines.length !== 0\r\n ? d.label\r\n ? highlightedLines.indexOf(d.label) !== -1\r\n ? 1\r\n : dimmedOpacity\r\n : dimmedOpacity\r\n : 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d);\r\n onSeriesMouseClick?.(d);\r\n }\r\n }\r\n }}\r\n >\r\n <motion.path\r\n d={lineShape(d.values) || ''}\r\n variants={{\r\n initial: {\r\n d: lineShape(d.values.map(_el => 0)) || '',\r\n stroke:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n fill: fillShape\r\n ? data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)]\r\n : 'none',\r\n strokeWidth,\r\n },\r\n whileInView: {\r\n d: lineShape(d.values) || '',\r\n transition: { duration: animate.duration },\r\n stroke:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n fill: fillShape\r\n ? data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)]\r\n : 'none',\r\n strokeWidth,\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n style={{\r\n fillOpacity: 0.1,\r\n }}\r\n />\r\n <g>\r\n {d.values.map((el, j) => (\r\n <g key={j}>\r\n {!checkIfNullOrUndefined(el) ? (\r\n <>\r\n {showDots ? (\r\n <motion.circle\r\n r={4}\r\n variants={{\r\n initial: {\r\n cx: 0,\r\n cy: 0,\r\n opacity: 0,\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n },\r\n whileInView: {\r\n cx: Math.cos(angleScale(j) - Math.PI / 2) * scale(el),\r\n cy: Math.sin(angleScale(j) - Math.PI / 2) * scale(el),\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n fill:\r\n data.filter(el => el.color).length === 0\r\n ? lineColors[0]\r\n : !d.color\r\n ? Colors.gray\r\n : lineColors[colorDomain.indexOf(d.color)],\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n />\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n style={{\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n dy={\r\n Math.sin(angleScale(j) - Math.PI / 2) < 0\r\n ? 10\r\n : Math.sin(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 0\r\n : 0\r\n }\r\n className={cn(\r\n 'graph-value text-xs font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n x: Math.cos(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n y: Math.sin(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n fill: lineColors[i],\r\n textAnchor:\r\n Math.cos(angleScale(j) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: Math.cos(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n y: Math.sin(angleScale(j) - Math.PI / 2) * (scale(el) + 6),\r\n fill: lineColors[i],\r\n textAnchor:\r\n Math.cos(angleScale(j) - Math.PI / 2) < 0\r\n ? 'end'\r\n : Math.cos(angleScale(j) - Math.PI / 2) < 0.00001\r\n ? 'middle'\r\n : 'start',\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n >\r\n {numberFormattingFunction(el, 'NA', precision)}\r\n </motion.text>\r\n ) : null}\r\n </>\r\n ) : null}\r\n </g>\r\n ))}\r\n </g>\r\n </motion.g>\r\n ))}\r\n </AnimatePresence>\r\n </g>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n </g>\r\n </motion.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 ) : null}\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","import { useEffect, useRef, useState } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n RadarChartDataType,\r\n Languages,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { ColorLegendWithMouseOver } from '@/Components/Elements/ColorLegendWithMouseOver';\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: RadarChartDataType[];\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 each line */\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 /** Radius of the radar chart */\r\n radius?: number;\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 /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Toggle visibility of dots on the line */\r\n showDots?: boolean;\r\n /** Stroke width of the line */\r\n strokeWidth?: number;\r\n /** Toggle is the shape is filled or not */\r\n fillShape?: boolean;\r\n /** No. of ticks on the x-axis */\r\n noOfTicks?: number;\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 highlightedLines?: (string | number)[];\r\n /** Defines the opacity of the non-highlighted data */\r\n dimmedOpacity?: number;\r\n /** Toggles if the graph animates in when loaded. */\r\n animate?: boolean | AnimateDataType;\r\n /** Labels for the axes */\r\n axisLabels: (string | number)[];\r\n /** Curve type for the line */\r\n curveType?: 'linear' | 'curve';\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Optional SVG <g> element or function that renders custom content behind or in front of the graph. */\r\n customLayers?: CustomLayerDataType[];\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\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 RadarChart(props: Props) {\r\n const {\r\n graphTitle,\r\n colors,\r\n sources,\r\n graphDescription,\r\n footNote,\r\n radius,\r\n data,\r\n showColorScale = true,\r\n padding,\r\n backgroundColor = false,\r\n tooltip,\r\n onSeriesMouseOver,\r\n graphID,\r\n onSeriesMouseClick,\r\n topMargin = 75,\r\n bottomMargin = 75,\r\n leftMargin = 75,\r\n rightMargin = 75,\r\n graphDownload = false,\r\n dataDownload = false,\r\n colorDomain,\r\n language = 'en',\r\n theme = 'light',\r\n highlightedLines = [],\r\n width,\r\n height,\r\n minHeight = 0,\r\n strokeWidth = 2,\r\n relativeHeight,\r\n ariaLabel,\r\n colorLegendTitle,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n showNAColor = true,\r\n axisLabels,\r\n showDots = true,\r\n showValues = false,\r\n curveType = 'curve',\r\n noOfTicks = 5,\r\n minValue,\r\n maxValue,\r\n fillShape = false,\r\n resetSelectionOnDoubleClick = true,\r\n animate = false,\r\n dimmedOpacity = 0.3,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const [graphRadius, setGraphRadius] = useState(0);\r\n const [selectedColor, setSelectedColor] = useState<string | undefined>(undefined);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setGraphRadius(\r\n (Math.min(\r\n ...[\r\n entries[0].target.clientWidth || 620,\r\n entries[0].target.clientHeight || 480,\r\n radius || Infinity,\r\n ],\r\n ) || 420) / 2,\r\n );\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [radius]);\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}\r\n className={classNames?.colorLegend}\r\n isCenter\r\n />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {data.length === 0 && <EmptyState />}\r\n {graphRadius && data.length > 0 ? (\r\n <Graph\r\n data={data}\r\n lineColors={\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 radius={graphRadius}\r\n tooltip={tooltip}\r\n colorDomain={colorDomain || (uniqBy(data, 'color', true) as string[])}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n selectedColor={selectedColor}\r\n axisLabels={axisLabels}\r\n strokeWidth={strokeWidth}\r\n showValues={showValues}\r\n showDots={showDots}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n curveType={curveType}\r\n noOfTicks={noOfTicks}\r\n minValue={minValue}\r\n maxValue={maxValue}\r\n fillShape={fillShape}\r\n highlightedLines={highlightedLines}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n animate={\r\n animate === true\r\n ? { duration: 0.5, once: true, amount: 0.5 }\r\n : animate || { duration: 0, once: true, amount: 0 }\r\n }\r\n dimmedOpacity={dimmedOpacity}\r\n precision={precision}\r\n customLayers={customLayers}\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":["curveRadialLinear","curveRadial","curveLinear","Radial","curve","a","r","radial","context","lineRadial","l","c","_","lineRadial$1","line","noop","point","that","x","y","Cardinal","tension","custom","cardinal","CardinalClosed","curveCardinalClosed","LinearClosed","curveLinearClosed","Graph","props","$","_c","data","radius","lineColors","tooltip","onSeriesMouseOver","onSeriesMouseClick","colorDomain","detailsOnClick","styles","classNames","selectedColor","axisLabels","strokeWidth","showValues","showDots","rightMargin","topMargin","bottomMargin","leftMargin","curveType","noOfTicks","minValue","maxValue","resetSelectionOnDoubleClick","fillShape","highlightedLines","animate","dimmedOpacity","precision","customLayers","svgRef","useRef","t0","amount","once","isInView","useInView","t1","top","bottom","left","right","margin","radiusWithoutMargin","Math","min","mouseOverData","setMouseOverData","useState","undefined","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","T0","T1","t10","t11","t12","t13","t2","t3","t4","t5","t6","t7","t8","t9","duration","graphObjectValues","xAxis","axis","gridLines","labels","angleScale","scaleLinear","domain","values","length","range","PI","t14","checkIfNullOrUndefined","max","map","_temp2","_temp4","maxVal","t15","_temp6","_temp8","minVal","scale","nice","ticksArray","ticks","lineShape","d_3","d","angle","i","motion","svg","filter","_temp9","_temp0","d_6","i_0","jsx","cos","sin","cn","textAnchor","d_7","i_1","Array","fill","numberFormattingFunction","AnimatePresence","d_8","i_2","jsxs","initial","opacity","label","color","indexOf","whileInView","transition","event","clientY","clientX","event_0","isEqual","_temp1","stroke","_temp10","Colors","gray","_temp11","_temp12","_temp13","fillOpacity","el_3","j","el","Fragment","cx","cy","_temp14","_temp15","t16","_temp16","_temp17","t17","t18","t19","Tooltip","t20","modal","DetailsModal","t21","d_10","layer","d_9","position","el_5","el_4","el_2","el_1","el_0","_el","d_5","d_4","d_1","_temp7","l_1","d_2","_temp5","l_2","_temp3","d_0","_temp","l_0","RadarChart","graphTitle","colors","sources","graphDescription","footNote","showColorScale","padding","backgroundColor","graphID","graphDownload","dataDownload","language","theme","width","height","minHeight","relativeHeight","ariaLabel","colorLegendTitle","showNAColor","graphRadius","setGraphRadius","setSelectedColor","graphDiv","graphParentDiv","useEffect","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","Infinity","current","observe","disconnect","GraphContainer","graphContainer","GraphHeader","title","description","ColorLegendWithMouseOver","categoricalColors","uniqBy","colorLegend","GraphArea","EmptyState","primaryColors","GraphFooter","footnote","source"],"mappings":";;;;;;;;;;;;;;;;;;;AAEO,IAAIA,KAAoBC,GAAYC,EAAW;AAEtD,SAASC,GAAOC,GAAO;AACrB,OAAK,SAASA;AAChB;AAEAD,GAAO,YAAY;AAAA,EACjB,WAAW,WAAW;AACpB,SAAK,OAAO,UAAS;AAAA,EACvB;AAAA,EACA,SAAS,WAAW;AAClB,SAAK,OAAO,QAAO;AAAA,EACrB;AAAA,EACA,WAAW,WAAW;AACpB,SAAK,OAAO,UAAS;AAAA,EACvB;AAAA,EACA,SAAS,WAAW;AAClB,SAAK,OAAO,QAAO;AAAA,EACrB;AAAA,EACA,OAAO,SAASE,GAAGC,GAAG;AACpB,SAAK,OAAO,MAAMA,IAAI,KAAK,IAAID,CAAC,GAAGC,IAAI,CAAC,KAAK,IAAID,CAAC,CAAC;AAAA,EACrD;AACF;AAEe,SAASJ,GAAYG,GAAO;AAEzC,WAASG,EAAOC,GAAS;AACvB,WAAO,IAAIL,GAAOC,EAAMI,CAAO,CAAC;AAAA,EAClC;AAEA,SAAAD,EAAO,SAASH,GAETG;AACT;AChCO,SAASE,GAAWC,GAAG;AAC5B,MAAIC,IAAID,EAAE;AAEV,SAAAA,EAAE,QAAQA,EAAE,GAAG,OAAOA,EAAE,GACxBA,EAAE,SAASA,EAAE,GAAG,OAAOA,EAAE,GAEzBA,EAAE,QAAQ,SAASE,GAAG;AACpB,WAAO,UAAU,SAASD,EAAEV,GAAYW,CAAC,CAAC,IAAID,EAAC,EAAG;AAAA,EACpD,GAEOD;AACT;AAEe,SAAAG,KAAW;AACxB,SAAOJ,GAAWK,GAAI,EAAG,MAAMd,EAAiB,CAAC;AACnD;AClBe,SAAAe,KAAW;AAAC;ACApB,SAASC,GAAMC,GAAMC,GAAGC,GAAG;AAChC,EAAAF,EAAK,SAAS;AAAA,IACZA,EAAK,MAAMA,EAAK,MAAMA,EAAK,MAAMA,EAAK;AAAA,IACtCA,EAAK,MAAMA,EAAK,MAAMA,EAAK,MAAMA,EAAK;AAAA,IACtCA,EAAK,MAAMA,EAAK,MAAMA,EAAK,MAAMC;AAAA,IACjCD,EAAK,MAAMA,EAAK,MAAMA,EAAK,MAAME;AAAA,IACjCF,EAAK;AAAA,IACLA,EAAK;AAAA,EACT;AACA;AAEO,SAASG,GAASZ,GAASa,GAAS;AACzC,OAAK,WAAWb,GAChB,KAAK,MAAM,IAAIa,KAAW;AAC5B;AAEAD,GAAS,YAAY;AAAA,EACnB,WAAW,WAAW;AACpB,SAAK,QAAQ;AAAA,EACf;AAAA,EACA,SAAS,WAAW;AAClB,SAAK,QAAQ;AAAA,EACf;AAAA,EACA,WAAW,WAAW;AACpB,SAAK,MAAM,KAAK,MAAM,KAAK,MAC3B,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KACjC,KAAK,SAAS;AAAA,EAChB;AAAA,EACA,SAAS,WAAW;AAClB,YAAQ,KAAK,QAAM;AAAA,MACjB,KAAK;AAAG,aAAK,SAAS,OAAO,KAAK,KAAK,KAAK,GAAG;AAAG;AAAA,MAClD,KAAK;AAAG,QAAAJ,GAAM,MAAM,KAAK,KAAK,KAAK,GAAG;AAAG;AAAA,IAC/C;AACI,KAAI,KAAK,SAAU,KAAK,UAAU,KAAK,KAAK,WAAW,MAAI,KAAK,SAAS,UAAS,GAClF,KAAK,QAAQ,IAAI,KAAK;AAAA,EACxB;AAAA,EACA,OAAO,SAASE,GAAGC,GAAG;AAEpB,YADAD,IAAI,CAACA,GAAGC,IAAI,CAACA,GACL,KAAK,QAAM;AAAA,MACjB,KAAK;AAAG,aAAK,SAAS,GAAG,KAAK,QAAQ,KAAK,SAAS,OAAOD,GAAGC,CAAC,IAAI,KAAK,SAAS,OAAOD,GAAGC,CAAC;AAAG;AAAA,MAC/F,KAAK;AAAG,aAAK,SAAS,GAAG,KAAK,MAAMD,GAAG,KAAK,MAAMC;AAAG;AAAA,MACrD,KAAK;AAAG,aAAK,SAAS;AAAA;AAAA,MACtB;AAAS,QAAAH,GAAM,MAAME,GAAGC,CAAC;AAAG;AAAA,IAClC;AACI,SAAK,MAAM,KAAK,KAAK,KAAK,MAAM,KAAK,KAAK,KAAK,MAAMD,GACrD,KAAK,MAAM,KAAK,KAAK,KAAK,MAAM,KAAK,KAAK,KAAK,MAAMC;AAAA,EACvD;AACF;AAAA,CAEgB,SAASG,EAAOD,GAAS;AAEvC,WAASE,EAASf,GAAS;AACzB,WAAO,IAAIY,GAASZ,GAASa,CAAO;AAAA,EACtC;AAEA,SAAAE,EAAS,UAAU,SAASF,GAAS;AACnC,WAAOC,EAAO,CAACD,CAAO;AAAA,EACxB,GAEOE;AACT,GAAG,CAAC;ACzDG,SAASC,GAAehB,GAASa,GAAS;AAC/C,OAAK,WAAWb,GAChB,KAAK,MAAM,IAAIa,KAAW;AAC5B;AAEAG,GAAe,YAAY;AAAA,EACzB,WAAWT;AAAA,EACX,SAASA;AAAA,EACT,WAAW,WAAW;AACpB,SAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAC5D,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAClE,KAAK,SAAS;AAAA,EAChB;AAAA,EACA,SAAS,WAAW;AAClB,YAAQ,KAAK,QAAM;AAAA,MACjB,KAAK,GAAG;AACN,aAAK,SAAS,OAAO,KAAK,KAAK,KAAK,GAAG,GACvC,KAAK,SAAS,UAAS;AACvB;AAAA,MACF;AAAA,MACA,KAAK,GAAG;AACN,aAAK,SAAS,OAAO,KAAK,KAAK,KAAK,GAAG,GACvC,KAAK,SAAS,UAAS;AACvB;AAAA,MACF;AAAA,MACA,KAAK,GAAG;AACN,aAAK,MAAM,KAAK,KAAK,KAAK,GAAG,GAC7B,KAAK,MAAM,KAAK,KAAK,KAAK,GAAG,GAC7B,KAAK,MAAM,KAAK,KAAK,KAAK,GAAG;AAC7B;AAAA,MACF;AAAA,IACN;AAAA,EACE;AAAA,EACA,OAAO,SAASG,GAAGC,GAAG;AAEpB,YADAD,IAAI,CAACA,GAAGC,IAAI,CAACA,GACL,KAAK,QAAM;AAAA,MACjB,KAAK;AAAG,aAAK,SAAS,GAAG,KAAK,MAAMD,GAAG,KAAK,MAAMC;AAAG;AAAA,MACrD,KAAK;AAAG,aAAK,SAAS,GAAG,KAAK,SAAS,OAAO,KAAK,MAAMD,GAAG,KAAK,MAAMC,CAAC;AAAG;AAAA,MAC3E,KAAK;AAAG,aAAK,SAAS,GAAG,KAAK,MAAMD,GAAG,KAAK,MAAMC;AAAG;AAAA,MACrD;AAAS,QAAAH,GAAM,MAAME,GAAGC,CAAC;AAAG;AAAA,IAClC;AACI,SAAK,MAAM,KAAK,KAAK,KAAK,MAAM,KAAK,KAAK,KAAK,MAAMD,GACrD,KAAK,MAAM,KAAK,KAAK,KAAK,MAAM,KAAK,KAAK,KAAK,MAAMC;AAAA,EACvD;AACF;AAEA,MAAAM,MAAgB,SAASH,EAAOD,GAAS;AAEvC,WAASE,EAASf,GAAS;AACzB,WAAO,IAAIgB,GAAehB,GAASa,CAAO;AAAA,EAC5C;AAEA,SAAAE,EAAS,UAAU,SAASF,GAAS;AACnC,WAAOC,EAAO,CAACD,CAAO;AAAA,EACxB,GAEOE;AACT,GAAG,CAAC;AC1DJ,SAASG,GAAalB,GAAS;AAC7B,OAAK,WAAWA;AAClB;AAEAkB,GAAa,YAAY;AAAA,EACvB,WAAWX;AAAA,EACX,SAASA;AAAA,EACT,WAAW,WAAW;AACpB,SAAK,SAAS;AAAA,EAChB;AAAA,EACA,SAAS,WAAW;AAClB,IAAI,KAAK,UAAQ,KAAK,SAAS,UAAS;AAAA,EAC1C;AAAA,EACA,OAAO,SAASG,GAAGC,GAAG;AACpB,IAAAD,IAAI,CAACA,GAAGC,IAAI,CAACA,GACT,KAAK,SAAQ,KAAK,SAAS,OAAOD,GAAGC,CAAC,KACrC,KAAK,SAAS,GAAG,KAAK,SAAS,OAAOD,GAAGC,CAAC;AAAA,EACjD;AACF;AAEe,SAAAQ,GAASnB,GAAS;AAC/B,SAAO,IAAIkB,GAAalB,CAAO;AACjC;ACgCO,SAAAoB,GAAAC,GAAA;AAAA,QAAAC,IAAAC,GAAAA,EAAA,GAAA,GACL;AAAA,IAAAC,MAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAC,mBAAAA;AAAAA,IAAAC,oBAAAA;AAAAA,IAAAC,aAAAA;AAAAA,IAAAC,gBAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,eAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,aAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,aAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,cAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,6BAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,kBAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAC,eAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,cAAAA;AAAAA,EAAAA,IA+BIhC,GACJiC,KAAeC,GAAO,IAAI;AAAE,MAAAC;AAAA,EAAAlC,EAAA,CAAA,MAAA4B,EAAAO,UAAAnC,EAAA,CAAA,MAAA4B,EAAAQ,QACOF,IAAA;AAAA,IAAAE,MAC3BR,EAAOQ;AAAAA,IAAKD,QACVP,EAAOO;AAAAA,EAAAA,GAChBnC,EAAA,CAAA,IAAA4B,EAAAO,QAAAnC,EAAA,CAAA,IAAA4B,EAAAQ,MAAApC,OAAAkC,KAAAA,IAAAlC,EAAA,CAAA;AAHD,QAAAqC,IAAiBC,GAAUN,IAAQE,CAGlC,GACD5D,KAAc+C,OAAc,WAAdxB,KAAAF;AAAiE,MAAA4C;AAAA,EAAAvC,EAAA,CAAA,MAAAmB,KAAAnB,EAAA,CAAA,MAAAoB,KAAApB,EAAA,CAAA,MAAAiB,KAAAjB,SAAAkB,KAChEqB,KAAA;AAAA,IAAAC,KACRtB;AAAAA,IAASuB,QACNtB;AAAAA,IAAYuB,MACdtB;AAAAA,IAAUuB,OACT1B;AAAAA,EAAAA,GACRjB,OAAAmB,GAAAnB,OAAAoB,GAAApB,OAAAiB,GAAAjB,OAAAkB,GAAAlB,OAAAuC,MAAAA,KAAAvC,EAAA,CAAA;AALD,QAAA4C,IAAeL,IAMfM,IAA4BC,KAAIC,KAC7B,IAAI5C,IAASiB,IAAaH,KAAe,IACzC,IAAId,IAASe,IAAYC,KAAgB,CAC5C,GACA,CAAA6B,GAAAC,EAAA,IAA0CC,GAAcC,MAAS,GAEjE,CAAAC,GAAAC,EAAA,IAA4CH,GAAcC,MAAS,GACnE,CAAAG,IAAAC,EAAA,IAA4BL,GAA6BC,MAAS,GAClE,CAAAK,GAAAC,EAAA,IAA4BP,GAA6BC,MAAS;AAAE,MAAAO,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,IAAAC,GAAAC,IAAAC;AAAA,MAAAvE,EAAA,CAAA,MAAA4B,EAAA4C,YAAAxE,EAAA,CAAA,MAAAa,KAAAb,EAAA,EAAA,MAAAW,GAAA8D,qBAAAzE,EAAA,EAAA,MAAAW,GAAA+D,OAAAC,QAAA3E,EAAA,EAAA,MAAAW,GAAA+D,OAAAE,aAAA5E,EAAA,EAAA,MAAAW,GAAA+D,OAAAG,UAAA7E,UAAAQ,KAAAR,EAAA,EAAA,MAAA1B,MAAA0B,UAAA+B,KAAA/B,EAAA,EAAA,MAAAE,KAAAF,EAAA,EAAA,MAAAS,KAAAT,UAAA6B,KAAA7B,EAAA,EAAA,MAAA0B,KAAA1B,UAAA2B,KAAA3B,EAAA,EAAA,MAAAqC,KAAArC,EAAA,EAAA,MAAAI,KAAAJ,UAAA4C,EAAAF,QAAA1C,UAAA4C,EAAAJ,OAAAxC,EAAA,EAAA,MAAAwB,KAAAxB,EAAA,EAAA,MAAAuB,KAAAvB,UAAAoD,KAAApD,EAAA,EAAA,MAAAgD,KAAAhD,EAAA,EAAA,MAAAsB,MAAAtB,EAAA,EAAA,MAAAO,KAAAP,EAAA,EAAA,MAAAM,KAAAN,UAAA8B,MAAA9B,EAAA,EAAA,MAAAG,KAAAH,EAAA,EAAA,MAAA6C,KAAA7C,UAAAyB,KAAAzB,EAAA,EAAA,MAAAY,KAAAZ,UAAAgB,MAAAhB,EAAA,EAAA,MAAAe,MAAAf,EAAA,EAAA,MAAAc,KAAAd,UAAAU,GAAA+D,qBAAAzE,EAAA,EAAA,MAAAU,GAAAgE,OAAAC,QAAA3E,UAAAU,GAAAgE,OAAAE,aAAA5E,EAAA,EAAA,MAAAU,GAAAgE,OAAAG,QAAA;AACpE,UAAAC,IAAmBC,KAAaC,OACtB,CAAC,GAAG9E,KAAO+E,OAAOC,MAAO,CAAC,EAACC,MAC5B,CAAC,GAAG,IAAIrC,KAAIsC,EAAG,CAAC;AAAE,QAAAC;AAAA,IAAArF,EAAA,EAAA,MAAAE,KAAAF,UAAAwB,KAEZ6D,KAACC,EAAuB9D,CAAQ,IAE3CsB,KAAIyC,IAAI,GACDrF,EAAIsF,IAAKC,EAEZ,CACF,IAAI,IAJN,IAME3C,KAAIyC,IAAI,GACHrF,EAAIsF,IAAKE,EAEZ,CACF,IAXDlE,GAWExB,QAAAE,GAAAF,QAAAwB,GAAAxB,QAAAqF,MAAAA,KAAArF,EAAA,EAAA;AAZP,UAAA2F,KAAeN;AAYP,QAAAO;AAAA,IAAA5F,EAAA,EAAA,MAAAE,KAAAF,UAAAuB,KAEOqE,KAACN,EAAuB/D,CAAQ,IAE3CuB,KAAIC,IAAI,GACD7C,EAAIsF,IAAKK,EAEZ,CACF,KAAK,IAJP,IAME/C,KAAIC,IAAI,GACH7C,EAAIsF,IAAKM,EAEZ,CACF,IAXDvE,GAWEvB,QAAAE,GAAAF,QAAAuB,GAAAvB,QAAA4F,MAAAA,KAAA5F,EAAA,EAAA;AAZP,UAAA+F,KAAeH,IAafI,IAAcjB,GAAAA,EAAaC,OAAQ,CAACe,IAAQJ,EAAM,CAAC,EAACR,MAAO,CAAC,GAAGtC,CAAmB,CAAC,EAACoD,KAAAA,GACpFC,KAAmBF,EAAKG,MAAO7E,EAAS,GACxC8E,KAAkBzH,KAAoBwB,OAC5BkG,CAAAA,MAAKL,EAAMM,CAAC,CAAC,EAACC,MACf,CAAAzH,GAAA0H,MAAU1B,EAAW0B,CAAC,CAAC,EAAClI,MACxBA,EAAK;AAGTqF,IAAAA,IAAA8C,GAAMC,KACEpC,KAAA,GAAGnE,IAAS,CAAC,MACZoE,KAAA,GAAGpE,IAAS,CAAC,MACZyD,IAAA,OAAOzD,IAAS,CAAC,IAAIA,IAAS,CAAC,IAC9B0D,IAAA,OACL7B,IAAAA,IACK+B,IAAA,WAEIK,KAAA,aAAaxB,EAAMF,IAAK,IAAIE,EAAMJ,GAAI,KAAGxC,UAAA+B,KACpDsC,IAAAtC,EAAY4E,OAAQC,EAA4B,EAACpB,IAAKqB,EAAY,GAAC7G,QAAA+B,GAAA/B,QAAAqE,KAAAA,IAAArE,EAAA,EAAA,GACtDiE,IAAA,aAAapB,CAAmB,IAAIA,CAAmB,KAClEqB,IAAArD,EAAU2E,IAAK,CAAAsB,GAAAC,6BACd,KAAA,EACE,UAAA;AAAA,MAAAC,gBAAAA,MAAA,UACM,IAAA,GACA,IAAA,GACA,IAAAlE,KAAImE,IAAKnC,EAAW0B,CAAC,IAAI1D,KAAIsC,KAAM,CAAC,IAAIvC,GACxC,IAAAC,KAAIoE,IAAKpC,EAAW0B,CAAC,IAAI1D,KAAIsC,KAAM,CAAC,IAAIvC,GAEjC,WAAAsE,GACT,iEACAxG,GAAU+D,OAAaC,IACzB,GACO,OAAAjE,GAAMgE,OAAaC,QALrB6B,CAKqB;AAAA,MAE5BQ,gBAAAA,EAAAA,IAAA,QAAA,EACK,GAAAlE,KAAImE,IAAKnC,EAAW0B,CAAC,IAAI1D,KAAIsC,KAAM,CAAC,KAAKvC,IAAsB,IAC/D,GAAAC,KAAIoE,IAAKpC,EAAW0B,CAAC,IAAI1D,KAAIsC,KAAM,CAAC,KAAKvC,IAAsB,IAC3D,OAAA;AAAA,QAAAuE,YAEHtE,KAAImE,IAAKnC,EAAW0B,CAAC,IAAI1D,KAAIsC,KAAM,CAAC,IAAI,IAAxC,QAEItC,KAAImE,IAAKnC,EAAW0B,CAAC,IAAI1D,KAAIsC,KAAM,CAAC,IAAI,OAAxC,WAAA;AAAA,QAES,GACX1E,GAAMgE,OAAeG,UAArB;AAAA,MAAA,GAGJ,IAAA/B,KAAIoE,IAAKpC,EAAW0B,CAAC,IAAI1D,KAAIsC,KAAM,CAAC,IAAI,IAAxC,IAEItC,KAAIoE,IAAKpC,EAAW0B,CAAC,IAAI1D,KAAIsC,KAAM,CAAC,IAAI,OAAxC,IAAA,IAIK,WAAA+B,GACT,4DACAxG,GAAU+D,OAAeG,MAC3B,GAECyB,UAAAA,EAAAA,CACH;AAAA,IAAA,EAAA,IACF,CACD,GACAnC,IAAA+B,GAAUV,IAAK,CAAA6B,GAAAC,6BACd,KAAA,EACE,UAAA;AAAA,MAAAN,gBAAAA,MAAA,UACK,GAAAZ,GAAUmB,MAAM1G,EAAUqE,MAAO,EAACsC,KAAMlB,CAAC,CAAO,KAAhD,IACQ,WAAAa,GACT,wDACAxG,GAAU+D,OAAkBE,SAC9B,GACO,OAAA;AAAA,QAAA,GACFlE,GAAMgE,OAAkBE;AAAAA,QAAA4C,MACrB;AAAA,MAAA,GACP;AAAA,MAEHR,gBAAAA,EAAAA,IAAA,iBAAA,EACK,GAAA,KAED,GAAAlE,KAAIoE,IAAK,CAACpE,KAAIsC,KAAM,CAAC,IAAIY,EAAMM,CAAC,IAAI,QAChCxD,KAAIoE,IAAK,CAACpE,KAAIsC,KAAM,CAAC,IAAIY,EAAMM,CAAC,IAAI,IACpCxD,KAAIoE,IAAK,CAACpE,KAAIsC,KAAM,CAAC,IAAIY,EAAMM,CAAC,IAAI,GAEnC,OAAA,IACC,QAAA,IAER,UAAAU,gBAAAA,EAAAA,IAAA,OAAA,EAAe,WAAA,uBACb,gCAAA,KAAA,EACa,WAAAG,GACT,+IACAxG,GAAU+D,OAAeG,MAC3B,GACO,OAAAnE,GAAMgE,OAAeG,QAE3B4C,UAAAA,GAAyBnB,GAAG,MAAMxE,EAAS,EAAA,CAC9C,GACF,EAAA,CACF;AAAA,IAAA,EAAA,GAjCM0E,CAkCR,CACD,GACA9C,IAAAgE,IACE1D,IAAA9D,EAAIsF,IAAK,CAAAmC,GAAAC,MACRC,gBAAAA,EAAAA,KAAApB,GAAA,GAAA,EAEY,UAAA;AAAA,MAAAqB,SACC;AAAA,QAAAC,SACE/E,IACLsD,EAAC0B,UAAWhF,EAAagF,QAAzB,IAAAnG,IAGAjB,IACE0F,EAAC2B,SACC7H,EAAWI,EAAW0H,QAAS5B,EAAC2B,KAAM,CAAC,MAAMrH,IAA7C,IADFiB,IAKAF,EAAgBuD,WAAY,IAC1BoB,EAAC0B,SACCrG,EAAgBuG,QAAS5B,EAAC0B,KAAM,MAAM,KAAtC,IADF,MADF;AAAA,MAAA;AAAA,MAOPG,aACY;AAAA,QAAAJ,SACF/E,IACLsD,EAAC0B,UAAWhF,EAAagF,QAAzB,IAAAnG,IAGAjB,IACE0F,EAAC2B,SACC7H,EAAWI,EAAW0H,QAAS5B,EAAC2B,KAAM,CAAC,MAAMrH,IAA7C,IADFiB,IAKAF,EAAgBuD,WAAY,IAC1BoB,EAAC0B,SACCrG,EAAgBuG,QAAS5B,EAAC0B,KAAM,MAAM,KAAtC,IADFnG,IADF;AAAA,QAMGuG,YACG;AAAA,UAAA5D,UAAY5C,EAAO4C;AAAAA,QAAAA;AAAAA,MAAU;AAAA,IAC3C,GAEM,SAAA,WACC,SAAAnC,IAAA,gBAAA,WACH,MAAA;AAAA,MAAA0F,SAAW;AAAA,MAACK,YAAc;AAAA,QAAA5D,UAAY5C,EAAO4C;AAAAA,MAAAA;AAAAA,IAAU,GAC/C,cAAA6D,CAAAA,MAAA;AACZpF,MAAAA,GAAiBqD,CAAC,GAClB7C,GAAU4E,EAAKC,OAAQ,GACvB/E,GAAU8E,EAAKE,OAAQ,GACvBjI,IAAoBgG,CAAC;AAAA,IAAC,GAEX,aAAAkC,CAAAA,MAAA;AACXvF,MAAAA,GAAiBqD,CAAC,GAClB7C,GAAU4E,EAAKC,OAAQ,GACvB/E,GAAU8E,EAAKE,OAAQ;AAAA,IAAC,GAEZ,cAAA,MAAA;AACZtF,MAAAA,GAAiBE,MAAS,GAC1BI,GAAUJ,MAAS,GACnBM,GAAUN,MAAS,GACnB7C,IAAoB6C,MAAS;AAAA,IAAC,GAEvB,SAAA,MAAA;AACP,OAAI5C,KAAAE,OACEgI,GAAQrF,GAAgBkD,CAAgC,KAAxD7E,KACF4B,GAAkBF,MAAS,GAC3B5C,IAAqB4C,MAAS,MAE9BE,GAAkBiD,CAAC,GACnB/F,IAAqB+F,CAAC;AAAA,IAEzB,GAGH,UAAA;AAAA,MAAAU,gBAAAA,MAAAP,GAAA,MAAA,EACK,GAAAL,GAAUE,EAACrB,MAAa,KAAxB,IACO,UAAA;AAAA,QAAA6C,SACC;AAAA,UAAAxB,GACJF,GAAUE,EAACrB,OAAOO,IAAKkD,EAAQ,CAAO,KAAtC;AAAA,UAAuCC,QAExCzI,EAAIyG,OAAQiC,EAAc,EAAC1D,WAAY,IACnC9E,EAAU,CAAA,IACTkG,EAAC2B,QAEA7H,EAAWI,EAAW0H,QAAS5B,EAAC2B,KAAM,CAAC,IADvCY,EAAMC;AAAAA,UACkCtB,MAC1C9F,IACFxB,EAAIyG,OAAQoC,EAAc,EAAC7D,WAAY,IACrC9E,EAAU,CAAA,IACTkG,EAAC2B,QAEA7H,EAAWI,EAAW0H,QAAS5B,EAAC2B,KAAM,CAAC,IADvCY,EAAMC,OAJR;AAAA,UAMIhI,aAAAA;AAAAA,QAAAA;AAAAA,QAEXqH,aACY;AAAA,UAAA7B,GACRF,GAAUE,EAACrB,MAAa,KAAxB;AAAA,UAAyBmD,YAChB;AAAA,YAAA5D,UAAY5C,EAAO4C;AAAAA,UAAAA;AAAAA,UAAWmE,QAExCzI,EAAIyG,OAAQqC,EAAc,EAAC9D,WAAY,IACnC9E,EAAU,CAAA,IACTkG,EAAC2B,QAEA7H,EAAWI,EAAW0H,QAAS5B,EAAC2B,KAAM,CAAC,IADvCY,EAAMC;AAAAA,UACkCtB,MAC1C9F,IACFxB,EAAIyG,OAAQsC,EAAc,EAAC/D,WAAY,IACrC9E,EAAU,CAAA,IACTkG,EAAC2B,QAEA7H,EAAWI,EAAW0H,QAAS5B,EAAC2B,KAAM,CAAC,IADvCY,EAAMC,OAJR;AAAA,UAMIhI,aAAAA;AAAAA,QAAAA;AAAAA,MAEZ,GAEM,SAAA,WACC,SAAAuB,IAAA,gBAAA,WACH,MAAA;AAAA,QAAA0F,SAAW;AAAA,QAACK,YAAc;AAAA,UAAA5D,UAAY5C,EAAO4C;AAAAA,QAAAA;AAAAA,MAAU,GACtD,OAAA;AAAA,QAAA0E,aACQ;AAAA,MAAA;MAGjBlC,gBAAAA,MAAA,KAAA,EACGV,UAAAA,EAACrB,OAAOO,IAAK,CAAA2D,GAAAC,MACZpC,gBAAAA,EAAAA,IAAA,KAAA,EACG,UAAC1B,EAAuB+D,CAAE,IAA1B,OAAAxB,gBAAAA,EAAAA,KAAAyB,YAAA,EAEItI,UAAAA;AAAAA,QAAAA,2BACCyF,GAAA,QAAA,EACK,GAAA,GACO,UAAA;AAAA,UAAAqB,SACC;AAAA,YAAAyB,IACH;AAAA,YAACC,IACD;AAAA,YAACzB,SACI;AAAA,YAACP,MAERtH,EAAIyG,OAAQ8C,EAAc,EAACvE,WAAY,IACnC9E,OACCkG,EAAC2B,QAEA7H,EAAWI,EAAW0H,QAAS5B,EAAC2B,KAAM,CAAC,IADvCY,EAAMC;AAAAA,UACiC;AAAA,UAChDX,aACY;AAAA,YAAAoB,IACPzG,KAAImE,IAAKnC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,IAAIY,EAAMqD,CAAE;AAAA,YAACG,IACjD1G,KAAIoE,IAAKpC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,IAAIY,EAAMqD,CAAE;AAAA,YAACtB,SAC5C;AAAA,YAACK,YACE;AAAA,cAAA5D,UAAY5C,EAAO4C;AAAAA,YAAAA;AAAAA,YAAWgD,MAExCtH,EAAIyG,OAAQ+C,EAAc,EAACxE,WAAY,IACnC9E,OACCkG,EAAC2B,QAEA7H,EAAWI,EAAW0H,QAAS5B,EAAC2B,KAAM,CAAC,IADvCY,EAAMC;AAAAA,UACiC;AAAA,QACjD,GAEM,SAAA,WACC,SAAAzG,IAAA,gBAAA,WACH,MAAA;AAAA,UAAA0F,SAAW;AAAA,UAACK,YAAc;AAAA,YAAA5D,UAAY5C,EAAO4C;AAAAA,UAAAA;AAAAA,QAAU,GAAG,IA9BnE;AAAA,QAiCAzD,KACCiG,gBAAAA,EAAAA,IAAAP,GAAA,MAAA,EACS,OAAA;AAAA,UAAA,GACD/F,GAAM+D,qBAAN,CAAA;AAAA,QAA8B,GAGlC,IAAA3B,KAAIoE,IAAKpC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,IAAI,IAAxC,MAEItC,KAAIoE,IAAKpC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,IAAI,MAAxC,IAIK,WAAA+B,GACT,iCACAxG,GAAU8D,iBACZ,GACU,UAAA;AAAA,UAAAqD,SACC;AAAA,YAAAC,SACE;AAAA,YAAC3I,GACP0D,KAAImE,IAAKnC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,KAAKY,EAAMqD,CAAE,IAAI;AAAA,YAAEhK,GACvDyD,KAAIoE,IAAKpC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,KAAKY,EAAMqD,CAAE,IAAI;AAAA,YAAE7B,MACpDpH,EAAWoG,CAAC;AAAA,YAACY,YAEjBtE,KAAImE,IAAKnC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,IAAI,IAAxC,QAEItC,KAAImE,IAAKnC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,IAAI,OAAxC,WAAA;AAAA,UAAA;AAAA,UAGP+C,aACY;AAAA,YAAAJ,SACF;AAAA,YAAC3I,GACP0D,KAAImE,IAAKnC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,KAAKY,EAAMqD,CAAE,IAAI;AAAA,YAAEhK,GACvDyD,KAAIoE,IAAKpC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,KAAKY,EAAMqD,CAAE,IAAI;AAAA,YAAE7B,MACpDpH,EAAWoG,CAAC;AAAA,YAACY,YAEjBtE,KAAImE,IAAKnC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,IAAI,IAAxC,QAEItC,KAAImE,IAAKnC,EAAWsE,CAAC,IAAItG,KAAIsC,KAAM,CAAC,IAAI,OAAxC,WAAA;AAAA,YAESgD,YACH;AAAA,cAAA5D,UAAY5C,EAAO4C;AAAAA,YAAAA;AAAAA,UAAU;AAAA,QAC3C,GAEM,SAAA,WACC,SAAAnC,IAAA,gBAAA,WACH,MAAA;AAAA,UAAA0F,SAAW;AAAA,UAACK,YAAc;AAAA,YAAA5D,UAAY5C,EAAO4C;AAAAA,UAAAA;AAAAA,QAAU,GAE5DiD,UAAAA,GAAyB4B,GAAI,MAAMvH,EAAS,GAC/C,IAhDD;AAAA,MAAA,EAAA,CAiDO,KArFNsH,CAwFR,CACD,EAAA,CACH;AAAA,IAAA,EAAA,GApNK9C,EAAC0B,SAADJ,CAqNP,CACD,GAAC5H,EAAA,CAAA,IAAA4B,EAAA4C,UAAAxE,OAAAa,GAAAb,EAAA,EAAA,IAAAW,GAAA8D,mBAAAzE,EAAA,EAAA,IAAAW,GAAA+D,OAAAC,MAAA3E,EAAA,EAAA,IAAAW,GAAA+D,OAAAE,WAAA5E,EAAA,EAAA,IAAAW,GAAA+D,OAAAG,QAAA7E,QAAAQ,GAAAR,QAAA1B,IAAA0B,QAAA+B,GAAA/B,QAAAE,GAAAF,QAAAS,GAAAT,QAAA6B,GAAA7B,QAAA0B,GAAA1B,QAAA2B,GAAA3B,QAAAqC,GAAArC,QAAAI,GAAAJ,EAAA,EAAA,IAAA4C,EAAAF,MAAA1C,EAAA,EAAA,IAAA4C,EAAAJ,KAAAxC,QAAAwB,GAAAxB,QAAAuB,GAAAvB,QAAAoD,GAAApD,QAAAgD,GAAAhD,QAAAsB,IAAAtB,QAAAO,GAAAP,QAAAM,GAAAN,QAAA8B,IAAA9B,QAAAG,GAAAH,QAAA6C,GAAA7C,QAAAyB,GAAAzB,QAAAY,GAAAZ,QAAAgB,IAAAhB,QAAAe,IAAAf,QAAAc,GAAAd,EAAA,EAAA,IAAAU,GAAA+D,mBAAAzE,EAAA,EAAA,IAAAU,GAAAgE,OAAAC,MAAA3E,EAAA,EAAA,IAAAU,GAAAgE,OAAAE,WAAA5E,EAAA,EAAA,IAAAU,GAAAgE,OAAAG,QAAA7E,QAAA0D,GAAA1D,QAAA2D,GAAA3D,QAAA4D,GAAA5D,QAAA6D,GAAA7D,QAAA8D,GAAA9D,QAAA+D,GAAA/D,QAAAgE,GAAAhE,QAAAiE,GAAAjE,QAAAkE,GAAAlE,QAAAmE,GAAAnE,QAAAoE,IAAApE,QAAAqE,GAAArE,QAAAsE,IAAAtE,QAAAuE;AAAAA,EAAA;AAAAb,IAAAA,IAAA1D,EAAA,EAAA,GAAA2D,IAAA3D,EAAA,EAAA,GAAA4D,IAAA5D,EAAA,EAAA,GAAA6D,IAAA7D,EAAA,EAAA,GAAA8D,IAAA9D,EAAA,EAAA,GAAA+D,IAAA/D,EAAA,EAAA,GAAAgE,IAAAhE,EAAA,EAAA,GAAAiE,IAAAjE,EAAA,EAAA,GAAAkE,IAAAlE,EAAA,EAAA,GAAAmE,IAAAnE,EAAA,EAAA,GAAAoE,KAAApE,EAAA,EAAA,GAAAqE,IAAArE,EAAA,EAAA,GAAAsE,KAAAtE,EAAA,EAAA,GAAAuE,KAAAvE,EAAA,EAAA;AAAA,MAAAqF;AAAA,EAAArF,EAAA,EAAA,MAAA0D,KAAA1D,UAAAgE,KAzNJqB,KAAA2B,gBAAAA,EAAAA,IAACtD,KACEM,UAAAA,EAAAA,CAyNH,GAAkBhE,QAAA0D,GAAA1D,QAAAgE,GAAAhE,QAAAqF,MAAAA,KAAArF,EAAA,EAAA;AAAA,MAAA4F;AAAA,EAAA5F,EAAA,EAAA,MAAAqF,MAAArF,EAAA,EAAA,MAAAiE,KAAAjE,EAAA,EAAA,MAAAkE,KAAAlE,UAAAmE,KA1SpByB,mCAAc,WAAA3B,GACXC,UAAAA;AAAAA,IAAAA;AAAAA,IA0CAC;AAAAA,IAqCDkB;AAAAA,EAAAA,GA2NF,GAAIrF,QAAAqF,IAAArF,QAAAiE,GAAAjE,QAAAkE,GAAAlE,QAAAmE,GAAAnE,QAAA4F,MAAAA,KAAA5F,EAAA,EAAA;AAAA,MAAA2J;AAAA,EAAA3J,UAAA+B,KACH4H,KAAA5H,EAAY4E,OAAQiD,EAA2B,EAACpE,IAAKqE,EAAY,GAAC7J,QAAA+B,GAAA/B,QAAA2J,MAAAA,KAAA3J,EAAA,EAAA;AAAA,MAAA8J;AAAA,EAAA9J,EAAA,EAAA,MAAA4F,MAAA5F,EAAA,EAAA,MAAA2J,MAAA3J,EAAA,EAAA,MAAAoE,MAAApE,UAAAqE,KA9SrEyF,mCAAc,WAAA1F,IACXC,UAAAA;AAAAA,IAAAA;AAAAA,IACDuB;AAAAA,IA4SC+D;AAAAA,EAAAA,GACH,GAAI3J,QAAA4F,IAAA5F,QAAA2J,IAAA3J,QAAAoE,IAAApE,QAAAqE,GAAArE,QAAA8J,MAAAA,KAAA9J,EAAA,EAAA;AAAA,MAAA+J;AAAA,EAAA/J,EAAA,EAAA,MAAA2D,KAAA3D,EAAA,EAAA,MAAA4D,KAAA5D,EAAA,EAAA,MAAA6D,KAAA7D,EAAA,EAAA,MAAA8D,KAAA9D,EAAA,EAAA,MAAA+D,KAAA/D,EAAA,EAAA,MAAA8J,MAAA9J,EAAA,EAAA,MAAAsE,MAAAtE,UAAAuE,MAvTNwF,2BAACpG,GAAA,EACQ,OAAAW,IACC,QAAAC,IACC,SAAAX,GACC,WAAAC,GACL7B,KAAAA,GACK,WAAA+B,GAEV+F,UAAAA,IAgTF,GAAa9J,QAAA2D,GAAA3D,QAAA4D,GAAA5D,QAAA6D,GAAA7D,QAAA8D,GAAA9D,QAAA+D,GAAA/D,QAAA8J,IAAA9J,QAAAsE,IAAAtE,QAAAuE,IAAAvE,QAAA+J,MAAAA,KAAA/J,EAAA,EAAA;AAAA,MAAAgK;AAAA,EAAAhK,EAAA,EAAA,MAAAW,GAAAN,WAAAL,EAAA,EAAA,MAAAsD,MAAAtD,EAAA,EAAA,MAAAwD,KAAAxD,EAAA,EAAA,MAAAgD,KAAAhD,EAAA,EAAA,MAAAU,GAAAL,WAAAL,EAAA,EAAA,MAAAK,KACZ2J,KAAAhH,KAAA3C,KAAAiD,MAAAE,0BACEyG,IAAA,EACOjH,SACA3C,MAAAA,GACAiD,UACAE,MAAAA,GACW,iBAAA9C,GAAML,SACZ,WAAAM,GAAUN,SAAS,IAPjC,MASOL,EAAA,EAAA,IAAAW,GAAAN,SAAAL,QAAAsD,IAAAtD,QAAAwD,GAAAxD,QAAAgD,GAAAhD,EAAA,EAAA,IAAAU,GAAAL,SAAAL,QAAAK,GAAAL,QAAAgK,MAAAA,KAAAhK,EAAA,EAAA;AAAA,MAAAkK;AAAA,EAAAlK,EAAA,EAAA,MAAAW,GAAAwJ,SAAAnK,EAAA,EAAA,MAAAS,KAAAT,EAAA,GAAA,MAAAoD,KACP8G,KAAAzJ,KAAkB2C,MAAmBD,SACpC6D,gBAAAA,EAAAA,IAACoD,MACO3J,MAAAA,GACA2C,MAAAA,GACGC,SAAAA,IACE,WAAA1C,GAAUwJ,OAAO,IAL/B,MAOOnK,EAAA,EAAA,IAAAW,GAAAwJ,OAAAnK,QAAAS,GAAAT,SAAAoD,GAAApD,SAAAkK,MAAAA,KAAAlK,EAAA,GAAA;AAAA,MAAAqK;AAAA,SAAArK,EAAA,GAAA,MAAA+J,MAAA/J,WAAAgK,MAAAhK,EAAA,GAAA,MAAAkK,MA3UVG,KAAAxC,gBAAAA,EAAAA,KAAAyB,YAAA,EACES,UAAAA;AAAAA,IAAAA;AAAAA,IAyTCC;AAAAA,IAUAE;AAAAA,EAAAA,GAOO,GACPlK,SAAA+J,IAAA/J,SAAAgK,IAAAhK,SAAAkK,IAAAlK,SAAAqK,MAAAA,KAAArK,EAAA,GAAA,GA5UHqK;AA4UG;AAxaA,SAAAR,GAAAS,GAAA;AAAA,SAmZ8DhE,EAACiE;AAAM;AAnZrE,SAAAX,GAAAY,GAAA;AAAA,SAmZ6BlE,EAACmE,aAAc;AAAO;AAnZnD,SAAAf,GAAAgB,GAAA;AAAA,SA4UiDrB,EAAEpB;AAAM;AA5UzD,SAAAwB,GAAAkB,GAAA;AAAA,SAgUiDtB,EAAEpB;AAAM;AAhUzD,SAAAgB,GAAA2B,GAAA;AAAA,SAkSuCvB,EAAEpB;AAAM;AAlS/C,SAAAe,GAAA6B,GAAA;AAAA,SA4RqCxB,EAAEpB;AAAM;AA5R7C,SAAAc,GAAA+B,GAAA;AAAA,SAgRuCzB,EAAEpB;AAAM;AAhR/C,SAAAW,GAAAS,GAAA;AAAA,SA0QqCA,EAAEpB;AAAM;AA1Q7C,SAAAS,GAAAqC,GAAA;AAAA,SAwQkD;AAAC;AAxQnD,SAAAlE,GAAAmE,GAAA;AAAA,SAsG+D1E,EAACiE;AAAM;AAtGtE,SAAA3D,GAAAqE,GAAA;AAAA,SAsG6B3E,EAACmE,aAAc;AAAQ;AAtGpD,SAAA3E,GAAAoF,GAAA;AAAA,SAkFKpI,KAAIC,IAAI,GAAKuD,EAACrB,OAAO0B,OAAQwE,EAA+B,CAAc;AAAC;AAlFhF,SAAAA,GAAAC,GAAA;AAAA,SAkFuC,CAAC9F,EAAuB1G,CAAC;AAAC;AAlFjE,SAAAiH,GAAAwF,GAAA;AAAA,SA4EKvI,KAAIC,IAAI,GAAKuD,EAACrB,OAAO0B,OAAQ2E,EAA+B,CAAc;AAAC;AA5EhF,SAAAA,GAAAC,GAAA;AAAA,SA4EuC,CAACjG,EAAuB1G,CAAC;AAAC;AA5EjE,SAAA8G,GAAAY,GAAA;AAAA,SAoEKxD,KAAIyC,IAAI,GAAKe,EAACrB,OAAO0B,OAAQ6E,EAA+B,CAAc;AAAC;AApEhF,SAAAA,GAAA5M,GAAA;AAAA,SAoEuC,CAAC0G,EAAuB1G,CAAC;AAAC;AApEjE,SAAA6G,GAAAgG,GAAA;AAAA,SA8DK3I,KAAIyC,IAAI,GAAKe,EAACrB,OAAO0B,OAAQ+E,EAA+B,CAAc;AAAC;AA9DhF,SAAAA,GAAAC,GAAA;AAAA,SA8DuC,CAACrG,EAAuB1G,CAAC;AAAC;ACqBjE,SAASgN,GAAW7L,GAAc;AACvC,QAAM;AAAA,IACJ8L,YAAAA;AAAAA,IACAC,QAAAA;AAAAA,IACAC,SAAAA;AAAAA,IACAC,kBAAAA;AAAAA,IACAC,UAAAA;AAAAA,IACA9L,QAAAA;AAAAA,IACAD,MAAAA;AAAAA,IACAgM,gBAAAA,IAAiB;AAAA,IACjBC,SAAAA;AAAAA,IACAC,iBAAAA,IAAkB;AAAA,IAClB/L,SAAAA;AAAAA,IACAC,mBAAAA;AAAAA,IACA+L,SAAAA;AAAAA,IACA9L,oBAAAA;AAAAA,IACAW,WAAAA,KAAY;AAAA,IACZC,cAAAA,KAAe;AAAA,IACfC,YAAAA,IAAa;AAAA,IACbH,aAAAA,IAAc;AAAA,IACdqL,eAAAA,IAAgB;AAAA,IAChBC,cAAAA,IAAe;AAAA,IACf/L,aAAAA;AAAAA,IACAgM,UAAAA,KAAW;AAAA,IACXC,OAAAA,IAAQ;AAAA,IACR9K,kBAAAA,IAAmB,CAAA;AAAA,IACnB+K,OAAAA;AAAAA,IACAC,QAAAA;AAAAA,IACAC,WAAAA,IAAY;AAAA,IACZ9L,aAAAA,IAAc;AAAA,IACd+L,gBAAAA;AAAAA,IACAC,WAAAA;AAAAA,IACAC,kBAAAA;AAAAA,IACAtM,gBAAAA;AAAAA,IACAC,QAAAA;AAAAA,IACAC,YAAAA;AAAAA,IACAqM,aAAAA,KAAc;AAAA,IACdnM,YAAAA;AAAAA,IACAG,UAAAA,IAAW;AAAA,IACXD,YAAAA,IAAa;AAAA,IACbM,WAAAA,IAAY;AAAA,IACZC,WAAAA,KAAY;AAAA,IACZC,UAAAA;AAAAA,IACAC,UAAAA;AAAAA,IACAE,WAAAA,KAAY;AAAA,IACZD,6BAAAA,KAA8B;AAAA,IAC9BG,SAAAA,IAAU;AAAA,IACVC,eAAAA,KAAgB;AAAA,IAChBC,WAAAA,IAAY;AAAA,IACZC,cAAAA,IAAe,CAAA;AAAA,EAAA,IACbhC,GAEE,CAACkN,GAAaC,CAAc,IAAIhK,GAAS,CAAC,GAC1C,CAACtC,GAAeuM,CAAgB,IAAIjK,GAA6BC,MAAS,GAE1EiK,IAAWnL,GAAuB,IAAI,GACtCoL,IAAiBpL,GAAuB,IAAI;AAElDqL,SAAAA,GAAU,MAAM;AACd,UAAMC,IAAiB,IAAIC,eAAeC,CAAAA,MAAW;AACnDP,MAAAA,GACGpK,KAAKC,IAEF0K,EAAQ,CAAC,EAAEC,OAAOC,eAAe,KACjCF,EAAQ,CAAC,EAAEC,OAAOE,gBAAgB,KAClCzN,KAAU0N,KAEd,KAAK,OAAO,CACd;AAAA,IACF,CAAC;AACD,WAAIT,EAASU,WACXP,EAAeQ,QAAQX,EAASU,OAAO,GAElC,MAAMP,EAAeS,WAAAA;AAAAA,EAC9B,GAAG,CAAC7N,CAAM,CAAC,GAET0H,gBAAAA,OAACoG,MACC,WAAWtN,GAAYuN,gBACvB,OAAOxN,GAAQwN,gBACf,IAAI7B,GACJ,KAAKgB,GACL,cAAYP,IACZ,iBAAAV,GACA,OAAAK,GACA,UAAAD,IACA,WAAAI,GACA,OAAAF,GACA,QAAAC,GACA,gBAAAE,GACA,SAAAV,GAECN,UAAAA;AAAAA,IAAAA,KAAcG,KAAoBM,KAAiBC,IAClDvF,gBAAAA,EAAAA,IAACmH,MACC,QAAQ;AAAA,MACNC,OAAO1N,GAAQ0N;AAAAA,MACfC,aAAa3N,GAAQ2N;AAAAA,IAAAA,GAEvB,YAAY;AAAA,MACVD,OAAOzN,GAAYyN;AAAAA,MACnBC,aAAa1N,GAAY0N;AAAAA,IAAAA,GAE3B,YAAAxC,GACA,kBAAAG,GACA,OAAAU,GACA,eAAeJ,IAAgBe,IAAiBlK,QAChD,cACEoJ,IACIrM,EAAKsF,IAAIc,CAAAA,MAAKA,EAAEpG,IAAI,EAAEyG,OAAOL,OAAKA,MAAMnD,MAAS,EAAE+B,SAAS,IAC1DhF,EAAKsF,IAAIc,OAAKA,EAAEpG,IAAI,EAAEyG,OAAOL,CAAAA,MAAKA,MAAMnD,MAAS,IACjDjD,EAAKyG,OAAOL,CAAAA,MAAKA,MAAMnD,MAAS,IAClC,MACL,IAED;AAAA,IACH+I,KAAkBhM,EAAKyG,OAAO0C,CAAAA,MAAMA,EAAGpB,KAAK,EAAE/C,WAAW,KAAKhF,EAAKgF,SAAS,IAC3E8B,gBAAAA,MAACsH,IAAA,EACC,OAAA5B,GACA,kBAAAK,GACA,QAASjB,KAAmCjD,EAAO4D,CAAK,EAAE8B,kBAAkBzC,QAC5E,aAAatL,MAAgBgO,GAAOtO,GAAM,SAAS,EAAI,GACvD,kBAAAiN,GACA,aAAAH,IACA,WAAWrM,GAAY8N,aACvB,UAAQ,IAAA,IAER;AAAA,IACJ5G,gBAAAA,EAAAA,KAAC6G,IAAA,EAAU,KAAKtB,GACblN,UAAAA;AAAAA,MAAAA,EAAKgF,WAAW,KAAK8B,gBAAAA,EAAAA,IAAC2H,IAAA,CAAA,CAAU;AAAA,MAChC1B,KAAe/M,EAAKgF,SAAS,IAC5B8B,gBAAAA,EAAAA,IAAClH,IAAA,EACC,MAAAI,GACA,YACEA,EAAKyG,OAAO0C,CAAAA,MAAMA,EAAGpB,KAAK,EAAE/C,WAAW,IACnC4G,IACE,CAACA,CAAgB,IACjB,CAACjD,EAAO+F,cAAc,UAAU,CAAC,IAClC9C,KAAmCjD,EAAO4D,CAAK,EAAE8B,kBAAkBzC,QAE1E,QAAQmB,GACR,SAAA5M,GACA,aAAaG,MAAgBgO,GAAOtO,GAAM,SAAS,EAAI,GACvD,mBAAAI,GACA,oBAAAC,GACA,QAAAG,GACA,gBAAAD,IACA,eAAAG,GACA,YAAAC,IACA,aAAAC,GACA,YAAAC,GACA,UAAAC,GACA,WAAAE,IACA,cAAAC,IACA,YAAAC,GACA,aAAAH,GACA,WAAAI,GACA,WAAAC,IACA,UAAAC,GACA,UAAAC,IACA,WAAAE,IACA,kBAAAC,GACA,6BAAAF,IACA,SACEG,MAAY,KACR;AAAA,QAAE4C,UAAU;AAAA,QAAKpC,MAAM;AAAA,QAAMD,QAAQ;AAAA,MAAA,IACrCP,KAAW;AAAA,QAAE4C,UAAU;AAAA,QAAGpC,MAAM;AAAA,QAAMD,QAAQ;AAAA,MAAA,GAEpD,eAAAN,IACA,WAAAC,GACA,cAAAC,EAAA,CAA2B,IAE3B;AAAA,IAAA,GACN;AAAA,IACCgK,KAAWE,IACVjF,gBAAAA,EAAAA,IAAC6H,IAAA,EACC,QAAQ;AAAA,MAAEC,UAAUpO,GAAQoO;AAAAA,MAAUC,QAAQrO,GAAQqO;AAAAA,IAAAA,GACtD,YAAY;AAAA,MACVD,UAAUnO,GAAYmO;AAAAA,MACtBC,QAAQpO,GAAYoO;AAAAA,IAAAA,GAEtB,SAAAhD,GACA,UAAAE,GACA,OAAAS,EAAA,CAAa,IAEb;AAAA,EAAA,GACN;AAEJ;","x_google_ignoreList":[0,1,2,3,4,5]}
|
package/dist/SankeyChart.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const d=require("./index-CHPV5EwG-CTPQjnHt.cjs"),A=require("react"),he=require("./index-CSNtgibC.cjs"),ge=require("./index-Cno4Q0YE.cjs"),Se=require("./index-DQA8q5sC.cjs"),Yt=require("./Typography-DX7PlgQU.cjs"),de=require("./numberFormattingFunction-02t-wJta.cjs"),Re=require("./Tooltip-uUdw6wJL.cjs"),Oe=require("./DetailsModal-BN0HDFlV.cjs"),Ce=require("./use-in-view-QcfiW0w3.cjs"),ne=require("./proxy-BxvUI_9l.cjs"),Ve=require("./index-DG2bgAva.cjs"),Ne=require("./GraphHeader.cjs"),De=require("./GraphFooter.cjs"),pe=require("./Colors.cjs"),Te=require("./generateRandomString-B5zBiJzS.cjs"),qe=require("./EmptyState-sAEZ_5rU.cjs"),Bt=require("./uniqBy-O05lp2S5.cjs"),me=require("./GraphContainer-d8A46BK2.cjs");function xe(e,t){let o;if(t===void 0)for(const r of e)r!=null&&(o<r||o===void 0&&r>=r)&&(o=r);else{let r=-1;for(let a of e)(a=t(a,++r,e))!=null&&(o<a||o===void 0&&a>=a)&&(o=a)}return o}function we(e,t){let o;if(t===void 0)for(const r of e)r!=null&&(o>r||o===void 0&&r>=r)&&(o=r);else{let r=-1;for(let a of e)(a=t(a,++r,e))!=null&&(o>a||o===void 0&&a>=a)&&(o=a)}return o}function oe(e,t){let o=0;if(t===void 0)for(let r of e)(r=+r)&&(o+=r);else{let r=-1;for(let a of e)(a=+t(a,++r,e))&&(o+=a)}return o}function Be(e){return e.target.depth}function Pe(e,t){return e.sourceLinks.length?e.depth:t-1}function ie(e){return e.targetLinks.length?e.depth:e.sourceLinks.length?we(e.sourceLinks,Be)-1:0}function _t(e){return function(){return e}}function ye(e,t){return Ut(e.source,t.source)||e.index-t.index}function ve(e,t){return Ut(e.target,t.target)||e.index-t.index}function Ut(e,t){return e.y0-t.y0}function re(e){return e.value}function ze(e){return e.index}function Ie(e){return e.nodes}function Ae(e){return e.links}function je(e,t){const o=e.get(t);if(!o)throw new Error("missing: "+t);return o}function ke({nodes:e}){for(const t of e){let o=t.y0,r=o;for(const a of t.sourceLinks)a.y0=o+a.width/2,o+=a.width;for(const a of t.targetLinks)a.y1=r+a.width/2,r+=a.width}}function se(){let e=0,t=0,o=1,r=1,a=24,x=8,h,g=ze,y=Pe,k,b,$=Ie,D=Ae,j=6;function p(){const n={nodes:$.apply(null,arguments),links:D.apply(null,arguments)};return M(n),H(n),w(n),S(n),F(n),ke(n),n}p.update=function(n){return ke(n),n},p.nodeId=function(n){return arguments.length?(g=typeof n=="function"?n:_t(n),p):g},p.nodeAlign=function(n){return arguments.length?(y=typeof n=="function"?n:_t(n),p):y},p.nodeSort=function(n){return arguments.length?(k=n,p):k},p.nodeWidth=function(n){return arguments.length?(a=+n,p):a},p.nodePadding=function(n){return arguments.length?(x=h=+n,p):x},p.nodes=function(n){return arguments.length?($=typeof n=="function"?n:_t(n),p):$},p.links=function(n){return arguments.length?(D=typeof n=="function"?n:_t(n),p):D},p.linkSort=function(n){return arguments.length?(b=n,p):b},p.size=function(n){return arguments.length?(e=t=0,o=+n[0],r=+n[1],p):[o-e,r-t]},p.extent=function(n){return arguments.length?(e=+n[0][0],o=+n[1][0],t=+n[0][1],r=+n[1][1],p):[[e,t],[o,r]]},p.iterations=function(n){return arguments.length?(j=+n,p):j};function M({nodes:n,links:l}){for(const[u,i]of n.entries())i.index=u,i.sourceLinks=[],i.targetLinks=[];const s=new Map(n.map((u,i)=>[g(u,i,n),u]));for(const[u,i]of l.entries()){i.index=u;let{source:f,target:v}=i;typeof f!="object"&&(f=i.source=je(s,f)),typeof v!="object"&&(v=i.target=je(s,v)),f.sourceLinks.push(i),v.targetLinks.push(i)}if(b!=null)for(const{sourceLinks:u,targetLinks:i}of n)u.sort(b),i.sort(b)}function H({nodes:n}){for(const l of n)l.value=l.fixedValue===void 0?Math.max(oe(l.sourceLinks,re),oe(l.targetLinks,re)):l.fixedValue}function w({nodes:n}){const l=n.length;let s=new Set(n),u=new Set,i=0;for(;s.size;){for(const f of s){f.depth=i;for(const{target:v}of f.sourceLinks)u.add(v)}if(++i>l)throw new Error("circular link");s=u,u=new Set}}function S({nodes:n}){const l=n.length;let s=new Set(n),u=new Set,i=0;for(;s.size;){for(const f of s){f.height=i;for(const{source:v}of f.targetLinks)u.add(v)}if(++i>l)throw new Error("circular link");s=u,u=new Set}}function B({nodes:n}){const l=xe(n,i=>i.depth)+1,s=(o-e-a)/(l-1),u=new Array(l);for(const i of n){const f=Math.max(0,Math.min(l-1,Math.floor(y.call(null,i,l))));i.layer=f,i.x0=e+f*s,i.x1=i.x0+a,u[f]?u[f].push(i):u[f]=[i]}if(k)for(const i of u)i.sort(k);return u}function z(n){const l=we(n,s=>(r-t-(s.length-1)*h)/oe(s,re));for(const s of n){let u=t;for(const i of s){i.y0=u,i.y1=u+i.value*l,u=i.y1+h;for(const f of i.sourceLinks)f.width=f.value*l}u=(r-u+h)/(s.length+1);for(let i=0;i<s.length;++i){const f=s[i];f.y0+=u*(i+1),f.y1+=u*(i+1)}Y(s)}}function F(n){const l=B(n);h=Math.min(x,(r-t)/(xe(l,s=>s.length)-1)),z(l);for(let s=0;s<j;++s){const u=Math.pow(.99,s),i=Math.max(1-u,(s+1)/j);X(l,u,i),G(l,u,i)}}function G(n,l,s){for(let u=1,i=n.length;u<i;++u){const f=n[u];for(const v of f){let C=0,T=0;for(const{source:I,value:_}of v.targetLinks){let U=_*(v.layer-I.layer);C+=O(I,v)*U,T+=U}if(!(T>0))continue;let V=(C/T-v.y0)*l;v.y0+=V,v.y1+=V,kt(v)}k===void 0&&f.sort(Ut),W(f,s)}}function X(n,l,s){for(let u=n.length,i=u-2;i>=0;--i){const f=n[i];for(const v of f){let C=0,T=0;for(const{target:I,value:_}of v.sourceLinks){let U=_*(I.layer-v.layer);C+=E(v,I)*U,T+=U}if(!(T>0))continue;let V=(C/T-v.y0)*l;v.y0+=V,v.y1+=V,kt(v)}k===void 0&&f.sort(Ut),W(f,s)}}function W(n,l){const s=n.length>>1,u=n[s];tt(n,u.y0-h,s-1,l),R(n,u.y1+h,s+1,l),tt(n,r,n.length-1,l),R(n,t,0,l)}function R(n,l,s,u){for(;s<n.length;++s){const i=n[s],f=(l-i.y0)*u;f>1e-6&&(i.y0+=f,i.y1+=f),l=i.y1+h}}function tt(n,l,s,u){for(;s>=0;--s){const i=n[s],f=(i.y1-l)*u;f>1e-6&&(i.y0-=f,i.y1-=f),l=i.y0-h}}function kt({sourceLinks:n,targetLinks:l}){if(b===void 0){for(const{source:{sourceLinks:s}}of l)s.sort(ve);for(const{target:{targetLinks:s}}of n)s.sort(ye)}}function Y(n){if(b===void 0)for(const{sourceLinks:l,targetLinks:s}of n)l.sort(ve),s.sort(ye)}function O(n,l){let s=n.y0-(n.sourceLinks.length-1)*h/2;for(const{target:u,width:i}of n.sourceLinks){if(u===l)break;s+=i+h}for(const{source:u,width:i}of l.targetLinks){if(u===n)break;s-=i}return s}function E(n,l){let s=l.y0-(l.targetLinks.length-1)*h/2;for(const{source:u,width:i}of l.targetLinks){if(u===n)break;s+=i+h}for(const{target:u,width:i}of n.sourceLinks){if(u===l)break;s-=i}return s}return p}var le=Math.PI,ae=2*le,Ct=1e-6,He=ae-Ct;function ue(){this._x0=this._y0=this._x1=this._y1=null,this._=""}function $e(){return new ue}ue.prototype=$e.prototype={constructor:ue,moveTo:function(e,t){this._+="M"+(this._x0=this._x1=+e)+","+(this._y0=this._y1=+t)},closePath:function(){this._x1!==null&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")},lineTo:function(e,t){this._+="L"+(this._x1=+e)+","+(this._y1=+t)},quadraticCurveTo:function(e,t,o,r){this._+="Q"+ +e+","+ +t+","+(this._x1=+o)+","+(this._y1=+r)},bezierCurveTo:function(e,t,o,r,a,x){this._+="C"+ +e+","+ +t+","+ +o+","+ +r+","+(this._x1=+a)+","+(this._y1=+x)},arcTo:function(e,t,o,r,a){e=+e,t=+t,o=+o,r=+r,a=+a;var x=this._x1,h=this._y1,g=o-e,y=r-t,k=x-e,b=h-t,$=k*k+b*b;if(a<0)throw new Error("negative radius: "+a);if(this._x1===null)this._+="M"+(this._x1=e)+","+(this._y1=t);else if($>Ct)if(!(Math.abs(b*g-y*k)>Ct)||!a)this._+="L"+(this._x1=e)+","+(this._y1=t);else{var D=o-x,j=r-h,p=g*g+y*y,M=D*D+j*j,H=Math.sqrt(p),w=Math.sqrt($),S=a*Math.tan((le-Math.acos((p+$-M)/(2*H*w)))/2),B=S/w,z=S/H;Math.abs(B-1)>Ct&&(this._+="L"+(e+B*k)+","+(t+B*b)),this._+="A"+a+","+a+",0,0,"+ +(b*D>k*j)+","+(this._x1=e+z*g)+","+(this._y1=t+z*y)}},arc:function(e,t,o,r,a,x){e=+e,t=+t,o=+o,x=!!x;var h=o*Math.cos(r),g=o*Math.sin(r),y=e+h,k=t+g,b=1^x,$=x?r-a:a-r;if(o<0)throw new Error("negative radius: "+o);this._x1===null?this._+="M"+y+","+k:(Math.abs(this._x1-y)>Ct||Math.abs(this._y1-k)>Ct)&&(this._+="L"+y+","+k),o&&($<0&&($=$%ae+ae),$>He?this._+="A"+o+","+o+",0,1,"+b+","+(e-h)+","+(t-g)+"A"+o+","+o+",0,1,"+b+","+(this._x1=y)+","+(this._y1=k):$>Ct&&(this._+="A"+o+","+o+",0,"+ +($>=le)+","+b+","+(this._x1=e+o*Math.cos(a))+","+(this._y1=t+o*Math.sin(a))))},rect:function(e,t,o,r){this._+="M"+(this._x0=this._x1=+e)+","+(this._y0=this._y1=+t)+"h"+ +o+"v"+ +r+"h"+-o+"Z"},toString:function(){return this._}};function be(e){return function(){return e}}function Ge(e){return e[0]}function We(e){return e[1]}var Fe=Array.prototype.slice;function Xe(e){return e.source}function Ye(e){return e.target}function _e(e){var t=Xe,o=Ye,r=Ge,a=We,x=null;function h(){var g,y=Fe.call(arguments),k=t.apply(this,y),b=o.apply(this,y);if(x||(x=g=$e()),e(x,+r.apply(this,(y[0]=k,y)),+a.apply(this,y),+r.apply(this,(y[0]=b,y)),+a.apply(this,y)),g)return x=null,g+""||null}return h.source=function(g){return arguments.length?(t=g,h):t},h.target=function(g){return arguments.length?(o=g,h):o},h.x=function(g){return arguments.length?(r=typeof g=="function"?g:be(+g),h):r},h.y=function(g){return arguments.length?(a=typeof g=="function"?g:be(+g),h):a},h.context=function(g){return arguments.length?(x=g??null,h):x},h}function Ue(e,t,o,r,a){e.moveTo(t,o),e.bezierCurveTo(t=(t+r)/2,o,t,a,r,a)}function Ze(){return _e(Ue)}function Qe(e){return[e.source.x1,e.y0]}function Je(e){return[e.target.x0,e.y1]}function Ke(){return Ze().source(Qe).target(Je)}function tn(e){const t=d.compilerRuntimeExports.c(136),{data:o,showLabels:r,leftMargin:a,rightMargin:x,truncateBy:h,width:g,height:y,topMargin:k,bottomMargin:b,tooltip:$,onSeriesMouseOver:D,suffix:j,prefix:p,showValues:M,onSeriesMouseClick:H,nodePadding:w,nodeWidth:S,id:B,highlightedSourceDataPoints:z,highlightedTargetDataPoints:F,defaultLinkOpacity:G,sourceTitle:X,targetTitle:W,animate:R,sortNodes:tt,resetSelectionOnDoubleClick:kt,detailsOnClick:Y,styles:O,classNames:E,precision:n,customLayers:l}=e,s=A.useRef(null);let u;t[0]!==R.amount||t[1]!==R.once?(u={once:R.once,amount:R.amount},t[0]=R.amount,t[1]=R.once,t[2]=u):u=t[2];const i=Ce.useInView(s,u),[f,v]=A.useState(void 0),[C,T]=A.useState(void 0),[V,I]=A.useState(void 0),[_,U]=A.useState(void 0),[St,Rt]=A.useState(void 0);let L;t[3]!==b||t[4]!==a||t[5]!==x||t[6]!==k?(L={top:k,bottom:b,left:a,right:x},t[3]=b,t[4]=a,t[5]=x,t[6]=k,t[7]=L):L=t[7];const m=L,wt=g-m.left-m.right,$t=y-m.top-m.bottom;let et,lt,at,Z,ut,ct,Q,J,ft,ht,K,nt,ot,it,gt,dt;if(t[8]!==R.duration||t[9]!==E?.graphObjectValues||t[10]!==l||t[11]!==o||t[12]!==G||t[13]!==Y||t[14]!==$t||t[15]!==wt||t[16]!==y||t[17]!==z||t[18]!==F||t[19]!==B||t[20]!==i||t[21]!==a||t[22]!==m.left||t[23]!==m.right||t[24]!==m.top||t[25]!==C||t[26]!==w||t[27]!==S||t[28]!==H||t[29]!==D||t[30]!==n||t[31]!==p||t[32]!==kt||t[33]!==x||t[34]!==V||t[35]!==r||t[36]!==M||t[37]!==tt||t[38]!==X||t[39]!==O?.graphObjectValues||t[40]!==j||t[41]!==W||t[42]!==h||t[43]!==g){const Pt=tt==="mostReadable"?se().nodeWidth(S).nodePadding(w).size([wt,$t]).nodeAlign(ie):tt==="none"?se().nodeWidth(S).nodePadding(w).size([wt,$t]).nodeAlign(ie).nodeSort(fn).linkSort(cn):se().nodeWidth(S).nodePadding(w).size([wt,$t]).nodeAlign(ie).nodeSort(tt==="desc"?un:an),{nodes:N,links:Vt}=Pt(o),Nt=Ke();lt=ne.motion.svg,gt=`${g}px`,dt=`${y}px`,at=`0 0 ${g} ${y}`,t[60]===Symbol.for("react.memo_cache_sentinel")?(Z={marginLeft:"auto",marginRight:"auto"},t[60]=Z):Z=t[60],ut="ltr",ct=s,t[61]!==m.left||t[62]!==m.top||t[63]!==X?(Q=X?d.jsxRuntimeExports.jsx("text",{x:m.left,y:m.top-10,className:"text-base font-bold fill-primary-gray-700 dark:fill-primary-gray-100",style:{textAnchor:"start"},children:X}):null,t[61]=m.left,t[62]=m.top,t[63]=X,t[64]=Q):Q=t[64],t[65]!==m.right||t[66]!==m.top||t[67]!==W||t[68]!==g?(J=W?d.jsxRuntimeExports.jsx("text",{x:g-m.right,y:m.top-10,className:"text-base font-bold fill-primary-gray-700 dark:fill-primary-gray-100",style:{textAnchor:"end"},children:W}):null,t[65]=m.right,t[66]=m.top,t[67]=W,t[68]=g,t[69]=J):J=t[69],ht=`translate(${m.left},${m.top})`,t[70]!==l?(K=l.filter(ln).map(sn),t[70]=l,t[71]=K):K=t[71];let Lt;t[72]!==E?.graphObjectValues||t[73]!==a||t[74]!==w||t[75]!==n||t[76]!==p||t[77]!==r||t[78]!==M||t[79]!==O?.graphObjectValues||t[80]!==j||t[81]!==h?(Lt=(c,vt)=>d.jsxRuntimeExports.jsx("g",{onMouseEnter:()=>{I(c)},onMouseLeave:()=>{I(void 0)},children:d.jsxRuntimeExports.jsxs("g",{transform:`translate(${c.x0},${c.y0})`,children:[d.jsxRuntimeExports.jsx("rect",{x:0,y:0,width:(c.x1||0)-(c.x0||0),height:(c.y1||0)-(c.y0||0),style:{fill:c.color}}),r||M?d.jsxRuntimeExports.jsx("foreignObject",{y:0-w/2,x:0-a,width:a,height:(c.y1||0)-(c.y0||0)+w,children:d.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-0.5 justify-center py-0 px-1.5",style:{height:`${(c.y1||0)-(c.y0||0)+w}px`,overflow:"visible"},children:[r?d.jsxRuntimeExports.jsx(Yt.j,{marginBottom:M?"3xs":"none",size:"sm",leading:"none",className:d.mo("sankey-right-label text-right",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...O?.graphObjectValues},children:`${c.label}`.length<h?`${c.label}`:`${`${c.label}`.substring(0,h)}...`}):null,M?d.jsxRuntimeExports.jsx(Yt.j,{marginBottom:"none",size:"sm",leading:"none",className:d.mo("sankey-right-value text-right font-bold",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...O?.graphObjectValues},children:de.numberFormattingFunction(c.value,"NA",n,p,j)}):null]})}):null]})},vt),t[72]=E?.graphObjectValues,t[73]=a,t[74]=w,t[75]=n,t[76]=p,t[77]=r,t[78]=M,t[79]=O?.graphObjectValues,t[80]=j,t[81]=h,t[82]=Lt):Lt=t[82],nt=N.filter(rn).map(Lt);let bt;t[83]!==E?.graphObjectValues||t[84]!==w||t[85]!==S||t[86]!==n||t[87]!==p||t[88]!==x||t[89]!==r||t[90]!==M||t[91]!==O?.graphObjectValues||t[92]!==j||t[93]!==h?(bt=(c,vt)=>d.jsxRuntimeExports.jsx("g",{onMouseEnter:()=>{I(c)},onMouseLeave:()=>{I(void 0)},children:d.jsxRuntimeExports.jsxs("g",{transform:`translate(${c.x0},${c.y0})`,children:[d.jsxRuntimeExports.jsx("rect",{x:0,y:0,width:(c.x1||0)-(c.x0||0),height:(c.y1||0)-(c.y0||0),style:{fill:c.color}}),r||M?d.jsxRuntimeExports.jsx("foreignObject",{y:0-w/2,x:S,width:x-S,height:(c.y1||0)-(c.y0||0)+w,children:d.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-0.5 justify-center py-0 px-1.5",style:{height:`${(c.y1||0)-(c.y0||0)+w}px`},children:[r?d.jsxRuntimeExports.jsx(Yt.j,{marginBottom:M?"3xs":"none",size:"sm",leading:"none",className:d.mo("sankey-left-label text-left",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...O?.graphObjectValues},children:`${c.label}`.length<h?`${c.label}`:`${`${c.label}`.substring(0,h)}...`}):null,M?d.jsxRuntimeExports.jsx(Yt.j,{size:"sm",leading:"none",marginBottom:"none",className:d.mo("sankey-left-value text-left font-bold",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...O?.graphObjectValues},children:de.numberFormattingFunction(c.value,"NA",n,p,j)}):null]})}):null]})},vt),t[83]=E?.graphObjectValues,t[84]=w,t[85]=S,t[86]=n,t[87]=p,t[88]=x,t[89]=r,t[90]=M,t[91]=O?.graphObjectValues,t[92]=j,t[93]=h,t[94]=bt):bt=t[94],ot=N.filter(on).map(bt);let Mt;t[95]!==B?(Mt=(c,vt)=>d.jsxRuntimeExports.jsxs("linearGradient",{id:`${B}-gradient-${vt}`,x1:"0%",y1:"0%",x2:"100%",y2:"0%",gradientUnits:"userSpaceOnUse",children:[d.jsxRuntimeExports.jsx("stop",{offset:"0%",style:{stopColor:c.source.color,stopOpacity:1}}),d.jsxRuntimeExports.jsx("stop",{offset:"100%",style:{stopColor:c.target.color,stopOpacity:1}})]},vt),t[95]=B,t[96]=Mt):Mt=t[96],it=d.jsxRuntimeExports.jsx("defs",{children:Vt.map(Mt)}),et=Ve.AnimatePresence,ft=Vt.map((c,vt)=>d.jsxRuntimeExports.jsx(ne.motion.g,{className:"undp-viz-g-with-hover",onMouseEnter:jt=>{v(c.data),Rt(jt.clientY),U(jt.clientX),D?.(c)},onMouseMove:jt=>{v(c.data),Rt(jt.clientY),U(jt.clientX)},onClick:()=>{(H||Y)&&(Se.isEqual(C,c.data)&&kt?(T(void 0),H?.(void 0)):(T(c.data),H?.(c.data)))},onMouseLeave:()=>{v(void 0),U(void 0),Rt(void 0),D?.(void 0)},variants:{initial:{opacity:V?c.source.name===V.name||c.target.name===V.name?.85:G:(z.length!==0||F.length!==0)&&(z.indexOf(c.source.label)!==-1||F.indexOf(c.target.label)!==-1)?.85:G},whileInView:{opacity:V?c.source.name===V.name||c.target.name===V.name?.85:G:(z.length!==0||F.length!==0)&&(z.indexOf(c.source.label)!==-1||F.indexOf(c.target.label)!==-1)?.85:G,transition:{duration:R.duration}}},initial:"initial",animate:i?"whileInView":"initial",exit:{opacity:0,transition:{duration:R.duration}},children:d.jsxRuntimeExports.jsx(ne.motion.path,{d:Nt(c)||"",style:{stroke:`url(#${B}-gradient-${vt})`,strokeWidth:c.width,fill:"none"},exit:{opacity:0,transition:{duration:R.duration}},variants:{initial:{pathLength:0,opacity:1},whileInView:{pathLength:1,opacity:1,transition:{duration:R.duration}}},initial:"initial",animate:i?"whileInView":"initial"},`${c.source}-${c.target}`)},`${c.source}-${c.target}`)),t[8]=R.duration,t[9]=E?.graphObjectValues,t[10]=l,t[11]=o,t[12]=G,t[13]=Y,t[14]=$t,t[15]=wt,t[16]=y,t[17]=z,t[18]=F,t[19]=B,t[20]=i,t[21]=a,t[22]=m.left,t[23]=m.right,t[24]=m.top,t[25]=C,t[26]=w,t[27]=S,t[28]=H,t[29]=D,t[30]=n,t[31]=p,t[32]=kt,t[33]=x,t[34]=V,t[35]=r,t[36]=M,t[37]=tt,t[38]=X,t[39]=O?.graphObjectValues,t[40]=j,t[41]=W,t[42]=h,t[43]=g,t[44]=et,t[45]=lt,t[46]=at,t[47]=Z,t[48]=ut,t[49]=ct,t[50]=Q,t[51]=J,t[52]=ft,t[53]=ht,t[54]=K,t[55]=nt,t[56]=ot,t[57]=it,t[58]=gt,t[59]=dt}else et=t[44],lt=t[45],at=t[46],Z=t[47],ut=t[48],ct=t[49],Q=t[50],J=t[51],ft=t[52],ht=t[53],K=t[54],nt=t[55],ot=t[56],it=t[57],gt=t[58],dt=t[59];let pt;t[97]!==et||t[98]!==ft?(pt=d.jsxRuntimeExports.jsx("g",{children:d.jsxRuntimeExports.jsx(et,{children:ft})}),t[97]=et,t[98]=ft,t[99]=pt):pt=t[99];let mt;t[100]!==l?(mt=l.filter(nn).map(en),t[100]=l,t[101]=mt):mt=t[101];let xt;t[102]!==pt||t[103]!==mt||t[104]!==ht||t[105]!==K||t[106]!==nt||t[107]!==ot||t[108]!==it?(xt=d.jsxRuntimeExports.jsxs("g",{transform:ht,children:[K,nt,ot,it,pt,mt]}),t[102]=pt,t[103]=mt,t[104]=ht,t[105]=K,t[106]=nt,t[107]=ot,t[108]=it,t[109]=xt):xt=t[109];let rt;t[110]!==lt||t[111]!==at||t[112]!==Z||t[113]!==ut||t[114]!==ct||t[115]!==Q||t[116]!==J||t[117]!==xt||t[118]!==gt||t[119]!==dt?(rt=d.jsxRuntimeExports.jsxs(lt,{width:gt,height:dt,viewBox:at,style:Z,direction:ut,ref:ct,children:[Q,J,xt]}),t[110]=lt,t[111]=at,t[112]=Z,t[113]=ut,t[114]=ct,t[115]=Q,t[116]=J,t[117]=xt,t[118]=gt,t[119]=dt,t[120]=rt):rt=t[120];let yt;t[121]!==E?.tooltip||t[122]!==_||t[123]!==St||t[124]!==f||t[125]!==O?.tooltip||t[126]!==$?(yt=f&&$&&_&&St?d.jsxRuntimeExports.jsx(Re.Tooltip,{data:f,body:$,xPos:_,yPos:St,backgroundStyle:O?.tooltip,className:E?.tooltip}):null,t[121]=E?.tooltip,t[122]=_,t[123]=St,t[124]=f,t[125]=O?.tooltip,t[126]=$,t[127]=yt):yt=t[127];let st;t[128]!==E?.modal||t[129]!==Y||t[130]!==C?(st=Y&&C!==void 0?d.jsxRuntimeExports.jsx(Oe.DetailsModal,{body:Y,data:C,setData:T,className:E?.modal}):null,t[128]=E?.modal,t[129]=Y,t[130]=C,t[131]=st):st=t[131];let Et;return t[132]!==rt||t[133]!==yt||t[134]!==st?(Et=d.jsxRuntimeExports.jsxs(d.jsxRuntimeExports.Fragment,{children:[rt,yt,st]}),t[132]=rt,t[133]=yt,t[134]=st,t[135]=Et):Et=t[135],Et}function en(e){return e.layer}function nn(e){return e.position==="after"}function on(e){return e.type==="target"}function rn(e){return e.type==="source"}function sn(e){return e.layer}function ln(e){return e.position==="before"}function an(e,t){return(e.value||0)-(t.value||0)}function un(e,t){return(t.value||0)-(e.value||0)}function cn(){return null}function fn(){return null}function hn(e){const t=d.compilerRuntimeExports.c(93),{data:o,graphTitle:r,sources:a,graphDescription:x,showLabels:h,leftMargin:g,rightMargin:y,topMargin:k,bottomMargin:b,truncateBy:$,height:D,width:j,footNote:p,padding:M,backgroundColor:H,tooltip:w,onSeriesMouseOver:S,suffix:B,prefix:z,relativeHeight:F,showValues:G,graphID:X,onSeriesMouseClick:W,graphDownload:R,dataDownload:tt,fillContainer:kt,language:Y,minHeight:O,theme:E,ariaLabel:n,sourceColors:l,targetColors:s,sourceColorDomain:u,targetColorDomain:i,nodePadding:f,nodeWidth:v,highlightedSourceDataPoints:C,highlightedTargetDataPoints:T,defaultLinkOpacity:V,sourceTitle:I,targetTitle:_,sortNodes:U,resetSelectionOnDoubleClick:St,detailsOnClick:Rt,styles:L,classNames:m,animate:wt,precision:$t,customLayers:et}=e,lt=h===void 0?!0:h,at=g===void 0?75:g,Z=y===void 0?75:y,ut=k===void 0?30:k,ct=b===void 0?10:b,Q=$===void 0?999:$,J=H===void 0?!1:H,ft=B===void 0?"":B,ht=z===void 0?"":z,K=G===void 0?!0:G,nt=R===void 0?!1:R,ot=tt===void 0?!1:tt,it=kt===void 0?!0:kt,gt=Y===void 0?"en":Y,dt=O===void 0?0:O,pt=E===void 0?"light":E,mt=f===void 0?5:f,xt=v===void 0?5:v;let rt;t[0]!==C?(rt=C===void 0?[]:C,t[0]=C,t[1]=rt):rt=t[1];const yt=rt;let st;t[2]!==T?(st=T===void 0?[]:T,t[2]=T,t[3]=st):st=t[3];const Et=st,Pt=V===void 0?.3:V,N=U===void 0?"mostReadable":U,Vt=St===void 0?!0:St,Nt=wt===void 0?!1:wt,Lt=$t===void 0?2:$t;let bt;t[4]!==et?(bt=et===void 0?[]:et,t[4]=et,t[5]=bt):bt=t[5];const Mt=bt,[c,vt]=A.useState(0),[jt,Ee]=A.useState(0),[zt,Le]=A.useState(void 0),Zt=A.useRef(null),ce=A.useRef(null);let It;t[6]===Symbol.for("react.memo_cache_sentinel")?(It=Ot=>{Le(Ot)},t[6]=It):It=t[6];const Qt=A.useEffectEvent(It);let At;t[7]!==o||t[8]!==N||t[9]!==u||t[10]!==l||t[11]!==i||t[12]!==s||t[13]!==Qt?(At=()=>{const Ot=Bt.uniqBy(o,"source",!0).map(q=>({name:`source_${q}`,type:"source",label:`${q}`,color:typeof l=="string"||!l?l||pe.Colors.graphMainColor:l[(u||Bt.uniqBy(o,"source",!0)).findIndex(P=>`${P}`==`${q}`)>l.length?l.length-1:(u||Bt.uniqBy(o,"source",!0)).findIndex(P=>`${P}`==`${q}`)],totalValue:he.sum(o.filter(P=>`${P.source}`==`${q}`).map(kn))})),Xt=N==="asc"||N==="desc"?ge.orderBy(Ot,["totalValue"],[N]):Ot,fe=Bt.uniqBy(o,"target",!0).map(q=>({name:`target_${q}`,type:"target",label:`${q}`,color:typeof s=="string"||!s?s||pe.Colors.graphMainColor:s[(i||Bt.uniqBy(o,"target",!0)).findIndex(P=>`${P}`==`${q}`)>s.length?s.length-1:(i||Bt.uniqBy(o,"target",!0)).findIndex(P=>`${P}`==`${q}`)],totalValue:he.sum(o.filter(P=>`${P.target}`==`${q}`).map(jn))})),Me=N==="asc"||N==="desc"?ge.orderBy(fe,["totalValue"],[N]):fe,ee=[...Xt,...Me];Qt({nodes:ee,links:o.map(q=>({source:ee.findIndex(P=>P.name===`source_${q.source}`),target:ee.findIndex(P=>P.name===`target_${q.target}`),value:q.value,data:{...q}}))})},t[7]=o,t[8]=N,t[9]=u,t[10]=l,t[11]=i,t[12]=s,t[13]=Qt,t[14]=At):At=t[14];let Ht;t[15]!==o||t[16]!==N||t[17]!==u||t[18]!==l||t[19]!==i||t[20]!==s?(Ht=[o,N,u,l,i,s],t[15]=o,t[16]=N,t[17]=u,t[18]=l,t[19]=i,t[20]=s,t[21]=Ht):Ht=t[21],A.useEffect(At,Ht);let Gt,Wt;t[22]===Symbol.for("react.memo_cache_sentinel")?(Gt=()=>{const Ot=new ResizeObserver(Xt=>{vt(Xt[0].target.clientWidth||620),Ee(Xt[0].target.clientHeight||480)});return Zt.current&&Ot.observe(Zt.current),()=>Ot.disconnect()},Wt=[],t[22]=Gt,t[23]=Wt):(Gt=t[22],Wt=t[23]),A.useEffect(Gt,Wt);const Jt=m?.graphContainer,Kt=L?.graphContainer,te=it?void 0:j;let Dt;t[24]!==m?.description||t[25]!==m?.title||t[26]!==o||t[27]!==ot||t[28]!==x||t[29]!==nt||t[30]!==r||t[31]!==L?.description||t[32]!==L?.title||t[33]!==j?(Dt=r||x||nt||ot?d.jsxRuntimeExports.jsx(Ne.GraphHeader,{styles:{title:L?.title,description:L?.description},classNames:{title:m?.title,description:m?.description},graphTitle:r,graphDescription:x,width:j,graphDownload:nt?ce:void 0,dataDownload:ot?o.map(vn).filter(yn).length>0?o.map(xn).filter(mn):o.filter(pn):null}):null,t[24]=m?.description,t[25]=m?.title,t[26]=o,t[27]=ot,t[28]=x,t[29]=nt,t[30]=r,t[31]=L?.description,t[32]=L?.title,t[33]=j,t[34]=Dt):Dt=t[34];let Tt;t[35]!==Nt||t[36]!==ct||t[37]!==m||t[38]!==Mt||t[39]!==o.length||t[40]!==Pt||t[41]!==Rt||t[42]!==it||t[43]!==yt||t[44]!==Et||t[45]!==at||t[46]!==mt||t[47]!==xt||t[48]!==W||t[49]!==S||t[50]!==Lt||t[51]!==ht||t[52]!==Vt||t[53]!==Z||t[54]!==zt||t[55]!==lt||t[56]!==K||t[57]!==N||t[58]!==I||t[59]!==L||t[60]!==ft||t[61]!==jt||t[62]!==c||t[63]!==_||t[64]!==w||t[65]!==ut||t[66]!==Q||t[67]!==j?(Tt=o.length===0?d.jsxRuntimeExports.jsx(qe.EmptyState,{}):d.jsxRuntimeExports.jsx(me.GraphArea,{ref:Zt,children:c&&jt&&zt?d.jsxRuntimeExports.jsx(tn,{data:zt,nodePadding:mt,nodeWidth:xt,width:it||!j||c<j?c:j,height:jt,showLabels:lt,leftMargin:at,rightMargin:Z,topMargin:ut,bottomMargin:ct,truncateBy:Q,tooltip:w,onSeriesMouseOver:S,showValues:K,suffix:ft,prefix:ht,onSeriesMouseClick:W,id:Te.generateRandomString(8),highlightedSourceDataPoints:yt.map(dn),highlightedTargetDataPoints:Et.map(gn),defaultLinkOpacity:Pt,sourceTitle:I,targetTitle:_,sortNodes:N,resetSelectionOnDoubleClick:Vt,styles:L,classNames:m,detailsOnClick:Rt,animate:Nt===!0?{duration:.5,once:!0,amount:.5}:Nt||{duration:0,once:!0,amount:0},precision:Lt,customLayers:Mt}):null}),t[35]=Nt,t[36]=ct,t[37]=m,t[38]=Mt,t[39]=o.length,t[40]=Pt,t[41]=Rt,t[42]=it,t[43]=yt,t[44]=Et,t[45]=at,t[46]=mt,t[47]=xt,t[48]=W,t[49]=S,t[50]=Lt,t[51]=ht,t[52]=Vt,t[53]=Z,t[54]=zt,t[55]=lt,t[56]=K,t[57]=N,t[58]=I,t[59]=L,t[60]=ft,t[61]=jt,t[62]=c,t[63]=_,t[64]=w,t[65]=ut,t[66]=Q,t[67]=j,t[68]=Tt):Tt=t[68];let qt;t[69]!==m?.footnote||t[70]!==m?.source||t[71]!==p||t[72]!==a||t[73]!==L?.footnote||t[74]!==L?.source||t[75]!==j?(qt=a||p?d.jsxRuntimeExports.jsx(De.GraphFooter,{styles:{footnote:L?.footnote,source:L?.source},classNames:{footnote:m?.footnote,source:m?.source},sources:a,footNote:p,width:j}):null,t[69]=m?.footnote,t[70]=m?.source,t[71]=p,t[72]=a,t[73]=L?.footnote,t[74]=L?.source,t[75]=j,t[76]=qt):qt=t[76];let Ft;return t[77]!==n||t[78]!==J||t[79]!==X||t[80]!==D||t[81]!==gt||t[82]!==dt||t[83]!==M||t[84]!==F||t[85]!==Jt||t[86]!==Kt||t[87]!==te||t[88]!==Dt||t[89]!==Tt||t[90]!==qt||t[91]!==pt?(Ft=d.jsxRuntimeExports.jsxs(me.GraphContainer,{className:Jt,style:Kt,id:X,ref:ce,"aria-label":n,backgroundColor:J,theme:pt,language:gt,minHeight:dt,width:te,height:D,relativeHeight:F,padding:M,children:[Dt,Tt,qt]}),t[77]=n,t[78]=J,t[79]=X,t[80]=D,t[81]=gt,t[82]=dt,t[83]=M,t[84]=F,t[85]=Jt,t[86]=Kt,t[87]=te,t[88]=Dt,t[89]=Tt,t[90]=qt,t[91]=pt,t[92]=Ft):Ft=t[92],Ft}function gn(e){return`${e}`}function dn(e){return`${e}`}function pn(e){return e!==void 0}function mn(e){return e!==void 0}function xn(e){return e.data}function yn(e){return e!==void 0}function vn(e){return e.data}function jn(e){return e.value}function kn(e){return e.value}exports.SankeyChart=hn;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const d=require("./index-CHPV5EwG-CTPQjnHt.cjs"),A=require("react"),de=require("./index-CSNtgibC.cjs"),pe=require("./index-Cno4Q0YE.cjs"),Oe=require("./index-DQA8q5sC.cjs"),Ut=require("./Typography-DX7PlgQU.cjs"),me=require("./numberFormattingFunction-02t-wJta.cjs"),Ce=require("./Tooltip-uUdw6wJL.cjs"),Ve=require("./DetailsModal-BN0HDFlV.cjs"),Ne=require("./use-in-view-QcfiW0w3.cjs"),ie=require("./proxy-BxvUI_9l.cjs"),De=require("./index-DG2bgAva.cjs"),Te=require("./GraphHeader.cjs"),qe=require("./GraphFooter.cjs"),xe=require("./Colors.cjs"),Be=require("./generateRandomString-B5zBiJzS.cjs"),Pe=require("./EmptyState-gLDRXBHm.cjs"),zt=require("./uniqBy-O05lp2S5.cjs"),ye=require("./GraphContainer-d8A46BK2.cjs");function ve(e,t){let o;if(t===void 0)for(const r of e)r!=null&&(o<r||o===void 0&&r>=r)&&(o=r);else{let r=-1;for(let a of e)(a=t(a,++r,e))!=null&&(o<a||o===void 0&&a>=a)&&(o=a)}return o}function Ee(e,t){let o;if(t===void 0)for(const r of e)r!=null&&(o>r||o===void 0&&r>=r)&&(o=r);else{let r=-1;for(let a of e)(a=t(a,++r,e))!=null&&(o>a||o===void 0&&a>=a)&&(o=a)}return o}function re(e,t){let o=0;if(t===void 0)for(let r of e)(r=+r)&&(o+=r);else{let r=-1;for(let a of e)(a=+t(a,++r,e))&&(o+=a)}return o}function ze(e){return e.target.depth}function Ie(e,t){return e.sourceLinks.length?e.depth:t-1}function se(e){return e.targetLinks.length?e.depth:e.sourceLinks.length?Ee(e.sourceLinks,ze)-1:0}function Zt(e){return function(){return e}}function je(e,t){return Qt(e.source,t.source)||e.index-t.index}function ke(e,t){return Qt(e.target,t.target)||e.index-t.index}function Qt(e,t){return e.y0-t.y0}function le(e){return e.value}function Ae(e){return e.index}function He(e){return e.nodes}function Ge(e){return e.links}function be(e,t){const o=e.get(t);if(!o)throw new Error("missing: "+t);return o}function we({nodes:e}){for(const t of e){let o=t.y0,r=o;for(const a of t.sourceLinks)a.y0=o+a.width/2,o+=a.width;for(const a of t.targetLinks)a.y1=r+a.width/2,r+=a.width}}function ae(){let e=0,t=0,o=1,r=1,a=24,x=8,h,g=Ae,y=Ie,k,b,$=He,D=Ge,j=6;function p(){const n={nodes:$.apply(null,arguments),links:D.apply(null,arguments)};return M(n),H(n),w(n),S(n),F(n),we(n),n}p.update=function(n){return we(n),n},p.nodeId=function(n){return arguments.length?(g=typeof n=="function"?n:Zt(n),p):g},p.nodeAlign=function(n){return arguments.length?(y=typeof n=="function"?n:Zt(n),p):y},p.nodeSort=function(n){return arguments.length?(k=n,p):k},p.nodeWidth=function(n){return arguments.length?(a=+n,p):a},p.nodePadding=function(n){return arguments.length?(x=h=+n,p):x},p.nodes=function(n){return arguments.length?($=typeof n=="function"?n:Zt(n),p):$},p.links=function(n){return arguments.length?(D=typeof n=="function"?n:Zt(n),p):D},p.linkSort=function(n){return arguments.length?(b=n,p):b},p.size=function(n){return arguments.length?(e=t=0,o=+n[0],r=+n[1],p):[o-e,r-t]},p.extent=function(n){return arguments.length?(e=+n[0][0],o=+n[1][0],t=+n[0][1],r=+n[1][1],p):[[e,t],[o,r]]},p.iterations=function(n){return arguments.length?(j=+n,p):j};function M({nodes:n,links:l}){for(const[u,i]of n.entries())i.index=u,i.sourceLinks=[],i.targetLinks=[];const s=new Map(n.map((u,i)=>[g(u,i,n),u]));for(const[u,i]of l.entries()){i.index=u;let{source:f,target:v}=i;typeof f!="object"&&(f=i.source=be(s,f)),typeof v!="object"&&(v=i.target=be(s,v)),f.sourceLinks.push(i),v.targetLinks.push(i)}if(b!=null)for(const{sourceLinks:u,targetLinks:i}of n)u.sort(b),i.sort(b)}function H({nodes:n}){for(const l of n)l.value=l.fixedValue===void 0?Math.max(re(l.sourceLinks,le),re(l.targetLinks,le)):l.fixedValue}function w({nodes:n}){const l=n.length;let s=new Set(n),u=new Set,i=0;for(;s.size;){for(const f of s){f.depth=i;for(const{target:v}of f.sourceLinks)u.add(v)}if(++i>l)throw new Error("circular link");s=u,u=new Set}}function S({nodes:n}){const l=n.length;let s=new Set(n),u=new Set,i=0;for(;s.size;){for(const f of s){f.height=i;for(const{source:v}of f.targetLinks)u.add(v)}if(++i>l)throw new Error("circular link");s=u,u=new Set}}function B({nodes:n}){const l=ve(n,i=>i.depth)+1,s=(o-e-a)/(l-1),u=new Array(l);for(const i of n){const f=Math.max(0,Math.min(l-1,Math.floor(y.call(null,i,l))));i.layer=f,i.x0=e+f*s,i.x1=i.x0+a,u[f]?u[f].push(i):u[f]=[i]}if(k)for(const i of u)i.sort(k);return u}function z(n){const l=Ee(n,s=>(r-t-(s.length-1)*h)/re(s,le));for(const s of n){let u=t;for(const i of s){i.y0=u,i.y1=u+i.value*l,u=i.y1+h;for(const f of i.sourceLinks)f.width=f.value*l}u=(r-u+h)/(s.length+1);for(let i=0;i<s.length;++i){const f=s[i];f.y0+=u*(i+1),f.y1+=u*(i+1)}Y(s)}}function F(n){const l=B(n);h=Math.min(x,(r-t)/(ve(l,s=>s.length)-1)),z(l);for(let s=0;s<j;++s){const u=Math.pow(.99,s),i=Math.max(1-u,(s+1)/j);X(l,u,i),G(l,u,i)}}function G(n,l,s){for(let u=1,i=n.length;u<i;++u){const f=n[u];for(const v of f){let C=0,T=0;for(const{source:I,value:_}of v.targetLinks){let U=_*(v.layer-I.layer);C+=O(I,v)*U,T+=U}if(!(T>0))continue;let V=(C/T-v.y0)*l;v.y0+=V,v.y1+=V,kt(v)}k===void 0&&f.sort(Qt),W(f,s)}}function X(n,l,s){for(let u=n.length,i=u-2;i>=0;--i){const f=n[i];for(const v of f){let C=0,T=0;for(const{target:I,value:_}of v.sourceLinks){let U=_*(I.layer-v.layer);C+=E(v,I)*U,T+=U}if(!(T>0))continue;let V=(C/T-v.y0)*l;v.y0+=V,v.y1+=V,kt(v)}k===void 0&&f.sort(Qt),W(f,s)}}function W(n,l){const s=n.length>>1,u=n[s];tt(n,u.y0-h,s-1,l),R(n,u.y1+h,s+1,l),tt(n,r,n.length-1,l),R(n,t,0,l)}function R(n,l,s,u){for(;s<n.length;++s){const i=n[s],f=(l-i.y0)*u;f>1e-6&&(i.y0+=f,i.y1+=f),l=i.y1+h}}function tt(n,l,s,u){for(;s>=0;--s){const i=n[s],f=(i.y1-l)*u;f>1e-6&&(i.y0-=f,i.y1-=f),l=i.y0-h}}function kt({sourceLinks:n,targetLinks:l}){if(b===void 0){for(const{source:{sourceLinks:s}}of l)s.sort(ke);for(const{target:{targetLinks:s}}of n)s.sort(je)}}function Y(n){if(b===void 0)for(const{sourceLinks:l,targetLinks:s}of n)l.sort(ke),s.sort(je)}function O(n,l){let s=n.y0-(n.sourceLinks.length-1)*h/2;for(const{target:u,width:i}of n.sourceLinks){if(u===l)break;s+=i+h}for(const{source:u,width:i}of l.targetLinks){if(u===n)break;s-=i}return s}function E(n,l){let s=l.y0-(l.targetLinks.length-1)*h/2;for(const{source:u,width:i}of l.targetLinks){if(u===n)break;s+=i+h}for(const{target:u,width:i}of n.sourceLinks){if(u===l)break;s-=i}return s}return p}var ue=Math.PI,ce=2*ue,Ct=1e-6,We=ce-Ct;function fe(){this._x0=this._y0=this._x1=this._y1=null,this._=""}function Le(){return new fe}fe.prototype=Le.prototype={constructor:fe,moveTo:function(e,t){this._+="M"+(this._x0=this._x1=+e)+","+(this._y0=this._y1=+t)},closePath:function(){this._x1!==null&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")},lineTo:function(e,t){this._+="L"+(this._x1=+e)+","+(this._y1=+t)},quadraticCurveTo:function(e,t,o,r){this._+="Q"+ +e+","+ +t+","+(this._x1=+o)+","+(this._y1=+r)},bezierCurveTo:function(e,t,o,r,a,x){this._+="C"+ +e+","+ +t+","+ +o+","+ +r+","+(this._x1=+a)+","+(this._y1=+x)},arcTo:function(e,t,o,r,a){e=+e,t=+t,o=+o,r=+r,a=+a;var x=this._x1,h=this._y1,g=o-e,y=r-t,k=x-e,b=h-t,$=k*k+b*b;if(a<0)throw new Error("negative radius: "+a);if(this._x1===null)this._+="M"+(this._x1=e)+","+(this._y1=t);else if($>Ct)if(!(Math.abs(b*g-y*k)>Ct)||!a)this._+="L"+(this._x1=e)+","+(this._y1=t);else{var D=o-x,j=r-h,p=g*g+y*y,M=D*D+j*j,H=Math.sqrt(p),w=Math.sqrt($),S=a*Math.tan((ue-Math.acos((p+$-M)/(2*H*w)))/2),B=S/w,z=S/H;Math.abs(B-1)>Ct&&(this._+="L"+(e+B*k)+","+(t+B*b)),this._+="A"+a+","+a+",0,0,"+ +(b*D>k*j)+","+(this._x1=e+z*g)+","+(this._y1=t+z*y)}},arc:function(e,t,o,r,a,x){e=+e,t=+t,o=+o,x=!!x;var h=o*Math.cos(r),g=o*Math.sin(r),y=e+h,k=t+g,b=1^x,$=x?r-a:a-r;if(o<0)throw new Error("negative radius: "+o);this._x1===null?this._+="M"+y+","+k:(Math.abs(this._x1-y)>Ct||Math.abs(this._y1-k)>Ct)&&(this._+="L"+y+","+k),o&&($<0&&($=$%ce+ce),$>We?this._+="A"+o+","+o+",0,1,"+b+","+(e-h)+","+(t-g)+"A"+o+","+o+",0,1,"+b+","+(this._x1=y)+","+(this._y1=k):$>Ct&&(this._+="A"+o+","+o+",0,"+ +($>=ue)+","+b+","+(this._x1=e+o*Math.cos(a))+","+(this._y1=t+o*Math.sin(a))))},rect:function(e,t,o,r){this._+="M"+(this._x0=this._x1=+e)+","+(this._y0=this._y1=+t)+"h"+ +o+"v"+ +r+"h"+-o+"Z"},toString:function(){return this._}};function $e(e){return function(){return e}}function Fe(e){return e[0]}function Xe(e){return e[1]}var Ye=Array.prototype.slice;function _e(e){return e.source}function Ue(e){return e.target}function Ze(e){var t=_e,o=Ue,r=Fe,a=Xe,x=null;function h(){var g,y=Ye.call(arguments),k=t.apply(this,y),b=o.apply(this,y);if(x||(x=g=Le()),e(x,+r.apply(this,(y[0]=k,y)),+a.apply(this,y),+r.apply(this,(y[0]=b,y)),+a.apply(this,y)),g)return x=null,g+""||null}return h.source=function(g){return arguments.length?(t=g,h):t},h.target=function(g){return arguments.length?(o=g,h):o},h.x=function(g){return arguments.length?(r=typeof g=="function"?g:$e(+g),h):r},h.y=function(g){return arguments.length?(a=typeof g=="function"?g:$e(+g),h):a},h.context=function(g){return arguments.length?(x=g??null,h):x},h}function Qe(e,t,o,r,a){e.moveTo(t,o),e.bezierCurveTo(t=(t+r)/2,o,t,a,r,a)}function Je(){return Ze(Qe)}function Ke(e){return[e.source.x1,e.y0]}function tn(e){return[e.target.x0,e.y1]}function en(){return Je().source(Ke).target(tn)}function nn(e){const t=d.compilerRuntimeExports.c(136),{data:o,showLabels:r,leftMargin:a,rightMargin:x,truncateBy:h,width:g,height:y,topMargin:k,bottomMargin:b,tooltip:$,onSeriesMouseOver:D,suffix:j,prefix:p,showValues:M,onSeriesMouseClick:H,nodePadding:w,nodeWidth:S,id:B,highlightedSourceDataPoints:z,highlightedTargetDataPoints:F,defaultLinkOpacity:G,sourceTitle:X,targetTitle:W,animate:R,sortNodes:tt,resetSelectionOnDoubleClick:kt,detailsOnClick:Y,styles:O,classNames:E,precision:n,customLayers:l}=e,s=A.useRef(null);let u;t[0]!==R.amount||t[1]!==R.once?(u={once:R.once,amount:R.amount},t[0]=R.amount,t[1]=R.once,t[2]=u):u=t[2];const i=Ne.useInView(s,u),[f,v]=A.useState(void 0),[C,T]=A.useState(void 0),[V,I]=A.useState(void 0),[_,U]=A.useState(void 0),[St,Rt]=A.useState(void 0);let L;t[3]!==b||t[4]!==a||t[5]!==x||t[6]!==k?(L={top:k,bottom:b,left:a,right:x},t[3]=b,t[4]=a,t[5]=x,t[6]=k,t[7]=L):L=t[7];const m=L,wt=g-m.left-m.right,$t=y-m.top-m.bottom;let et,lt,at,Z,ut,ct,Q,J,ft,ht,K,nt,ot,it,gt,dt;if(t[8]!==R.duration||t[9]!==E?.graphObjectValues||t[10]!==l||t[11]!==o||t[12]!==G||t[13]!==Y||t[14]!==$t||t[15]!==wt||t[16]!==y||t[17]!==z||t[18]!==F||t[19]!==B||t[20]!==i||t[21]!==a||t[22]!==m.left||t[23]!==m.right||t[24]!==m.top||t[25]!==C||t[26]!==w||t[27]!==S||t[28]!==H||t[29]!==D||t[30]!==n||t[31]!==p||t[32]!==kt||t[33]!==x||t[34]!==V||t[35]!==r||t[36]!==M||t[37]!==tt||t[38]!==X||t[39]!==O?.graphObjectValues||t[40]!==j||t[41]!==W||t[42]!==h||t[43]!==g){const It=tt==="mostReadable"?ae().nodeWidth(S).nodePadding(w).size([wt,$t]).nodeAlign(se):tt==="none"?ae().nodeWidth(S).nodePadding(w).size([wt,$t]).nodeAlign(se).nodeSort(gn).linkSort(hn):ae().nodeWidth(S).nodePadding(w).size([wt,$t]).nodeAlign(se).nodeSort(tt==="desc"?fn:cn),{nodes:N,links:Vt}=It(o),Nt=en();lt=ie.motion.svg,gt=`${g}px`,dt=`${y}px`,at=`0 0 ${g} ${y}`,t[60]===Symbol.for("react.memo_cache_sentinel")?(Z={marginLeft:"auto",marginRight:"auto"},t[60]=Z):Z=t[60],ut="ltr",ct=s,t[61]!==m.left||t[62]!==m.top||t[63]!==X?(Q=X?d.jsxRuntimeExports.jsx("text",{x:m.left,y:m.top-10,className:"text-base font-bold fill-primary-gray-700 dark:fill-primary-gray-100",style:{textAnchor:"start"},children:X}):null,t[61]=m.left,t[62]=m.top,t[63]=X,t[64]=Q):Q=t[64],t[65]!==m.right||t[66]!==m.top||t[67]!==W||t[68]!==g?(J=W?d.jsxRuntimeExports.jsx("text",{x:g-m.right,y:m.top-10,className:"text-base font-bold fill-primary-gray-700 dark:fill-primary-gray-100",style:{textAnchor:"end"},children:W}):null,t[65]=m.right,t[66]=m.top,t[67]=W,t[68]=g,t[69]=J):J=t[69],ht=`translate(${m.left},${m.top})`,t[70]!==l?(K=l.filter(un).map(an),t[70]=l,t[71]=K):K=t[71];let Lt;t[72]!==E?.graphObjectValues||t[73]!==a||t[74]!==w||t[75]!==n||t[76]!==p||t[77]!==r||t[78]!==M||t[79]!==O?.graphObjectValues||t[80]!==j||t[81]!==h?(Lt=(c,vt)=>d.jsxRuntimeExports.jsx("g",{onMouseEnter:()=>{I(c)},onMouseLeave:()=>{I(void 0)},children:d.jsxRuntimeExports.jsxs("g",{transform:`translate(${c.x0},${c.y0})`,children:[d.jsxRuntimeExports.jsx("rect",{x:0,y:0,width:(c.x1||0)-(c.x0||0),height:(c.y1||0)-(c.y0||0),style:{fill:c.color}}),r||M?d.jsxRuntimeExports.jsx("foreignObject",{y:0-w/2,x:0-a,width:a,height:(c.y1||0)-(c.y0||0)+w,children:d.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-0.5 justify-center py-0 px-1.5",style:{height:`${(c.y1||0)-(c.y0||0)+w}px`,overflow:"visible"},children:[r?d.jsxRuntimeExports.jsx(Ut.j,{marginBottom:M?"3xs":"none",size:"sm",leading:"none",className:d.mo("sankey-right-label text-right",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...O?.graphObjectValues},children:`${c.label}`.length<h?`${c.label}`:`${`${c.label}`.substring(0,h)}...`}):null,M?d.jsxRuntimeExports.jsx(Ut.j,{marginBottom:"none",size:"sm",leading:"none",className:d.mo("sankey-right-value text-right font-bold",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...O?.graphObjectValues},children:me.numberFormattingFunction(c.value,"NA",n,p,j)}):null]})}):null]})},vt),t[72]=E?.graphObjectValues,t[73]=a,t[74]=w,t[75]=n,t[76]=p,t[77]=r,t[78]=M,t[79]=O?.graphObjectValues,t[80]=j,t[81]=h,t[82]=Lt):Lt=t[82],nt=N.filter(ln).map(Lt);let bt;t[83]!==E?.graphObjectValues||t[84]!==w||t[85]!==S||t[86]!==n||t[87]!==p||t[88]!==x||t[89]!==r||t[90]!==M||t[91]!==O?.graphObjectValues||t[92]!==j||t[93]!==h?(bt=(c,vt)=>d.jsxRuntimeExports.jsx("g",{onMouseEnter:()=>{I(c)},onMouseLeave:()=>{I(void 0)},children:d.jsxRuntimeExports.jsxs("g",{transform:`translate(${c.x0},${c.y0})`,children:[d.jsxRuntimeExports.jsx("rect",{x:0,y:0,width:(c.x1||0)-(c.x0||0),height:(c.y1||0)-(c.y0||0),style:{fill:c.color}}),r||M?d.jsxRuntimeExports.jsx("foreignObject",{y:0-w/2,x:S,width:x-S,height:(c.y1||0)-(c.y0||0)+w,children:d.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-0.5 justify-center py-0 px-1.5",style:{height:`${(c.y1||0)-(c.y0||0)+w}px`},children:[r?d.jsxRuntimeExports.jsx(Ut.j,{marginBottom:M?"3xs":"none",size:"sm",leading:"none",className:d.mo("sankey-left-label text-left",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...O?.graphObjectValues},children:`${c.label}`.length<h?`${c.label}`:`${`${c.label}`.substring(0,h)}...`}):null,M?d.jsxRuntimeExports.jsx(Ut.j,{size:"sm",leading:"none",marginBottom:"none",className:d.mo("sankey-left-value text-left font-bold",E?.graphObjectValues),style:{hyphens:"auto",color:c.color,...O?.graphObjectValues},children:me.numberFormattingFunction(c.value,"NA",n,p,j)}):null]})}):null]})},vt),t[83]=E?.graphObjectValues,t[84]=w,t[85]=S,t[86]=n,t[87]=p,t[88]=x,t[89]=r,t[90]=M,t[91]=O?.graphObjectValues,t[92]=j,t[93]=h,t[94]=bt):bt=t[94],ot=N.filter(sn).map(bt);let Mt;t[95]!==B?(Mt=(c,vt)=>d.jsxRuntimeExports.jsxs("linearGradient",{id:`${B}-gradient-${vt}`,x1:"0%",y1:"0%",x2:"100%",y2:"0%",gradientUnits:"userSpaceOnUse",children:[d.jsxRuntimeExports.jsx("stop",{offset:"0%",style:{stopColor:c.source.color,stopOpacity:1}}),d.jsxRuntimeExports.jsx("stop",{offset:"100%",style:{stopColor:c.target.color,stopOpacity:1}})]},vt),t[95]=B,t[96]=Mt):Mt=t[96],it=d.jsxRuntimeExports.jsx("defs",{children:Vt.map(Mt)}),et=De.AnimatePresence,ft=Vt.map((c,vt)=>d.jsxRuntimeExports.jsx(ie.motion.g,{className:"undp-viz-g-with-hover",onMouseEnter:jt=>{v(c.data),Rt(jt.clientY),U(jt.clientX),D?.(c)},onMouseMove:jt=>{v(c.data),Rt(jt.clientY),U(jt.clientX)},onClick:()=>{(H||Y)&&(Oe.isEqual(C,c.data)&&kt?(T(void 0),H?.(void 0)):(T(c.data),H?.(c.data)))},onMouseLeave:()=>{v(void 0),U(void 0),Rt(void 0),D?.(void 0)},variants:{initial:{opacity:V?c.source.name===V.name||c.target.name===V.name?.85:G:(z.length!==0||F.length!==0)&&(z.indexOf(c.source.label)!==-1||F.indexOf(c.target.label)!==-1)?.85:G},whileInView:{opacity:V?c.source.name===V.name||c.target.name===V.name?.85:G:(z.length!==0||F.length!==0)&&(z.indexOf(c.source.label)!==-1||F.indexOf(c.target.label)!==-1)?.85:G,transition:{duration:R.duration}}},initial:"initial",animate:i?"whileInView":"initial",exit:{opacity:0,transition:{duration:R.duration}},children:d.jsxRuntimeExports.jsx(ie.motion.path,{d:Nt(c)||"",style:{stroke:`url(#${B}-gradient-${vt})`,strokeWidth:c.width,fill:"none"},exit:{opacity:0,transition:{duration:R.duration}},variants:{initial:{pathLength:0,opacity:1},whileInView:{pathLength:1,opacity:1,transition:{duration:R.duration}}},initial:"initial",animate:i?"whileInView":"initial"},`${c.source}-${c.target}`)},`${c.source}-${c.target}`)),t[8]=R.duration,t[9]=E?.graphObjectValues,t[10]=l,t[11]=o,t[12]=G,t[13]=Y,t[14]=$t,t[15]=wt,t[16]=y,t[17]=z,t[18]=F,t[19]=B,t[20]=i,t[21]=a,t[22]=m.left,t[23]=m.right,t[24]=m.top,t[25]=C,t[26]=w,t[27]=S,t[28]=H,t[29]=D,t[30]=n,t[31]=p,t[32]=kt,t[33]=x,t[34]=V,t[35]=r,t[36]=M,t[37]=tt,t[38]=X,t[39]=O?.graphObjectValues,t[40]=j,t[41]=W,t[42]=h,t[43]=g,t[44]=et,t[45]=lt,t[46]=at,t[47]=Z,t[48]=ut,t[49]=ct,t[50]=Q,t[51]=J,t[52]=ft,t[53]=ht,t[54]=K,t[55]=nt,t[56]=ot,t[57]=it,t[58]=gt,t[59]=dt}else et=t[44],lt=t[45],at=t[46],Z=t[47],ut=t[48],ct=t[49],Q=t[50],J=t[51],ft=t[52],ht=t[53],K=t[54],nt=t[55],ot=t[56],it=t[57],gt=t[58],dt=t[59];let pt;t[97]!==et||t[98]!==ft?(pt=d.jsxRuntimeExports.jsx("g",{children:d.jsxRuntimeExports.jsx(et,{children:ft})}),t[97]=et,t[98]=ft,t[99]=pt):pt=t[99];let mt;t[100]!==l?(mt=l.filter(rn).map(on),t[100]=l,t[101]=mt):mt=t[101];let xt;t[102]!==pt||t[103]!==mt||t[104]!==ht||t[105]!==K||t[106]!==nt||t[107]!==ot||t[108]!==it?(xt=d.jsxRuntimeExports.jsxs("g",{transform:ht,children:[K,nt,ot,it,pt,mt]}),t[102]=pt,t[103]=mt,t[104]=ht,t[105]=K,t[106]=nt,t[107]=ot,t[108]=it,t[109]=xt):xt=t[109];let rt;t[110]!==lt||t[111]!==at||t[112]!==Z||t[113]!==ut||t[114]!==ct||t[115]!==Q||t[116]!==J||t[117]!==xt||t[118]!==gt||t[119]!==dt?(rt=d.jsxRuntimeExports.jsxs(lt,{width:gt,height:dt,viewBox:at,style:Z,direction:ut,ref:ct,children:[Q,J,xt]}),t[110]=lt,t[111]=at,t[112]=Z,t[113]=ut,t[114]=ct,t[115]=Q,t[116]=J,t[117]=xt,t[118]=gt,t[119]=dt,t[120]=rt):rt=t[120];let yt;t[121]!==E?.tooltip||t[122]!==_||t[123]!==St||t[124]!==f||t[125]!==O?.tooltip||t[126]!==$?(yt=f&&$&&_&&St?d.jsxRuntimeExports.jsx(Ce.Tooltip,{data:f,body:$,xPos:_,yPos:St,backgroundStyle:O?.tooltip,className:E?.tooltip}):null,t[121]=E?.tooltip,t[122]=_,t[123]=St,t[124]=f,t[125]=O?.tooltip,t[126]=$,t[127]=yt):yt=t[127];let st;t[128]!==E?.modal||t[129]!==Y||t[130]!==C?(st=Y&&C!==void 0?d.jsxRuntimeExports.jsx(Ve.DetailsModal,{body:Y,data:C,setData:T,className:E?.modal}):null,t[128]=E?.modal,t[129]=Y,t[130]=C,t[131]=st):st=t[131];let Et;return t[132]!==rt||t[133]!==yt||t[134]!==st?(Et=d.jsxRuntimeExports.jsxs(d.jsxRuntimeExports.Fragment,{children:[rt,yt,st]}),t[132]=rt,t[133]=yt,t[134]=st,t[135]=Et):Et=t[135],Et}function on(e){return e.layer}function rn(e){return e.position==="after"}function sn(e){return e.type==="target"}function ln(e){return e.type==="source"}function an(e){return e.layer}function un(e){return e.position==="before"}function cn(e,t){return(e.value||0)-(t.value||0)}function fn(e,t){return(t.value||0)-(e.value||0)}function hn(){return null}function gn(){return null}function dn(e){const t=d.compilerRuntimeExports.c(98),{data:o,graphTitle:r,sources:a,graphDescription:x,showLabels:h,leftMargin:g,rightMargin:y,topMargin:k,bottomMargin:b,truncateBy:$,height:D,width:j,footNote:p,padding:M,backgroundColor:H,tooltip:w,onSeriesMouseOver:S,suffix:B,prefix:z,relativeHeight:F,showValues:G,graphID:X,onSeriesMouseClick:W,graphDownload:R,dataDownload:tt,fillContainer:kt,language:Y,minHeight:O,theme:E,ariaLabel:n,sourceColors:l,targetColors:s,sourceColorDomain:u,targetColorDomain:i,nodePadding:f,nodeWidth:v,highlightedSourceDataPoints:C,highlightedTargetDataPoints:T,defaultLinkOpacity:V,sourceTitle:I,targetTitle:_,sortNodes:U,resetSelectionOnDoubleClick:St,detailsOnClick:Rt,styles:L,classNames:m,animate:wt,precision:$t,customLayers:et}=e,lt=h===void 0?!0:h,at=g===void 0?75:g,Z=y===void 0?75:y,ut=k===void 0?30:k,ct=b===void 0?10:b,Q=$===void 0?999:$,J=H===void 0?!1:H,ft=B===void 0?"":B,ht=z===void 0?"":z,K=G===void 0?!0:G,nt=R===void 0?!1:R,ot=tt===void 0?!1:tt,it=kt===void 0?!0:kt,gt=Y===void 0?"en":Y,dt=O===void 0?0:O,pt=E===void 0?"light":E,mt=f===void 0?5:f,xt=v===void 0?5:v;let rt;t[0]!==C?(rt=C===void 0?[]:C,t[0]=C,t[1]=rt):rt=t[1];const yt=rt;let st;t[2]!==T?(st=T===void 0?[]:T,t[2]=T,t[3]=st):st=t[3];const Et=st,It=V===void 0?.3:V,N=U===void 0?"mostReadable":U,Vt=St===void 0?!0:St,Nt=wt===void 0?!1:wt,Lt=$t===void 0?2:$t;let bt;t[4]!==et?(bt=et===void 0?[]:et,t[4]=et,t[5]=bt):bt=t[5];const Mt=bt,[c,vt]=A.useState(0),[jt,Me]=A.useState(0),[At,Se]=A.useState(void 0),Jt=A.useRef(null),he=A.useRef(null);let Ht;t[6]===Symbol.for("react.memo_cache_sentinel")?(Ht=Ot=>{Se(Ot)},t[6]=Ht):Ht=t[6];const Kt=A.useEffectEvent(Ht);let Gt;t[7]!==o||t[8]!==N||t[9]!==u||t[10]!==l||t[11]!==i||t[12]!==s||t[13]!==Kt?(Gt=()=>{const Ot=zt.uniqBy(o,"source",!0).map(q=>({name:`source_${q}`,type:"source",label:`${q}`,color:typeof l=="string"||!l?l||xe.Colors.graphMainColor:l[(u||zt.uniqBy(o,"source",!0)).findIndex(P=>`${P}`==`${q}`)>l.length?l.length-1:(u||zt.uniqBy(o,"source",!0)).findIndex(P=>`${P}`==`${q}`)],totalValue:de.sum(o.filter(P=>`${P.source}`==`${q}`).map(wn))})),_t=N==="asc"||N==="desc"?pe.orderBy(Ot,["totalValue"],[N]):Ot,ge=zt.uniqBy(o,"target",!0).map(q=>({name:`target_${q}`,type:"target",label:`${q}`,color:typeof s=="string"||!s?s||xe.Colors.graphMainColor:s[(i||zt.uniqBy(o,"target",!0)).findIndex(P=>`${P}`==`${q}`)>s.length?s.length-1:(i||zt.uniqBy(o,"target",!0)).findIndex(P=>`${P}`==`${q}`)],totalValue:de.sum(o.filter(P=>`${P.target}`==`${q}`).map(bn))})),Re=N==="asc"||N==="desc"?pe.orderBy(ge,["totalValue"],[N]):ge,oe=[..._t,...Re];Kt({nodes:oe,links:o.map(q=>({source:oe.findIndex(P=>P.name===`source_${q.source}`),target:oe.findIndex(P=>P.name===`target_${q.target}`),value:q.value,data:{...q}}))})},t[7]=o,t[8]=N,t[9]=u,t[10]=l,t[11]=i,t[12]=s,t[13]=Kt,t[14]=Gt):Gt=t[14];let Wt;t[15]!==o||t[16]!==N||t[17]!==u||t[18]!==l||t[19]!==i||t[20]!==s?(Wt=[o,N,u,l,i,s],t[15]=o,t[16]=N,t[17]=u,t[18]=l,t[19]=i,t[20]=s,t[21]=Wt):Wt=t[21],A.useEffect(Gt,Wt);let Ft,Xt;t[22]===Symbol.for("react.memo_cache_sentinel")?(Ft=()=>{const Ot=new ResizeObserver(_t=>{vt(_t[0].target.clientWidth||620),Me(_t[0].target.clientHeight||480)});return Jt.current&&Ot.observe(Jt.current),()=>Ot.disconnect()},Xt=[],t[22]=Ft,t[23]=Xt):(Ft=t[22],Xt=t[23]),A.useEffect(Ft,Xt);const te=m?.graphContainer,ee=L?.graphContainer,ne=it?void 0:j;let Dt;t[24]!==m?.description||t[25]!==m?.title||t[26]!==o||t[27]!==ot||t[28]!==x||t[29]!==nt||t[30]!==r||t[31]!==L?.description||t[32]!==L?.title||t[33]!==j?(Dt=r||x||nt||ot?d.jsxRuntimeExports.jsx(Te.GraphHeader,{styles:{title:L?.title,description:L?.description},classNames:{title:m?.title,description:m?.description},graphTitle:r,graphDescription:x,width:j,graphDownload:nt?he:void 0,dataDownload:ot?o.map(kn).filter(jn).length>0?o.map(vn).filter(yn):o.filter(xn):null}):null,t[24]=m?.description,t[25]=m?.title,t[26]=o,t[27]=ot,t[28]=x,t[29]=nt,t[30]=r,t[31]=L?.description,t[32]=L?.title,t[33]=j,t[34]=Dt):Dt=t[34];let Tt;t[35]!==o.length?(Tt=o.length===0&&d.jsxRuntimeExports.jsx(Pe.EmptyState,{}),t[35]=o.length,t[36]=Tt):Tt=t[36];let qt;t[37]!==Nt||t[38]!==ct||t[39]!==m||t[40]!==Mt||t[41]!==o.length||t[42]!==It||t[43]!==Rt||t[44]!==it||t[45]!==yt||t[46]!==Et||t[47]!==at||t[48]!==mt||t[49]!==xt||t[50]!==W||t[51]!==S||t[52]!==Lt||t[53]!==ht||t[54]!==Vt||t[55]!==Z||t[56]!==At||t[57]!==lt||t[58]!==K||t[59]!==N||t[60]!==I||t[61]!==L||t[62]!==ft||t[63]!==jt||t[64]!==c||t[65]!==_||t[66]!==w||t[67]!==ut||t[68]!==Q||t[69]!==j?(qt=c&&jt&&At&&o.length>0?d.jsxRuntimeExports.jsx(nn,{data:At,nodePadding:mt,nodeWidth:xt,width:it||!j||c<j?c:j,height:jt,showLabels:lt,leftMargin:at,rightMargin:Z,topMargin:ut,bottomMargin:ct,truncateBy:Q,tooltip:w,onSeriesMouseOver:S,showValues:K,suffix:ft,prefix:ht,onSeriesMouseClick:W,id:Be.generateRandomString(8),highlightedSourceDataPoints:yt.map(mn),highlightedTargetDataPoints:Et.map(pn),defaultLinkOpacity:It,sourceTitle:I,targetTitle:_,sortNodes:N,resetSelectionOnDoubleClick:Vt,styles:L,classNames:m,detailsOnClick:Rt,animate:Nt===!0?{duration:.5,once:!0,amount:.5}:Nt||{duration:0,once:!0,amount:0},precision:Lt,customLayers:Mt}):null,t[37]=Nt,t[38]=ct,t[39]=m,t[40]=Mt,t[41]=o.length,t[42]=It,t[43]=Rt,t[44]=it,t[45]=yt,t[46]=Et,t[47]=at,t[48]=mt,t[49]=xt,t[50]=W,t[51]=S,t[52]=Lt,t[53]=ht,t[54]=Vt,t[55]=Z,t[56]=At,t[57]=lt,t[58]=K,t[59]=N,t[60]=I,t[61]=L,t[62]=ft,t[63]=jt,t[64]=c,t[65]=_,t[66]=w,t[67]=ut,t[68]=Q,t[69]=j,t[70]=qt):qt=t[70];let Bt;t[71]!==Tt||t[72]!==qt?(Bt=d.jsxRuntimeExports.jsxs(ye.GraphArea,{ref:Jt,children:[Tt,qt]}),t[71]=Tt,t[72]=qt,t[73]=Bt):Bt=t[73];let Pt;t[74]!==m?.footnote||t[75]!==m?.source||t[76]!==p||t[77]!==a||t[78]!==L?.footnote||t[79]!==L?.source||t[80]!==j?(Pt=a||p?d.jsxRuntimeExports.jsx(qe.GraphFooter,{styles:{footnote:L?.footnote,source:L?.source},classNames:{footnote:m?.footnote,source:m?.source},sources:a,footNote:p,width:j}):null,t[74]=m?.footnote,t[75]=m?.source,t[76]=p,t[77]=a,t[78]=L?.footnote,t[79]=L?.source,t[80]=j,t[81]=Pt):Pt=t[81];let Yt;return t[82]!==n||t[83]!==J||t[84]!==X||t[85]!==D||t[86]!==gt||t[87]!==dt||t[88]!==M||t[89]!==F||t[90]!==te||t[91]!==ee||t[92]!==ne||t[93]!==Dt||t[94]!==Bt||t[95]!==Pt||t[96]!==pt?(Yt=d.jsxRuntimeExports.jsxs(ye.GraphContainer,{className:te,style:ee,id:X,ref:he,"aria-label":n,backgroundColor:J,theme:pt,language:gt,minHeight:dt,width:ne,height:D,relativeHeight:F,padding:M,children:[Dt,Bt,Pt]}),t[82]=n,t[83]=J,t[84]=X,t[85]=D,t[86]=gt,t[87]=dt,t[88]=M,t[89]=F,t[90]=te,t[91]=ee,t[92]=ne,t[93]=Dt,t[94]=Bt,t[95]=Pt,t[96]=pt,t[97]=Yt):Yt=t[97],Yt}function pn(e){return`${e}`}function mn(e){return`${e}`}function xn(e){return e!==void 0}function yn(e){return e!==void 0}function vn(e){return e.data}function jn(e){return e!==void 0}function kn(e){return e.data}function bn(e){return e.value}function wn(e){return e.value}exports.SankeyChart=dn;
|
|
2
2
|
//# sourceMappingURL=SankeyChart.cjs.map
|