@undp/data-viz 2.0.0 → 2.0.1
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/BarGraph.cjs +1 -1
- package/dist/BarGraph.cjs.map +1 -1
- package/dist/BarGraph.js +957 -957
- package/dist/BarGraph.js.map +1 -1
- package/dist/BasicStatCard.cjs +1 -1
- package/dist/BasicStatCard.cjs.map +1 -1
- package/dist/BasicStatCard.js +45 -47
- package/dist/BasicStatCard.js.map +1 -1
- package/dist/BeeSwarmChart.cjs +1 -1
- package/dist/BeeSwarmChart.cjs.map +1 -1
- package/dist/BeeSwarmChart.js +76 -56
- package/dist/BeeSwarmChart.js.map +1 -1
- package/dist/BiVariateChoroplethMap.cjs +1 -1
- package/dist/BiVariateChoroplethMap.cjs.map +1 -1
- package/dist/BiVariateChoroplethMap.js +157 -157
- package/dist/BiVariateChoroplethMap.js.map +1 -1
- package/dist/ChoroplethMap.cjs +1 -1
- package/dist/ChoroplethMap.cjs.map +1 -1
- package/dist/ChoroplethMap.js +185 -185
- package/dist/ChoroplethMap.js.map +1 -1
- package/dist/CirclePackingGraph.cjs +1 -1
- package/dist/CirclePackingGraph.js +2 -4
- package/dist/CirclePackingGraph.js.map +1 -1
- package/dist/Data/barChart.json +70 -0
- package/dist/Data/basic.csv +20 -0
- package/dist/DifferenceLineChart.cjs +1 -1
- package/dist/DifferenceLineChart.cjs.map +1 -1
- package/dist/DifferenceLineChart.js +224 -223
- package/dist/DifferenceLineChart.js.map +1 -1
- package/dist/DotDensityMap.cjs +1 -1
- package/dist/DotDensityMap.cjs.map +1 -1
- package/dist/DotDensityMap.js +156 -156
- package/dist/DotDensityMap.js.map +1 -1
- package/dist/DualAxisLineChart.cjs +1 -1
- package/dist/DualAxisLineChart.cjs.map +1 -1
- package/dist/DualAxisLineChart.js +326 -325
- package/dist/DualAxisLineChart.js.map +1 -1
- package/dist/GeoHubCompareMaps.cjs +1 -1
- package/dist/GeoHubCompareMaps.cjs.map +1 -1
- package/dist/GeoHubCompareMaps.js +183 -183
- package/dist/GeoHubCompareMaps.js.map +1 -1
- package/dist/{GraphEl-DzRon4cb.js → GraphEl-BZne2JIx.js} +3 -3
- package/dist/{GraphEl-DzRon4cb.js.map → GraphEl-BZne2JIx.js.map} +1 -1
- package/dist/{GraphEl-BkyLYXG5.cjs → GraphEl-D5MUfp45.cjs} +2 -2
- package/dist/{GraphEl-BkyLYXG5.cjs.map → GraphEl-D5MUfp45.cjs.map} +1 -1
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.js +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 +133 -132
- package/dist/LineChartWithConfidenceInterval.js.map +1 -1
- package/dist/MultiGraphDashboard.cjs +1 -1
- package/dist/MultiGraphDashboard.cjs.map +1 -1
- package/dist/MultiGraphDashboard.js +52 -50
- package/dist/MultiGraphDashboard.js.map +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.cjs.map +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.js +11 -9
- package/dist/MultiGraphDashboardWideToLongFormat.js.map +1 -1
- package/dist/MultiLineAltChart.cjs +1 -1
- package/dist/MultiLineAltChart.cjs.map +1 -1
- package/dist/MultiLineAltChart.js +149 -148
- package/dist/MultiLineAltChart.js.map +1 -1
- package/dist/MultiLineChart.cjs +1 -1
- package/dist/MultiLineChart.cjs.map +1 -1
- package/dist/MultiLineChart.js +182 -181
- package/dist/MultiLineChart.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.js +14 -12
- package/dist/PerformanceIntensiveMultiGraphDashboard.js.map +1 -1
- package/dist/SimpleLineChart.cjs +1 -1
- package/dist/SimpleLineChart.cjs.map +1 -1
- package/dist/SimpleLineChart.js +123 -122
- package/dist/SimpleLineChart.js.map +1 -1
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.cjs.map +1 -1
- package/dist/SingleGraphDashboard.js +83 -79
- package/dist/SingleGraphDashboard.js.map +1 -1
- package/dist/SingleGraphDashboardGeoHubMaps.cjs +1 -1
- package/dist/SingleGraphDashboardGeoHubMaps.cjs.map +1 -1
- package/dist/SingleGraphDashboardGeoHubMaps.js +49 -45
- package/dist/SingleGraphDashboardGeoHubMaps.js.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.cjs.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.js +56 -52
- package/dist/SingleGraphDashboardThreeDGraphs.js.map +1 -1
- package/dist/StatCardFromData.cjs +1 -1
- package/dist/StatCardFromData.cjs.map +1 -1
- package/dist/StatCardFromData.js +44 -46
- package/dist/StatCardFromData.js.map +1 -1
- package/dist/ThreeDGlobe.cjs +1 -1
- package/dist/ThreeDGlobe.cjs.map +1 -1
- package/dist/ThreeDGlobe.js +134 -134
- package/dist/ThreeDGlobe.js.map +1 -1
- package/dist/getNoOfTicks-C_1CFXv_.cjs +2 -0
- package/dist/getNoOfTicks-C_1CFXv_.cjs.map +1 -0
- package/dist/getNoOfTicks-CpmRjcRF.js +7 -0
- package/dist/getNoOfTicks-CpmRjcRF.js.map +1 -0
- package/dist/index-C6LorfZ-.cjs +2 -0
- package/dist/index-C6LorfZ-.cjs.map +1 -0
- package/dist/index-Ceppbd8C.js +342 -0
- package/dist/index-Ceppbd8C.js.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.js +1 -1
- package/package.json +1 -1
- package/dist/index-DoY3Ga3W.cjs +0 -2
- package/dist/index-DoY3Ga3W.cjs.map +0 -1
- package/dist/index-leTnKT2q.js +0 -329
- package/dist/index-leTnKT2q.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LineChartWithConfidenceInterval.js","sources":["../src/Components/Graphs/LineCharts/LineChartWithConfidenceInterval/Graph.tsx","../src/Components/Graphs/LineCharts/LineChartWithConfidenceInterval/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\r\nimport {\r\n line,\r\n curveMonotoneX,\r\n area,\r\n curveLinear,\r\n curveStep,\r\n curveStepAfter,\r\n curveStepBefore,\r\n} from 'd3-shape';\r\nimport { scaleLinear, scaleTime } from 'd3-scale';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { bisectCenter } from 'd3-array';\r\nimport { pointer, select } from 'd3-selection';\r\nimport { linearRegression, linearRegressionLine } from 'simple-statistics';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { motion, useInView } from 'motion/react';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n AnnotationSettingsDataType,\r\n ClassNameObject,\r\n CurveTypes,\r\n CustomHighlightAreaSettingsDataType,\r\n CustomLayerDataType,\r\n HighlightAreaSettingsDataType,\r\n LineChartWithConfidenceIntervalDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { getLineEndPoint } from '@/Utils/getLineEndPoint';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { RefLineY } from '@/Components/Elements/ReferenceLine';\r\nimport { RegressionLine } from '@/Components/Elements/RegressionLine';\r\nimport { Annotation } from '@/Components/Elements/Annotations';\r\nimport { YTicksAndGridLines } from '@/Components/Elements/Axes/YTicksAndGridLines';\r\nimport { CustomArea } from '@/Components/Elements/HighlightArea/customArea';\r\nimport { HighlightArea } from '@/Components/Elements/HighlightArea';\r\n\r\ninterface Props {\r\n data: LineChartWithConfidenceIntervalDataType[];\r\n lineColor: string;\r\n width: number;\r\n height: number;\r\n suffix: string;\r\n prefix: string;\r\n dateFormat: string;\r\n showValues?: boolean;\r\n noOfXTicks: number;\r\n rightMargin: number;\r\n leftMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues: ReferenceDataType[];\r\n highlightAreaSettings: HighlightAreaSettingsDataType[];\r\n maxValue?: number;\r\n minValue?: number;\r\n animate: AnimateDataType;\r\n rtl: boolean;\r\n strokeWidth: number;\r\n showDots: boolean;\r\n annotations: AnnotationSettingsDataType[];\r\n customHighlightAreaSettings: CustomHighlightAreaSettingsDataType[];\r\n regressionLine: boolean | string;\r\n showIntervalDots: boolean;\r\n showIntervalValues: boolean;\r\n intervalLineStrokeWidth: number;\r\n intervalLineColors: [string, string];\r\n intervalAreaColor: string;\r\n intervalAreaOpacity: number;\r\n yAxisTitle?: string;\r\n noOfYTicks: number;\r\n minDate?: string | number;\r\n maxDate?: string | number;\r\n curveType: CurveTypes;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\ninterface FormattedDataType {\r\n y: number;\r\n date: Date;\r\n yMin: number;\r\n yMax: number;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n lineColor,\r\n suffix,\r\n prefix,\r\n dateFormat,\r\n highlightAreaSettings,\r\n showValues,\r\n noOfXTicks,\r\n rightMargin,\r\n leftMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n minValue,\r\n maxValue,\r\n animate,\r\n rtl,\r\n strokeWidth,\r\n showDots,\r\n annotations,\r\n customHighlightAreaSettings,\r\n regressionLine,\r\n showIntervalDots,\r\n showIntervalValues,\r\n intervalLineStrokeWidth,\r\n intervalLineColors,\r\n intervalAreaColor,\r\n intervalAreaOpacity,\r\n yAxisTitle,\r\n noOfYTicks,\r\n minDate,\r\n maxDate,\r\n curveType,\r\n styles,\r\n classNames,\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 [hasAnimatedOnce, setHasAnimatedOnce] = useState(false);\r\n\r\n useEffect(() => {\r\n if (isInView && !hasAnimatedOnce) {\r\n const timeout = setTimeout(\r\n () => {\r\n setHasAnimatedOnce(true);\r\n },\r\n (animate.duration + 0.5) * 1000,\r\n );\r\n return () => clearTimeout(timeout);\r\n }\r\n }, [isInView, hasAnimatedOnce, animate.duration]);\r\n const curve =\r\n curveType === 'linear'\r\n ? curveLinear\r\n : curveType === 'step'\r\n ? curveStep\r\n : curveType === 'stepAfter'\r\n ? curveStepAfter\r\n : curveType === 'stepBefore'\r\n ? curveStepBefore\r\n : curveMonotoneX;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: yAxisTitle ? leftMargin + 30 : leftMargin,\r\n right: rightMargin,\r\n };\r\n const MouseoverRectRef = useRef(null);\r\n const dataFormatted: FormattedDataType[] = orderBy(\r\n data\r\n .filter(d => !checkIfNullOrUndefined(d.y))\r\n .map(d => ({\r\n date: parse(`${d.date}`, dateFormat, new Date()),\r\n y: d.y as number,\r\n yMin: checkIfNullOrUndefined(d.yMin) ? (d.y as number) : (d.yMin as number),\r\n yMax: checkIfNullOrUndefined(d.yMax) ? (d.y as number) : (d.yMax as number),\r\n data: d.data,\r\n })),\r\n ['date'],\r\n ['asc'],\r\n );\r\n const highlightAreaSettingsFormatted = highlightAreaSettings.map(d => ({\r\n ...d,\r\n coordinates: [\r\n d.coordinates[0] === null ? null : parse(`${d.coordinates[0]}`, dateFormat, new Date()),\r\n d.coordinates[1] === null ? null : parse(`${d.coordinates[1]}`, dateFormat, new Date()),\r\n ],\r\n }));\r\n const customHighlightAreaSettingsFormatted = customHighlightAreaSettings.map(d => ({\r\n ...d,\r\n coordinates: d.coordinates.map((el, j) =>\r\n j % 2 === 0 ? parse(`${el}`, dateFormat, new Date()) : (el as number),\r\n ),\r\n }));\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n const minYear = minDate ? parse(`${minDate}`, dateFormat, new Date()) : dataFormatted[0].date;\r\n const maxYear = maxDate\r\n ? parse(`${maxDate}`, dateFormat, new Date())\r\n : dataFormatted[dataFormatted.length - 1].date;\r\n const minParam: number = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(...dataFormatted.map(d => Math.min(d.y, d.yMax, d.yMin)))\r\n ? Math.min(...dataFormatted.map(d => Math.min(d.y, d.yMax, d.yMin))) > 0\r\n ? 0\r\n : Math.min(...dataFormatted.map(d => Math.min(d.y, d.yMax, d.yMin)))\r\n : 0;\r\n const maxParam: number = Math.max(...dataFormatted.map(d => Math.max(d.y, d.yMax, d.yMin)))\r\n ? Math.max(...dataFormatted.map(d => Math.max(d.y, d.yMax, d.yMin)))\r\n : 0;\r\n const x = scaleTime().domain([minYear, maxYear]).range([0, graphWidth]);\r\n const y = scaleLinear()\r\n .domain([\r\n minParam,\r\n checkIfNullOrUndefined(maxValue) ? (maxParam > 0 ? maxParam : 0) : (maxValue as number),\r\n ])\r\n .range([graphHeight, 0])\r\n .nice();\r\n\r\n const lineShape = line<FormattedDataType>()\r\n .x(d => x(d.date))\r\n .y(d => y(d.y))\r\n .curve(curve);\r\n\r\n const lineShapeMin = line<FormattedDataType>()\r\n .x(d => x(d.date))\r\n .y(d => y(d.yMin))\r\n .curve(curve);\r\n\r\n const lineShapeMax = line<FormattedDataType>()\r\n .x(d => x(d.date))\r\n .y(d => y(d.yMax))\r\n .curve(curve);\r\n\r\n const areaShape = area<FormattedDataType>()\r\n .x(d => x(d.date))\r\n .y0(d => y(d.yMin))\r\n .y1(d => y(d.yMax))\r\n .curve(curve);\r\n\r\n const yTicks = y.ticks(noOfYTicks);\r\n\r\n const xTicks = x.ticks(noOfXTicks);\r\n\r\n useEffect(() => {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const mousemove = (event: any) => {\r\n const selectedData =\r\n dataFormatted[\r\n bisectCenter(\r\n dataFormatted.map(d => d.date),\r\n x.invert(pointer(event)[0]),\r\n 0,\r\n )\r\n ];\r\n setMouseOverData(selectedData || dataFormatted[dataFormatted.length - 1]);\r\n onSeriesMouseOver?.(selectedData || dataFormatted[dataFormatted.length - 1]);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n };\r\n const mouseout = () => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n };\r\n select(MouseoverRectRef.current).on('mousemove', mousemove).on('mouseout', mouseout);\r\n }, [x, dataFormatted, onSeriesMouseOver]);\r\n const regressionLineParam = linearRegression(\r\n dataFormatted\r\n .filter(d => !checkIfNullOrUndefined(d.date) && !checkIfNullOrUndefined(d.y))\r\n .map(d => [x(d.date), y(d.y as number)]),\r\n );\r\n const predict = linearRegressionLine(regressionLineParam);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n <HighlightArea\r\n areaSettings={highlightAreaSettingsFormatted}\r\n width={graphWidth}\r\n height={graphHeight}\r\n scale={x}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n <CustomArea\r\n areaSettings={customHighlightAreaSettingsFormatted}\r\n scaleX={x}\r\n scaleY={y}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n <g>\r\n <YTicksAndGridLines\r\n values={yTicks.filter(d => d !== 0)}\r\n y={yTicks.filter(d => d !== 0).map(d => y(d))}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n styles={{\r\n gridLines: styles?.yAxis?.gridLines,\r\n labels: styles?.yAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.yAxis?.gridLines,\r\n labels: classNames?.yAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n labelPos='vertical'\r\n precision={precision}\r\n />\r\n <Axis\r\n y1={y(minParam < 0 ? 0 : minParam)}\r\n y2={y(minParam < 0 ? 0 : minParam)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n label={numberFormattingFunction(\r\n minParam < 0 ? 0 : minParam,\r\n 'NA',\r\n precision,\r\n prefix,\r\n suffix,\r\n )}\r\n labelPos={{\r\n x: 0 - leftMargin,\r\n y: y(minParam < 0 ? 0 : minParam),\r\n dx: 0,\r\n dy: maxParam < 0 ? '1em' : -5,\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{\r\n axis: styles?.xAxis?.axis,\r\n label: styles?.yAxis?.labels,\r\n }}\r\n />\r\n <AxisTitle\r\n x={0 - leftMargin + 15}\r\n y={graphHeight / 2}\r\n style={styles?.yAxis?.title}\r\n className={classNames?.yAxis?.title}\r\n text={yAxisTitle}\r\n rotate90\r\n />\r\n </g>\r\n <g>\r\n {xTicks.map((d, i) => (\r\n <g key={i}>\r\n <text\r\n y={graphHeight}\r\n x={x(d)}\r\n style={{ textAnchor: 'middle' }}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs'\r\n dy={15}\r\n >\r\n {format(d, dateFormat)}\r\n </text>\r\n </g>\r\n ))}\r\n </g>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <motion.path\r\n style={{\r\n fill: intervalAreaColor,\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: { opacity: 0, d: areaShape(dataFormatted) || '' },\r\n whileInView: {\r\n opacity: intervalAreaOpacity,\r\n d: areaShape(dataFormatted) || '',\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n {intervalLineStrokeWidth ? (\r\n <>\r\n <motion.path\r\n style={{\r\n stroke: intervalLineColors[0],\r\n fill: 'none',\r\n strokeWidth: intervalLineStrokeWidth,\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n pathLength: 0,\r\n d: lineShapeMin(dataFormatted) || '',\r\n opacity: 1,\r\n },\r\n whileInView: {\r\n pathLength: 1,\r\n d: lineShapeMin(dataFormatted) || '',\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n <motion.path\r\n style={{\r\n stroke: intervalLineColors[1],\r\n fill: 'none',\r\n strokeWidth: intervalLineStrokeWidth,\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n pathLength: 0,\r\n d: lineShapeMax(dataFormatted) || '',\r\n opacity: 1,\r\n },\r\n whileInView: {\r\n pathLength: 1,\r\n d: lineShapeMax(dataFormatted) || '',\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n </>\r\n ) : null}\r\n <motion.path\r\n style={{\r\n stroke: lineColor,\r\n fill: 'none',\r\n strokeWidth,\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n pathLength: 0,\r\n d: lineShape(dataFormatted) || '',\r\n opacity: 1,\r\n },\r\n whileInView: {\r\n pathLength: 1,\r\n d: lineShape(dataFormatted) || '',\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n {mouseOverData ? (\r\n <line\r\n y1={0}\r\n y2={graphHeight}\r\n x1={x(mouseOverData.date)}\r\n x2={x(mouseOverData.date)}\r\n className={cn(\r\n 'undp-tick-line stroke-primary-gray-700 dark:stroke-primary-gray-100',\r\n classNames?.mouseOverLine,\r\n )}\r\n style={styles?.mouseOverLine}\r\n />\r\n ) : null}\r\n <g>\r\n {dataFormatted.map((d, i) => (\r\n <motion.g key={i}>\r\n {!checkIfNullOrUndefined(d.y) ? (\r\n <>\r\n {showDots ? (\r\n <motion.circle\r\n r={\r\n graphWidth / dataFormatted.length < 5\r\n ? 0\r\n : graphWidth / dataFormatted.length < 20\r\n ? 2\r\n : 4\r\n }\r\n style={{ fill: lineColor }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: { opacity: 0, cx: x(d.date), cy: y(d.y) },\r\n whileInView: {\r\n opacity: 1,\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n cx: x(d.date),\r\n cy: y(d.y),\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n ) : null}\r\n {showIntervalDots ? (\r\n <>\r\n <motion.circle\r\n r={\r\n graphWidth / dataFormatted.length < 5\r\n ? 0\r\n : graphWidth / dataFormatted.length < 20\r\n ? 2\r\n : 4\r\n }\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n fill: intervalLineColors[0],\r\n cx: x(d.date),\r\n cy: y(d.yMin),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n cx: x(d.date),\r\n cy: y(d.yMin),\r\n fill: intervalLineColors[0],\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n <motion.circle\r\n r={\r\n graphWidth / dataFormatted.length < 5\r\n ? 0\r\n : graphWidth / dataFormatted.length < 20\r\n ? 2\r\n : 4\r\n }\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n fill: intervalLineColors[1],\r\n cx: x(d.date),\r\n cy: y(d.yMax),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n fill: intervalLineColors[1],\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n cx: x(d.date),\r\n cy: y(d.yMax),\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n </>\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n dy={-8}\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-xs font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: { opacity: 0, fill: lineColor, x: x(d.date), y: y(d.y) },\r\n whileInView: {\r\n opacity: 1,\r\n x: x(d.date),\r\n fill: lineColor,\r\n y: y(d.y),\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(d.y, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n {showIntervalValues ? (\r\n <>\r\n <motion.text\r\n dy='1em'\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn('text-xs font-bold', classNames?.graphObjectValues)}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n fill: intervalLineColors[0],\r\n x: x(d.date),\r\n y: y(d.yMin),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: x(d.date),\r\n y: y(d.yMin),\r\n fill: intervalLineColors[0],\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(d.yMin, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n <motion.text\r\n dy={-8}\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn('text-xs font-bold', classNames?.graphObjectValues)}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n fill: intervalLineColors[1],\r\n x: x(d.date),\r\n y: y(d.yMax),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n fill: intervalLineColors[1],\r\n x: x(d.date),\r\n y: y(d.yMax),\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(d.yMax, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n </>\r\n ) : null}\r\n </>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n </g>\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineY\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n y={y(el.value as number)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n <g>\r\n {annotations.map((d, i) => {\r\n const endPoints = getLineEndPoint(\r\n {\r\n x: d.xCoordinate\r\n ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) + (d.xOffset || 0)\r\n : 0 + (d.xOffset || 0),\r\n y: d.yCoordinate\r\n ? y(d.yCoordinate as number) + (d.yOffset || 0) - 8\r\n : 0 + (d.yOffset || 0) - 8,\r\n },\r\n {\r\n x: d.xCoordinate ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) : 0,\r\n y: d.yCoordinate ? y(d.yCoordinate as number) : 0,\r\n },\r\n checkIfNullOrUndefined(d.connectorRadius) ? 3.5 : (d.connectorRadius as number),\r\n );\r\n const connectorSettings = d.showConnector\r\n ? {\r\n y1: endPoints.y,\r\n x1: endPoints.x,\r\n y2: d.yCoordinate\r\n ? y(d.yCoordinate as number) + (d.yOffset || 0)\r\n : 0 + (d.yOffset || 0),\r\n x2: d.xCoordinate\r\n ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) + (d.xOffset || 0)\r\n : 0 + (d.xOffset || 0),\r\n cy: d.yCoordinate ? y(d.yCoordinate as number) : 0,\r\n cx: d.xCoordinate ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) : 0,\r\n circleRadius: checkIfNullOrUndefined(d.connectorRadius)\r\n ? 3.5\r\n : (d.connectorRadius as number),\r\n strokeWidth: d.showConnector === true ? 2 : Math.min(d.showConnector || 0, 1),\r\n }\r\n : undefined;\r\n const labelSettings = {\r\n y: d.yCoordinate\r\n ? y(d.yCoordinate as number) + (d.yOffset || 0) - 8\r\n : 0 + (d.yOffset || 0) - 8,\r\n x: rtl\r\n ? 0\r\n : d.xCoordinate\r\n ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) + (d.xOffset || 0)\r\n : 0 + (d.xOffset || 0),\r\n width: rtl\r\n ? d.xCoordinate\r\n ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) + (d.xOffset || 0)\r\n : 0 + (d.xOffset || 0)\r\n : graphWidth +\r\n margin.right -\r\n (d.xCoordinate\r\n ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) + (d.xOffset || 0)\r\n : 0 + (d.xOffset || 0)),\r\n maxWidth: d.maxWidth,\r\n fontWeight: d.fontWeight,\r\n align: d.align,\r\n };\r\n return (\r\n <Annotation\r\n key={i}\r\n color={d.color}\r\n connectorsSettings={connectorSettings}\r\n labelSettings={labelSettings}\r\n text={d.text}\r\n classNames={d.classNames}\r\n styles={d.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n );\r\n })}\r\n </g>\r\n <g>\r\n {regressionLine ? (\r\n <RegressionLine\r\n x1={0}\r\n x2={graphWidth}\r\n y1={predict(0)}\r\n y2={predict(graphWidth)}\r\n graphHeight={graphHeight}\r\n graphWidth={graphWidth}\r\n className={classNames?.regLine}\r\n style={styles?.regLine}\r\n color={typeof regressionLine === 'string' ? regressionLine : undefined}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n </g>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n <rect\r\n ref={MouseoverRectRef}\r\n style={{\r\n fill: 'none',\r\n pointerEvents: 'all',\r\n }}\r\n width={graphWidth}\r\n height={graphHeight}\r\n />\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 </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport {\r\n AnnotationSettingsDataType,\r\n CustomHighlightAreaSettingsDataType,\r\n Languages,\r\n LineChartWithConfidenceIntervalDataType,\r\n ReferenceDataType,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n HighlightAreaSettingsDataType,\r\n CurveTypes,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { ColorLegend } from '@/Components/Elements/ColorLegend';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\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: LineChartWithConfidenceIntervalDataType[];\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 /** Colors of the line */\r\n lineColor?: string;\r\n /** Colors of the interval area */\r\n intervalAreaColor?: string;\r\n /** Colors of the top and bottom lines of the interval */\r\n intervalLineColors?: [string, string];\r\n /** Colors for the legend */\r\n colorLegendColors?: string[];\r\n /** Domain of colors for the legend */\r\n colorLegendDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n /** Reference values for comparison */\r\n refValues?: ReferenceDataType[];\r\n /** Maximum value of the date for the chart */\r\n maxDate?: string | number;\r\n /** Minimum value of the date for the chart */\r\n minDate?: string | number;\r\n /** No. of ticks on the x-axis */\r\n noOfXTicks?: number;\r\n /** No. of ticks on the y-axis */\r\n noOfYTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Toggle visibility of values of the interval area */\r\n showIntervalValues?: boolean;\r\n /** Toggle visibility of dots on the line */\r\n showDots?: boolean;\r\n /** Toggle visibility of dots on the line of te interval area */\r\n showIntervalDots?: boolean;\r\n /** Stroke width of the line */\r\n strokeWidth?: number;\r\n /** Stroke width of the lines of the interval area */\r\n intervalLineStrokeWidth?: number;\r\n /** Opacity of the interval area */\r\n intervalAreaOpacity?: number;\r\n /** Toggle the initial animation of the line. If the type is number then it uses the number as the time in seconds for animation. */\r\n animate?: boolean | AnimateDataType;\r\n /** Format of the date in the data object. Available formats can be found [here](https://date-fns.org/docs/format) */\r\n dateFormat?: string;\r\n /** Title for the Y-axis */\r\n yAxisTitle?: string;\r\n /** Annotations on the chart */\r\n annotations?: AnnotationSettingsDataType[];\r\n /** Highlighted area(square) on the chart */\r\n highlightAreaSettings?: HighlightAreaSettingsDataType[];\r\n /** Highlighted area(custom shape) on the chart */\r\n customHighlightAreaSettings?: CustomHighlightAreaSettingsDataType[];\r\n /** Toggles the visibility of the regression line for the data. If the type is string then string is use to define the color of the line. */\r\n regressionLine?: boolean | string;\r\n /** Curve type for the line */\r\n curveType?: CurveTypes;\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 /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_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 LineChartWithConfidenceInterval(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n suffix = '',\r\n sources,\r\n prefix = '',\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n noOfXTicks = 10,\r\n dateFormat = 'yyyy',\r\n showValues = false,\r\n backgroundColor = false,\r\n padding,\r\n lineColor,\r\n leftMargin = 30,\r\n rightMargin = 30,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n tooltip,\r\n refValues = [],\r\n highlightAreaSettings = [],\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n graphID,\r\n minValue,\r\n maxValue,\r\n regressionLine = false,\r\n showIntervalDots = false,\r\n showIntervalValues = false,\r\n intervalLineStrokeWidth = 0,\r\n intervalLineColors = [Colors.light.grays['gray-500'], Colors.light.grays['gray-500']],\r\n intervalAreaColor = Colors.primaryColors['blue-100'],\r\n intervalAreaOpacity = 0.4,\r\n graphDownload = false,\r\n dataDownload = false,\r\n animate = false,\r\n language = 'en',\r\n minHeight = 0,\r\n strokeWidth = 2,\r\n showDots = true,\r\n annotations = [],\r\n customHighlightAreaSettings = [],\r\n theme = 'light',\r\n ariaLabel,\r\n yAxisTitle,\r\n noOfYTicks = 5,\r\n minDate,\r\n maxDate,\r\n colorLegendTitle,\r\n colorLegendColors,\r\n colorLegendDomain,\r\n curveType = 'curve',\r\n styles,\r\n classNames,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n\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 {colorLegendColors && colorLegendDomain ? (\r\n <ColorLegend\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={colorLegendColors}\r\n colorDomain={colorLegendDomain}\r\n showNAColor={false}\r\n className={classNames?.colorLegend}\r\n />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {svgWidth && svgHeight ? (\r\n <Graph\r\n data={data}\r\n lineColor={lineColor || Colors.primaryColors['blue-600']}\r\n width={svgWidth}\r\n height={svgHeight}\r\n suffix={suffix}\r\n prefix={prefix}\r\n dateFormat={dateFormat}\r\n showValues={showValues}\r\n noOfXTicks={noOfXTicks}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n highlightAreaSettings={highlightAreaSettings}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n minValue={minValue}\r\n maxValue={maxValue}\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 rtl={language === 'he' || language === 'ar'}\r\n strokeWidth={strokeWidth}\r\n showDots={showDots}\r\n annotations={annotations}\r\n customHighlightAreaSettings={customHighlightAreaSettings}\r\n regressionLine={regressionLine}\r\n showIntervalDots={showIntervalDots}\r\n showIntervalValues={showIntervalValues}\r\n intervalLineStrokeWidth={intervalLineStrokeWidth}\r\n intervalLineColors={intervalLineColors}\r\n intervalAreaColor={intervalAreaColor}\r\n intervalAreaOpacity={intervalAreaOpacity}\r\n yAxisTitle={yAxisTitle}\r\n noOfYTicks={noOfYTicks}\r\n minDate={minDate}\r\n maxDate={maxDate}\r\n curveType={curveType}\r\n styles={styles}\r\n classNames={classNames}\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":["Graph","props","$","_c","data","width","height","lineColor","suffix","prefix","dateFormat","highlightAreaSettings","showValues","noOfXTicks","rightMargin","leftMargin","topMargin","bottomMargin","tooltip","onSeriesMouseOver","refValues","minValue","maxValue","animate","rtl","strokeWidth","showDots","annotations","customHighlightAreaSettings","regressionLine","showIntervalDots","showIntervalValues","intervalLineStrokeWidth","intervalLineColors","intervalAreaColor","intervalAreaOpacity","yAxisTitle","noOfYTicks","minDate","maxDate","curveType","styles","classNames","precision","customLayers","svgRef","useRef","t0","amount","once","isInView","useInView","hasAnimatedOnce","setHasAnimatedOnce","useState","t1","t2","duration","timeout","setTimeout","clearTimeout","useEffect","curve","curveLinear","curveStep","curveStepAfter","curveStepBefore","curveMonotoneX","mouseOverData","setMouseOverData","undefined","eventX","setEventX","eventY","setEventY","t3","t4","top","bottom","left","right","margin","MouseoverRectRef","t5","d_0","date","parse","d","Date","y","yMin","checkIfNullOrUndefined","yMax","dataFormatted","orderBy","filter","_temp","map","t6","t7","d_1","coordinates","highlightAreaSettingsFormatted","t8","d_2","el","j","customHighlightAreaSettingsFormatted","graphWidth","graphHeight","minYear","maxYear","length","minParam","Math","min","_temp2","_temp3","_temp4","maxParam","max","_temp5","_temp6","x","scaleTime","domain","range","scaleLinear","nice","lineShape","line","d_8","d_9","lineShapeMin","d_10","d_11","lineShapeMax","d_12","d_13","areaShape","area","d_14","y0","d_15","y1","d_16","yTicks","ticks","xTicks","mousemove","event","selectedData","bisectCenter","_temp7","invert","pointer","clientY","clientX","mouseout","select","current","on","regressionLineParam","linearRegression","_temp8","d_19","predict","linearRegressionLine","t9","jsx","HighlightArea","t10","yAxis","gridLines","t11","labels","t12","t13","t14","t15","t16","t17","t18","t19","t20","t21","numberFormattingFunction","t22","t23","t24","t25","dx","dy","t26","xAxis","axis","t27","t28","label","t29","t30","t31","t32","Axis","t33","t34","t35","title","t36","t37","AxisTitle","t38","_temp1","_temp10","t39","fill","t40","opacity","transition","t41","stroke","t42","t43","d_26","i_0","motion","jsxs","Fragment","initial","cx","cy","whileInView","delay","textAnchor","graphObjectValues","cn","i","t44","t45","d_27","i_2","endPoints","getLineEndPoint","xCoordinate","xOffset","yCoordinate","yOffset","connectorRadius","connectorSettings","showConnector","x1","y2","x2","circleRadius","labelSettings","maxWidth","fontWeight","align","Annotation","color","text","t46","t47","RegressionLine","regLine","t48","t49","_temp11","_temp12","t50","Symbol","for","pointerEvents","t51","t52","Tooltip","CustomArea","YTicksAndGridLines","_temp9","_temp0","d_22","d_23","format","pathLength","mouseOverLine","el_0","i_1","RefLineY","value","d_29","layer","d_28","position","d_25","d_24","d_21","d_20","d_18","d_17","d_6","d_7","d_3","d_4","d_5","LineChartWithConfidenceInterval","graphTitle","sources","graphDescription","footNote","backgroundColor","padding","relativeHeight","graphID","graphDownload","dataDownload","language","minHeight","theme","ariaLabel","colorLegendTitle","colorLegendColors","colorLegendDomain","Colors","light","grays","primaryColors","svgWidth","setSvgWidth","svgHeight","setSvgHeight","graphDiv","graphParentDiv","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","observe","disconnect","graphContainer","description","GraphHeader","EmptyState","ColorLegend","colorLegend","GraphArea","footnote","source","GraphFooter","GraphContainer"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"LineChartWithConfidenceInterval.js","sources":["../src/Components/Graphs/LineCharts/LineChartWithConfidenceInterval/Graph.tsx","../src/Components/Graphs/LineCharts/LineChartWithConfidenceInterval/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\r\nimport {\r\n line,\r\n curveMonotoneX,\r\n area,\r\n curveLinear,\r\n curveStep,\r\n curveStepAfter,\r\n curveStepBefore,\r\n} from 'd3-shape';\r\nimport { scaleLinear, scaleTime } from 'd3-scale';\r\nimport { format } from 'date-fns/format';\r\nimport { parse } from 'date-fns/parse';\r\nimport { bisectCenter } from 'd3-array';\r\nimport { pointer, select } from 'd3-selection';\r\nimport { linearRegression, linearRegressionLine } from 'simple-statistics';\r\nimport { cn } from '@undp/design-system-react/cn';\r\nimport { motion, useInView } from 'motion/react';\r\nimport orderBy from 'lodash.orderby';\r\n\r\nimport {\r\n AnimateDataType,\r\n AnnotationSettingsDataType,\r\n ClassNameObject,\r\n CurveTypes,\r\n CustomHighlightAreaSettingsDataType,\r\n CustomLayerDataType,\r\n HighlightAreaSettingsDataType,\r\n LineChartWithConfidenceIntervalDataType,\r\n ReferenceDataType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { checkIfNullOrUndefined } from '@/Utils/checkIfNullOrUndefined';\r\nimport { getLineEndPoint } from '@/Utils/getLineEndPoint';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { RefLineY } from '@/Components/Elements/ReferenceLine';\r\nimport { RegressionLine } from '@/Components/Elements/RegressionLine';\r\nimport { Annotation } from '@/Components/Elements/Annotations';\r\nimport { YTicksAndGridLines } from '@/Components/Elements/Axes/YTicksAndGridLines';\r\nimport { CustomArea } from '@/Components/Elements/HighlightArea/customArea';\r\nimport { HighlightArea } from '@/Components/Elements/HighlightArea';\r\n\r\ninterface Props {\r\n data: LineChartWithConfidenceIntervalDataType[];\r\n lineColor: string;\r\n width: number;\r\n height: number;\r\n suffix: string;\r\n prefix: string;\r\n dateFormat: string;\r\n showValues?: boolean;\r\n noOfXTicks: number;\r\n rightMargin: number;\r\n leftMargin: number;\r\n topMargin: number;\r\n bottomMargin: number;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n refValues: ReferenceDataType[];\r\n highlightAreaSettings: HighlightAreaSettingsDataType[];\r\n maxValue?: number;\r\n minValue?: number;\r\n animate: AnimateDataType;\r\n rtl: boolean;\r\n strokeWidth: number;\r\n showDots: boolean;\r\n annotations: AnnotationSettingsDataType[];\r\n customHighlightAreaSettings: CustomHighlightAreaSettingsDataType[];\r\n regressionLine: boolean | string;\r\n showIntervalDots: boolean;\r\n showIntervalValues: boolean;\r\n intervalLineStrokeWidth: number;\r\n intervalLineColors: [string, string];\r\n intervalAreaColor: string;\r\n intervalAreaOpacity: number;\r\n yAxisTitle?: string;\r\n noOfYTicks: number;\r\n minDate?: string | number;\r\n maxDate?: string | number;\r\n curveType: CurveTypes;\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n precision: number;\r\n customLayers: CustomLayerDataType[];\r\n}\r\ninterface FormattedDataType {\r\n y: number;\r\n date: Date;\r\n yMin: number;\r\n yMax: number;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n data,\r\n width,\r\n height,\r\n lineColor,\r\n suffix,\r\n prefix,\r\n dateFormat,\r\n highlightAreaSettings,\r\n showValues,\r\n noOfXTicks,\r\n rightMargin,\r\n leftMargin,\r\n topMargin,\r\n bottomMargin,\r\n tooltip,\r\n onSeriesMouseOver,\r\n refValues,\r\n minValue,\r\n maxValue,\r\n animate,\r\n rtl,\r\n strokeWidth,\r\n showDots,\r\n annotations,\r\n customHighlightAreaSettings,\r\n regressionLine,\r\n showIntervalDots,\r\n showIntervalValues,\r\n intervalLineStrokeWidth,\r\n intervalLineColors,\r\n intervalAreaColor,\r\n intervalAreaOpacity,\r\n yAxisTitle,\r\n noOfYTicks,\r\n minDate,\r\n maxDate,\r\n curveType,\r\n styles,\r\n classNames,\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 [hasAnimatedOnce, setHasAnimatedOnce] = useState(false);\r\n\r\n useEffect(() => {\r\n if (isInView && !hasAnimatedOnce) {\r\n const timeout = setTimeout(\r\n () => {\r\n setHasAnimatedOnce(true);\r\n },\r\n (animate.duration + 0.5) * 1000,\r\n );\r\n return () => clearTimeout(timeout);\r\n }\r\n }, [isInView, hasAnimatedOnce, animate.duration]);\r\n const curve =\r\n curveType === 'linear'\r\n ? curveLinear\r\n : curveType === 'step'\r\n ? curveStep\r\n : curveType === 'stepAfter'\r\n ? curveStepAfter\r\n : curveType === 'stepBefore'\r\n ? curveStepBefore\r\n : curveMonotoneX;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n const margin = {\r\n top: topMargin,\r\n bottom: bottomMargin,\r\n left: yAxisTitle ? leftMargin + 30 : leftMargin,\r\n right: rightMargin,\r\n };\r\n const MouseoverRectRef = useRef(null);\r\n const dataFormatted: FormattedDataType[] = orderBy(\r\n data\r\n .filter(d => !checkIfNullOrUndefined(d.y))\r\n .map(d => ({\r\n date: parse(`${d.date}`, dateFormat, new Date()),\r\n y: d.y as number,\r\n yMin: checkIfNullOrUndefined(d.yMin) ? (d.y as number) : (d.yMin as number),\r\n yMax: checkIfNullOrUndefined(d.yMax) ? (d.y as number) : (d.yMax as number),\r\n data: d.data,\r\n })),\r\n ['date'],\r\n ['asc'],\r\n );\r\n const highlightAreaSettingsFormatted = highlightAreaSettings.map(d => ({\r\n ...d,\r\n coordinates: [\r\n d.coordinates[0] === null ? null : parse(`${d.coordinates[0]}`, dateFormat, new Date()),\r\n d.coordinates[1] === null ? null : parse(`${d.coordinates[1]}`, dateFormat, new Date()),\r\n ],\r\n }));\r\n const customHighlightAreaSettingsFormatted = customHighlightAreaSettings.map(d => ({\r\n ...d,\r\n coordinates: d.coordinates.map((el, j) =>\r\n j % 2 === 0 ? parse(`${el}`, dateFormat, new Date()) : (el as number),\r\n ),\r\n }));\r\n const graphWidth = width - margin.left - margin.right;\r\n const graphHeight = height - margin.top - margin.bottom;\r\n const minYear = minDate ? parse(`${minDate}`, dateFormat, new Date()) : dataFormatted[0].date;\r\n const maxYear = maxDate\r\n ? parse(`${maxDate}`, dateFormat, new Date())\r\n : dataFormatted[dataFormatted.length - 1].date;\r\n const minParam: number = !checkIfNullOrUndefined(minValue)\r\n ? (minValue as number)\r\n : Math.min(...dataFormatted.map(d => Math.min(d.y, d.yMax, d.yMin)))\r\n ? Math.min(...dataFormatted.map(d => Math.min(d.y, d.yMax, d.yMin))) > 0\r\n ? 0\r\n : Math.min(...dataFormatted.map(d => Math.min(d.y, d.yMax, d.yMin)))\r\n : 0;\r\n const maxParam: number = Math.max(...dataFormatted.map(d => Math.max(d.y, d.yMax, d.yMin)))\r\n ? Math.max(...dataFormatted.map(d => Math.max(d.y, d.yMax, d.yMin)))\r\n : 0;\r\n const x = scaleTime().domain([minYear, maxYear]).range([0, graphWidth]);\r\n const y = scaleLinear()\r\n .domain([\r\n minParam,\r\n checkIfNullOrUndefined(maxValue) ? (maxParam > 0 ? maxParam : 0) : (maxValue as number),\r\n ])\r\n .range([graphHeight, 0])\r\n .nice();\r\n\r\n const lineShape = line<FormattedDataType>()\r\n .x(d => x(d.date))\r\n .y(d => y(d.y))\r\n .curve(curve);\r\n\r\n const lineShapeMin = line<FormattedDataType>()\r\n .x(d => x(d.date))\r\n .y(d => y(d.yMin))\r\n .curve(curve);\r\n\r\n const lineShapeMax = line<FormattedDataType>()\r\n .x(d => x(d.date))\r\n .y(d => y(d.yMax))\r\n .curve(curve);\r\n\r\n const areaShape = area<FormattedDataType>()\r\n .x(d => x(d.date))\r\n .y0(d => y(d.yMin))\r\n .y1(d => y(d.yMax))\r\n .curve(curve);\r\n\r\n const yTicks = y.ticks(noOfYTicks);\r\n\r\n const xTicks = x.ticks(noOfXTicks);\r\n\r\n useEffect(() => {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const mousemove = (event: any) => {\r\n const selectedData =\r\n dataFormatted[\r\n bisectCenter(\r\n dataFormatted.map(d => d.date),\r\n x.invert(pointer(event)[0]),\r\n 0,\r\n )\r\n ];\r\n setMouseOverData(selectedData || dataFormatted[dataFormatted.length - 1]);\r\n onSeriesMouseOver?.(selectedData || dataFormatted[dataFormatted.length - 1]);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n };\r\n const mouseout = () => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n };\r\n select(MouseoverRectRef.current).on('mousemove', mousemove).on('mouseout', mouseout);\r\n }, [x, dataFormatted, onSeriesMouseOver]);\r\n const regressionLineParam = linearRegression(\r\n dataFormatted\r\n .filter(d => !checkIfNullOrUndefined(d.date) && !checkIfNullOrUndefined(d.y))\r\n .map(d => [x(d.date), y(d.y as number)]),\r\n );\r\n const predict = linearRegressionLine(regressionLineParam);\r\n return (\r\n <>\r\n <motion.svg\r\n width={`${width}px`}\r\n height={`${height}px`}\r\n viewBox={`0 0 ${width} ${height}`}\r\n direction='ltr'\r\n ref={svgRef}\r\n >\r\n <g transform={`translate(${margin.left},${margin.top})`}>\r\n <HighlightArea\r\n areaSettings={highlightAreaSettingsFormatted}\r\n width={graphWidth}\r\n height={graphHeight}\r\n scale={x}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n <CustomArea\r\n areaSettings={customHighlightAreaSettingsFormatted}\r\n scaleX={x}\r\n scaleY={y}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n <g>\r\n <YTicksAndGridLines\r\n values={yTicks.filter(d => d !== 0)}\r\n y={yTicks.filter(d => d !== 0).map(d => y(d))}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n styles={{\r\n gridLines: styles?.yAxis?.gridLines,\r\n labels: styles?.yAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: classNames?.yAxis?.gridLines,\r\n labels: classNames?.yAxis?.labels,\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='secondary'\r\n showGridLines\r\n labelPos='vertical'\r\n precision={precision}\r\n />\r\n <Axis\r\n y1={y(minParam < 0 ? 0 : minParam)}\r\n y2={y(minParam < 0 ? 0 : minParam)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n label={numberFormattingFunction(\r\n minParam < 0 ? 0 : minParam,\r\n 'NA',\r\n precision,\r\n prefix,\r\n suffix,\r\n )}\r\n labelPos={{\r\n x: 0 - leftMargin,\r\n y: y(minParam < 0 ? 0 : minParam),\r\n dx: 0,\r\n dy: maxParam < 0 ? '1em' : -5,\r\n }}\r\n classNames={{\r\n axis: classNames?.xAxis?.axis,\r\n label: classNames?.yAxis?.labels,\r\n }}\r\n styles={{\r\n axis: styles?.xAxis?.axis,\r\n label: styles?.yAxis?.labels,\r\n }}\r\n />\r\n <AxisTitle\r\n x={0 - leftMargin + 15}\r\n y={graphHeight / 2}\r\n style={styles?.yAxis?.title}\r\n className={classNames?.yAxis?.title}\r\n text={yAxisTitle}\r\n rotate90\r\n />\r\n </g>\r\n <g>\r\n {xTicks.map((d, i) => (\r\n <g key={i}>\r\n <text\r\n y={graphHeight}\r\n x={x(d)}\r\n style={{ textAnchor: 'middle' }}\r\n className='fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs'\r\n dy={15}\r\n >\r\n {format(d, dateFormat)}\r\n </text>\r\n </g>\r\n ))}\r\n </g>\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <motion.path\r\n style={{\r\n fill: intervalAreaColor,\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: { opacity: 0, d: areaShape(dataFormatted) || '' },\r\n whileInView: {\r\n opacity: intervalAreaOpacity,\r\n d: areaShape(dataFormatted) || '',\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n {intervalLineStrokeWidth ? (\r\n <>\r\n <motion.path\r\n style={{\r\n stroke: intervalLineColors[0],\r\n fill: 'none',\r\n strokeWidth: intervalLineStrokeWidth,\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n pathLength: 0,\r\n d: lineShapeMin(dataFormatted) || '',\r\n opacity: 1,\r\n },\r\n whileInView: {\r\n pathLength: 1,\r\n d: lineShapeMin(dataFormatted) || '',\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n <motion.path\r\n style={{\r\n stroke: intervalLineColors[1],\r\n fill: 'none',\r\n strokeWidth: intervalLineStrokeWidth,\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n pathLength: 0,\r\n d: lineShapeMax(dataFormatted) || '',\r\n opacity: 1,\r\n },\r\n whileInView: {\r\n pathLength: 1,\r\n d: lineShapeMax(dataFormatted) || '',\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n </>\r\n ) : null}\r\n <motion.path\r\n style={{\r\n stroke: lineColor,\r\n fill: 'none',\r\n strokeWidth,\r\n }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n pathLength: 0,\r\n d: lineShape(dataFormatted) || '',\r\n opacity: 1,\r\n },\r\n whileInView: {\r\n pathLength: 1,\r\n d: lineShape(dataFormatted) || '',\r\n opacity: 1,\r\n transition: { duration: animate.duration },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n {mouseOverData ? (\r\n <line\r\n y1={0}\r\n y2={graphHeight}\r\n x1={x(mouseOverData.date)}\r\n x2={x(mouseOverData.date)}\r\n className={cn(\r\n 'undp-tick-line stroke-primary-gray-700 dark:stroke-primary-gray-100',\r\n classNames?.mouseOverLine,\r\n )}\r\n style={styles?.mouseOverLine}\r\n />\r\n ) : null}\r\n <g>\r\n {dataFormatted.map((d, i) => (\r\n <motion.g key={i}>\r\n {!checkIfNullOrUndefined(d.y) ? (\r\n <>\r\n {showDots ? (\r\n <motion.circle\r\n r={\r\n graphWidth / dataFormatted.length < 5\r\n ? 0\r\n : graphWidth / dataFormatted.length < 20\r\n ? 2\r\n : 4\r\n }\r\n style={{ fill: lineColor }}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: { opacity: 0, cx: x(d.date), cy: y(d.y) },\r\n whileInView: {\r\n opacity: 1,\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n cx: x(d.date),\r\n cy: y(d.y),\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n ) : null}\r\n {showIntervalDots ? (\r\n <>\r\n <motion.circle\r\n r={\r\n graphWidth / dataFormatted.length < 5\r\n ? 0\r\n : graphWidth / dataFormatted.length < 20\r\n ? 2\r\n : 4\r\n }\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n fill: intervalLineColors[0],\r\n cx: x(d.date),\r\n cy: y(d.yMin),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n cx: x(d.date),\r\n cy: y(d.yMin),\r\n fill: intervalLineColors[0],\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n <motion.circle\r\n r={\r\n graphWidth / dataFormatted.length < 5\r\n ? 0\r\n : graphWidth / dataFormatted.length < 20\r\n ? 2\r\n : 4\r\n }\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n fill: intervalLineColors[1],\r\n cx: x(d.date),\r\n cy: y(d.yMax),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n fill: intervalLineColors[1],\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n cx: x(d.date),\r\n cy: y(d.yMax),\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n />\r\n </>\r\n ) : null}\r\n {showValues ? (\r\n <motion.text\r\n dy={-8}\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn(\r\n 'graph-value text-xs font-bold',\r\n classNames?.graphObjectValues,\r\n )}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: { opacity: 0, fill: lineColor, x: x(d.date), y: y(d.y) },\r\n whileInView: {\r\n opacity: 1,\r\n x: x(d.date),\r\n fill: lineColor,\r\n y: y(d.y),\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(d.y, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n ) : null}\r\n {showIntervalValues ? (\r\n <>\r\n <motion.text\r\n dy='1em'\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn('text-xs font-bold', classNames?.graphObjectValues)}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n fill: intervalLineColors[0],\r\n x: x(d.date),\r\n y: y(d.yMin),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n x: x(d.date),\r\n y: y(d.yMin),\r\n fill: intervalLineColors[0],\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(d.yMin, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n <motion.text\r\n dy={-8}\r\n style={{\r\n textAnchor: 'middle',\r\n ...(styles?.graphObjectValues || {}),\r\n }}\r\n className={cn('text-xs font-bold', classNames?.graphObjectValues)}\r\n exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n fill: intervalLineColors[1],\r\n x: x(d.date),\r\n y: y(d.yMax),\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n fill: intervalLineColors[1],\r\n x: x(d.date),\r\n y: y(d.yMax),\r\n transition: {\r\n duration: hasAnimatedOnce ? animate.duration : 0.5,\r\n delay: hasAnimatedOnce ? 0 : animate.duration,\r\n },\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\r\n >\r\n {numberFormattingFunction(d.yMax, 'NA', precision, prefix, suffix)}\r\n </motion.text>\r\n </>\r\n ) : null}\r\n </>\r\n ) : null}\r\n </motion.g>\r\n ))}\r\n </g>\r\n {refValues ? (\r\n <>\r\n {refValues.map((el, i) => (\r\n <RefLineY\r\n key={i}\r\n text={el.text}\r\n color={el.color}\r\n y={y(el.value as number)}\r\n x1={0 - leftMargin}\r\n x2={graphWidth + margin.right}\r\n classNames={el.classNames}\r\n styles={el.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ))}\r\n </>\r\n ) : null}\r\n <g>\r\n {annotations.map((d, i) => {\r\n const endPoints = getLineEndPoint(\r\n {\r\n x: d.xCoordinate\r\n ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) + (d.xOffset || 0)\r\n : 0 + (d.xOffset || 0),\r\n y: d.yCoordinate\r\n ? y(d.yCoordinate as number) + (d.yOffset || 0) - 8\r\n : 0 + (d.yOffset || 0) - 8,\r\n },\r\n {\r\n x: d.xCoordinate ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) : 0,\r\n y: d.yCoordinate ? y(d.yCoordinate as number) : 0,\r\n },\r\n checkIfNullOrUndefined(d.connectorRadius) ? 3.5 : (d.connectorRadius as number),\r\n );\r\n const connectorSettings = d.showConnector\r\n ? {\r\n y1: endPoints.y,\r\n x1: endPoints.x,\r\n y2: d.yCoordinate\r\n ? y(d.yCoordinate as number) + (d.yOffset || 0)\r\n : 0 + (d.yOffset || 0),\r\n x2: d.xCoordinate\r\n ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) + (d.xOffset || 0)\r\n : 0 + (d.xOffset || 0),\r\n cy: d.yCoordinate ? y(d.yCoordinate as number) : 0,\r\n cx: d.xCoordinate ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) : 0,\r\n circleRadius: checkIfNullOrUndefined(d.connectorRadius)\r\n ? 3.5\r\n : (d.connectorRadius as number),\r\n strokeWidth: d.showConnector === true ? 2 : Math.min(d.showConnector || 0, 1),\r\n }\r\n : undefined;\r\n const labelSettings = {\r\n y: d.yCoordinate\r\n ? y(d.yCoordinate as number) + (d.yOffset || 0) - 8\r\n : 0 + (d.yOffset || 0) - 8,\r\n x: rtl\r\n ? 0\r\n : d.xCoordinate\r\n ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) + (d.xOffset || 0)\r\n : 0 + (d.xOffset || 0),\r\n width: rtl\r\n ? d.xCoordinate\r\n ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) + (d.xOffset || 0)\r\n : 0 + (d.xOffset || 0)\r\n : graphWidth +\r\n margin.right -\r\n (d.xCoordinate\r\n ? x(parse(`${d.xCoordinate}`, dateFormat, new Date())) + (d.xOffset || 0)\r\n : 0 + (d.xOffset || 0)),\r\n maxWidth: d.maxWidth,\r\n fontWeight: d.fontWeight,\r\n align: d.align,\r\n };\r\n return (\r\n <Annotation\r\n key={i}\r\n color={d.color}\r\n connectorsSettings={connectorSettings}\r\n labelSettings={labelSettings}\r\n text={d.text}\r\n classNames={d.classNames}\r\n styles={d.styles}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n );\r\n })}\r\n </g>\r\n <g>\r\n {regressionLine ? (\r\n <RegressionLine\r\n x1={0}\r\n x2={graphWidth}\r\n y1={predict(0)}\r\n y2={predict(graphWidth)}\r\n graphHeight={graphHeight}\r\n graphWidth={graphWidth}\r\n className={classNames?.regLine}\r\n style={styles?.regLine}\r\n color={typeof regressionLine === 'string' ? regressionLine : undefined}\r\n animate={animate}\r\n isInView={isInView}\r\n />\r\n ) : null}\r\n </g>\r\n {customLayers.filter(d => d.position === 'after').map(d => d.layer)}\r\n <rect\r\n ref={MouseoverRectRef}\r\n style={{\r\n fill: 'none',\r\n pointerEvents: 'all',\r\n }}\r\n width={graphWidth}\r\n height={graphHeight}\r\n />\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 </>\r\n );\r\n}\r\n","import { useState, useRef, useEffect } from 'react';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport {\r\n AnnotationSettingsDataType,\r\n CustomHighlightAreaSettingsDataType,\r\n Languages,\r\n LineChartWithConfidenceIntervalDataType,\r\n ReferenceDataType,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n HighlightAreaSettingsDataType,\r\n CurveTypes,\r\n CustomLayerDataType,\r\n AnimateDataType,\r\n} from '@/Types';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { ColorLegend } from '@/Components/Elements/ColorLegend';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\nimport { getNoOfTicks } from '@/Utils/getNoOfTicks';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: LineChartWithConfidenceIntervalDataType[];\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 /** Colors of the line */\r\n lineColor?: string;\r\n /** Colors of the interval area */\r\n intervalAreaColor?: string;\r\n /** Colors of the top and bottom lines of the interval */\r\n intervalLineColors?: [string, string];\r\n /** Colors for the legend */\r\n colorLegendColors?: string[];\r\n /** Domain of colors for the legend */\r\n colorLegendDomain?: string[];\r\n /** Title for the color legend */\r\n colorLegendTitle?: string;\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Left margin of the graph */\r\n leftMargin?: number;\r\n /** Right margin of the graph */\r\n rightMargin?: number;\r\n /** Top margin of the graph */\r\n topMargin?: number;\r\n /** Bottom margin of the graph */\r\n bottomMargin?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n /** Maximum value for the chart */\r\n maxValue?: number;\r\n /** Minimum value for the chart */\r\n minValue?: number;\r\n /** Reference values for comparison */\r\n refValues?: ReferenceDataType[];\r\n /** Maximum value of the date for the chart */\r\n maxDate?: string | number;\r\n /** Minimum value of the date for the chart */\r\n minDate?: string | number;\r\n /** No. of ticks on the x-axis */\r\n noOfXTicks?: number;\r\n /** No. of ticks on the y-axis */\r\n noOfYTicks?: number;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of values */\r\n showValues?: boolean;\r\n /** Toggle visibility of values of the interval area */\r\n showIntervalValues?: boolean;\r\n /** Toggle visibility of dots on the line */\r\n showDots?: boolean;\r\n /** Toggle visibility of dots on the line of te interval area */\r\n showIntervalDots?: boolean;\r\n /** Stroke width of the line */\r\n strokeWidth?: number;\r\n /** Stroke width of the lines of the interval area */\r\n intervalLineStrokeWidth?: number;\r\n /** Opacity of the interval area */\r\n intervalAreaOpacity?: number;\r\n /** Toggle the initial animation of the line. If the type is number then it uses the number as the time in seconds for animation. */\r\n animate?: boolean | AnimateDataType;\r\n /** Format of the date in the data object. Available formats can be found [here](https://date-fns.org/docs/format) */\r\n dateFormat?: string;\r\n /** Title for the Y-axis */\r\n yAxisTitle?: string;\r\n /** Annotations on the chart */\r\n annotations?: AnnotationSettingsDataType[];\r\n /** Highlighted area(square) on the chart */\r\n highlightAreaSettings?: HighlightAreaSettingsDataType[];\r\n /** Highlighted area(custom shape) on the chart */\r\n customHighlightAreaSettings?: CustomHighlightAreaSettingsDataType[];\r\n /** Toggles the visibility of the regression line for the data. If the type is string then string is use to define the color of the line. */\r\n regressionLine?: boolean | string;\r\n /** Curve type for the line */\r\n curveType?: CurveTypes;\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 /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_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 LineChartWithConfidenceInterval(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n suffix = '',\r\n sources,\r\n prefix = '',\r\n graphDescription,\r\n height,\r\n width,\r\n footNote,\r\n noOfXTicks = 10,\r\n dateFormat = 'yyyy',\r\n showValues = false,\r\n backgroundColor = false,\r\n padding,\r\n lineColor,\r\n leftMargin = 30,\r\n rightMargin = 30,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n tooltip,\r\n refValues = [],\r\n highlightAreaSettings = [],\r\n relativeHeight,\r\n onSeriesMouseOver,\r\n graphID,\r\n minValue,\r\n maxValue,\r\n regressionLine = false,\r\n showIntervalDots = false,\r\n showIntervalValues = false,\r\n intervalLineStrokeWidth = 0,\r\n intervalLineColors = [Colors.light.grays['gray-500'], Colors.light.grays['gray-500']],\r\n intervalAreaColor = Colors.primaryColors['blue-100'],\r\n intervalAreaOpacity = 0.4,\r\n graphDownload = false,\r\n dataDownload = false,\r\n animate = false,\r\n language = 'en',\r\n minHeight = 0,\r\n strokeWidth = 2,\r\n showDots = true,\r\n annotations = [],\r\n customHighlightAreaSettings = [],\r\n theme = 'light',\r\n ariaLabel,\r\n yAxisTitle,\r\n noOfYTicks = 5,\r\n minDate,\r\n maxDate,\r\n colorLegendTitle,\r\n colorLegendColors,\r\n colorLegendDomain,\r\n curveType = 'curve',\r\n styles,\r\n classNames,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\r\n\r\n const [svgWidth, setSvgWidth] = useState(0);\r\n const [svgHeight, setSvgHeight] = useState(0);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setSvgWidth(entries[0].target.clientWidth || 620);\r\n setSvgHeight(entries[0].target.clientHeight || 480);\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, []);\r\n\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 {colorLegendColors && colorLegendDomain ? (\r\n <ColorLegend\r\n width={width}\r\n colorLegendTitle={colorLegendTitle}\r\n colors={colorLegendColors}\r\n colorDomain={colorLegendDomain}\r\n showNAColor={false}\r\n className={classNames?.colorLegend}\r\n />\r\n ) : null}\r\n <GraphArea ref={graphDiv}>\r\n {svgWidth && svgHeight ? (\r\n <Graph\r\n data={data}\r\n lineColor={lineColor || Colors.primaryColors['blue-600']}\r\n width={svgWidth}\r\n height={svgHeight}\r\n suffix={suffix}\r\n prefix={prefix}\r\n dateFormat={dateFormat}\r\n showValues={showValues}\r\n noOfXTicks={noOfXTicks ?? getNoOfTicks(svgWidth)}\r\n leftMargin={leftMargin}\r\n rightMargin={rightMargin}\r\n topMargin={topMargin}\r\n bottomMargin={bottomMargin}\r\n tooltip={tooltip}\r\n highlightAreaSettings={highlightAreaSettings}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n refValues={refValues}\r\n minValue={minValue}\r\n maxValue={maxValue}\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 rtl={language === 'he' || language === 'ar'}\r\n strokeWidth={strokeWidth}\r\n showDots={showDots}\r\n annotations={annotations}\r\n customHighlightAreaSettings={customHighlightAreaSettings}\r\n regressionLine={regressionLine}\r\n showIntervalDots={showIntervalDots}\r\n showIntervalValues={showIntervalValues}\r\n intervalLineStrokeWidth={intervalLineStrokeWidth}\r\n intervalLineColors={intervalLineColors}\r\n intervalAreaColor={intervalAreaColor}\r\n intervalAreaOpacity={intervalAreaOpacity}\r\n yAxisTitle={yAxisTitle}\r\n noOfYTicks={noOfYTicks}\r\n minDate={minDate}\r\n maxDate={maxDate}\r\n curveType={curveType}\r\n styles={styles}\r\n classNames={classNames}\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":["Graph","props","$","_c","data","width","height","lineColor","suffix","prefix","dateFormat","highlightAreaSettings","showValues","noOfXTicks","rightMargin","leftMargin","topMargin","bottomMargin","tooltip","onSeriesMouseOver","refValues","minValue","maxValue","animate","rtl","strokeWidth","showDots","annotations","customHighlightAreaSettings","regressionLine","showIntervalDots","showIntervalValues","intervalLineStrokeWidth","intervalLineColors","intervalAreaColor","intervalAreaOpacity","yAxisTitle","noOfYTicks","minDate","maxDate","curveType","styles","classNames","precision","customLayers","svgRef","useRef","t0","amount","once","isInView","useInView","hasAnimatedOnce","setHasAnimatedOnce","useState","t1","t2","duration","timeout","setTimeout","clearTimeout","useEffect","curve","curveLinear","curveStep","curveStepAfter","curveStepBefore","curveMonotoneX","mouseOverData","setMouseOverData","undefined","eventX","setEventX","eventY","setEventY","t3","t4","top","bottom","left","right","margin","MouseoverRectRef","t5","d_0","date","parse","d","Date","y","yMin","checkIfNullOrUndefined","yMax","dataFormatted","orderBy","filter","_temp","map","t6","t7","d_1","coordinates","highlightAreaSettingsFormatted","t8","d_2","el","j","customHighlightAreaSettingsFormatted","graphWidth","graphHeight","minYear","maxYear","length","minParam","Math","min","_temp2","_temp3","_temp4","maxParam","max","_temp5","_temp6","x","scaleTime","domain","range","scaleLinear","nice","lineShape","line","d_8","d_9","lineShapeMin","d_10","d_11","lineShapeMax","d_12","d_13","areaShape","area","d_14","y0","d_15","y1","d_16","yTicks","ticks","xTicks","mousemove","event","selectedData","bisectCenter","_temp7","invert","pointer","clientY","clientX","mouseout","select","current","on","regressionLineParam","linearRegression","_temp8","d_19","predict","linearRegressionLine","t9","jsx","HighlightArea","t10","yAxis","gridLines","t11","labels","t12","t13","t14","t15","t16","t17","t18","t19","t20","t21","numberFormattingFunction","t22","t23","t24","t25","dx","dy","t26","xAxis","axis","t27","t28","label","t29","t30","t31","t32","Axis","t33","t34","t35","title","t36","t37","AxisTitle","t38","_temp1","_temp10","t39","fill","t40","opacity","transition","t41","stroke","t42","t43","d_26","i_0","motion","jsxs","Fragment","initial","cx","cy","whileInView","delay","textAnchor","graphObjectValues","cn","i","t44","t45","d_27","i_2","endPoints","getLineEndPoint","xCoordinate","xOffset","yCoordinate","yOffset","connectorRadius","connectorSettings","showConnector","x1","y2","x2","circleRadius","labelSettings","maxWidth","fontWeight","align","Annotation","color","text","t46","t47","RegressionLine","regLine","t48","t49","_temp11","_temp12","t50","Symbol","for","pointerEvents","t51","t52","Tooltip","CustomArea","YTicksAndGridLines","_temp9","_temp0","d_22","d_23","format","pathLength","mouseOverLine","el_0","i_1","RefLineY","value","d_29","layer","d_28","position","d_25","d_24","d_21","d_20","d_18","d_17","d_6","d_7","d_3","d_4","d_5","LineChartWithConfidenceInterval","graphTitle","sources","graphDescription","footNote","backgroundColor","padding","relativeHeight","graphID","graphDownload","dataDownload","language","minHeight","theme","ariaLabel","colorLegendTitle","colorLegendColors","colorLegendDomain","Colors","light","grays","primaryColors","svgWidth","setSvgWidth","svgHeight","setSvgHeight","graphDiv","graphParentDiv","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","observe","disconnect","graphContainer","description","GraphHeader","EmptyState","ColorLegend","colorLegend","GraphArea","getNoOfTicks","footnote","source","GraphFooter","GraphContainer"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiGO,SAAAA,GAAAC,GAAA;AAAA,QAAAC,IAAAC,GAAAA,EAAA,GAAA,GACL;AAAA,IAAAC,MAAAA;AAAAA,IAAAC,OAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,uBAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,aAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,cAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAC,mBAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAC,KAAAA;AAAAA,IAAAC,aAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAC,aAAAA;AAAAA,IAAAC,6BAAAA;AAAAA,IAAAC,gBAAAA;AAAAA,IAAAC,kBAAAA;AAAAA,IAAAC,oBAAAA;AAAAA,IAAAC,yBAAAA;AAAAA,IAAAC,oBAAAA;AAAAA,IAAAC,mBAAAA;AAAAA,IAAAC,qBAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,QAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,WAAAA;AAAAA,IAAAC,cAAAA;AAAAA,EAAAA,IA0CI3C,GACJ4C,KAAeC,GAAO,IAAI;AAAE,MAAAC;AAAA,EAAA7C,EAAA,CAAA,MAAAqB,EAAAyB,UAAA9C,EAAA,CAAA,MAAAqB,EAAA0B,QACOF,IAAA;AAAA,IAAAE,MAC3B1B,EAAO0B;AAAAA,IAAKD,QACVzB,EAAOyB;AAAAA,EAAAA,GAChB9C,EAAA,CAAA,IAAAqB,EAAAyB,QAAA9C,EAAA,CAAA,IAAAqB,EAAA0B,MAAA/C,OAAA6C,KAAAA,IAAA7C,EAAA,CAAA;AAHD,QAAAgD,IAAiBC,GAAUN,IAAQE,CAGlC,GACD,CAAAK,GAAAC,EAAA,IAA8CC,GAAS,EAAK;AAAE,MAAAC,IAAAC;AAAA,EAAAtD,EAAA,CAAA,MAAAqB,EAAAkC,YAAAvD,EAAA,CAAA,MAAAkD,KAAAlD,EAAA,CAAA,MAAAgD,KAEpDK,KAAAA,MAAA;AACR,QAAIL,KAAA,CAAaE,GAAe;AAC9B,YAAAM,IAAgBC,WACd,MAAA;AACEN,QAAAA,GAAmB,EAAI;AAAA,MAAC,IAEzB9B,EAAOkC,WAAY,OAAO,GAC7B;AAAE,aACK,MAAMG,aAAaF,CAAO;AAAA,IAAC;AAAA,EACnC,GACAF,IAAA,CAACN,GAAUE,GAAiB7B,EAAOkC,QAAS,GAACvD,EAAA,CAAA,IAAAqB,EAAAkC,UAAAvD,OAAAkD,GAAAlD,OAAAgD,GAAAhD,OAAAqD,IAAArD,OAAAsD,MAAAD,KAAArD,EAAA,CAAA,GAAAsD,IAAAtD,EAAA,CAAA,IAVhD2D,GAAUN,IAUPC,CAA6C;AAChD,QAAAM,IACEtB,OAAc,WAAduB,KAEIvB,OAAc,SAAdwB,KAEExB,OAAc,cAAdyB,KAEEzB,OAAc,eAAd0B,KAAAC,IAIV,CAAAC,GAAAC,EAAA,IAA0Cf,GAAcgB,MAAS,GACjE,CAAAC,GAAAC,EAAA,IAA4BlB,GAA6BgB,MAAS,GAClE,CAAAG,GAAAC,CAAA,IAA4BpB,GAA6BgB,MAAS,GAI1DK,KAAAvC,KAAarB,IAAa,KAA1BA;AAAyC,MAAA6D;AAAA,EAAA1E,EAAA,CAAA,MAAAe,MAAAf,EAAA,CAAA,MAAAY,MAAAZ,EAAA,EAAA,MAAAyE,MAAAzE,UAAAc,MAHlC4D,IAAA;AAAA,IAAAC,KACR7D;AAAAA,IAAS8D,QACN7D;AAAAA,IAAY8D,MACdJ;AAAAA,IAAyCK,OACxClE;AAAAA,EAAAA,GACRZ,OAAAe,IAAAf,OAAAY,IAAAZ,QAAAyE,IAAAzE,QAAAc,IAAAd,QAAA0E,KAAAA,IAAA1E,EAAA,EAAA;AALD,QAAA+E,IAAeL,GAMfM,IAAyBpC,GAAO,IAAI;AAAE,MAAAqC;AAAA,EAAAjF,UAAAQ,KAI7ByE,KAAAC,CAAAA,OAAM;AAAA,IAAAC,MACHC,EAAM,GAAGC,EAACF,IAAK,IAAI3E,GAAY,oBAAI8E,MAAM;AAAA,IAACC,GAC7CF,EAACE;AAAAA,IAAYC,MACVC,EAAuBJ,EAACG,IAA4C,IAAlCH,EAACE,IAAiBF,EAACG;AAAAA,IAAgBE,MACrED,EAAuBJ,EAACK,IAA4C,IAAlCL,EAACE,IAAiBF,EAACK;AAAAA,IAAgBxF,MACrEmF,EAACnF;AAAAA,EAAAA,IACPF,QAAAQ,GAAAR,QAAAiF,MAAAA,KAAAjF,EAAA,EAAA;AATN,QAAA2F,IAA2CC,GACzC1F,EAAI2F,OACMC,EAAiC,EAACC,IACrCd,EAMH,GACJ,CAAC,MAAM,GACP,CAAC,KAAK,CACR;AAAE,MAAAe;AAAA,MAAAhG,EAAA,EAAA,MAAAQ,KAAAR,UAAAS,GAAA;AAAA,QAAAwF;AAAA,IAAAjG,UAAAQ,KAC+DyF,IAAAC,CAAAA,OAAM;AAAA,MAAA,GAClEb;AAAAA,MAACc,aACS,CACXd,EAACc,mBAAoB,OAArB,OAAmCf,EAAM,GAAGC,EAACc,YAAY,CAAA,CAAG,IAAI3F,GAAY,oBAAI8E,KAAAA,CAAM,GACtFD,EAACc,YAAY,CAAA,MAAQ,OAArB,OAAmCf,EAAM,GAAGC,EAACc,YAAY,CAAA,CAAG,IAAI3F,GAAY,oBAAI8E,MAAM,CAAC;AAAA,IAAA,IAEzFtF,QAAAQ,GAAAR,QAAAiG,KAAAA,IAAAjG,EAAA,EAAA,GANqCgG,KAAAvF,EAAqBsF,IAAKE,CAM/D,GAACjG,QAAAQ,GAAAR,QAAAS,GAAAT,QAAAgG;AAAAA,EAAA;AAAAA,IAAAA,KAAAhG,EAAA,EAAA;AANH,QAAAoG,KAAuCJ;AAMnC,MAAAC;AAAA,MAAAjG,EAAA,EAAA,MAAA0B,MAAA1B,UAAAQ,GAAA;AAAA,QAAA6F;AAAA,IAAArG,UAAAQ,KACyE6F,IAAAC,CAAAA,OAAM;AAAA,MAAA,GAC9EjB;AAAAA,MAACc,aACSd,EAACc,YAAYJ,IAAK,CAAAQ,GAAAC,OAC7BA,KAAI,MAAM,IAAIpB,EAAM,GAAGmB,CAAE,IAAI/F,uBAAgB8E,KAAAA,CAAuB,IAAZiB,CAC1D;AAAA,IAAA,IACAvG,QAAAQ,GAAAR,QAAAqG,KAAAA,IAAArG,EAAA,EAAA,GAL2CiG,KAAAvE,GAA2BqE,IAAKM,CAK3E,GAACrG,QAAA0B,IAAA1B,QAAAQ,GAAAR,QAAAiG;AAAAA,EAAA;AAAAA,IAAAA,KAAAjG,EAAA,EAAA;AALH,QAAAyG,KAA6CR,IAM7CS,IAAmBvG,IAAQ4E,EAAMF,OAAQE,EAAMD,OAC/C6B,IAAoBvG,KAAS2E,EAAMJ,MAAOI,EAAMH,QAChDgC,KAAgBxE,KAAUgD,EAAM,GAAGhD,EAAO,IAAI5B,GAAY,oBAAI8E,KAAAA,CAA8B,IAApBK,EAAa,CAAA,EAAGR,MACxF0B,KAAgBxE,KACZ+C,EAAM,GAAG/C,EAAO,IAAI7B,GAAY,oBAAI8E,KAAAA,CACO,IAA3CK,EAAcA,EAAamB,SAAU,CAAC,EAAC3B,MAC3C4B,IAA0BtB,EAAuBtE,EAAQ,IAErD6F,KAAIC,IAAI,GAAItB,EAAaI,IAAKmB,EAAkC,CAI9D,IAHAF,KAAIC,IAAI,GAAItB,EAAaI,IAAKoB,EAAkC,CAAC,IAAI,IAArE,IAEEH,KAAIC,IAAI,GAAItB,EAAaI,IAAKqB,EAAkC,CAAC,IAHrE,IADCjG,IAMLkG,IAAyBL,KAAIM,IAAI,GAAI3B,EAAaI,IAAKwB,EAAkC,CAErF,IADAP,KAAIM,IAAI,GAAI3B,EAAaI,IAAKyB,EAAkC,CAChE,IAFqB,GAGzBC,IAAUC,KAAWC,OAAQ,CAACf,IAASC,EAAO,CAAC,EAACe,MAAO,CAAC,GAAGlB,CAAU,CAAC;AAAE,MAAAL;AAAA,EAAArG,EAAA,EAAA,MAAAqH,KAAArH,UAAAoB,MAIpEiF,KAAAZ,EAAuBrE,EAA+D,IAAlDiG,IAAW,IAAXA,IAAA,IAAgCjG,IAAmBpB,QAAAqH,GAAArH,QAAAoB,IAAApB,QAAAqG,MAAAA,KAAArG,EAAA,EAAA;AAH3F,QAAAuF,IAAUsC,GAAAA,EAAaF,OACb,CACNZ,GACAV,EAAuF,CACxF,EAACuB,MACK,CAACjB,GAAa,CAAC,CAAC,EAACmB,KAAAA,GAG1BC,KAAkBC,KAAyBP,EACtCQ,CAAAA,MAAKR,EAAEpC,EAACF,IAAK,CAAC,EAACI,EACf2C,OAAK3C,EAAEF,EAACE,CAAE,CAAC,EAAC3B,MACRA,CAAK,GAEduE,KAAqBH,KAAyBP,EACzCW,CAAAA,MAAKX,EAAEpC,EAACF,IAAK,CAAC,EAACI,EACf8C,OAAK9C,EAAEF,EAACG,IAAK,CAAC,EAAC5B,MACXA,CAAK,GAEd0E,KAAqBN,KAAyBP,EACzCc,CAAAA,MAAKd,EAAEpC,EAACF,IAAK,CAAC,EAACI,EACfiD,OAAKjD,EAAEF,EAACK,IAAK,CAAC,EAAC9B,MACXA,CAAK,GAEd6E,KAAkBC,KAAyBjB,EACtCkB,CAAAA,MAAKlB,EAAEpC,EAACF,IAAK,CAAC,EAACyD,GACdC,CAAAA,MAAKtD,EAAEF,EAACG,IAAK,CAAC,EAACsD,GACfC,CAAAA,MAAKxD,EAAEF,EAACK,IAAK,CAAC,EAAC9B,MACZA,CAAK,GAEdoF,KAAezD,EAAC0D,MAAO9G,EAAU,GAEjC+G,KAAezB,EAACwB,MAAOtI,EAAU;AAEjCgD,EAAAA,GAAU,MAAA;AAER,UAAAwF,IAAkBC,CAAAA,MAAA;AAChB,YAAAC,KACE1D,EACE2D,GACE3D,EAAaI,IAAKwD,EAAW,GAC7B9B,EAAC+B,OAAQC,GAAQL,CAAK,EAAC,CAAA,CAAG,GAC1B,CACF,CAAC;AAELjF,MAAAA,GAAiBkF,MAAgB1D,EAAcA,EAAamB,SAAU,CAAC,CAAC,GACxE7F,KAAoBoI,MAAgB1D,EAAcA,EAAamB,SAAU,CAAC,CAAC,GAC3EtC,EAAU4E,EAAKM,OAAQ,GACvBpF,GAAU8E,EAAKO,OAAQ;AAAA,IAAC,GAE1BC,IAAiBA,MAAA;AACfzF,MAAAA,GAAiBC,MAAS,GAC1BE,GAAUF,MAAS,GACnBI,EAAUJ,MAAS,GACnBnD,KAAoBmD,MAAS;AAAA,IAAC;AAEhCyF,IAAAA,GAAO7E,EAAgB8E,OAAQ,EAACC,GAAI,aAAaZ,CAAS,EAACY,GAAI,YAAYH,CAAQ;AAAA,EAAC,GACnF,CAACnC,GAAG9B,GAAe1E,EAAiB,CAAC;AACxC,QAAA+I,KAA4BC,GAC1BtE,EAAaE,OACHqE,EAAoE,EAACnE,IACxEoE,CAAAA,MAAK,CAAC1C,EAAEpC,EAACF,IAAK,GAAGI,EAAEF,EAACE,CAAY,CAAC,CAAC,CAC3C,GACA6E,KAAgBC,GAAqBL,EAAmB;AAAE,MAAAM;AAAA,EAAAtK,UAAAqB,KAAArB,EAAA,EAAA,MAAA2G,KAAA3G,EAAA,EAAA,MAAA0G,KAAA1G,EAAA,EAAA,MAAAoG,MAAApG,UAAAgD,KAAAhD,EAAA,EAAA,MAAAyH,KAWlD6C,IAAAC,gBAAAA,EAAAA,IAACC,IAAA,EACepE,cAAAA,IACPM,OAAAA,GACCC,QAAAA,GACDc,OAAAA,GACEpG,SAAAA,GACC2B,UAAAA,EAAAA,CAAQ,GAClBhD,QAAAqB,GAAArB,QAAA2G,GAAA3G,QAAA0G,GAAA1G,QAAAoG,IAAApG,QAAAgD,GAAAhD,QAAAyH,GAAAzH,QAAAsK,KAAAA,IAAAtK,EAAA,EAAA;AAee,QAAAyK,KAAAlI,GAAMmI,OAAkBC,WAC3BC,KAAArI,GAAMmI,OAAeG;AAAA,MAAAC;AAAA,EAAA9K,EAAA,EAAA,MAAAyK,MAAAzK,UAAA4K,MAFvBE,KAAA;AAAA,IAAAH,WACKF;AAAAA,IAAwBI,QAC3BD;AAAAA,EAAAA,GACT5K,QAAAyK,IAAAzK,QAAA4K,IAAA5K,QAAA8K,MAAAA,KAAA9K,EAAA,EAAA;AAEY,QAAA+K,KAAAvI,GAAUkI,OAAkBC,WAC/BK,KAAAxI,GAAUkI,OAAeG;AAAA,MAAAI;AAAA,EAAAjL,EAAA,EAAA,MAAA+K,MAAA/K,UAAAgL,MAFvBC,IAAA;AAAA,IAAAN,WACCI;AAAAA,IAA4BF,QAC/BG;AAAAA,EAAAA,GACThL,QAAA+K,IAAA/K,QAAAgL,IAAAhL,QAAAiL,KAAAA,IAAAjL,EAAA,EAAA;AASG,QAAAkL,KAAA3F,EAAEwB,IAAW,IAAX,IAAAA,CAA2B,GAC7BoE,KAAA5F,EAAEwB,IAAW,IAAX,IAAAA,CAA2B,GAC7BqE,KAAA,IAAIvK,GACJwK,KAAA3E,IAAa3B,EAAMD,OAErBwG,KAAAvE,IAAW,IAAX,IAAAA;AAA2B,MAAAwE;AAAA,EAAAvL,EAAA,EAAA,MAAAyC,KAAAzC,EAAA,EAAA,MAAAO,KAAAP,EAAA,EAAA,MAAAM,KAAAN,UAAAsL,MADtBC,IAAAC,GACLF,IACA,MACA7I,GACAlC,GACAD,CACF,GAACN,QAAAyC,GAAAzC,QAAAO,GAAAP,QAAAM,GAAAN,QAAAsL,IAAAtL,QAAAuL,KAAAA,IAAAvL,EAAA,EAAA;AAEI,QAAAyL,KAAA,IAAI5K,GACJ6K,IAAAnG,EAAEwB,IAAW,IAAX,IAAAA,CAA2B,GAE5B4E,KAAAtE,IAAW,IAAX,QAAA;AAAyB,MAAAuE;AAAA,EAAA5L,EAAA,EAAA,MAAAyL,MAAAzL,UAAA0L,KAAA1L,EAAA,EAAA,MAAA2L,MAJrBC,IAAA;AAAA,IAAAnE,GACLgE;AAAAA,IAAclG,GACdmG;AAAAA,IAA8BG,IAC7B;AAAA,IAACC,IACDH;AAAAA,EAAAA,GACL3L,QAAAyL,IAAAzL,QAAA0L,GAAA1L,QAAA2L,IAAA3L,QAAA4L,KAAAA,IAAA5L,EAAA,EAAA;AAEO,QAAA+L,KAAAvJ,GAAUwJ,OAAaC,MACtBC,KAAA1J,GAAUkI,OAAeG;AAAA,MAAAsB;AAAA,EAAAnM,EAAA,EAAA,MAAA+L,MAAA/L,UAAAkM,MAFtBC,IAAA;AAAA,IAAAF,MACJF;AAAAA,IAAuBK,OACtBF;AAAAA,EAAAA,GACRlM,QAAA+L,IAAA/L,QAAAkM,IAAAlM,QAAAmM,KAAAA,IAAAnM,EAAA,EAAA;AAEO,QAAAqM,KAAA9J,GAAMyJ,OAAaC,MAClBK,KAAA/J,GAAMmI,OAAeG;AAAA,MAAA0B;AAAA,EAAAvM,EAAA,EAAA,MAAAqM,MAAArM,UAAAsM,MAFtBC,IAAA;AAAA,IAAAN,MACAI;AAAAA,IAAmBD,OAClBE;AAAAA,EAAAA,GACRtM,QAAAqM,IAAArM,QAAAsM,IAAAtM,QAAAuM,KAAAA,IAAAvM,EAAA,EAAA;AAAA,MAAAwM;AAAA,EAAAxM,EAAA,EAAA,MAAAkL,MAAAlL,EAAA,EAAA,MAAAmL,MAAAnL,EAAA,EAAA,MAAAoL,MAAApL,EAAA,EAAA,MAAAqL,MAAArL,EAAA,EAAA,MAAAuL,KAAAvL,EAAA,EAAA,MAAA4L,KAAA5L,EAAA,EAAA,MAAAmM,KAAAnM,UAAAuM,KAzBHC,2BAACC,IAAA,EACK,IAAAvB,IACA,IAAAC,IACA,IAAAC,IACA,IAAAC,IACG,OAAAE,GAOG,UAAAK,GAME,YAAAO,GAIJ,QAAAI,GAGP,GACDvM,QAAAkL,IAAAlL,QAAAmL,IAAAnL,QAAAoL,IAAApL,QAAAqL,IAAArL,QAAAuL,GAAAvL,QAAA4L,GAAA5L,QAAAmM,GAAAnM,QAAAuM,GAAAvM,QAAAwM,MAAAA,KAAAxM,EAAA,EAAA;AAEG,QAAA0M,IAAA,IAAI7L,IAAa,IACjB8L,IAAAhG,IAAc,GACViG,IAAArK,GAAMmI,OAAcmC,OAChBC,KAAAtK,GAAUkI,OAAcmC;AAAA,MAAAE;AAAA,EAAA/M,EAAA,EAAA,MAAA0M,KAAA1M,EAAA,EAAA,MAAA2M,KAAA3M,EAAA,EAAA,MAAA4M,KAAA5M,EAAA,EAAA,MAAA8M,MAAA9M,UAAAkC,MAJrC6K,2BAACC,IAAA,EACI,GAAAN,GACA,GAAAC,GACI,OAAAC,GACI,WAAAE,IACL5K,MAAAA,IACN,UAAA,IAAQ,GACRlC,QAAA0M,GAAA1M,QAAA2M,GAAA3M,QAAA4M,GAAA5M,QAAA8M,IAAA9M,QAAAkC,IAAAlC,QAAA+M,MAAAA,KAAA/M,EAAA,EAAA;AAAA,MAAAiN;AAAA,EAAAjN,UAAA0C,KAiBHuK,KAAAvK,EAAYmD,OAAQqH,EAA4B,EAACnH,IAAKoH,EAAY,GAACnN,QAAA0C,GAAA1C,QAAAiN,MAAAA,KAAAjN,EAAA,EAAA;AAAA,MAAAoN;AAAA,EAAApN,UAAAgC,MAE3DoL,KAAA;AAAA,IAAAC,MACCrL;AAAAA,EAAAA,GACPhC,QAAAgC,IAAAhC,QAAAoN,MAAAA,KAAApN,EAAA,EAAA;AAAA,MAAAsN;AAAA,EAAAtN,EAAA,EAAA,MAAAqB,EAAAkC,YACK+J,KAAA;AAAA,IAAAC,SAAW;AAAA,IAACC,YAAc;AAAA,MAAAjK,UAAYlC,EAAOkC;AAAAA,IAAAA;AAAAA,EAAU,GAAGvD,EAAA,EAAA,IAAAqB,EAAAkC,UAAAvD,QAAAsN,MAAAA,KAAAtN,EAAA,EAAA;AAAA,MAAAyN;AAAA,EAAAzN,EAAA,EAAA,MAAAK,KAAAL,UAAAuB,KA+DzDkM,KAAA;AAAA,IAAAC,QACGrN;AAAAA,IAASgN,MACX;AAAA,IAAM9L,aAAAA;AAAAA,EAAAA,GAEbvB,QAAAK,GAAAL,QAAAuB,GAAAvB,QAAAyN,MAAAA,KAAAzN,EAAA,EAAA;AAAA,MAAA2N;AAAA,EAAA3N,EAAA,EAAA,MAAAqB,EAAAkC,YACKoK,KAAA;AAAA,IAAAJ,SAAW;AAAA,IAACC,YAAc;AAAA,MAAAjK,UAAYlC,EAAOkC;AAAAA,IAAAA;AAAAA,EAAU,GAAGvD,EAAA,EAAA,IAAAqB,EAAAkC,UAAAvD,QAAA2N,MAAAA,KAAA3N,EAAA,EAAA;AA+B/D,QAAA4N,KAAAjI,EAAaI,IAAK,CAAA8H,GAAAC,MACjBvD,gBAAAA,EAAAA,IAAAwD,EAAA,GAAA,EACG,UAACtI,EAAuBJ,EAACE,CAAE,IAA3B,OAAAyI,gBAAAA,OAAAC,EAAAA,UAAA,EAEIzM,UAAAA;AAAAA,IAAAA,2BACCuM,EAAA,QAAA,EAEI,GAAArH,IAAaf,EAAamB,SAAU,IAApC,IAEIJ,IAAaf,EAAamB,SAAU,KAApC,IAAA,GAIC,OAAA;AAAA,MAAAuG,MAAQhN;AAAAA,IAAAA,GACT,MAAA;AAAA,MAAAkN,SAAW;AAAA,MAACC,YAAc;AAAA,QAAAjK,UAAYlC,EAAOkC;AAAAA,MAAAA;AAAAA,IAAU,GACnD,UAAA;AAAA,MAAA2K,SACC;AAAA,QAAAX,SAAW;AAAA,QAACY,IAAM1G,EAAEpC,EAACF,IAAK;AAAA,QAACiJ,IAAM7I,EAAEF,EAACE,CAAE;AAAA,MAAA;AAAA,MAAG8I,aACrC;AAAA,QAAAd,SACF;AAAA,QAACC,YACE;AAAA,UAAAjK,UACAL,IAAkB7B,EAAOkC,WAAzB;AAAA,UAAwC+K,OAC3CpL,IAAA,IAAsB7B,EAAOkC;AAAAA,QAAAA;AAAAA,QACrC4K,IACG1G,EAAEpC,EAACF,IAAK;AAAA,QAACiJ,IACT7I,EAAEF,EAACE,CAAE;AAAA,MAAA;AAAA,IACX,GAEM,SAAA,WACC,SAAAvC,IAAA,gBAAA,WAAoC,IAxBhD;AAAA,IA2BApB,KAAAoM,gBAAAA,EAAAA,KAAAC,YAAA,EAEG,UAAA;AAAA,MAAA1D,gBAAAA,EAAAA,IAAAwD,EAAA,QAAA,EAEI,GAAArH,IAAaf,EAAamB,SAAU,IAApC,IAEIJ,IAAaf,EAAamB,SAAU,KAApC,IAAA,GAIA,MAAA;AAAA,QAAAyG,SAAW;AAAA,QAACC,YAAc;AAAA,UAAAjK,UAAYlC,EAAOkC;AAAAA,QAAAA;AAAAA,MAAU,GACnD,UAAA;AAAA,QAAA2K,SACC;AAAA,UAAAX,SACE;AAAA,UAACF,MACJtL,EAAkB,CAAA;AAAA,UAAGoM,IACvB1G,EAAEpC,EAACF,IAAK;AAAA,UAACiJ,IACT7I,EAAEF,EAACG,IAAK;AAAA,QAAA;AAAA,QACb6I,aACY;AAAA,UAAAd,SACF;AAAA,UAACC,YACE;AAAA,YAAAjK,UACAL,IAAkB7B,EAAOkC,WAAzB;AAAA,YAAwC+K,OAC3CpL,IAAA,IAAsB7B,EAAOkC;AAAAA,UAAAA;AAAAA,UACrC4K,IACG1G,EAAEpC,EAACF,IAAK;AAAA,UAACiJ,IACT7I,EAAEF,EAACG,IAAK;AAAA,UAAC6H,MACPtL,EAAkB,CAAA;AAAA,QAAA;AAAA,MAC1B,GAEM,SAAA,WACC,SAAAiB,IAAA,gBAAA,WAAoC;AAAA,wCAI3C,GAAA0D,IAAaf,EAAamB,SAAU,IAApC,IAEIJ,IAAaf,EAAamB,SAAU,KAApC,IAAA,GAIA,MAAA;AAAA,QAAAyG,SAAW;AAAA,QAACC,YAAc;AAAA,UAAAjK,UAAYlC,EAAOkC;AAAAA,QAAAA;AAAAA,MAAU,GACnD,UAAA;AAAA,QAAA2K,SACC;AAAA,UAAAX,SACE;AAAA,UAACF,MACJtL,EAAkB,CAAA;AAAA,UAAGoM,IACvB1G,EAAEpC,EAACF,IAAK;AAAA,UAACiJ,IACT7I,EAAEF,EAACK,IAAK;AAAA,QAAA;AAAA,QACb2I,aACY;AAAA,UAAAd,SACF;AAAA,UAACF,MACJtL,EAAkB,CAAA;AAAA,UAAGyL,YACf;AAAA,YAAAjK,UACAL,IAAkB7B,EAAOkC,WAAzB;AAAA,YAAwC+K,OAC3CpL,IAAA,IAAsB7B,EAAOkC;AAAAA,UAAAA;AAAAA,UACrC4K,IACG1G,EAAEpC,EAACF,IAAK;AAAA,UAACiJ,IACT7I,EAAEF,EAACK,IAAK;AAAA,QAAA;AAAA,MACd,GAEM,SAAA,WACC,SAAA1C,IAAA,gBAAA,UAAA,CAAoC;AAAA,IAAA,EAAA,CAC7C,IA7DL;AAAA,IAgEAtC,KACC6J,gBAAAA,EAAAA,IAAAwD,EAAA,MAAA,EACM,IAAA,IACG,OAAA;AAAA,MAAAQ,YACO;AAAA,MAAQ,GAChBhM,GAAMiM,qBAAN,CAAA;AAAA,IAA8B,GAEzB,WAAAC,GACT,iCACAjM,GAAUgM,iBACZ,GACM,MAAA;AAAA,MAAAjB,SAAW;AAAA,MAACC,YAAc;AAAA,QAAAjK,UAAYlC,EAAOkC;AAAAA,MAAAA;AAAAA,IAAU,GACnD,UAAA;AAAA,MAAA2K,SACC;AAAA,QAAAX,SAAW;AAAA,QAACF,MAAQhN;AAAAA,QAASoH,GAAKA,EAAEpC,EAACF,IAAK;AAAA,QAACI,GAAKA,EAAEF,EAACE,CAAE;AAAA,MAAA;AAAA,MAAG8I,aACpD;AAAA,QAAAd,SACF;AAAA,QAAC9F,GACPA,EAAEpC,EAACF,IAAK;AAAA,QAACkI,MACNhN;AAAAA,QAASkF,GACZA,EAAEF,EAACE,CAAE;AAAA,QAACiI,YACG;AAAA,UAAAjK,UACAL,IAAkB7B,EAAOkC,WAAzB;AAAA,UAAwC+K,OAC3CpL,IAAA,IAAsB7B,EAAOkC;AAAAA,QAAAA;AAAAA,MACtC;AAAA,IACF,GAEM,SAAA,WACC,SAAAP,IAAA,gBAAA,WAERwI,UAAAA,GAAyBnG,EAACE,GAAI,MAAM9C,GAAWlC,GAAQD,CAAM,GAChE,IA7BD;AAAA,IA+BAuB,KAAAmM,gBAAAA,EAAAA,KAAAC,YAAA,EAEG,UAAA;AAAA,MAAA1D,gBAAAA,EAAAA,IAAAwD,EAAA,MAAA,EACK,IAAA,OACI,OAAA;AAAA,QAAAQ,YACO;AAAA,QAAQ,GAChBhM,GAAMiM,qBAAN,CAAA;AAAA,MAA8B,GAEzB,WAAAC,GAAG,qBAAqBjM,GAAUgM,iBAAmB,GAC1D,MAAA;AAAA,QAAAjB,SAAW;AAAA,QAACC,YAAc;AAAA,UAAAjK,UAAYlC,EAAOkC;AAAAA,QAAAA;AAAAA,MAAU,GACnD,UAAA;AAAA,QAAA2K,SACC;AAAA,UAAAX,SACE;AAAA,UAACF,MACJtL,EAAkB,CAAA;AAAA,UAAG0F,GACxBA,EAAEpC,EAACF,IAAK;AAAA,UAACI,GACTA,EAAEF,EAACG,IAAK;AAAA,QAAA;AAAA,QACZ6I,aACY;AAAA,UAAAd,SACF;AAAA,UAAC9F,GACPA,EAAEpC,EAACF,IAAK;AAAA,UAACI,GACTA,EAAEF,EAACG,IAAK;AAAA,UAAC6H,MACNtL,EAAkB,CAAA;AAAA,UAAGyL,YACf;AAAA,YAAAjK,UACAL,IAAkB7B,EAAOkC,WAAzB;AAAA,YAAwC+K,OAC3CpL,IAAA,IAAsB7B,EAAOkC;AAAAA,UAAAA;AAAAA,QACtC;AAAA,MACF,GAEM,SAAA,WACC,SAAAP,IAAA,gBAAA,WAERwI,UAAAA,GAAyBnG,EAACG,MAAO,MAAM/C,GAAWlC,GAAQD,CAAM,GACnE;AAAA,sCAEM,QACG,OAAA;AAAA,QAAAiO,YACO;AAAA,QAAQ,GAChBhM,GAAMiM,qBAAN,CAAA;AAAA,MAA8B,GAEzB,WAAAC,GAAG,qBAAqBjM,GAAUgM,iBAAmB,GAC1D,MAAA;AAAA,QAAAjB,SAAW;AAAA,QAACC,YAAc;AAAA,UAAAjK,UAAYlC,EAAOkC;AAAAA,QAAAA;AAAAA,MAAU,GACnD,UAAA;AAAA,QAAA2K,SACC;AAAA,UAAAX,SACE;AAAA,UAACF,MACJtL,EAAkB,CAAA;AAAA,UAAG0F,GACxBA,EAAEpC,EAACF,IAAK;AAAA,UAACI,GACTA,EAAEF,EAACK,IAAK;AAAA,QAAA;AAAA,QACZ2I,aACY;AAAA,UAAAd,SACF;AAAA,UAACF,MACJtL,EAAkB,CAAA;AAAA,UAAG0F,GACxBA,EAAEpC,EAACF,IAAK;AAAA,UAACI,GACTA,EAAEF,EAACK,IAAK;AAAA,UAAC8H,YACA;AAAA,YAAAjK,UACAL,IAAkB7B,EAAOkC,WAAzB;AAAA,YAAwC+K,OAC3CpL,IAAA,IAAsB7B,EAAOkC;AAAAA,UAAAA;AAAAA,QACtC;AAAA,MACF,GAEM,SAAA,WACC,SAAAP,IAAA,gBAAA,WAERwI,UAAAA,GAAyBnG,EAACK,MAAO,MAAMjD,GAAWlC,GAAQD,CAAM,EAAA,CACnE;AAAA,IAAA,EAAA,CAAc,IA/DjB;AAAA,EAAA,EAAA,CAiEO,KA9LCoO,CAiMf,CACD;AAAC,MAAAC;AAAA,EAAA3O,UAAA4N,MApMJe,kCACGf,UAAAA,GAAAA,CAoMH,GAAI5N,QAAA4N,IAAA5N,QAAA2O,MAAAA,KAAA3O,EAAA,EAAA;AAoBD,QAAA4O,KAAAnN,GAAWsE,IAAK,CAAA8I,GAAAC,MAAA;AACf,UAAAC,IAAkBC,GAChB;AAAA,MAAAvH,GACKpC,EAAC4J,cACAxH,EAAErC,EAAM,GAAGC,EAAC4J,WAAY,IAAIzO,uBAAgB8E,MAAM,CAAC,KAAKD,EAAC6J,WAAD,KACxD,KAAK7J,EAAC6J,WAAD;AAAA,MAAe3J,GACrBF,EAAC8J,cACA5J,EAAEF,EAAC8J,WAAsB,KAAK9J,EAAC+J,WAAD,KAAkB,IAChD,KAAK/J,EAAC+J,WAAD,KAAkB;AAAA,IAAA,GAE7B;AAAA,MAAA3H,GACKpC,EAAC4J,cAAexH,EAAErC,EAAM,GAAGC,EAAC4J,WAAY,IAAIzO,GAAY,oBAAI8E,KAAAA,CAAM,CAAK,IAAvE;AAAA,MAAwEC,GACxEF,EAAC8J,cAAe5J,EAAEF,EAAC8J,WAA0B,IAA7C;AAAA,IAAA,GAEL1J,EAAuBJ,EAACgK,eAAsD,IAA9E,MAAmDhK,EAACgK,eACtD,GACAC,KAA0BjK,EAACkK,gBAAD;AAAA,MAAAzG,IAEhBiG,EAASxJ;AAAAA,MAAEiK,IACXT,EAAStH;AAAAA,MAAEgI,IACXpK,EAAC8J,cACD5J,EAAEF,EAAC8J,WAAsB,KAAK9J,EAAC+J,WAAD,KAC9B,KAAK/J,EAAC+J,WAAD;AAAA,MAAeM,IACpBrK,EAAC4J,cACDxH,EAAErC,EAAM,GAAGC,EAAC4J,WAAY,IAAIzO,uBAAgB8E,MAAM,CAAC,KAAKD,EAAC6J,WAAD,KACxD,KAAK7J,EAAC6J,WAAD;AAAA,MAAed,IACpB/I,EAAC8J,cAAe5J,EAAEF,EAAC8J,WAA0B,IAA7C;AAAA,MAA8ChB,IAC9C9I,EAAC4J,cAAexH,EAAErC,EAAM,GAAGC,EAAC4J,WAAY,IAAIzO,GAAY,oBAAI8E,KAAAA,CAAM,CAAK,IAAvE;AAAA,MAAwEqK,cAC9DlK,EAAuBJ,EAACgK,eAEN,IAFlB,MAEThK,EAACgK;AAAAA,MAA2B9N,aACpB8D,EAACkK,kBAAmB,KAApB,IAA+BvI,KAAIC,IAAK5B,EAACkK,iBAAD,GAAsB,CAAC;AAAA,IAAA,IAfxDnL,QAkB1BwL,KAAsB;AAAA,MAAArK,GACjBF,EAAC8J,cACA5J,EAAEF,EAAC8J,WAAsB,KAAK9J,EAAC+J,WAAD,KAAkB,IAChD,KAAK/J,EAAC+J,WAAD,KAAkB;AAAA,MAAC3H,GACzBnG,KAAA,IAEC+D,EAAC4J,cACCxH,EAAErC,EAAM,GAAGC,EAAC4J,WAAY,IAAIzO,GAAY,oBAAI8E,KAAAA,CAAM,CAAC,KAAKD,EAAC6J,WAAD,KACxD,KAAK7J,EAAC6J,WAAD;AAAA,MAAe/O,OACnBmB,KACH+D,EAAC4J,cACCxH,EAAErC,EAAM,GAAGC,EAAC4J,WAAY,IAAIzO,GAAY,oBAAI8E,KAAAA,CAAM,CAAC,KAAKD,EAAC6J,WAAD,KACxD,KAAK7J,EAAC6J,WAAD,KACPxI,IACA3B,EAAMD,SACLO,EAAC4J,cACExH,EAAErC,EAAM,GAAGC,EAAC4J,WAAY,IAAIzO,GAAY,oBAAI8E,MAAM,CAAC,KAAKD,EAAC6J,WAAD,KACxD,KAAK7J,EAAC6J,WAAD;AAAA,MAAgBW,UACnBxK,EAACwK;AAAAA,MAASC,YACRzK,EAACyK;AAAAA,MAAWC,OACjB1K,EAAC0K;AAAAA,IAAAA;AACR,iCAECC,IAAA,EAEQ,OAAA3K,EAAC4K,OACYX,oBAAAA,IACLM,eAAAA,IACT,MAAAvK,EAAC6K,MACK,YAAA7K,EAAC7C,YACL,QAAA6C,EAAC9C,QACAlB,SAAAA,GACC2B,UAAAA,KARL0L,CAQa;AAAA,EAClB,CAEL;AAAC,MAAAyB;AAAA,EAAAnQ,UAAA4O,MAtEJuB,kCACGvB,UAAAA,GAAAA,CAsEH,GAAI5O,QAAA4O,IAAA5O,QAAAmQ,MAAAA,KAAAnQ,EAAA,EAAA;AAED,QAAAoQ,KAAAzO,KACC4I,gBAAAA,EAAAA,IAAC8F,IAAA,EACK,IAAA,GACA3J,OACA,IAAA0D,GAAQ,CAAC,GACT,IAAAA,GAAQ1D,CAAU,GACTC,aAAAA,GACDD,YAAAA,GACD,WAAAlE,GAAU8N,SACd,OAAA/N,GAAM+N,SACN,OAAA,OAAO3O,MAAmB,WAA1BA,KAAAyC,QACE/C,SAAAA,GACC2B,UAAAA,GAAQ,IAZrB;AAcO,MAAAuN;AAAA,EAAAvQ,UAAAoQ,MAfVG,kCACGH,UAAAA,GAAAA,CAeH,GAAIpQ,QAAAoQ,IAAApQ,QAAAuQ,MAAAA,KAAAvQ,EAAA,EAAA;AAAA,MAAAwQ;AAAA,EAAAxQ,UAAA0C,KACH8N,KAAA9N,EAAYmD,OAAQ4K,EAA2B,EAAC1K,IAAK2K,EAAY,GAAC1Q,QAAA0C,GAAA1C,QAAAwQ,MAAAA,KAAAxQ,EAAA,EAAA;AAAA,MAAA2Q;AAAA,EAAA3Q,EAAA,EAAA,MAAA4Q,OAAAC,IAAA,2BAAA,KAG1DF,KAAA;AAAA,IAAAtD,MACC;AAAA,IAAMyD,eACG;AAAA,EAAA,GAChB9Q,QAAA2Q,MAAAA,KAAA3Q,EAAA,EAAA;AAAA,MAAA+Q;AAAA,EAAA/Q,EAAA,EAAA,MAAAgF,KAAAhF,UAAA2G,KAAA3G,EAAA,EAAA,MAAA0G,KALHqK,KAAAxG,gBAAAA,EAAAA,IAAA,UACOvF,QACE,OAAA2L,IAIAjK,OAAAA,GACCC,QAAAA,EAAAA,CAAW,GACnB3G,QAAAgF,GAAAhF,QAAA2G,GAAA3G,QAAA0G,GAAA1G,QAAA+Q,MAAAA,KAAA/Q,EAAA,EAAA;AAAA,MAAAgR;AAAA,SAAAhR,EAAA,EAAA,MAAAwC,GAAAxB,WAAAhB,EAAA,EAAA,MAAAqE,KAAArE,EAAA,EAAA,MAAAuE,KAAAvE,EAAA,EAAA,MAAAkE,KAAAlE,EAAA,EAAA,MAAAuC,GAAAvB,WAAAhB,EAAA,GAAA,MAAAgB,KAGLgQ,KAAA9M,KAAAlD,KAAAqD,KAAAE,0BACE0M,IAAA,EACO/M,SACAlD,MAAAA,GACAqD,SACAE,MAAAA,GACW,iBAAAhC,GAAMvB,SACZ,WAAAwB,GAAUxB,SAAS,IAPjC,MASOhB,EAAA,EAAA,IAAAwC,GAAAxB,SAAAhB,QAAAqE,GAAArE,QAAAuE,GAAAvE,QAAAkE,GAAAlE,EAAA,EAAA,IAAAuC,GAAAvB,SAAAhB,SAAAgB,GAAAhB,SAAAgR,MAAAA,KAAAhR,EAAA,GAAA,GA7gBVgO,gBAAAA,EAAAA,KAAAC,YAAA,EACE,UAAA;AAAA,IAAA1D,gBAAAA,EAAAA,aACS,UAAGpK,CAAK,MACP,WAAGC,EAAM,MACR,gBAAOD,CAAK,IAAIC,EAAM,IACrB,WAAA,OACLuC,KAAAA,IAEL,UAAAqL,gBAAAA,EAAAA,KAAA,KAAA,EAAc,WAAA,aAAajJ,EAAMF,IAAK,IAAIE,EAAMJ,GAAI,KAClD2F,UAAAA;AAAAA,MAAAA;AAAAA,MAQAC,gBAAAA,EAAAA,IAAC2G,MACezK,cAAAA,IACNgB,QAAAA,GACAlC,QAAAA,GACClE,SAAAA,GACC2B,UAAAA,EAAAA,CAAQ;AAAA,oCAGlB,UAAA;AAAA,QAAAuH,gBAAAA,EAAAA,IAAC4G,MACS,QAAAnI,GAAMnD,OAAQuL,EAAY,GAC/B,GAAApI,GAAMnD,OAAQwL,EAAY,EAACtL,IAAKuL,CAAAA,MAAK/L,EAAEF,CAAC,CAAC,GACxC,IAAA,IAAIxE,GACJ,IAAA6F,IAAa3B,EAAMD,OACf,QAAAgG,IAII,YAAAG,GAIJ3K,QAAAA,GACAC,QAAAA,GACE,WAAA,aACV,eAAA,IACS,UAAA,YACEkC,WAAAA,GAAS;AAAA,QAEtB+J;AAAAA,QA2BAO;AAAAA,MAAAA,GAQF;AAAA,4BACA,KAAA,EACG7D,UAAAA,GAAMnD,IAAK,CAAAwL,GAAA7C,MACVnE,gBAAAA,EAAAA,IAAA,KAAA,EACE,UAAAA,gBAAAA,EAAAA,IAAA,UACK5D,MACA,GAAAc,EAAEpC,CAAC,GACC,OAAA;AAAA,QAAAkJ,YAAc;AAAA,MAAA,GACX,WAAA,+GACN,QAEHiD,UAAAA,GAAOnM,GAAG7E,CAAU,EAAA,CACvB,EAAA,IACF,CACD,EAAA,CACH;AAAA,MACCyM;AAAAA,MACD1C,gBAAAA,MAAAwD,EAAA,MAAA,EACS,OAAAX,IAGD,MAAAE,IACI,UAAA;AAAA,QAAAY,SACC;AAAA,UAAAX,SAAW;AAAA,UAAClI,GAAKoD,GAAU9C,CAAmB,KAA7B;AAAA,QAAA;AAAA,QAAgC0I,aAC7C;AAAA,UAAAd,SACFtL;AAAAA,UAAmBoD,GACzBoD,GAAU9C,CAAmB,KAA7B;AAAA,UAA8B6H,YACrB;AAAA,YAAAjK,UAAYlC,EAAOkC;AAAAA,UAAAA;AAAAA,QAAU;AAAA,MAC3C,GAEM,SAAA,WACC,SAAAP,IAAA,gBAAA,WAAoC;AAAA,MAE9ClB,KAAAkM,gBAAAA,EAAAA,KAAAC,YAAA,EAEG,UAAA;AAAA,QAAA1D,gBAAAA,EAAAA,IAAAwD,EAAA,MAAA,EACS,OAAA;AAAA,UAAAL,QACG3L,EAAkB,CAAA;AAAA,UAAGsL,MACvB;AAAA,UAAM9L,aACCO;AAAAA,QAAAA,GAET,MAAA;AAAA,UAAAyL,SAAW;AAAA,UAACC,YAAc;AAAA,YAAAjK,UAAYlC,EAAOkC;AAAAA,UAAAA;AAAAA,QAAU,GACnD,UAAA;AAAA,UAAA2K,SACC;AAAA,YAAAuD,YACK;AAAA,YAACpM,GACV8C,GAAaxC,CAAmB,KAAhC;AAAA,YAAiC4H,SAC3B;AAAA,UAAA;AAAA,UACVc,aACY;AAAA,YAAAoD,YACC;AAAA,YAACpM,GACV8C,GAAaxC,CAAmB,KAAhC;AAAA,YAAiC4H,SAC3B;AAAA,YAACC,YACE;AAAA,cAAAjK,UAAYlC,EAAOkC;AAAAA,YAAAA;AAAAA,UAAU;AAAA,QAC3C,GAEM,SAAA,WACC,SAAAP,IAAA,gBAAA,WAAoC;AAAA,QAE/CuH,gBAAAA,EAAAA,IAAAwD,EAAA,MAAA,EACS,OAAA;AAAA,UAAAL,QACG3L,EAAkB,CAAA;AAAA,UAAGsL,MACvB;AAAA,UAAM9L,aACCO;AAAAA,QAAAA,GAET,MAAA;AAAA,UAAAyL,SAAW;AAAA,UAACC,YAAc;AAAA,YAAAjK,UAAYlC,EAAOkC;AAAAA,UAAAA;AAAAA,QAAU,GACnD,UAAA;AAAA,UAAA2K,SACC;AAAA,YAAAuD,YACK;AAAA,YAACpM,GACViD,GAAa3C,CAAmB,KAAhC;AAAA,YAAiC4H,SAC3B;AAAA,UAAA;AAAA,UACVc,aACY;AAAA,YAAAoD,YACC;AAAA,YAACpM,GACViD,GAAa3C,CAAmB,KAAhC;AAAA,YAAiC4H,SAC3B;AAAA,YAACC,YACE;AAAA,cAAAjK,UAAYlC,EAAOkC;AAAAA,YAAAA;AAAAA,UAAU;AAAA,QAC3C,GAEM,SAAA,WACC,SAAAP,IAAA,gBAAA,UAAA,CAAoC;AAAA,MAAA,EAAA,CAC7C,IA/CL;AAAA,MAkDDuH,gBAAAA,MAAAwD,EAAA,MAAA,EACS,OAAAN,IAKD,MAAAE,IACI,UAAA;AAAA,QAAAO,SACC;AAAA,UAAAuD,YACK;AAAA,UAACpM,GACV0C,GAAUpC,CAAmB,KAA7B;AAAA,UAA8B4H,SACxB;AAAA,QAAA;AAAA,QACVc,aACY;AAAA,UAAAoD,YACC;AAAA,UAACpM,GACV0C,GAAUpC,CAAmB,KAA7B;AAAA,UAA8B4H,SACxB;AAAA,UAACC,YACE;AAAA,YAAAjK,UAAYlC,EAAOkC;AAAAA,UAAAA;AAAAA,QAAU;AAAA,MAC3C,GAEM,SAAA,WACC,SAAAP,IAAA,gBAAA,WAAoC;AAAA,MAE9CkB,IACCqG,gBAAAA,EAAAA,IAAA,QAAA,EACM,OACA5D,IAAAA,GACA,IAAAc,EAAEvD,EAAaiB,IAAK,GACpB,IAAAsC,EAAEvD,EAAaiB,IAAK,GACb,WAAAsJ,GACT,uEACAjM,GAAUkP,aACZ,GACO,OAAAnP,GAAMmP,cAAAA,KAVhB;AAAA,MAaD/C;AAAAA,MAsMCzN,KAAAqJ,gBAAAA,EAAAA,IAAA0D,EAAAA,UAAA,EAEI/M,UAAAA,GAAS6E,IAAK,CAAA4L,GAAAC,MACbrH,gBAAAA,EAAAA,IAACsH,IAAA,EAEO,MAAAtL,EAAE2J,MACD,OAAA3J,EAAE0J,OACN,GAAA1K,EAAEgB,EAAEuL,KAAgB,GACnB,IAAA,IAAIjR,GACJ,IAAA6F,IAAa3B,EAAMD,OACX,YAAAyB,EAAE/D,YACN,QAAA+D,EAAEhE,QACDlB,SAAAA,GACC2B,UAAAA,KATL0L,CASa,CAErB,GAAC,IAfL;AAAA,MAkBDyB;AAAAA,MAwEAI;AAAAA,MAiBCC;AAAAA,MACDO;AAAAA,IAAAA,EAAAA,CASF,EAAA,CACF;AAAA,IACCC;AAAAA,EAAAA,GASO;AACP;AA5sBA,SAAAN,GAAAqB,GAAA;AAAA,SAsrB8D1M,EAAC2M;AAAM;AAtrBrE,SAAAvB,GAAAwB,GAAA;AAAA,SAsrB6B5M,EAAC6M,aAAc;AAAO;AAtrBnD,SAAA/E,GAAAgF,GAAA;AAAA,SA8R+D9M,EAAC2M;AAAM;AA9RtE,SAAA9E,GAAAkF,GAAA;AAAA,SA8R6B/M,EAAC6M,aAAc;AAAQ;AA9RpD,SAAAb,GAAAgB,GAAA;AAAA,SAyN6BhN,MAAM;AAAC;AAzNpC,SAAA+L,GAAAkB,GAAA;AAAA,SAwNkCjN,MAAM;AAAC;AAxNzC,SAAA6E,GAAAqI,GAAA;AAAA,SAyLY,CAAC9M,EAAuBJ,EAACF,IAAK,KAA9B,CAAoCM,EAAuBJ,EAACE,CAAE;AAAC;AAzL3E,SAAAgE,GAAAiJ,GAAA;AAAA,SAqK4BnN,EAACF;AAAK;AArKlC,SAAAqC,GAAAiL,GAAA;AAAA,SA2HkCzL,KAAIM,IAAKjC,EAACE,GAAIF,EAACK,MAAOL,EAACG,IAAK;AAAC;AA3H/D,SAAA+B,GAAAmL,GAAA;AAAA,SA0HuD1L,KAAIM,IAAKjC,EAACE,GAAIF,EAACK,MAAOL,EAACG,IAAK;AAAC;AA1HpF,SAAA4B,GAAAuL,GAAA;AAAA,SAwHsC3L,KAAIC,IAAK5B,EAACE,GAAIF,EAACK,MAAOL,EAACG,IAAK;AAAC;AAxHnE,SAAA2B,GAAAyL,GAAA;AAAA,SAsHoC5L,KAAIC,IAAK5B,EAACE,GAAIF,EAACK,MAAOL,EAACG,IAAK;AAAC;AAtHjE,SAAA0B,GAAA2L,GAAA;AAAA,SAqHkC7L,KAAIC,IAAK5B,EAACE,GAAIF,EAACK,MAAOL,EAACG,IAAK;AAAC;AArH/D,SAAAM,GAAAT,GAAA;AAAA,SAqFY,CAACI,EAAuBJ,EAACE,CAAE;AAAC;ACtBxC,SAAAuN,GAAA/S,GAAA;AAAA,QAAAC,IAAAC,GAAAA,EAAA,EAAA,GACL;AAAA,IAAAC,MAAAA;AAAAA,IAAA6S,YAAAA;AAAAA,IAAAzS,QAAAuC;AAAAA,IAAAmQ,SAAAA;AAAAA,IAAAzS,QAAA8C;AAAAA,IAAA4P,kBAAAA;AAAAA,IAAA7S,QAAAA;AAAAA,IAAAD,OAAAA;AAAAA,IAAA+S,UAAAA;AAAAA,IAAAvS,YAAA2C;AAAAA,IAAA9C,YAAAiE;AAAAA,IAAA/D,YAAAgE;AAAAA,IAAAyO,iBAAAlO;AAAAA,IAAAmO,SAAAA;AAAAA,IAAA/S,WAAAA;AAAAA,IAAAQ,YAAAmF;AAAAA,IAAApF,aAAAqF;AAAAA,IAAAnF,WAAAuF;AAAAA,IAAAtF,cAAAuJ;AAAAA,IAAAtJ,SAAAA;AAAAA,IAAAE,WAAAuJ;AAAAA,IAAAhK,uBAAAmK;AAAAA,IAAAyI,gBAAAA;AAAAA,IAAApS,mBAAAA;AAAAA,IAAAqS,SAAAA;AAAAA,IAAAnS,UAAAA;AAAAA,IAAAC,UAAAA;AAAAA,IAAAO,gBAAAmJ;AAAAA,IAAAlJ,kBAAAmJ;AAAAA,IAAAlJ,oBAAAmJ;AAAAA,IAAAlJ,yBAAAmJ;AAAAA,IAAAlJ,oBAAAmJ;AAAAA,IAAAlJ,mBAAAmJ;AAAAA,IAAAlJ,qBAAAmJ;AAAAA,IAAAmI,eAAAlI;AAAAA,IAAAmI,cAAAlI;AAAAA,IAAAjK,SAAAkK;AAAAA,IAAAkI,UAAAhI;AAAAA,IAAAiI,WAAAhI;AAAAA,IAAAnK,aAAAoK;AAAAA,IAAAnK,UAAAoK;AAAAA,IAAAnK,aAAAsK;AAAAA,IAAArK,6BAAAwK;AAAAA,IAAAyH,OAAAxH;AAAAA,IAAAyH,WAAAA;AAAAA,IAAA1R,YAAAA;AAAAA,IAAAC,YAAAkK;AAAAA,IAAAjK,SAAAA;AAAAA,IAAAC,SAAAA;AAAAA,IAAAwR,kBAAAA;AAAAA,IAAAC,mBAAAA;AAAAA,IAAAC,mBAAAA;AAAAA,IAAAzR,WAAAgK;AAAAA,IAAA/J,QAAAA;AAAAA,IAAAC,YAAAA;AAAAA,IAAAC,WAAA8J;AAAAA,IAAA7J,cAAA8J;AAAAA,EAAAA,IA0DIzM,GAvDFO,IAAAuC,OAAAuB,SAAA,KAAAvB,IAEAtC,IAAA8C,MAAAe,SAAA,KAAAf,GAKA1C,KAAA2C,OAAAc,SAAA,KAAAd,IACA9C,IAAAiE,OAAAL,SAAA,SAAAK,IACA/D,KAAAgE,MAAAN,SAAA,KAAAM,GACAyO,KAAAlO,OAAAb,SAAA,KAAAa,IAGApE,KAAAmF,OAAA5B,SAAA,KAAA4B,IACApF,KAAAqF,OAAA7B,SAAA,KAAA6B,IACAnF,IAAAuF,OAAAjC,SAAA,KAAAiC,IACAtF,IAAAuJ,OAAAlG,SAAA,KAAAkG;AAAiB,MAAAoC;AAAA,EAAA1M,SAAAyK,MAEjBiC,KAAAjC,OAAArG,SAAA,CAAA,IAAAqG,IAAczK,OAAAyK,IAAAzK,OAAA0M,MAAAA,KAAA1M,EAAA,CAAA;AAAd,QAAAkB,KAAAwL;AAAc,MAAAC;AAAA,EAAA3M,SAAA4K,KACd+B,IAAA/B,MAAAxG,SAAA,CAAA,IAAAwG,GAA0B5K,OAAA4K,GAAA5K,OAAA2M,KAAAA,IAAA3M,EAAA,CAAA;AAA1B,QAAAS,IAAAkM,GAMAhL,IAAAmJ,OAAA1G,SAAA,KAAA0G,IACAlJ,KAAAmJ,OAAA3G,SAAA,KAAA2G,IACAlJ,IAAAmJ,MAAA5G,SAAA,KAAA4G,GACAlJ,KAAAmJ,OAAA7G,SAAA,IAAA6G;AAA2B,MAAA2B;AAAA,EAAA5M,SAAAkL,MAC3B0B,KAAA1B,OAAA9G,SAAA,CAAsB4P,GAAMC,MAAMC,MAAO,UAAU,GAAGF,GAAMC,MAAMC,MAAO,UAAU,CAAC,IAApFhJ,IAAqFlL,OAAAkL,IAAAlL,OAAA4M,MAAAA,KAAA5M,EAAA,CAAA;AAArF,QAAA+B,KAAA6K,IACA5K,KAAAmJ,OAAA/G,SAAoB4P,GAAMG,cAAe,UAAU,IAAnDhJ,IACAlJ,KAAAmJ,OAAAhH,SAAA,MAAAgH,IACAmI,KAAAlI,OAAAjH,SAAA,KAAAiH,IACAmI,KAAAlI,OAAAlH,SAAA,KAAAkH,IACAjK,KAAAkK,OAAAnH,SAAA,KAAAmH,IACAkI,IAAAhI,MAAArH,SAAA,OAAAqH,GACAiI,KAAAhI,MAAAtH,SAAA,IAAAsH,GACAnK,KAAAoK,MAAAvH,SAAA,IAAAuH,GACAnK,KAAAoK,MAAAxH,SAAA,KAAAwH;AAAe,MAAAkB;AAAA,EAAA9M,SAAA+L,MACfe,KAAAf,OAAA3H,SAAA,CAAA,IAAA2H,IAAgB/L,OAAA+L,IAAA/L,OAAA8M,MAAAA,KAAA9M,EAAA,CAAA;AAAhB,QAAAyB,KAAAqL;AAAgB,MAAAC;AAAA,EAAA/M,SAAAkM,KAChBa,IAAAb,MAAA9H,SAAA,CAAA,IAAA8H,GAAgClM,OAAAkM,GAAAlM,OAAA+M,KAAAA,IAAA/M,EAAA,CAAA;AAAhC,QAAA0B,KAAAqL,GACA4G,KAAAxH,MAAA/H,SAAA,UAAA+H,GAGAhK,KAAAkK,OAAAjI,SAAA,IAAAiI,IAMA/J,KAAAgK,OAAAlI,SAAA,UAAAkI,IAGA7J,KAAA8J,OAAAnI,SAAA,IAAAmI;AAAa,MAAAU;AAAA,EAAAjN,UAAAwM,KACbS,IAAAT,MAAApI,SAAA,CAAA,IAAAoI,GAAiBxM,QAAAwM,GAAAxM,QAAAiN,KAAAA,IAAAjN,EAAA,EAAA;AAAjB,QAAA0C,KAAAuK,GAGF,CAAAmH,GAAAC,EAAA,IAAgCjR,GAAS,CAAC,GAC1C,CAAAkR,GAAAC,EAAA,IAAkCnR,GAAS,CAAC,GAE5CoR,KAAiB5R,GAAuB,IAAI,GAC5C6R,IAAuB7R,GAAuB,IAAI;AAAE,MAAAwK,IAAAE;AAAA,EAAAtN,EAAA,EAAA,MAAA4Q,OAAAC,IAAA,2BAAA,KAC1CzD,KAAAA,MAAA;AACR,UAAAsH,KAAuB,IAAIC,eAAeC,CAAAA,OAAA;AACxCP,MAAAA,GAAYO,GAAO,CAAA,EAAGC,OAAOC,eAAjB,GAAoC,GAChDP,GAAaK,GAAO,CAAA,EAAGC,OAAOE,gBAAjB,GAAqC;AAAA,IAAC,CACpD;AACD,WAAIP,GAAQ1K,WACV4K,GAAcM,QAASR,GAAQ1K,OAAQ,GAElC,MAAM4K,GAAcO,WAAAA;AAAAA,EAAa,GACvC3H,KAAA,CAAA,GAAEtN,QAAAoN,IAAApN,QAAAsN,OAAAF,KAAApN,EAAA,EAAA,GAAAsN,KAAAtN,EAAA,EAAA,IATL2D,GAAUyJ,IASPE,EAAE;AAIU,QAAAG,IAAAjL,GAAU0S,gBACdvH,KAAApL,GAAM2S;AAAgB,MAAAtH;AAAA,EAAA5N,UAAAwC,GAAA2S,eAAAnV,UAAAwC,GAAAqK,SAAA7M,UAAAE,KAAAF,EAAA,EAAA,MAAAwT,MAAAxT,EAAA,EAAA,MAAAiT,KAAAjT,EAAA,EAAA,MAAAuT,MAAAvT,UAAA+S,KAAA/S,EAAA,EAAA,MAAAuC,GAAA4S,eAAAnV,EAAA,EAAA,MAAAuC,GAAAsK,SAAA7M,EAAA,EAAA,MAAAG,KAa5ByN,IAAAmF,KAAAE,KAAAM,MAAAC,KACCjJ,gBAAAA,MAAC6K,MACS,QAAA;AAAA,IAAAvI,OACCtK,GAAMsK;AAAAA,IAAOsI,aACP5S,GAAM4S;AAAAA,EAAAA,GAET,YAAA;AAAA,IAAAtI,OACHrK,GAAUqK;AAAAA,IAAOsI,aACX3S,GAAU2S;AAAAA,EAAAA,GAEbpC,YAAAA,GACME,kBAAAA,GACX9S,OAAAA,GACQ,eAAAoT,KAAAkB,IAAArQ,QAEb,cAAAoP,KACItT,EAAI6F,IAAKD,EAAW,EAACD,OAAQqB,EAAoB,EAACJ,SAAU,IAC1D5G,EAAI6F,IAAKoB,EAAW,EAACtB,OAAQuB,EACG,IAAhClH,EAAI2F,OAAQ0B,EAAoB,IAHtC,MAIQ,IAnBb,MAsBOvH,EAAA,EAAA,IAAAwC,GAAA2S,aAAAnV,EAAA,EAAA,IAAAwC,GAAAqK,OAAA7M,QAAAE,GAAAF,QAAAwT,IAAAxT,QAAAiT,GAAAjT,QAAAuT,IAAAvT,QAAA+S,GAAA/S,EAAA,EAAA,IAAAuC,GAAA4S,aAAAnV,EAAA,EAAA,IAAAuC,GAAAsK,OAAA7M,QAAAG,GAAAH,QAAA4N,KAAAA,IAAA5N,EAAA,EAAA;AAAA,MAAA2O;AAAA,EAAA3O,EAAA,EAAA,MAAAqB,MAAArB,EAAA,EAAA,MAAAyB,MAAAzB,EAAA,EAAA,MAAAe,KAAAf,EAAA,EAAA,MAAAwC,KAAAxC,UAAA8T,MAAA9T,EAAA,EAAA,MAAA+T,KAAA/T,UAAA6T,KAAA7T,EAAA,EAAA,MAAAsC,MAAAtC,EAAA,EAAA,MAAA0B,MAAA1B,UAAA0C,MAAA1C,EAAA,EAAA,MAAAE,KAAAF,UAAAQ,KAAAR,EAAA,EAAA,MAAAS,KAAAT,EAAA,EAAA,MAAAgC,MAAAhC,UAAAiC,MAAAjC,EAAA,EAAA,MAAA+B,MAAA/B,EAAA,EAAA,MAAA8B,MAAA9B,EAAA,EAAA,MAAAyT,KAAAzT,EAAA,EAAA,MAAAa,MAAAb,UAAAK,KAAAL,EAAA,EAAA,MAAAqC,KAAArC,EAAA,EAAA,MAAAoB,MAAApB,EAAA,EAAA,MAAAoC,KAAApC,EAAA,EAAA,MAAAmB,MAAAnB,UAAAW,MAAAX,EAAA,EAAA,MAAAmC,MAAAnC,UAAAiB,MAAAjB,EAAA,EAAA,MAAAyC,MAAAzC,UAAAO,KAAAP,EAAA,EAAA,MAAAkB,MAAAlB,EAAA,EAAA,MAAA2B,KAAA3B,UAAAY,MAAAZ,EAAA,EAAA,MAAAwB,MAAAxB,EAAA,EAAA,MAAA4B,MAAA5B,EAAA,EAAA,MAAA6B,KAAA7B,EAAA,EAAA,MAAAU,MAAAV,UAAAuB,MAAAvB,EAAA,EAAA,MAAAuC,KAAAvC,EAAA,EAAA,MAAAM,KAAAN,EAAA,EAAA,MAAAsU,KAAAtU,EAAA,EAAA,MAAAoU,KAAApU,UAAAgB,KAAAhB,EAAA,EAAA,MAAAc,KAAAd,EAAA,EAAA,MAAAG,KAAAH,UAAAkC,MACPyM,IAAAzO,EAAI4G,WAAY,IACfyD,gBAAAA,EAAAA,IAAC8K,IAAA,CAAA,KADFrH,gBAAAA,EAAAA,KAAAC,EAAAA,UAAA,EAII6F,UAAAA;AAAAA,IAAAA,MAAAC,IACCxJ,gBAAAA,MAAC+K,IAAA,EACQnV,OAAAA,GACW0T,kBAAAA,GACVC,QAAAA,IACKC,aAAAA,GACA,iBACF,WAAAvR,GAAU+S,aAAa,IAPrC;AAAA,0BAUAC,IAAA,EAAehB,KAAAA,IACbJ,UAAAA,KAAAE,0BACExU,IAAA,EACOI,MAAAA,GACK,WAAAG,KAAa2T,GAAMG,cAAe,UAAU,GAChDC,OAAAA,GACCE,QAAAA,GACAhU,QAAAA,GACAC,QAAAA,GACIC,YAAAA,GACAE,YAAAA,IACA,YAAAC,MAAc8U,GAAarB,CAAQ,GACnCvT,YAAAA,IACCD,aAAAA,IACFE,WAAAA,GACGC,cAAAA,GACLC,SAAAA,GACcP,uBAAAA,GACJQ,mBAAAA,IACRC,WAAAA,IACDC,UAAAA,IACAC,UAAAA,IAER,SAAAC,OAAY,KAAZ;AAAA,MAAAkC,UACgB;AAAA,MAAGR,MAAQ;AAAA,MAAID,QAAU;AAAA,IAAA,IACrCzB,MAAA;AAAA,MAAAkC,UAAuB;AAAA,MAACR,MAAQ;AAAA,MAAID,QAAU;AAAA,IAAA,GAE/C,KAAA2Q,MAAa,QAAQA,MAAa,MAC1BlS,aAAAA,IACHC,UAAAA,IACGC,aAAAA,IACgBC,6BAAAA,IACbC,gBAAAA,GACEC,kBAAAA,IACEC,oBAAAA,GACKC,yBAAAA,IACLC,oBAAAA,IACDC,mBAAAA,IACEC,qBAAAA,IACTC,YAAAA,IACAC,YAAAA,IACHC,SAAAA,GACAC,SAAAA,GACEC,WAAAA,IACHC,QAAAA,GACIC,YAAAA,GACDC,WAAAA,IACGC,cAAAA,GAAAA,CAAY,IA9C7B,KAAA,CAiDH;AAAA,EAAA,GAAY,GAEf1C,QAAAqB,IAAArB,QAAAyB,IAAAzB,QAAAe,GAAAf,QAAAwC,GAAAxC,QAAA8T,IAAA9T,QAAA+T,GAAA/T,QAAA6T,GAAA7T,QAAAsC,IAAAtC,QAAA0B,IAAA1B,QAAA0C,IAAA1C,QAAAE,GAAAF,QAAAQ,GAAAR,QAAAS,GAAAT,QAAAgC,IAAAhC,QAAAiC,IAAAjC,QAAA+B,IAAA/B,QAAA8B,IAAA9B,QAAAyT,GAAAzT,QAAAa,IAAAb,QAAAK,GAAAL,QAAAqC,GAAArC,QAAAoB,IAAApB,QAAAoC,GAAApC,QAAAmB,IAAAnB,QAAAW,IAAAX,QAAAmC,IAAAnC,QAAAiB,IAAAjB,QAAAyC,IAAAzC,QAAAO,GAAAP,QAAAkB,IAAAlB,QAAA2B,GAAA3B,QAAAY,IAAAZ,QAAAwB,IAAAxB,QAAA4B,IAAA5B,QAAA6B,GAAA7B,QAAAU,IAAAV,QAAAuB,IAAAvB,QAAAuC,GAAAvC,QAAAM,GAAAN,QAAAsU,GAAAtU,QAAAoU,GAAApU,QAAAgB,GAAAhB,QAAAc,GAAAd,QAAAG,GAAAH,QAAAkC,IAAAlC,QAAA2O,KAAAA,IAAA3O,EAAA,EAAA;AAAA,MAAA4O;AAAA,EAAA5O,EAAA,EAAA,MAAAwC,GAAAkT,YAAA1V,EAAA,EAAA,MAAAwC,GAAAmT,UAAA3V,EAAA,EAAA,MAAAkT,MAAAlT,EAAA,EAAA,MAAAgT,KAAAhT,EAAA,EAAA,MAAAuC,GAAAmT,YAAA1V,EAAA,EAAA,MAAAuC,GAAAoT,UAAA3V,UAAAG,KACAyO,IAAAoE,KAAAE,KACC3I,gBAAAA,EAAAA,IAACqL,IAAA,EACS,QAAA;AAAA,IAAAF,UAAYnT,GAAMmT;AAAAA,IAAUC,QAAUpT,GAAMoT;AAAAA,EAAAA,GACxC,YAAA;AAAA,IAAAD,UACAlT,GAAUkT;AAAAA,IAAUC,QACtBnT,GAAUmT;AAAAA,EAAAA,GAEX3C,SAAAA,GACCE,UAAAA,IACH/S,OAAAA,EAAAA,CAAK,IATf,MAWOH,EAAA,EAAA,IAAAwC,GAAAkT,UAAA1V,EAAA,EAAA,IAAAwC,GAAAmT,QAAA3V,QAAAkT,IAAAlT,QAAAgT,GAAAhT,EAAA,EAAA,IAAAuC,GAAAmT,UAAA1V,EAAA,EAAA,IAAAuC,GAAAoT,QAAA3V,QAAAG,GAAAH,QAAA4O,KAAAA,IAAA5O,EAAA,EAAA;AAAA,MAAAmQ;AAAA,SAAAnQ,EAAA,EAAA,MAAA4T,KAAA5T,EAAA,EAAA,MAAAmT,MAAAnT,EAAA,EAAA,MAAAsT,MAAAtT,EAAA,EAAA,MAAAI,KAAAJ,EAAA,EAAA,MAAAyT,KAAAzT,EAAA,EAAA,MAAA0T,MAAA1T,EAAA,EAAA,MAAAoT,MAAApT,UAAAqT,MAAArT,EAAA,EAAA,MAAAyN,KAAAzN,EAAA,EAAA,MAAA2N,MAAA3N,EAAA,EAAA,MAAA4N,KAAA5N,EAAA,EAAA,MAAA2O,KAAA3O,EAAA,EAAA,MAAA4O,KAAA5O,EAAA,EAAA,MAAA2T,MAAA3T,EAAA,EAAA,MAAAG,KApHVgQ,4BAAC0F,IAAA,EACY,WAAApI,GACJ,OAAAE,IACH2F,IAAAA,IACCmB,KAAAA,GACOb,cAAAA,GACKT,iBAAAA,IACVQ,OAAAA,IACGF,UAAAA,GACCC,WAAAA,IACJvT,OAAAA,GACCC,QAAAA,GACQiT,gBAAAA,IACPD,SAAAA,IAERxF,UAAAA;AAAAA,IAAAA;AAAAA,IAuBAe;AAAAA,IAmEAC;AAAAA,EAAAA,GAYH,GAAiB5O,QAAA4T,GAAA5T,QAAAmT,IAAAnT,QAAAsT,IAAAtT,QAAAI,GAAAJ,QAAAyT,GAAAzT,QAAA0T,IAAA1T,QAAAoT,IAAApT,QAAAqT,IAAArT,QAAAyN,GAAAzN,QAAA2N,IAAA3N,QAAA4N,GAAA5N,QAAA2O,GAAA3O,QAAA4O,GAAA5O,QAAA2T,IAAA3T,QAAAG,GAAAH,QAAAmQ,MAAAA,KAAAnQ,EAAA,EAAA,GArHjBmQ;AAqHiB;AAnMd,SAAA5I,GAAArB,GAAA;AAAA,SA+G4Bb,MAAMjB;AAAS;AA/G3C,SAAAgD,GAAAlC,GAAA;AAAA,SA8G6CG,MAAMjB;AAAS;AA9G5D,SAAA+C,GAAA9B,GAAA;AAAA,SA8GyBA,EAACnF;AAAK;AA9G/B,SAAAgH,GAAAyL,GAAA;AAAA,SA6G2CtN,MAAMjB;AAAS;AA7G1D,SAAA0B,GAAAQ,GAAA;AAAA,SA6GuBjB,EAACnF;AAAK;"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("./index-CHPV5EwG-CTPQjnHt.cjs"),n=require("react"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("./index-CHPV5EwG-CTPQjnHt.cjs"),n=require("react"),k=require("./index-CyZ1lmi_.cjs"),v=require("./index-BS2TADPj.cjs"),f=require("./DropdownSelect-Doz3mCrM.cjs"),U=require("./checkIfMultiple-wg6hJLXy.cjs"),W=require("./GraphContainer-d8A46BK2.cjs"),$=require("./SingleGraphDashboard.cjs"),h=require("./fetchAndParseData-l5HGMAEs.cjs"),L=require("./getUniqValue-RViz8tTw.cjs"),I=require("./GraphHeader.cjs"),z=require("./filterData-T5DQBE9b.cjs"),F=require("./transformDataForSelect-YmStusCI.cjs"),S=g=>g.map(a=>a.columnWidth||1).reduce((a,p)=>a+p,0),J=["barChart","choroplethMap","biVariateChoroplethMap","circlePacking","treeMap"];function B(g){const{dashboardID:j,dashboardLayout:s,dataSettings:a,filters:p,debugMode:c,theme:D="light",readableHeader:V,dataFilters:A,noOfFiltersPerRow:x=4,filterPosition:w,uiMode:b="normal",graphStyles:q,graphClassNames:O}=g,[y,E]=n.useState(void 0),[d,M]=n.useState(void 0),[l,R]=n.useState([]),T={ignoreCase:!0,ignoreAccents:!0,trim:!0},C=n.useEffectEvent(()=>{const t=(p||[]).map(r=>({filter:r.column,label:r.label||`Filter by ${r.column}`,singleSelect:r.singleSelect,clearable:r.clearable,defaultValue:F.transformDefaultValue(r.defaultValue),value:F.transformDefaultValue(r.defaultValue),availableValues:L.getUniqValue(d,r.column).filter(e=>!r.excludeValues?.includes(`${e}`)).map(e=>({value:e,label:e})),allowSelectAll:r.allowSelectAll,width:r.width}));R(t)}),N=n.useEffectEvent(()=>{if(!d||l.length===0)E(d);else{const t=d.filter(r=>l.every(e=>e.value&&v.flattenDeep([e.value]).length>0?k.intersection(v.flattenDeep([r[e.filter]]),v.flattenDeep([e.value]).map(o=>o.value)).length>0:!0));E(t)}});n.useEffect(()=>{N()},[l,d]),n.useEffect(()=>{(async()=>{try{const r=a.dataURL?typeof a.dataURL=="string"?a.fileType==="json"?await h.fetchAndParseJSON(a.dataURL,a.columnsToArray,a.dataTransformation,c):a.fileType==="api"?await h.fetchAndTransformDataFromAPI(a.dataURL,a.apiHeaders,a.columnsToArray,a.dataTransformation,c):await h.fetchAndParseCSV(a.dataURL,a.dataTransformation,a.columnsToArray,c,a.delimiter,!0):await h.fetchAndParseMultipleDataSources(a.dataURL,a.idColumnTitle):await h.transformColumnsToArray(a.data,a.columnsToArray);M(r)}catch(r){console.error("Data fetching error:",r)}})(),C()},[a,c]),n.useEffect(()=>{C()},[p]);const m=(t,r)=>{R(e=>e.map(o=>o.filter===t?{...o,value:r}:o))};return i.jsxRuntimeExports.jsxs(W.GraphContainer,{id:j,"aria-label":"This is a dashboard",backgroundColor:s.backgroundColor??!1,theme:D||"light",language:s.language||"en",padding:s.padding,children:[s.title||s.description?i.jsxRuntimeExports.jsx(I.GraphHeader,{graphTitle:s.title,graphDescription:s.description,isDashboard:!0}):null,i.jsxRuntimeExports.jsxs("div",{className:"flex gap-4 flex-wrap",children:[l.length!==0?i.jsxRuntimeExports.jsx("div",{className:"flex-grow flex-shrink-0",style:{width:w==="side"?"280px":"100%"},children:i.jsxRuntimeExports.jsx("div",{className:"flex flex-wrap items-start gap-4 w-full sticky top-4",children:l?.map((t,r)=>i.jsxRuntimeExports.jsxs("div",{style:{width:t.width||`calc(${100/x}% - ${(x-1)/x}rem)`,flexGrow:1,flexShrink:0,minWidth:"240px"},children:[i.jsxRuntimeExports.jsx(U.b,{className:"mb-2",children:t.label}),t.singleSelect?i.jsxRuntimeExports.jsx(f.ja,{options:t.availableValues,isClearable:t.clearable===void 0?!0:t.clearable,size:"sm",variant:b,isMulti:!1,isSearchable:!0,filterOption:f.Du(T),onChange:e=>{m(t.filter,e)},defaultValue:t.defaultValue,value:t.value}):i.jsxRuntimeExports.jsxs(i.jsxRuntimeExports.Fragment,{children:[i.jsxRuntimeExports.jsx(f.ja,{options:t.availableValues,isMulti:!0,size:"sm",isClearable:t.clearable===void 0?!0:t.clearable,variant:b,isSearchable:!0,controlShouldRenderValue:!0,closeMenuOnSelect:!1,hideSelectedOptions:!1,filterOption:f.Du(T),onChange:e=>{m(t.filter,e)},value:t.value,defaultValue:t.defaultValue}),t.allowSelectAll?i.jsxRuntimeExports.jsx("button",{type:"button",className:"bg-transparent border-0 p-0 mt-2 cursor-pointer text-primary-blue-600 dark:text-primary-blue-400",onClick:()=>{m(t.filter,t.availableValues)},children:"Select all options"}):null]})]},r))})}):null,i.jsxRuntimeExports.jsx("div",{className:"flex flex-wrap gap-4 flex-grow flex-shrink-0 min-w-[280px]",style:{width:w==="side"?"calc(100% - 280px - 1rem)":"100%"},children:s.rows.map((t,r)=>i.jsxRuntimeExports.jsx("div",{className:"flex flex-wrap items-stretch gap-4 w-full h-auto",style:{minHeight:`${t.height||0}px`},children:t.columns.map((e,o)=>i.jsxRuntimeExports.jsx("div",{className:"flex bg-transparent grow min-w-60",style:{width:`calc(${100*(e.columnWidth||1)/S(t.columns)}% - ${(S(t.columns)-(e.columnWidth||1))/S(t.columns)}rem)`,minHeight:"inherit"},children:i.jsxRuntimeExports.jsx($.SingleGraphDashboard,{graphType:e.graphType,dataFilters:e.dataFilters,uiMode:b,graphSettings:{...e.settings||{},width:void 0,height:void 0,minHeight:void 0,relativeHeight:void 0,resetSelectionOnDoubleClick:e.attachedFilter?!1:e.settings?.resetSelectionOnDoubleClick,styles:e.settings?.styles||q,classNames:e.settings?.classNames||O,radius:e.graphType==="donutChart"?void 0:e.settings?.radius,size:e.graphType==="unitChart"?e.settings?.size:void 0,language:e.settings?.language||s.language,theme:e.settings?.theme||D},dataSettings:{data:y?z.filterData(y,A||[]):void 0},updateFilters:e.attachedFilter&&J.indexOf(e.graphType)!==-1&&l.findIndex(u=>u.filter===e.attachedFilter)!==-1?u=>{const G=l.findIndex(P=>P.filter===e.attachedFilter),H=u?l[G].singleSelect?{value:u,label:u}:[{value:u,label:u}]:void 0;m(e.attachedFilter,H)}:void 0,dataTransform:e.dataTransform,dataSelectionOptions:e.dataSelectionOptions,advancedDataSelectionOptions:e.advancedDataSelectionOptions,graphDataConfiguration:e.graphDataConfiguration,debugMode:c,readableHeader:V||[]})},o))},r))})]})]})}exports.MultiGraphDashboard=B;
|
|
2
2
|
//# sourceMappingURL=MultiGraphDashboard.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MultiGraphDashboard.cjs","sources":["../src/Components/Dashboard/MultiGraphDashboard.tsx"],"sourcesContent":["import { useEffect, useEffectEvent, useState } from 'react';\r\nimport intersection from 'lodash.intersection';\r\nimport flattenDeep from 'lodash.flattendeep';\r\nimport { createFilter, DropdownSelect } from '@undp/design-system-react/DropdownSelect';\r\nimport { Label } from '@undp/design-system-react/Label';\r\n\r\nimport { GraphContainer } from '../Elements/GraphContainer';\r\n\r\nimport { SingleGraphDashboard } from './SingleGraphDashboard';\r\n\r\nimport {\r\n ClassNameObject,\r\n DashboardColumnDataType,\r\n DashboardLayoutDataType,\r\n DataFilterDataType,\r\n DataSettingsDataType,\r\n FilterSettingsDataType,\r\n FilterUiSettingsDataType,\r\n GraphType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport {\r\n fetchAndParseCSV,\r\n fetchAndParseJSON,\r\n fetchAndParseMultipleDataSources,\r\n fetchAndTransformDataFromAPI,\r\n} from '@/Utils/fetchAndParseData';\r\nimport { getUniqValue } from '@/Utils/getUniqValue';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { transformColumnsToArray } from '@/Utils/transformData/transformColumnsToArray';\r\nimport { filterData } from '@/Utils/transformData/filterData';\r\nimport { transformDefaultValue } from '@/Utils/transformDataForSelect';\r\n\r\ninterface Props {\r\n dashboardID?: string;\r\n dashboardLayout: DashboardLayoutDataType;\r\n dataSettings: DataSettingsDataType;\r\n filters?: FilterUiSettingsDataType[];\r\n noOfFiltersPerRow?: number;\r\n dataFilters?: DataFilterDataType[];\r\n debugMode?: boolean;\r\n theme?: 'dark' | 'light';\r\n filterPosition?: 'top' | 'side';\r\n readableHeader?: {\r\n value: string;\r\n label: string;\r\n }[];\r\n uiMode?: 'light' | 'normal';\r\n graphStyles?: StyleObject;\r\n graphClassNames?: ClassNameObject;\r\n}\r\n\r\nconst TotalWidth = (columns: DashboardColumnDataType[]) => {\r\n const columnWidth = columns.map(d => d.columnWidth || 1);\r\n const sum = columnWidth.reduce((acc, cur) => acc + cur, 0);\r\n return sum;\r\n};\r\n\r\nconst GraphWithAttachedFilter: GraphType[] = [\r\n 'barChart',\r\n 'choroplethMap',\r\n 'biVariateChoroplethMap',\r\n 'circlePacking',\r\n 'treeMap',\r\n];\r\n\r\nexport function MultiGraphDashboard(props: Props) {\r\n const {\r\n dashboardID,\r\n dashboardLayout,\r\n dataSettings,\r\n filters,\r\n debugMode,\r\n theme = 'light',\r\n readableHeader,\r\n dataFilters,\r\n noOfFiltersPerRow = 4,\r\n filterPosition,\r\n uiMode = 'normal',\r\n graphStyles,\r\n graphClassNames,\r\n } = props;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [filteredData, setFilteredData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [data, setData] = useState<any>(undefined);\r\n const [filterSettings, setFilterSettings] = useState<FilterSettingsDataType[]>([]);\r\n\r\n const filterConfig = {\r\n ignoreCase: true,\r\n ignoreAccents: true,\r\n trim: true,\r\n };\r\n\r\n const updateFiltersEvent = useEffectEvent(() => {\r\n const filterSettingsTemp = (filters || []).map(el => ({\r\n filter: el.column,\r\n label: el.label || `Filter by ${el.column}`,\r\n singleSelect: el.singleSelect,\r\n clearable: el.clearable,\r\n defaultValue: transformDefaultValue(el.defaultValue),\r\n value: transformDefaultValue(el.defaultValue),\r\n availableValues: getUniqValue(data, el.column)\r\n .filter(v => !el.excludeValues?.includes(`${v}`))\r\n .map(v => ({ value: v, label: v })),\r\n allowSelectAll: el.allowSelectAll,\r\n width: el.width,\r\n }));\r\n setFilterSettings(filterSettingsTemp);\r\n });\r\n\r\n const filteredDataEvent = useEffectEvent(() => {\r\n if (!data || filterSettings.length === 0) setFilteredData(data);\r\n else {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const result = data.filter((item: any) =>\r\n filterSettings.every(filter =>\r\n filter.value && flattenDeep([filter.value]).length > 0\r\n ? intersection(\r\n flattenDeep([item[filter.filter]]),\r\n flattenDeep([filter.value]).map(el => el.value),\r\n ).length > 0\r\n : true,\r\n ),\r\n );\r\n setFilteredData(result);\r\n }\r\n });\r\n useEffect(() => {\r\n filteredDataEvent();\r\n }, [filterSettings, data]);\r\n\r\n useEffect(() => {\r\n const fetchData = async () => {\r\n try {\r\n const dataFromFile = dataSettings.dataURL\r\n ? typeof dataSettings.dataURL === 'string'\r\n ? dataSettings.fileType === 'json'\r\n ? await fetchAndParseJSON(\r\n dataSettings.dataURL,\r\n dataSettings.columnsToArray,\r\n dataSettings.dataTransformation,\r\n debugMode,\r\n )\r\n : dataSettings.fileType === 'api'\r\n ? await fetchAndTransformDataFromAPI(\r\n dataSettings.dataURL,\r\n dataSettings.apiHeaders,\r\n dataSettings.columnsToArray,\r\n dataSettings.dataTransformation,\r\n debugMode,\r\n )\r\n : await fetchAndParseCSV(\r\n dataSettings.dataURL,\r\n dataSettings.dataTransformation,\r\n dataSettings.columnsToArray,\r\n debugMode,\r\n dataSettings.delimiter,\r\n true,\r\n )\r\n : await fetchAndParseMultipleDataSources(\r\n dataSettings.dataURL,\r\n dataSettings.idColumnTitle,\r\n )\r\n : await transformColumnsToArray(dataSettings.data, dataSettings.columnsToArray);\r\n setData(dataFromFile);\r\n } catch (error) {\r\n console.error('Data fetching error:', error);\r\n }\r\n };\r\n fetchData();\r\n updateFiltersEvent();\r\n }, [dataSettings, debugMode]);\r\n\r\n useEffect(() => {\r\n updateFiltersEvent();\r\n }, [filters]);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleFilterChange = (filter: string, values: any) => {\r\n setFilterSettings(prev => prev.map(f => (f.filter === filter ? { ...f, value: values } : f)));\r\n };\r\n return (\r\n <GraphContainer\r\n id={dashboardID}\r\n aria-label='This is a dashboard'\r\n backgroundColor={dashboardLayout.backgroundColor ?? false}\r\n theme={theme || 'light'}\r\n language={dashboardLayout.language || 'en'}\r\n padding={dashboardLayout.padding}\r\n >\r\n {dashboardLayout.title || dashboardLayout.description ? (\r\n <GraphHeader\r\n graphTitle={dashboardLayout.title}\r\n graphDescription={dashboardLayout.description}\r\n isDashboard\r\n />\r\n ) : null}\r\n <div className='flex gap-4 flex-wrap'>\r\n {filterSettings.length !== 0 ? (\r\n <div\r\n className='flex-grow flex-shrink-0'\r\n style={{\r\n width: filterPosition === 'side' ? '280px' : '100%',\r\n }}\r\n >\r\n <div className='flex flex-wrap items-start gap-4 w-full sticky top-4'>\r\n {filterSettings?.map((d, i) => (\r\n <div\r\n style={{\r\n width:\r\n d.width ||\r\n `calc(${100 / noOfFiltersPerRow}% - ${\r\n (noOfFiltersPerRow - 1) / noOfFiltersPerRow\r\n }rem)`,\r\n flexGrow: 1,\r\n flexShrink: 0,\r\n minWidth: '240px',\r\n }}\r\n key={i}\r\n >\r\n <Label className='mb-2'>{d.label}</Label>\r\n {d.singleSelect ? (\r\n <DropdownSelect\r\n options={d.availableValues}\r\n isClearable={d.clearable === undefined ? true : d.clearable}\r\n size='sm'\r\n variant={uiMode}\r\n isMulti={false}\r\n isSearchable\r\n filterOption={createFilter(filterConfig)}\r\n onChange={el => {\r\n handleFilterChange(d.filter, el);\r\n }}\r\n defaultValue={d.defaultValue}\r\n value={d.value}\r\n />\r\n ) : (\r\n <>\r\n <DropdownSelect\r\n options={d.availableValues}\r\n isMulti\r\n size='sm'\r\n isClearable={d.clearable === undefined ? true : d.clearable}\r\n variant={uiMode}\r\n isSearchable\r\n controlShouldRenderValue\r\n closeMenuOnSelect={false}\r\n hideSelectedOptions={false}\r\n filterOption={createFilter(filterConfig)}\r\n onChange={el => {\r\n handleFilterChange(d.filter, el);\r\n }}\r\n value={d.value}\r\n defaultValue={d.defaultValue}\r\n />\r\n {d.allowSelectAll ? (\r\n <button\r\n type='button'\r\n className='bg-transparent border-0 p-0 mt-2 cursor-pointer text-primary-blue-600 dark:text-primary-blue-400'\r\n onClick={() => {\r\n handleFilterChange(d.filter, d.availableValues);\r\n }}\r\n >\r\n Select all options\r\n </button>\r\n ) : null}\r\n </>\r\n )}\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n ) : null}\r\n <div\r\n className='flex flex-wrap gap-4 flex-grow flex-shrink-0 min-w-[280px]'\r\n style={{\r\n width: filterPosition === 'side' ? 'calc(100% - 280px - 1rem)' : '100%',\r\n }}\r\n >\r\n {dashboardLayout.rows.map((d, i) => (\r\n <div\r\n key={i}\r\n className='flex flex-wrap items-stretch gap-4 w-full h-auto'\r\n style={{\r\n minHeight: `${d.height || 0}px`,\r\n }}\r\n >\r\n {d.columns.map((el, j) => (\r\n <div\r\n key={j}\r\n className='flex bg-transparent h-inherit grow min-w-60'\r\n style={{\r\n width: `calc(${(100 * (el.columnWidth || 1)) / TotalWidth(d.columns)}% - ${\r\n (TotalWidth(d.columns) - (el.columnWidth || 1)) / TotalWidth(d.columns)\r\n }rem)`,\r\n minHeight: 'inherit',\r\n }}\r\n >\r\n <SingleGraphDashboard\r\n graphType={el.graphType}\r\n dataFilters={el.dataFilters}\r\n uiMode={uiMode}\r\n graphSettings={{\r\n ...(el.settings || {}),\r\n width: undefined,\r\n height: undefined,\r\n resetSelectionOnDoubleClick: el.attachedFilter\r\n ? false\r\n : el.settings?.resetSelectionOnDoubleClick,\r\n styles: el.settings?.styles || graphStyles,\r\n classNames: el.settings?.classNames || graphClassNames,\r\n radius: el.graphType === 'donutChart' ? undefined : el.settings?.radius,\r\n size: el.graphType === 'unitChart' ? el.settings?.size : undefined,\r\n language: el.settings?.language || dashboardLayout.language,\r\n theme: el.settings?.theme || theme,\r\n }}\r\n dataSettings={{\r\n data: filteredData ? filterData(filteredData, dataFilters || []) : undefined,\r\n }}\r\n updateFilters={\r\n el.attachedFilter &&\r\n GraphWithAttachedFilter.indexOf(el.graphType) !== -1 &&\r\n filterSettings.findIndex(f => f.filter === el.attachedFilter) !== -1\r\n ? dClicked => {\r\n const indx = filterSettings.findIndex(\r\n f => f.filter === el.attachedFilter,\r\n );\r\n const value = dClicked\r\n ? filterSettings[indx].singleSelect\r\n ? { value: dClicked, label: dClicked }\r\n : [{ value: dClicked, label: dClicked }]\r\n : undefined;\r\n handleFilterChange(el.attachedFilter as string, value);\r\n }\r\n : undefined\r\n }\r\n dataTransform={el.dataTransform}\r\n dataSelectionOptions={el.dataSelectionOptions}\r\n advancedDataSelectionOptions={el.advancedDataSelectionOptions}\r\n graphDataConfiguration={el.graphDataConfiguration}\r\n debugMode={debugMode}\r\n readableHeader={readableHeader || []}\r\n />\r\n </div>\r\n ))}\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["TotalWidth","columns","map","d","columnWidth","reduce","acc","cur","GraphWithAttachedFilter","MultiGraphDashboard","props","dashboardID","dashboardLayout","dataSettings","filters","debugMode","theme","readableHeader","dataFilters","noOfFiltersPerRow","filterPosition","uiMode","graphStyles","graphClassNames","filteredData","setFilteredData","useState","undefined","data","setData","filterSettings","setFilterSettings","filterConfig","ignoreCase","ignoreAccents","trim","updateFiltersEvent","useEffectEvent","filterSettingsTemp","el","filter","column","label","singleSelect","clearable","defaultValue","transformDefaultValue","value","availableValues","getUniqValue","v","excludeValues","includes","allowSelectAll","width","filteredDataEvent","length","result","item","every","flattenDeep","intersection","useEffect","dataFromFile","dataURL","fileType","fetchAndParseJSON","columnsToArray","dataTransformation","fetchAndTransformDataFromAPI","apiHeaders","fetchAndParseCSV","delimiter","fetchAndParseMultipleDataSources","idColumnTitle","transformColumnsToArray","error","console","fetchData","handleFilterChange","values","prev","f","GraphContainer","backgroundColor","language","padding","title","description","jsx","GraphHeader","jsxs","i","flexGrow","flexShrink","minWidth","Label","DropdownSelect","createFilter","Fragment","rows","minHeight","height","j","SingleGraphDashboard","graphType","settings","resetSelectionOnDoubleClick","attachedFilter","styles","classNames","radius","size","filterData","indexOf","findIndex","dClicked","indx","dataTransform","dataSelectionOptions","advancedDataSelectionOptions","graphDataConfiguration"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"MultiGraphDashboard.cjs","sources":["../src/Components/Dashboard/MultiGraphDashboard.tsx"],"sourcesContent":["import { useEffect, useEffectEvent, useState } from 'react';\r\nimport intersection from 'lodash.intersection';\r\nimport flattenDeep from 'lodash.flattendeep';\r\nimport { createFilter, DropdownSelect } from '@undp/design-system-react/DropdownSelect';\r\nimport { Label } from '@undp/design-system-react/Label';\r\n\r\nimport { GraphContainer } from '../Elements/GraphContainer';\r\n\r\nimport { SingleGraphDashboard } from './SingleGraphDashboard';\r\n\r\nimport {\r\n ClassNameObject,\r\n DashboardColumnDataType,\r\n DashboardLayoutDataType,\r\n DataFilterDataType,\r\n DataSettingsDataType,\r\n FilterSettingsDataType,\r\n FilterUiSettingsDataType,\r\n GraphType,\r\n StyleObject,\r\n} from '@/Types';\r\nimport {\r\n fetchAndParseCSV,\r\n fetchAndParseJSON,\r\n fetchAndParseMultipleDataSources,\r\n fetchAndTransformDataFromAPI,\r\n} from '@/Utils/fetchAndParseData';\r\nimport { getUniqValue } from '@/Utils/getUniqValue';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { transformColumnsToArray } from '@/Utils/transformData/transformColumnsToArray';\r\nimport { filterData } from '@/Utils/transformData/filterData';\r\nimport { transformDefaultValue } from '@/Utils/transformDataForSelect';\r\n\r\ninterface Props {\r\n dashboardID?: string;\r\n dashboardLayout: DashboardLayoutDataType;\r\n dataSettings: DataSettingsDataType;\r\n filters?: FilterUiSettingsDataType[];\r\n noOfFiltersPerRow?: number;\r\n dataFilters?: DataFilterDataType[];\r\n debugMode?: boolean;\r\n theme?: 'dark' | 'light';\r\n filterPosition?: 'top' | 'side';\r\n readableHeader?: {\r\n value: string;\r\n label: string;\r\n }[];\r\n uiMode?: 'light' | 'normal';\r\n graphStyles?: StyleObject;\r\n graphClassNames?: ClassNameObject;\r\n}\r\n\r\nconst TotalWidth = (columns: DashboardColumnDataType[]) => {\r\n const columnWidth = columns.map(d => d.columnWidth || 1);\r\n const sum = columnWidth.reduce((acc, cur) => acc + cur, 0);\r\n return sum;\r\n};\r\n\r\nconst GraphWithAttachedFilter: GraphType[] = [\r\n 'barChart',\r\n 'choroplethMap',\r\n 'biVariateChoroplethMap',\r\n 'circlePacking',\r\n 'treeMap',\r\n];\r\n\r\nexport function MultiGraphDashboard(props: Props) {\r\n const {\r\n dashboardID,\r\n dashboardLayout,\r\n dataSettings,\r\n filters,\r\n debugMode,\r\n theme = 'light',\r\n readableHeader,\r\n dataFilters,\r\n noOfFiltersPerRow = 4,\r\n filterPosition,\r\n uiMode = 'normal',\r\n graphStyles,\r\n graphClassNames,\r\n } = props;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [filteredData, setFilteredData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [data, setData] = useState<any>(undefined);\r\n const [filterSettings, setFilterSettings] = useState<FilterSettingsDataType[]>([]);\r\n\r\n const filterConfig = {\r\n ignoreCase: true,\r\n ignoreAccents: true,\r\n trim: true,\r\n };\r\n\r\n const updateFiltersEvent = useEffectEvent(() => {\r\n const filterSettingsTemp = (filters || []).map(el => ({\r\n filter: el.column,\r\n label: el.label || `Filter by ${el.column}`,\r\n singleSelect: el.singleSelect,\r\n clearable: el.clearable,\r\n defaultValue: transformDefaultValue(el.defaultValue),\r\n value: transformDefaultValue(el.defaultValue),\r\n availableValues: getUniqValue(data, el.column)\r\n .filter(v => !el.excludeValues?.includes(`${v}`))\r\n .map(v => ({ value: v, label: v })),\r\n allowSelectAll: el.allowSelectAll,\r\n width: el.width,\r\n }));\r\n setFilterSettings(filterSettingsTemp);\r\n });\r\n\r\n const filteredDataEvent = useEffectEvent(() => {\r\n if (!data || filterSettings.length === 0) setFilteredData(data);\r\n else {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const result = data.filter((item: any) =>\r\n filterSettings.every(filter =>\r\n filter.value && flattenDeep([filter.value]).length > 0\r\n ? intersection(\r\n flattenDeep([item[filter.filter]]),\r\n flattenDeep([filter.value]).map(el => el.value),\r\n ).length > 0\r\n : true,\r\n ),\r\n );\r\n setFilteredData(result);\r\n }\r\n });\r\n useEffect(() => {\r\n filteredDataEvent();\r\n }, [filterSettings, data]);\r\n\r\n useEffect(() => {\r\n const fetchData = async () => {\r\n try {\r\n const dataFromFile = dataSettings.dataURL\r\n ? typeof dataSettings.dataURL === 'string'\r\n ? dataSettings.fileType === 'json'\r\n ? await fetchAndParseJSON(\r\n dataSettings.dataURL,\r\n dataSettings.columnsToArray,\r\n dataSettings.dataTransformation,\r\n debugMode,\r\n )\r\n : dataSettings.fileType === 'api'\r\n ? await fetchAndTransformDataFromAPI(\r\n dataSettings.dataURL,\r\n dataSettings.apiHeaders,\r\n dataSettings.columnsToArray,\r\n dataSettings.dataTransformation,\r\n debugMode,\r\n )\r\n : await fetchAndParseCSV(\r\n dataSettings.dataURL,\r\n dataSettings.dataTransformation,\r\n dataSettings.columnsToArray,\r\n debugMode,\r\n dataSettings.delimiter,\r\n true,\r\n )\r\n : await fetchAndParseMultipleDataSources(\r\n dataSettings.dataURL,\r\n dataSettings.idColumnTitle,\r\n )\r\n : await transformColumnsToArray(dataSettings.data, dataSettings.columnsToArray);\r\n setData(dataFromFile);\r\n } catch (error) {\r\n console.error('Data fetching error:', error);\r\n }\r\n };\r\n fetchData();\r\n updateFiltersEvent();\r\n }, [dataSettings, debugMode]);\r\n\r\n useEffect(() => {\r\n updateFiltersEvent();\r\n }, [filters]);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleFilterChange = (filter: string, values: any) => {\r\n setFilterSettings(prev => prev.map(f => (f.filter === filter ? { ...f, value: values } : f)));\r\n };\r\n return (\r\n <GraphContainer\r\n id={dashboardID}\r\n aria-label='This is a dashboard'\r\n backgroundColor={dashboardLayout.backgroundColor ?? false}\r\n theme={theme || 'light'}\r\n language={dashboardLayout.language || 'en'}\r\n padding={dashboardLayout.padding}\r\n >\r\n {dashboardLayout.title || dashboardLayout.description ? (\r\n <GraphHeader\r\n graphTitle={dashboardLayout.title}\r\n graphDescription={dashboardLayout.description}\r\n isDashboard\r\n />\r\n ) : null}\r\n <div className='flex gap-4 flex-wrap'>\r\n {filterSettings.length !== 0 ? (\r\n <div\r\n className='flex-grow flex-shrink-0'\r\n style={{\r\n width: filterPosition === 'side' ? '280px' : '100%',\r\n }}\r\n >\r\n <div className='flex flex-wrap items-start gap-4 w-full sticky top-4'>\r\n {filterSettings?.map((d, i) => (\r\n <div\r\n style={{\r\n width:\r\n d.width ||\r\n `calc(${100 / noOfFiltersPerRow}% - ${\r\n (noOfFiltersPerRow - 1) / noOfFiltersPerRow\r\n }rem)`,\r\n flexGrow: 1,\r\n flexShrink: 0,\r\n minWidth: '240px',\r\n }}\r\n key={i}\r\n >\r\n <Label className='mb-2'>{d.label}</Label>\r\n {d.singleSelect ? (\r\n <DropdownSelect\r\n options={d.availableValues}\r\n isClearable={d.clearable === undefined ? true : d.clearable}\r\n size='sm'\r\n variant={uiMode}\r\n isMulti={false}\r\n isSearchable\r\n filterOption={createFilter(filterConfig)}\r\n onChange={el => {\r\n handleFilterChange(d.filter, el);\r\n }}\r\n defaultValue={d.defaultValue}\r\n value={d.value}\r\n />\r\n ) : (\r\n <>\r\n <DropdownSelect\r\n options={d.availableValues}\r\n isMulti\r\n size='sm'\r\n isClearable={d.clearable === undefined ? true : d.clearable}\r\n variant={uiMode}\r\n isSearchable\r\n controlShouldRenderValue\r\n closeMenuOnSelect={false}\r\n hideSelectedOptions={false}\r\n filterOption={createFilter(filterConfig)}\r\n onChange={el => {\r\n handleFilterChange(d.filter, el);\r\n }}\r\n value={d.value}\r\n defaultValue={d.defaultValue}\r\n />\r\n {d.allowSelectAll ? (\r\n <button\r\n type='button'\r\n className='bg-transparent border-0 p-0 mt-2 cursor-pointer text-primary-blue-600 dark:text-primary-blue-400'\r\n onClick={() => {\r\n handleFilterChange(d.filter, d.availableValues);\r\n }}\r\n >\r\n Select all options\r\n </button>\r\n ) : null}\r\n </>\r\n )}\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n ) : null}\r\n <div\r\n className='flex flex-wrap gap-4 flex-grow flex-shrink-0 min-w-[280px]'\r\n style={{\r\n width: filterPosition === 'side' ? 'calc(100% - 280px - 1rem)' : '100%',\r\n }}\r\n >\r\n {dashboardLayout.rows.map((d, i) => (\r\n <div\r\n key={i}\r\n className='flex flex-wrap items-stretch gap-4 w-full h-auto'\r\n style={{\r\n minHeight: `${d.height || 0}px`,\r\n }}\r\n >\r\n {d.columns.map((el, j) => (\r\n <div\r\n key={j}\r\n className='flex bg-transparent grow min-w-60'\r\n style={{\r\n width: `calc(${(100 * (el.columnWidth || 1)) / TotalWidth(d.columns)}% - ${\r\n (TotalWidth(d.columns) - (el.columnWidth || 1)) / TotalWidth(d.columns)\r\n }rem)`,\r\n minHeight: 'inherit',\r\n }}\r\n >\r\n <SingleGraphDashboard\r\n graphType={el.graphType}\r\n dataFilters={el.dataFilters}\r\n uiMode={uiMode}\r\n graphSettings={{\r\n ...(el.settings || {}),\r\n width: undefined,\r\n height: undefined,\r\n minHeight: undefined,\r\n relativeHeight: undefined,\r\n resetSelectionOnDoubleClick: el.attachedFilter\r\n ? false\r\n : el.settings?.resetSelectionOnDoubleClick,\r\n styles: el.settings?.styles || graphStyles,\r\n classNames: el.settings?.classNames || graphClassNames,\r\n radius: el.graphType === 'donutChart' ? undefined : el.settings?.radius,\r\n size: el.graphType === 'unitChart' ? el.settings?.size : undefined,\r\n language: el.settings?.language || dashboardLayout.language,\r\n theme: el.settings?.theme || theme,\r\n }}\r\n dataSettings={{\r\n data: filteredData ? filterData(filteredData, dataFilters || []) : undefined,\r\n }}\r\n updateFilters={\r\n el.attachedFilter &&\r\n GraphWithAttachedFilter.indexOf(el.graphType) !== -1 &&\r\n filterSettings.findIndex(f => f.filter === el.attachedFilter) !== -1\r\n ? dClicked => {\r\n const indx = filterSettings.findIndex(\r\n f => f.filter === el.attachedFilter,\r\n );\r\n const value = dClicked\r\n ? filterSettings[indx].singleSelect\r\n ? { value: dClicked, label: dClicked }\r\n : [{ value: dClicked, label: dClicked }]\r\n : undefined;\r\n handleFilterChange(el.attachedFilter as string, value);\r\n }\r\n : undefined\r\n }\r\n dataTransform={el.dataTransform}\r\n dataSelectionOptions={el.dataSelectionOptions}\r\n advancedDataSelectionOptions={el.advancedDataSelectionOptions}\r\n graphDataConfiguration={el.graphDataConfiguration}\r\n debugMode={debugMode}\r\n readableHeader={readableHeader || []}\r\n />\r\n </div>\r\n ))}\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["TotalWidth","columns","map","d","columnWidth","reduce","acc","cur","GraphWithAttachedFilter","MultiGraphDashboard","props","dashboardID","dashboardLayout","dataSettings","filters","debugMode","theme","readableHeader","dataFilters","noOfFiltersPerRow","filterPosition","uiMode","graphStyles","graphClassNames","filteredData","setFilteredData","useState","undefined","data","setData","filterSettings","setFilterSettings","filterConfig","ignoreCase","ignoreAccents","trim","updateFiltersEvent","useEffectEvent","filterSettingsTemp","el","filter","column","label","singleSelect","clearable","defaultValue","transformDefaultValue","value","availableValues","getUniqValue","v","excludeValues","includes","allowSelectAll","width","filteredDataEvent","length","result","item","every","flattenDeep","intersection","useEffect","dataFromFile","dataURL","fileType","fetchAndParseJSON","columnsToArray","dataTransformation","fetchAndTransformDataFromAPI","apiHeaders","fetchAndParseCSV","delimiter","fetchAndParseMultipleDataSources","idColumnTitle","transformColumnsToArray","error","console","fetchData","handleFilterChange","values","prev","f","GraphContainer","backgroundColor","language","padding","title","description","jsx","GraphHeader","jsxs","i","flexGrow","flexShrink","minWidth","Label","DropdownSelect","createFilter","Fragment","rows","minHeight","height","j","SingleGraphDashboard","graphType","settings","relativeHeight","resetSelectionOnDoubleClick","attachedFilter","styles","classNames","radius","size","filterData","indexOf","findIndex","dClicked","indx","dataTransform","dataSelectionOptions","advancedDataSelectionOptions","graphDataConfiguration"],"mappings":"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"}
|