@undp/data-viz 2.1.3 → 2.1.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AreaChart.cjs +1 -1
- package/dist/AreaChart.cjs.map +1 -1
- package/dist/AreaChart.js +279 -272
- package/dist/AreaChart.js.map +1 -1
- package/dist/BarGraph.cjs +1 -1
- package/dist/BarGraph.cjs.map +1 -1
- package/dist/BarGraph.d.ts +2 -0
- package/dist/BarGraph.js +1795 -1724
- package/dist/BarGraph.js.map +1 -1
- package/dist/BeeSwarmChart.cjs +1 -1
- package/dist/BeeSwarmChart.cjs.map +1 -1
- package/dist/BeeSwarmChart.js +312 -305
- package/dist/BeeSwarmChart.js.map +1 -1
- package/dist/BiVariateChoroplethMap.cjs +1 -1
- package/dist/BiVariateChoroplethMap.js +1 -1
- package/dist/BulletChart.cjs +1 -1
- package/dist/BulletChart.cjs.map +1 -1
- package/dist/BulletChart.js +298 -287
- package/dist/BulletChart.js.map +1 -1
- package/dist/ButterflyChart.cjs +1 -1
- package/dist/ButterflyChart.cjs.map +1 -1
- package/dist/ButterflyChart.js +224 -217
- package/dist/ButterflyChart.js.map +1 -1
- package/dist/ChoroplethMap.cjs +1 -1
- package/dist/ChoroplethMap.js +1 -1
- package/dist/CirclePackingGraph.cjs +1 -1
- package/dist/CirclePackingGraph.js +2 -2
- package/dist/DifferenceLineChart.cjs +1 -1
- package/dist/DifferenceLineChart.cjs.map +1 -1
- package/dist/DifferenceLineChart.js +404 -397
- package/dist/DifferenceLineChart.js.map +1 -1
- package/dist/DonutChart.cjs +1 -1
- package/dist/DonutChart.cjs.map +1 -1
- package/dist/DonutChart.js +116 -113
- package/dist/DonutChart.js.map +1 -1
- package/dist/DotDensityMap.cjs +1 -1
- package/dist/DotDensityMap.js +1 -1
- package/dist/DualAxisLineChart.cjs +1 -1
- package/dist/DualAxisLineChart.cjs.map +1 -1
- package/dist/DualAxisLineChart.js +320 -313
- package/dist/DualAxisLineChart.js.map +1 -1
- package/dist/DumbbellChart.cjs +1 -1
- package/dist/DumbbellChart.cjs.map +1 -1
- package/dist/DumbbellChart.js +298 -291
- package/dist/DumbbellChart.js.map +1 -1
- package/dist/{EmptyState-BZo1BbAn.js → EmptyState-C7ZXkZWd.js} +4 -4
- package/dist/EmptyState-C7ZXkZWd.js.map +1 -0
- package/dist/EmptyState-gLDRXBHm.cjs +2 -0
- package/dist/EmptyState-gLDRXBHm.cjs.map +1 -0
- package/dist/GraphEl-BixTEyKW.cjs +2 -0
- package/dist/GraphEl-BixTEyKW.cjs.map +1 -0
- package/dist/{GraphEl-CRrAlbcr.js → GraphEl-Dyu_EIQb.js} +3 -2
- package/dist/GraphEl-Dyu_EIQb.js.map +1 -0
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.js +2 -2
- package/dist/GriddedGraphsFromConfig.cjs +1 -1
- package/dist/GriddedGraphsFromConfig.js +1 -1
- package/dist/HeatMap.cjs +1 -1
- package/dist/HeatMap.cjs.map +1 -1
- package/dist/HeatMap.js +179 -172
- package/dist/HeatMap.js.map +1 -1
- package/dist/Histogram.cjs +1 -1
- package/dist/Histogram.js +2 -2
- package/dist/HybridMap.cjs +1 -1
- package/dist/HybridMap.js +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs.map +1 -1
- package/dist/LineChartWithConfidenceInterval.js +368 -361
- package/dist/LineChartWithConfidenceInterval.js.map +1 -1
- package/dist/MultiGraphDashboardFromConfig.cjs +1 -1
- package/dist/MultiGraphDashboardFromConfig.js +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormat.js +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.cjs +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.js +1 -1
- package/dist/MultiLineAltChart.cjs +1 -1
- package/dist/MultiLineAltChart.cjs.map +1 -1
- package/dist/MultiLineAltChart.js +327 -320
- package/dist/MultiLineAltChart.js.map +1 -1
- package/dist/MultiLineChart.cjs +1 -1
- package/dist/MultiLineChart.cjs.map +1 -1
- package/dist/MultiLineChart.js +374 -367
- package/dist/MultiLineChart.js.map +1 -1
- package/dist/ParetoChart.cjs +1 -1
- package/dist/ParetoChart.cjs.map +1 -1
- package/dist/ParetoChart.js +385 -378
- package/dist/ParetoChart.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.js +1 -1
- package/dist/RadarChart.cjs +1 -1
- package/dist/RadarChart.cjs.map +1 -1
- package/dist/RadarChart.js +34 -33
- package/dist/RadarChart.js.map +1 -1
- package/dist/SankeyChart.cjs +1 -1
- package/dist/SankeyChart.cjs.map +1 -1
- package/dist/SankeyChart.js +176 -169
- package/dist/SankeyChart.js.map +1 -1
- package/dist/ScatterPlot.cjs +1 -1
- package/dist/ScatterPlot.cjs.map +1 -1
- package/dist/ScatterPlot.js +366 -359
- package/dist/ScatterPlot.js.map +1 -1
- package/dist/SimpleLineChart.cjs +1 -1
- package/dist/SimpleLineChart.cjs.map +1 -1
- package/dist/SimpleLineChart.js +285 -278
- package/dist/SimpleLineChart.js.map +1 -1
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.js +2 -2
- package/dist/SingleGraphDashboardFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardFromConfig.js +1 -1
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.js +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.js +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.js +1 -1
- package/dist/SlopeChart.cjs +1 -1
- package/dist/SlopeChart.cjs.map +1 -1
- package/dist/SlopeChart.js +243 -236
- package/dist/SlopeChart.js.map +1 -1
- package/dist/Spinner-CQZcjzwd.cjs +2 -0
- package/dist/Spinner-CQZcjzwd.cjs.map +1 -0
- package/dist/{Spinner-D7rnnwnA.js → Spinner-DVBnY6Vg.js} +5 -5
- package/dist/Spinner-DVBnY6Vg.js.map +1 -0
- package/dist/StripChart.cjs +1 -1
- package/dist/StripChart.cjs.map +1 -1
- package/dist/StripChart.js +293 -286
- package/dist/StripChart.js.map +1 -1
- package/dist/ThreeDGlobe.cjs +1 -1
- package/dist/ThreeDGlobe.js +1 -1
- package/dist/TreeMapGraph.cjs +1 -1
- package/dist/TreeMapGraph.cjs.map +1 -1
- package/dist/TreeMapGraph.js +222 -215
- package/dist/TreeMapGraph.js.map +1 -1
- package/dist/index-R1gTfap5.js +337 -0
- package/dist/index-R1gTfap5.js.map +1 -0
- package/dist/index-WML2dCZ0.cjs +2 -0
- package/dist/{index-CF5hnGvG.cjs.map → index-WML2dCZ0.cjs.map} +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.js +1 -1
- package/dist/style.css +1 -1
- package/package.json +2 -2
- package/dist/EmptyState-BZo1BbAn.js.map +0 -1
- package/dist/EmptyState-sAEZ_5rU.cjs +0 -2
- package/dist/EmptyState-sAEZ_5rU.cjs.map +0 -1
- package/dist/GraphEl-BLMih7RN.cjs +0 -2
- package/dist/GraphEl-BLMih7RN.cjs.map +0 -1
- package/dist/GraphEl-CRrAlbcr.js.map +0 -1
- package/dist/Spinner-D7rnnwnA.js.map +0 -1
- package/dist/Spinner-DRMBUsX7.cjs +0 -2
- package/dist/Spinner-DRMBUsX7.cjs.map +0 -1
- package/dist/index-CF5hnGvG.cjs +0 -2
- package/dist/index-DPGq3eIL.js +0 -330
- package/dist/index-DPGq3eIL.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SimpleLineChart.js","sources":["../src/Components/Graphs/LineCharts/LineChart/Graph.tsx","../src/Components/Graphs/LineCharts/LineChart/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\r\nimport {\r\n line,\r\n curveMonotoneX,\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 LineChartDataType,\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 { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\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 { HighlightArea } from '@/Components/Elements/HighlightArea';\r\nimport { CustomArea } from '@/Components/Elements/HighlightArea/customArea';\r\n\r\ninterface Props {\r\n data: LineChartDataType[];\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 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\n\r\ninterface FormattedDataType {\r\n y: number;\r\n date: Date;\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 yAxisTitle,\r\n noOfYTicks,\r\n maxDate,\r\n minDate,\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 = orderBy(\r\n data.map(d => ({\r\n ...d,\r\n date: parse(`${d.date}`, dateFormat, new Date()),\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 => d.y).filter(d => d !== undefined && d !== null)) !==\r\n Infinity\r\n ? Math.min(...dataFormatted.map(d => d.y).filter(d => d !== undefined && d !== null)) > 0\r\n ? 0\r\n : Math.min(...dataFormatted.map(d => d.y).filter(d => d !== undefined && d !== null))\r\n : 0;\r\n const maxParam: number =\r\n Math.max(...dataFormatted.map(d => d.y).filter(d => d !== undefined && d !== null)) !== Infinity\r\n ? Math.max(...dataFormatted.map(d => d.y).filter(d => d !== undefined && d !== null))\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 const yTicks = y.ticks(noOfYTicks);\r\n const xTicks = x.ticks(noOfXTicks);\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 <XTicksAndGridLines\r\n values={xTicks.map(d => format(d, dateFormat))}\r\n x={xTicks.map(d => x(d))}\r\n y1={0}\r\n y2={graphHeight}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: cn('opacity-0', classNames?.xAxis?.gridLines),\r\n labels: cn(\r\n 'fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs',\r\n classNames?.xAxis?.labels,\r\n ),\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='primary'\r\n showGridLines\r\n precision={precision}\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <g>\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 <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 exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n cx: x(d.date),\r\n cy: y(d.y as number),\r\n fill: lineColor,\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n fill: lineColor,\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 as number),\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\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, x: x(d.date), y: y(d.y) },\r\n whileInView: {\r\n opacity: 1,\r\n x: x(d.date),\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 </>\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 {\r\n AnnotationSettingsDataType,\r\n CustomHighlightAreaSettingsDataType,\r\n Languages,\r\n LineChartDataType,\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 { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { 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: LineChartDataType[];\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 lines */\r\n lineColor?: 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 dots on the line */\r\n showDots?: boolean;\r\n /** Stroke width of the line */\r\n strokeWidth?: 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 SimpleLineChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n lineColor,\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 padding,\r\n backgroundColor = false,\r\n leftMargin = 30,\r\n rightMargin = 30,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n highlightAreaSettings = [],\r\n graphID,\r\n minValue,\r\n maxValue,\r\n maxDate,\r\n minDate,\r\n graphDownload = false,\r\n dataDownload = false,\r\n animate = false,\r\n language = 'en',\r\n refValues = [],\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 regressionLine = false,\r\n yAxisTitle,\r\n noOfYTicks = 5,\r\n curveType = 'curve',\r\n styles,\r\n classNames,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\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 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 <div className='grow flex flex-col justify-center gap-3 w-full'>\r\n <EmptyState />\r\n </div>\r\n ) : (\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 yAxisTitle={yAxisTitle}\r\n noOfYTicks={noOfYTicks}\r\n maxDate={maxDate}\r\n minDate={minDate}\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 {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","yAxisTitle","noOfYTicks","maxDate","minDate","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","date","parse","Date","dataFormatted","orderBy","map","t6","t7","d_0","coordinates","highlightAreaSettingsFormatted","t8","d_1","el","j","customHighlightAreaSettingsFormatted","graphWidth","graphHeight","minYear","maxYear","length","minParam","checkIfNullOrUndefined","Math","min","_temp","filter","_temp2","Infinity","_temp3","_temp4","_temp5","_temp6","maxParam","max","_temp7","_temp8","_temp9","_temp0","x","scaleTime","domain","range","y","scaleLinear","nice","lineShape","line","d_12","d_13","yTicks","ticks","xTicks","mousemove","event","selectedData","bisectCenter","_temp1","invert","pointer","clientY","clientX","mouseout","select","current","on","regressionLineParam","linearRegression","_temp10","d_16","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","d_20","format","t39","t40","d_21","t41","t42","t43","t44","t45","cn","t46","t47","t48","t49","_temp13","_temp14","t50","stroke","fill","t51","opacity","transition","t52","d_24","i","motion","jsxs","Fragment","initial","cx","cy","whileInView","delay","textAnchor","graphObjectValues","t53","t54","d_25","i_1","endPoints","getLineEndPoint","xCoordinate","xOffset","yCoordinate","yOffset","connectorRadius","connectorSettings","showConnector","y1","x1","y2","x2","circleRadius","labelSettings","maxWidth","fontWeight","align","Annotation","color","text","t55","t56","RegressionLine","regLine","t57","t58","_temp15","_temp16","t59","Symbol","for","pointerEvents","t60","t61","Tooltip","CustomArea","YTicksAndGridLines","_temp11","_temp12","d_19","XTicksAndGridLines","pathLength","mouseOverLine","el_0","i_0","RefLineY","value","d_27","layer","d_26","position","d_23","d_22","d_18","d_17","d_15","d_14","d_9","d_8","d_11","d_10","d_3","d_2","d_5","d_4","d_7","d_6","SimpleLineChart","graphTitle","sources","graphDescription","footNote","padding","backgroundColor","relativeHeight","graphID","graphDownload","dataDownload","language","minHeight","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","graphDiv","graphParentDiv","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","observe","disconnect","graphContainer","description","GraphHeader","EmptyState","GraphArea","Colors","primaryColors","getNoOfTicks","footnote","source","GraphFooter","GraphContainer"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"SimpleLineChart.js","sources":["../src/Components/Graphs/LineCharts/LineChart/Graph.tsx","../src/Components/Graphs/LineCharts/LineChart/index.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\r\nimport {\r\n line,\r\n curveMonotoneX,\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 LineChartDataType,\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 { Axis } from '@/Components/Elements/Axes/Axis';\r\nimport { AxisTitle } from '@/Components/Elements/Axes/AxisTitle';\r\nimport { XTicksAndGridLines } from '@/Components/Elements/Axes/XTicksAndGridLines';\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 { HighlightArea } from '@/Components/Elements/HighlightArea';\r\nimport { CustomArea } from '@/Components/Elements/HighlightArea/customArea';\r\n\r\ninterface Props {\r\n data: LineChartDataType[];\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 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\n\r\ninterface FormattedDataType {\r\n y: number;\r\n date: Date;\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 yAxisTitle,\r\n noOfYTicks,\r\n maxDate,\r\n minDate,\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 = orderBy(\r\n data.map(d => ({\r\n ...d,\r\n date: parse(`${d.date}`, dateFormat, new Date()),\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 => d.y).filter(d => d !== undefined && d !== null)) !==\r\n Infinity\r\n ? Math.min(...dataFormatted.map(d => d.y).filter(d => d !== undefined && d !== null)) > 0\r\n ? 0\r\n : Math.min(...dataFormatted.map(d => d.y).filter(d => d !== undefined && d !== null))\r\n : 0;\r\n const maxParam: number =\r\n Math.max(...dataFormatted.map(d => d.y).filter(d => d !== undefined && d !== null)) !== Infinity\r\n ? Math.max(...dataFormatted.map(d => d.y).filter(d => d !== undefined && d !== null))\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 const yTicks = y.ticks(noOfYTicks);\r\n const xTicks = x.ticks(noOfXTicks);\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 <XTicksAndGridLines\r\n values={xTicks.map(d => format(d, dateFormat))}\r\n x={xTicks.map(d => x(d))}\r\n y1={0}\r\n y2={graphHeight}\r\n styles={{\r\n gridLines: styles?.xAxis?.gridLines,\r\n labels: styles?.xAxis?.labels,\r\n }}\r\n classNames={{\r\n gridLines: cn('opacity-0', classNames?.xAxis?.gridLines),\r\n labels: cn(\r\n 'fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs',\r\n classNames?.xAxis?.labels,\r\n ),\r\n }}\r\n suffix={suffix}\r\n prefix={prefix}\r\n labelType='primary'\r\n showGridLines\r\n precision={precision}\r\n />\r\n {customLayers.filter(d => d.position === 'before').map(d => d.layer)}\r\n <g>\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 <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 exit={{ opacity: 0, transition: { duration: animate.duration } }}\r\n variants={{\r\n initial: {\r\n opacity: 0,\r\n cx: x(d.date),\r\n cy: y(d.y as number),\r\n fill: lineColor,\r\n },\r\n whileInView: {\r\n opacity: 1,\r\n fill: lineColor,\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 as number),\r\n },\r\n }}\r\n initial='initial'\r\n animate={isInView ? 'whileInView' : 'initial'}\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, x: x(d.date), y: y(d.y) },\r\n whileInView: {\r\n opacity: 1,\r\n x: x(d.date),\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 </>\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 {\r\n AnnotationSettingsDataType,\r\n CustomHighlightAreaSettingsDataType,\r\n Languages,\r\n LineChartDataType,\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 { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { 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: LineChartDataType[];\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 lines */\r\n lineColor?: 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 dots on the line */\r\n showDots?: boolean;\r\n /** Stroke width of the line */\r\n strokeWidth?: 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 SimpleLineChart(props: Props) {\r\n const {\r\n data,\r\n graphTitle,\r\n lineColor,\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 padding,\r\n backgroundColor = false,\r\n leftMargin = 30,\r\n rightMargin = 30,\r\n topMargin = 20,\r\n bottomMargin = 25,\r\n relativeHeight,\r\n tooltip,\r\n onSeriesMouseOver,\r\n highlightAreaSettings = [],\r\n graphID,\r\n minValue,\r\n maxValue,\r\n maxDate,\r\n minDate,\r\n graphDownload = false,\r\n dataDownload = false,\r\n animate = false,\r\n language = 'en',\r\n refValues = [],\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 regressionLine = false,\r\n yAxisTitle,\r\n noOfYTicks = 5,\r\n curveType = 'curve',\r\n styles,\r\n classNames,\r\n precision = 2,\r\n customLayers = [],\r\n } = props;\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 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 <GraphArea ref={graphDiv}>\r\n {data.length === 0 && <EmptyState />}\r\n {svgWidth && svgHeight && data.length > 0 ? (\r\n <Graph\r\n data={data}\r\n 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 yAxisTitle={yAxisTitle}\r\n noOfYTicks={noOfYTicks}\r\n maxDate={maxDate}\r\n minDate={minDate}\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 {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","yAxisTitle","noOfYTicks","maxDate","minDate","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","date","parse","Date","dataFormatted","orderBy","map","t6","t7","d_0","coordinates","highlightAreaSettingsFormatted","t8","d_1","el","j","customHighlightAreaSettingsFormatted","graphWidth","graphHeight","minYear","maxYear","length","minParam","checkIfNullOrUndefined","Math","min","_temp","filter","_temp2","Infinity","_temp3","_temp4","_temp5","_temp6","maxParam","max","_temp7","_temp8","_temp9","_temp0","x","scaleTime","domain","range","y","scaleLinear","nice","lineShape","line","d_12","d_13","yTicks","ticks","xTicks","mousemove","event","selectedData","bisectCenter","_temp1","invert","pointer","clientY","clientX","mouseout","select","current","on","regressionLineParam","linearRegression","_temp10","d_16","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","d_20","format","t39","t40","d_21","t41","t42","t43","t44","t45","cn","t46","t47","t48","t49","_temp13","_temp14","t50","stroke","fill","t51","opacity","transition","t52","d_24","i","motion","jsxs","Fragment","initial","cx","cy","whileInView","delay","textAnchor","graphObjectValues","t53","t54","d_25","i_1","endPoints","getLineEndPoint","xCoordinate","xOffset","yCoordinate","yOffset","connectorRadius","connectorSettings","showConnector","y1","x1","y2","x2","circleRadius","labelSettings","maxWidth","fontWeight","align","Annotation","color","text","t55","t56","RegressionLine","regLine","t57","t58","_temp15","_temp16","t59","Symbol","for","pointerEvents","t60","t61","Tooltip","CustomArea","YTicksAndGridLines","_temp11","_temp12","d_19","XTicksAndGridLines","pathLength","mouseOverLine","el_0","i_0","RefLineY","value","d_27","layer","d_26","position","d_23","d_22","d_18","d_17","d_15","d_14","d_9","d_8","d_11","d_10","d_3","d_2","d_5","d_4","d_7","d_6","SimpleLineChart","graphTitle","sources","graphDescription","footNote","padding","backgroundColor","relativeHeight","graphID","graphDownload","dataDownload","language","minHeight","theme","ariaLabel","svgWidth","setSvgWidth","svgHeight","setSvgHeight","graphDiv","graphParentDiv","resizeObserver","ResizeObserver","entries","target","clientWidth","clientHeight","observe","disconnect","graphContainer","description","GraphHeader","EmptyState","Colors","primaryColors","getNoOfTicks","GraphArea","footnote","source","GraphFooter","GraphContainer"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("./index-CHPV5EwG-CTPQjnHt.cjs"),o=require("react"),te=require("./index-CyZ1lmi_.cjs"),q=require("./index-BS2TADPj.cjs"),le=require("./index-DQA8q5sC.cjs"),C=require("./DropdownSelect-Doz3mCrM.cjs"),d=require("./checkIfMultiple-wg6hJLXy.cjs"),ne=require("./Spinner-DRMBUsX7.cjs"),ie=require("./GraphContainer-d8A46BK2.cjs"),re=require("./GraphEl-BLMih7RN.cjs"),$=require("./fetchAndParseData-l5HGMAEs.cjs"),U=require("./transformDataForAggregation-CYoB5Xsk.cjs"),z=require("./getUniqValue-NX8DgwND.cjs"),se=require("./GraphHeader.cjs"),W=require("./filterData-T5DQBE9b.cjs"),oe=require("./getGraphList-CA17dvFB.cjs"),J=require("./transformDataForSelect-YmStusCI.cjs"),ue=u=>{if(u.findIndex(n=>n.chartConfigId==="yMin")!==-1&&u.findIndex(n=>n.chartConfigId==="yMax")!==-1)return u;const i=[...u];return u.findIndex(n=>n.chartConfigId==="yMin")===-1&&i.push({chartConfigId:"yMin",columnId:`${u[u.findIndex(n=>n.chartConfigId==="y")].columnId}Min`}),u.findIndex(n=>n.chartConfigId==="yMax")===-1&&i.push({chartConfigId:"yMax",columnId:`${u[u.findIndex(n=>n.chartConfigId==="y")].columnId}Max`}),i},M=(u,i)=>{const n=i?.map(D=>{const b=u?.findIndex(s=>s.chartConfigId===D.chartConfigId);if(b===-1)return{};const w=u[b]?.allowedColumnIds?.findIndex(s=>s.value===D.columnId);return w===-1?{}:u[b].allowedColumnIds[w].graphSettings||{}})||[];return Object.assign({},...n)};function de(u){const{graphSettings:i,dataSettings:n,filters:D,graphType:b,dataTransform:w,graphDataConfiguration:s,dataFilters:A,debugMode:S,dataSelectionOptions:I,advancedDataSelectionOptions:N,readableHeader:B,noOfFiltersPerRow:p=4,updateFilters:K,uiMode:f="normal",highlightDataPointSettings:m}=u,[P,F]=o.useState(void 0),[c,Q]=o.useState(void 0),[v,j]=o.useState(s),[x,V]=o.useState({}),[E,X]=o.useState(void 0),[Y,Z]=o.useState([]),H=o.useRef(null),O=o.useRef(s),[R,k]=o.useState([]),G={ignoreCase:!0,ignoreAccents:!0,trim:!0},L=o.useEffectEvent(()=>{const e=(D||[]).map(r=>({filter:r.column,label:r.label||`Filter by ${r.column}`,singleSelect:r.singleSelect,clearable:r.clearable,ui:r.ui,defaultValue:J.transformDefaultValue(r.defaultValue),value:J.transformDefaultValue(r.defaultValue),availableValues:z.getUniqValue(c,r.column).filter(a=>!r.excludeValues?.includes(`${a}`)).map(a=>({value:a,label:a})),allowSelectAll:r.allowSelectAll,width:r.width}));k(e)});o.useEffect(()=>{(async()=>{try{const r=n.dataURL?typeof n.dataURL=="string"?n.fileType==="json"?await $.fetchAndParseJSON(n.dataURL,n.columnsToArray,n.dataTransformation,S):n.fileType==="api"?await $.fetchAndTransformDataFromAPI(n.dataURL,n.apiHeaders,n.columnsToArray,n.dataTransformation,S):await $.fetchAndParseCSV(n.dataURL,n.dataTransformation,n.columnsToArray,S,n.delimiter,!0):await $.fetchAndParseMultipleDataSources(n.dataURL,n.idColumnTitle):await $.transformColumnsToArray(n.data,n.columnsToArray);Q(r)}catch(r){console.error("Data fetching error:",r)}})(),L()},[n,S]),o.useEffect(()=>{L()},[D,c]);const _=o.useEffectEvent(()=>{if(!c||R.length===0)F(c);else{const e=c.filter(r=>R.every(a=>a.value&&q.flattenDeep([a.value]).length>0?te.intersection(q.flattenDeep([r[a.filter]]),q.flattenDeep([a.value]).map(t=>t.value)).length>0:!0));F(e)}});o.useEffect(()=>{_()},[R,c]),o.useEffect(()=>{I&&V(M(I,s))},[I,s]);const ee=o.useEffectEvent(()=>{m?.column&&P&&Z(z.getUniqValue(P,m.column).filter(e=>!m?.excludeValues?.includes(`${e}`)).map(e=>({value:e,label:e})))});o.useEffect(()=>{ee()},[m]),o.useEffect(()=>{le.isEqual(O.current,s)||(j(s),O.current=s)},[s]);const y=(e,r)=>{k(a=>a.map(t=>t.filter===e?{...t,value:r}:t))},ae=c?U.transformDataForGraph(w?U.transformDataForAggregation(W.filterData(c,A||[]),w.keyColumn,w.aggregationColumnsSetting):W.filterData(c,A||[]),b,b==="lineChartWithConfidenceInterval"&&v?ue(v):v):void 0;return l.jsxRuntimeExports.jsx(ie.GraphContainer,{className:i?.classNames?.graphContainer,style:i?.styles?.graphContainer,id:i?.graphID,ref:H,"aria-label":i?.ariaLabel,backgroundColor:i?.backgroundColor??!1,theme:i?.theme||"light",language:i?.language||"en",width:i?.width,height:i?.height,padding:i?.padding,minHeight:i?.minHeight,relativeHeight:i?.relativeHeight,children:c||oe.graphList.filter(e=>e.geoHubMapPresentation).map(e=>e.graphID).indexOf(b)!==-1?l.jsxRuntimeExports.jsxs(l.jsxRuntimeExports.Fragment,{children:[x?.graphTitle||x?.graphDescription||i?.graphTitle||i?.graphDescription||i?.graphDownload||i?.dataDownload?l.jsxRuntimeExports.jsx(se.GraphHeader,{styles:{title:x?.styles?.title||i?.styles?.title,description:x?.styles?.description||i?.styles?.description},classNames:{title:x?.classNames?.title||i?.classNames?.title,description:x?.classNames?.description||i?.classNames?.description},graphTitle:x?.graphTitle||i?.graphTitle,graphDescription:x?.graphDescription||i?.graphDescription,width:x?.width||i?.width,graphDownload:i?.graphDownload?H:void 0,dataDownload:i?.dataDownload&&c&&c.length>0?c:null}):null,R.length!==0||(I||[]).length!==0||(N||[]).length!==0||m?l.jsxRuntimeExports.jsxs("div",{className:"flex flex-wrap items-start gap-x-4 gap-y-0 w-full",children:[N?.map((e,r)=>l.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/p}% - ${(p-1)/p}rem)`,flexGrow:e.width?0:1,flexShrink:e.ui!=="radio"||e.width?0:1,minWidth:"240px"},className:"pb-4",children:[l.jsxRuntimeExports.jsx(d.b,{className:"mb-2",children:e.label||"Graph by"}),e.ui!=="radio"?l.jsxRuntimeExports.jsx(C.ja,{options:e.options.map(a=>({...a,value:a.label})),size:"sm",isClearable:!1,isSearchable:!0,variant:f,controlShouldRenderValue:!0,defaultValue:e.defaultValue?{...e.defaultValue,value:e.defaultValue?.label}:{...e.options[0],value:e.options[0].label},onChange:a=>{V(a?.graphSettings||{}),j(a?.dataConfiguration)}}):l.jsxRuntimeExports.jsx(d.ye,{defaultValue:e.defaultValue?.label||e.options[0].label,variant:f,onValueChange:a=>{const t=e.options[e.options.findIndex(g=>g.label===a)];V(t.graphSettings||{}),j(t.dataConfiguration)},children:e.options.map((a,t)=>l.jsxRuntimeExports.jsx(d.he,{label:a.label,value:a.label},t))})]},r)),I?.map((e,r)=>l.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/p}% - ${(p-1)/p}rem)`,flexGrow:e.width?0:1,flexShrink:e.ui!=="radio"||e.width?0:1,minWidth:"240px"},className:"pb-4",children:[l.jsxRuntimeExports.jsx(d.b,{className:"mb-2",children:e.label||`Visualize ${e.chartConfigId} by`}),d.checkIfMultiple(e.chartConfigId,v||[])?e.ui!=="radio"?l.jsxRuntimeExports.jsx(C.ja,{options:e.allowedColumnIds,size:"sm",isMulti:!0,isSearchable:!0,variant:f,controlShouldRenderValue:!0,defaultValue:s?s[s.findIndex(a=>a.chartConfigId===e.chartConfigId)].columnId.map(a=>e.allowedColumnIds[e.allowedColumnIds.findIndex(t=>t.value===a)]):void 0,filterOption:C.Du(G),onChange:a=>{const t={columnId:(a||[]).map(h=>h.value),chartConfigId:e.chartConfigId},g=v?.map(h=>h.chartConfigId===t.chartConfigId?t:h);j(g)}}):l.jsxRuntimeExports.jsx(d.$,{variant:f,defaultValue:s?s[s.findIndex(a=>a.chartConfigId===e.chartConfigId)].columnId.map(a=>e.allowedColumnIds[e.allowedColumnIds.findIndex(t=>t.value===a)]).map(a=>a.value):[],onValueChange:a=>{const t={columnId:a||[],chartConfigId:e.chartConfigId},g=v?.map(h=>h.chartConfigId===t.chartConfigId?t:h);j(g)},children:e.allowedColumnIds.map((a,t)=>l.jsxRuntimeExports.jsx(d.P,{label:a.label,value:a.label},t))}):e.ui!=="radio"?l.jsxRuntimeExports.jsx(C.ja,{options:e.allowedColumnIds,size:"sm",isClearable:!1,isSearchable:!0,variant:f,controlShouldRenderValue:!0,defaultValue:s?e.allowedColumnIds[e.allowedColumnIds.findIndex(a=>a.value===s[s.findIndex(t=>t.chartConfigId===e.chartConfigId)].columnId)]:void 0,onChange:a=>{const t={columnId:a?.value,chartConfigId:e.chartConfigId},g=v?.map(h=>h.chartConfigId===t.chartConfigId?t:h);V(M(I,g)),j(g)}}):l.jsxRuntimeExports.jsx(d.ye,{variant:f,defaultValue:s?e.allowedColumnIds[e.allowedColumnIds.findIndex(a=>a.value===s[s.findIndex(t=>t.chartConfigId===e.chartConfigId)].columnId)].label:"",onValueChange:a=>{const g={columnId:e.allowedColumnIds[e.allowedColumnIds.findIndex(T=>T.label===a)].value,chartConfigId:e.chartConfigId},h=v?.map(T=>T.chartConfigId===g.chartConfigId?g:T);V(M(I,h)),j(h)},children:e.allowedColumnIds.map((a,t)=>l.jsxRuntimeExports.jsx(d.he,{label:a.label,value:a.label},t))})]},r)),R?.map((e,r)=>l.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/p}% - ${(p-1)/p}rem)`,flexGrow:e.width?0:1,flexShrink:0,minWidth:"240px"},className:"pb-4",children:[l.jsxRuntimeExports.jsx(d.b,{className:"mb-2",children:e.label}),e.singleSelect?e.ui!=="radio"?l.jsxRuntimeExports.jsx(C.ja,{options:e.availableValues,variant:f,isClearable:e.clearable===void 0?!0:e.clearable,isSearchable:!0,controlShouldRenderValue:!0,filterOption:C.Du(G),onChange:a=>{y(e.filter,a)},value:e.value,defaultValue:e.defaultValue}):l.jsxRuntimeExports.jsx(d.ye,{variant:f,defaultValue:e.defaultValue.value,onValueChange:a=>{y(e.filter,e.availableValues.filter(t=>t.value===a))},children:e.availableValues.map((a,t)=>l.jsxRuntimeExports.jsx(d.he,{label:`${a.label}`,value:`${a.value}`},t))}):l.jsxRuntimeExports.jsxs(l.jsxRuntimeExports.Fragment,{children:[e.ui!=="radio"?l.jsxRuntimeExports.jsx(C.ja,{options:e.availableValues,variant:f,size:"sm",isMulti:!0,isClearable:e.clearable===void 0?!0:e.clearable,isSearchable:!0,controlShouldRenderValue:!0,filterOption:C.Du(G),onChange:a=>{y(e.filter,a)},value:e.value,defaultValue:e.defaultValue}):l.jsxRuntimeExports.jsx(d.$,{variant:f,defaultValue:e.defaultValue?e.defaultValue.map(a=>`${a.value}`):[],value:e.value?e.value.map(a=>`${a.value}`):void 0,onValueChange:a=>{y(e.filter,e.availableValues.filter(t=>a.indexOf(`${t.value}`)!==-1))},children:e.availableValues.map((a,t)=>l.jsxRuntimeExports.jsx(d.P,{label:`${a.label}`,value:`${a.value}`},t))}),e.allowSelectAll?l.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:()=>{y(e.filter,e.availableValues)},children:"Select all options"}):null]})]},r)),m?l.jsxRuntimeExports.jsxs("div",{style:{width:m.width||`calc(${100/p}% - ${(p-1)/p}rem)`,flexGrow:m.width?0:1,flexShrink:0,minWidth:"240px"},className:"pb-4",children:[l.jsxRuntimeExports.jsx(d.b,{className:"mb-2",children:m.label||"Highlight data"}),l.jsxRuntimeExports.jsx(C.ja,{options:Y,variant:f,size:"sm",isMulti:!0,isClearable:!0,isSearchable:!0,controlShouldRenderValue:!0,filterOption:C.Du(G),onChange:e=>{X(e?.map(r=>r.value))},value:E?.map(e=>({label:e,value:e})),defaultValue:m.defaultValues?.map(e=>({label:e,value:e}))})]}):null]}):null,l.jsxRuntimeExports.jsx(re.GraphEl,{graph:b,graphData:ae,graphDataConfiguration:v,debugMode:S,readableHeader:B||[],updateFilters:K,settings:{...i||{},...x,graphTitle:void 0,graphDescription:void 0,graphDownload:!1,dataDownload:!1,backgroundColor:void 0,width:void 0,height:void 0,relativeHeight:void 0,minHeight:void 0,padding:"0",theme:i?.theme,...E?{highlightedDataPoints:E,highlightedIds:E?.map(e=>`${e}`),highlightedLines:E?.map(e=>e)}:{}}})]}):l.jsxRuntimeExports.jsx("div",{className:"w-full flex justify-center p-4",children:l.jsxRuntimeExports.jsx(ne.w,{})})})}exports.SingleGraphDashboard=de;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("./index-CHPV5EwG-CTPQjnHt.cjs"),o=require("react"),te=require("./index-CyZ1lmi_.cjs"),q=require("./index-BS2TADPj.cjs"),le=require("./index-DQA8q5sC.cjs"),C=require("./DropdownSelect-Doz3mCrM.cjs"),d=require("./checkIfMultiple-wg6hJLXy.cjs"),ne=require("./Spinner-CQZcjzwd.cjs"),ie=require("./GraphContainer-d8A46BK2.cjs"),re=require("./GraphEl-BixTEyKW.cjs"),$=require("./fetchAndParseData-l5HGMAEs.cjs"),U=require("./transformDataForAggregation-CYoB5Xsk.cjs"),z=require("./getUniqValue-NX8DgwND.cjs"),se=require("./GraphHeader.cjs"),W=require("./filterData-T5DQBE9b.cjs"),oe=require("./getGraphList-CA17dvFB.cjs"),J=require("./transformDataForSelect-YmStusCI.cjs"),ue=u=>{if(u.findIndex(n=>n.chartConfigId==="yMin")!==-1&&u.findIndex(n=>n.chartConfigId==="yMax")!==-1)return u;const i=[...u];return u.findIndex(n=>n.chartConfigId==="yMin")===-1&&i.push({chartConfigId:"yMin",columnId:`${u[u.findIndex(n=>n.chartConfigId==="y")].columnId}Min`}),u.findIndex(n=>n.chartConfigId==="yMax")===-1&&i.push({chartConfigId:"yMax",columnId:`${u[u.findIndex(n=>n.chartConfigId==="y")].columnId}Max`}),i},M=(u,i)=>{const n=i?.map(D=>{const b=u?.findIndex(s=>s.chartConfigId===D.chartConfigId);if(b===-1)return{};const w=u[b]?.allowedColumnIds?.findIndex(s=>s.value===D.columnId);return w===-1?{}:u[b].allowedColumnIds[w].graphSettings||{}})||[];return Object.assign({},...n)};function de(u){const{graphSettings:i,dataSettings:n,filters:D,graphType:b,dataTransform:w,graphDataConfiguration:s,dataFilters:A,debugMode:S,dataSelectionOptions:I,advancedDataSelectionOptions:N,readableHeader:B,noOfFiltersPerRow:p=4,updateFilters:K,uiMode:f="normal",highlightDataPointSettings:m}=u,[P,F]=o.useState(void 0),[c,Q]=o.useState(void 0),[v,j]=o.useState(s),[x,V]=o.useState({}),[E,X]=o.useState(void 0),[Y,Z]=o.useState([]),H=o.useRef(null),O=o.useRef(s),[R,k]=o.useState([]),G={ignoreCase:!0,ignoreAccents:!0,trim:!0},L=o.useEffectEvent(()=>{const e=(D||[]).map(r=>({filter:r.column,label:r.label||`Filter by ${r.column}`,singleSelect:r.singleSelect,clearable:r.clearable,ui:r.ui,defaultValue:J.transformDefaultValue(r.defaultValue),value:J.transformDefaultValue(r.defaultValue),availableValues:z.getUniqValue(c,r.column).filter(a=>!r.excludeValues?.includes(`${a}`)).map(a=>({value:a,label:a})),allowSelectAll:r.allowSelectAll,width:r.width}));k(e)});o.useEffect(()=>{(async()=>{try{const r=n.dataURL?typeof n.dataURL=="string"?n.fileType==="json"?await $.fetchAndParseJSON(n.dataURL,n.columnsToArray,n.dataTransformation,S):n.fileType==="api"?await $.fetchAndTransformDataFromAPI(n.dataURL,n.apiHeaders,n.columnsToArray,n.dataTransformation,S):await $.fetchAndParseCSV(n.dataURL,n.dataTransformation,n.columnsToArray,S,n.delimiter,!0):await $.fetchAndParseMultipleDataSources(n.dataURL,n.idColumnTitle):await $.transformColumnsToArray(n.data,n.columnsToArray);Q(r)}catch(r){console.error("Data fetching error:",r)}})(),L()},[n,S]),o.useEffect(()=>{L()},[D,c]);const _=o.useEffectEvent(()=>{if(!c||R.length===0)F(c);else{const e=c.filter(r=>R.every(a=>a.value&&q.flattenDeep([a.value]).length>0?te.intersection(q.flattenDeep([r[a.filter]]),q.flattenDeep([a.value]).map(t=>t.value)).length>0:!0));F(e)}});o.useEffect(()=>{_()},[R,c]),o.useEffect(()=>{I&&V(M(I,s))},[I,s]);const ee=o.useEffectEvent(()=>{m?.column&&P&&Z(z.getUniqValue(P,m.column).filter(e=>!m?.excludeValues?.includes(`${e}`)).map(e=>({value:e,label:e})))});o.useEffect(()=>{ee()},[m]),o.useEffect(()=>{le.isEqual(O.current,s)||(j(s),O.current=s)},[s]);const y=(e,r)=>{k(a=>a.map(t=>t.filter===e?{...t,value:r}:t))},ae=c?U.transformDataForGraph(w?U.transformDataForAggregation(W.filterData(c,A||[]),w.keyColumn,w.aggregationColumnsSetting):W.filterData(c,A||[]),b,b==="lineChartWithConfidenceInterval"&&v?ue(v):v):void 0;return l.jsxRuntimeExports.jsx(ie.GraphContainer,{className:i?.classNames?.graphContainer,style:i?.styles?.graphContainer,id:i?.graphID,ref:H,"aria-label":i?.ariaLabel,backgroundColor:i?.backgroundColor??!1,theme:i?.theme||"light",language:i?.language||"en",width:i?.width,height:i?.height,padding:i?.padding,minHeight:i?.minHeight,relativeHeight:i?.relativeHeight,children:c||oe.graphList.filter(e=>e.geoHubMapPresentation).map(e=>e.graphID).indexOf(b)!==-1?l.jsxRuntimeExports.jsxs(l.jsxRuntimeExports.Fragment,{children:[x?.graphTitle||x?.graphDescription||i?.graphTitle||i?.graphDescription||i?.graphDownload||i?.dataDownload?l.jsxRuntimeExports.jsx(se.GraphHeader,{styles:{title:x?.styles?.title||i?.styles?.title,description:x?.styles?.description||i?.styles?.description},classNames:{title:x?.classNames?.title||i?.classNames?.title,description:x?.classNames?.description||i?.classNames?.description},graphTitle:x?.graphTitle||i?.graphTitle,graphDescription:x?.graphDescription||i?.graphDescription,width:x?.width||i?.width,graphDownload:i?.graphDownload?H:void 0,dataDownload:i?.dataDownload&&c&&c.length>0?c:null}):null,R.length!==0||(I||[]).length!==0||(N||[]).length!==0||m?l.jsxRuntimeExports.jsxs("div",{className:"flex flex-wrap items-start gap-x-4 gap-y-0 w-full",children:[N?.map((e,r)=>l.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/p}% - ${(p-1)/p}rem)`,flexGrow:e.width?0:1,flexShrink:e.ui!=="radio"||e.width?0:1,minWidth:"240px"},className:"pb-4",children:[l.jsxRuntimeExports.jsx(d.b,{className:"mb-2",children:e.label||"Graph by"}),e.ui!=="radio"?l.jsxRuntimeExports.jsx(C.ja,{options:e.options.map(a=>({...a,value:a.label})),size:"sm",isClearable:!1,isSearchable:!0,variant:f,controlShouldRenderValue:!0,defaultValue:e.defaultValue?{...e.defaultValue,value:e.defaultValue?.label}:{...e.options[0],value:e.options[0].label},onChange:a=>{V(a?.graphSettings||{}),j(a?.dataConfiguration)}}):l.jsxRuntimeExports.jsx(d.ye,{defaultValue:e.defaultValue?.label||e.options[0].label,variant:f,onValueChange:a=>{const t=e.options[e.options.findIndex(g=>g.label===a)];V(t.graphSettings||{}),j(t.dataConfiguration)},children:e.options.map((a,t)=>l.jsxRuntimeExports.jsx(d.he,{label:a.label,value:a.label},t))})]},r)),I?.map((e,r)=>l.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/p}% - ${(p-1)/p}rem)`,flexGrow:e.width?0:1,flexShrink:e.ui!=="radio"||e.width?0:1,minWidth:"240px"},className:"pb-4",children:[l.jsxRuntimeExports.jsx(d.b,{className:"mb-2",children:e.label||`Visualize ${e.chartConfigId} by`}),d.checkIfMultiple(e.chartConfigId,v||[])?e.ui!=="radio"?l.jsxRuntimeExports.jsx(C.ja,{options:e.allowedColumnIds,size:"sm",isMulti:!0,isSearchable:!0,variant:f,controlShouldRenderValue:!0,defaultValue:s?s[s.findIndex(a=>a.chartConfigId===e.chartConfigId)].columnId.map(a=>e.allowedColumnIds[e.allowedColumnIds.findIndex(t=>t.value===a)]):void 0,filterOption:C.Du(G),onChange:a=>{const t={columnId:(a||[]).map(h=>h.value),chartConfigId:e.chartConfigId},g=v?.map(h=>h.chartConfigId===t.chartConfigId?t:h);j(g)}}):l.jsxRuntimeExports.jsx(d.$,{variant:f,defaultValue:s?s[s.findIndex(a=>a.chartConfigId===e.chartConfigId)].columnId.map(a=>e.allowedColumnIds[e.allowedColumnIds.findIndex(t=>t.value===a)]).map(a=>a.value):[],onValueChange:a=>{const t={columnId:a||[],chartConfigId:e.chartConfigId},g=v?.map(h=>h.chartConfigId===t.chartConfigId?t:h);j(g)},children:e.allowedColumnIds.map((a,t)=>l.jsxRuntimeExports.jsx(d.P,{label:a.label,value:a.label},t))}):e.ui!=="radio"?l.jsxRuntimeExports.jsx(C.ja,{options:e.allowedColumnIds,size:"sm",isClearable:!1,isSearchable:!0,variant:f,controlShouldRenderValue:!0,defaultValue:s?e.allowedColumnIds[e.allowedColumnIds.findIndex(a=>a.value===s[s.findIndex(t=>t.chartConfigId===e.chartConfigId)].columnId)]:void 0,onChange:a=>{const t={columnId:a?.value,chartConfigId:e.chartConfigId},g=v?.map(h=>h.chartConfigId===t.chartConfigId?t:h);V(M(I,g)),j(g)}}):l.jsxRuntimeExports.jsx(d.ye,{variant:f,defaultValue:s?e.allowedColumnIds[e.allowedColumnIds.findIndex(a=>a.value===s[s.findIndex(t=>t.chartConfigId===e.chartConfigId)].columnId)].label:"",onValueChange:a=>{const g={columnId:e.allowedColumnIds[e.allowedColumnIds.findIndex(T=>T.label===a)].value,chartConfigId:e.chartConfigId},h=v?.map(T=>T.chartConfigId===g.chartConfigId?g:T);V(M(I,h)),j(h)},children:e.allowedColumnIds.map((a,t)=>l.jsxRuntimeExports.jsx(d.he,{label:a.label,value:a.label},t))})]},r)),R?.map((e,r)=>l.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/p}% - ${(p-1)/p}rem)`,flexGrow:e.width?0:1,flexShrink:0,minWidth:"240px"},className:"pb-4",children:[l.jsxRuntimeExports.jsx(d.b,{className:"mb-2",children:e.label}),e.singleSelect?e.ui!=="radio"?l.jsxRuntimeExports.jsx(C.ja,{options:e.availableValues,variant:f,isClearable:e.clearable===void 0?!0:e.clearable,isSearchable:!0,controlShouldRenderValue:!0,filterOption:C.Du(G),onChange:a=>{y(e.filter,a)},value:e.value,defaultValue:e.defaultValue}):l.jsxRuntimeExports.jsx(d.ye,{variant:f,defaultValue:e.defaultValue.value,onValueChange:a=>{y(e.filter,e.availableValues.filter(t=>t.value===a))},children:e.availableValues.map((a,t)=>l.jsxRuntimeExports.jsx(d.he,{label:`${a.label}`,value:`${a.value}`},t))}):l.jsxRuntimeExports.jsxs(l.jsxRuntimeExports.Fragment,{children:[e.ui!=="radio"?l.jsxRuntimeExports.jsx(C.ja,{options:e.availableValues,variant:f,size:"sm",isMulti:!0,isClearable:e.clearable===void 0?!0:e.clearable,isSearchable:!0,controlShouldRenderValue:!0,filterOption:C.Du(G),onChange:a=>{y(e.filter,a)},value:e.value,defaultValue:e.defaultValue}):l.jsxRuntimeExports.jsx(d.$,{variant:f,defaultValue:e.defaultValue?e.defaultValue.map(a=>`${a.value}`):[],value:e.value?e.value.map(a=>`${a.value}`):void 0,onValueChange:a=>{y(e.filter,e.availableValues.filter(t=>a.indexOf(`${t.value}`)!==-1))},children:e.availableValues.map((a,t)=>l.jsxRuntimeExports.jsx(d.P,{label:`${a.label}`,value:`${a.value}`},t))}),e.allowSelectAll?l.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:()=>{y(e.filter,e.availableValues)},children:"Select all options"}):null]})]},r)),m?l.jsxRuntimeExports.jsxs("div",{style:{width:m.width||`calc(${100/p}% - ${(p-1)/p}rem)`,flexGrow:m.width?0:1,flexShrink:0,minWidth:"240px"},className:"pb-4",children:[l.jsxRuntimeExports.jsx(d.b,{className:"mb-2",children:m.label||"Highlight data"}),l.jsxRuntimeExports.jsx(C.ja,{options:Y,variant:f,size:"sm",isMulti:!0,isClearable:!0,isSearchable:!0,controlShouldRenderValue:!0,filterOption:C.Du(G),onChange:e=>{X(e?.map(r=>r.value))},value:E?.map(e=>({label:e,value:e})),defaultValue:m.defaultValues?.map(e=>({label:e,value:e}))})]}):null]}):null,l.jsxRuntimeExports.jsx(re.GraphEl,{graph:b,graphData:ae,graphDataConfiguration:v,debugMode:S,readableHeader:B||[],updateFilters:K,settings:{...i||{},...x,graphTitle:void 0,graphDescription:void 0,graphDownload:!1,dataDownload:!1,backgroundColor:void 0,width:void 0,height:void 0,relativeHeight:void 0,minHeight:void 0,padding:"0",theme:i?.theme,...E?{highlightedDataPoints:E,highlightedIds:E?.map(e=>`${e}`),highlightedLines:E?.map(e=>e)}:{}}})]}):l.jsxRuntimeExports.jsx("div",{className:"w-full flex justify-center p-4",children:l.jsxRuntimeExports.jsx(ne.w,{})})})}exports.SingleGraphDashboard=de;
|
|
2
2
|
//# sourceMappingURL=SingleGraphDashboard.cjs.map
|
|
@@ -5,9 +5,9 @@ import { f as F } from "./index-EArKRVKg.js";
|
|
|
5
5
|
import { i as ua } from "./index-Bwrro8-q.js";
|
|
6
6
|
import { j as V, D as M } from "./DropdownSelect-BbdPQa2k.js";
|
|
7
7
|
import { b as A, y as H, h as O, c as da, $ as K, P as Q } from "./checkIfMultiple-CIRtG0KE.js";
|
|
8
|
-
import { w as ha } from "./Spinner-
|
|
8
|
+
import { w as ha } from "./Spinner-DVBnY6Vg.js";
|
|
9
9
|
import { G as ca } from "./GraphContainer-CRqzdKu2.js";
|
|
10
|
-
import { G as fa } from "./GraphEl-
|
|
10
|
+
import { G as fa } from "./GraphEl-Dyu_EIQb.js";
|
|
11
11
|
import { f as ga, a as pa, b as ma, c as Ca, t as va } from "./fetchAndParseData-BpqkBPQL.js";
|
|
12
12
|
import { a as Ia, t as ba } from "./transformDataForAggregation-j34UL73s.js";
|
|
13
13
|
import { g as X } from "./getUniqValue-DsqSii6M.js";
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./index-CHPV5EwG-CTPQjnHt.cjs"),g=require("react"),f=require("./Spinner-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./index-CHPV5EwG-CTPQjnHt.cjs"),g=require("react"),f=require("./Spinner-CQZcjzwd.cjs"),h=require("./SingleGraphDashboard.cjs"),p=require("./fetchAndParseData-l5HGMAEs.cjs");function S(l){const e=s.compilerRuntimeExports.c(19),{config:a}=l,[t,d]=g.useState(void 0);let n,r;if(e[0]!==a?(n=()=>{(async()=>{if(typeof a=="string"){const c=await p.fetchAndParseJSON(a);d(c)}else d(a)})()},r=[a],e[0]=a,e[1]=n,e[2]=r):(n=e[1],r=e[2]),g.useEffect(n,r),!t){let i;return e[3]===Symbol.for("react.memo_cache_sentinel")?(i=s.jsxRuntimeExports.jsx("div",{className:"w-full flex justify-center p-4",children:s.jsxRuntimeExports.jsx(f.w,{})}),e[3]=i):i=e[3],i}let o;return e[4]!==t.advancedDataSelectionOptions||e[5]!==t.dataFilters||e[6]!==t.dataSelectionOptions||e[7]!==t.dataSettings||e[8]!==t.dataTransform||e[9]!==t.debugMode||e[10]!==t.filters||e[11]!==t.graphDataConfiguration||e[12]!==t.graphSettings||e[13]!==t.graphType||e[14]!==t.highlightDataPointSettings||e[15]!==t.noOfFiltersPerRow||e[16]!==t.readableHeader||e[17]!==t.uiMode?(o=s.jsxRuntimeExports.jsx(h.SingleGraphDashboard,{graphSettings:t.graphSettings,dataSettings:t.dataSettings,filters:t.filters,graphType:t.graphType,dataTransform:t.dataTransform,graphDataConfiguration:t.graphDataConfiguration,dataFilters:t.dataFilters,debugMode:t.debugMode,dataSelectionOptions:t.dataSelectionOptions,advancedDataSelectionOptions:t.advancedDataSelectionOptions,readableHeader:t.readableHeader,noOfFiltersPerRow:t.noOfFiltersPerRow,uiMode:t.uiMode,highlightDataPointSettings:t.highlightDataPointSettings}),e[4]=t.advancedDataSelectionOptions,e[5]=t.dataFilters,e[6]=t.dataSelectionOptions,e[7]=t.dataSettings,e[8]=t.dataTransform,e[9]=t.debugMode,e[10]=t.filters,e[11]=t.graphDataConfiguration,e[12]=t.graphSettings,e[13]=t.graphType,e[14]=t.highlightDataPointSettings,e[15]=t.noOfFiltersPerRow,e[16]=t.readableHeader,e[17]=t.uiMode,e[18]=o):o=e[18],o}exports.SingleGraphDashboardFromConfig=S;
|
|
2
2
|
//# sourceMappingURL=SingleGraphDashboardFromConfig.cjs.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { c as f, j as s } from "./index-CHPV5EwG-Curnpaqc.js";
|
|
2
2
|
import { useState as p, useEffect as c } from "react";
|
|
3
|
-
import { w as h } from "./Spinner-
|
|
3
|
+
import { w as h } from "./Spinner-DVBnY6Vg.js";
|
|
4
4
|
import { SingleGraphDashboard as S } from "./SingleGraphDashboard.js";
|
|
5
5
|
import { f as m } from "./fetchAndParseData-BpqkBPQL.js";
|
|
6
6
|
function P(g) {
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("./index-CHPV5EwG-CTPQjnHt.cjs"),g=require("react"),d=require("./Spinner-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("./index-CHPV5EwG-CTPQjnHt.cjs"),g=require("react"),d=require("./Spinner-CQZcjzwd.cjs"),l=require("./SingleGraphDashboardGeoHubMaps.cjs"),f=require("./fetchAndParseData-l5HGMAEs.cjs");function h(c){const e=a.compilerRuntimeExports.c(9),{config:s}=c,[t,u]=g.useState(void 0);let o,i;if(e[0]!==s?(o=()=>{(async()=>{if(typeof s=="string"){const p=await f.fetchAndParseJSON(s);u(p)}else u(s)})()},i=[s],e[0]=s,e[1]=o,e[2]=i):(o=e[1],i=e[2]),g.useEffect(o,i),!t){let r;return e[3]===Symbol.for("react.memo_cache_sentinel")?(r=a.jsxRuntimeExports.jsx("div",{className:"w-full flex justify-center p-4",children:a.jsxRuntimeExports.jsx(d.w,{})}),e[3]=r):r=e[3],r}let n;return e[4]!==t.debugMode||e[5]!==t.graphSettings||e[6]!==t.graphType||e[7]!==t.uiMode?(n=a.jsxRuntimeExports.jsx(l.SingleGraphDashboardGeoHubMaps,{graphSettings:t.graphSettings,graphType:t.graphType,debugMode:t.debugMode,uiMode:t.uiMode}),e[4]=t.debugMode,e[5]=t.graphSettings,e[6]=t.graphType,e[7]=t.uiMode,e[8]=n):n=e[8],n}exports.SingleGraphDashboardGeoHubMapsFromConfig=h;
|
|
2
2
|
//# sourceMappingURL=SingleGraphDashboardGeoHubMapsFromConfig.cjs.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { c, j as n } from "./index-CHPV5EwG-Curnpaqc.js";
|
|
2
2
|
import { useState as d, useEffect as u } from "react";
|
|
3
|
-
import { w as l } from "./Spinner-
|
|
3
|
+
import { w as l } from "./Spinner-DVBnY6Vg.js";
|
|
4
4
|
import { SingleGraphDashboardGeoHubMaps as m } from "./SingleGraphDashboardGeoHubMaps.js";
|
|
5
5
|
import { f as h } from "./fetchAndParseData-BpqkBPQL.js";
|
|
6
6
|
function j(f) {
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("./index-CHPV5EwG-CTPQjnHt.cjs"),u=require("react"),le=require("./index-CyZ1lmi_.cjs"),F=require("./index-BS2TADPj.cjs"),ie=require("./index-DQA8q5sC.cjs"),D=require("./DropdownSelect-Doz3mCrM.cjs"),g=require("./checkIfMultiple-wg6hJLXy.cjs"),oe=require("./Spinner-DRMBUsX7.cjs"),W=require("./Typography-DX7PlgQU.cjs"),ne=require("./ThreeDGlobe.cjs"),A=require("./fetchAndParseData-l5HGMAEs.cjs"),Z=require("./transformDataForAggregation-CYoB5Xsk.cjs"),J=require("./getUniqValue-NX8DgwND.cjs"),re=require("./GraphHeader.cjs"),K=require("./filterData-T5DQBE9b.cjs"),se=require("./getGraphList-CA17dvFB.cjs"),Q=require("./transformDataForSelect-YmStusCI.cjs"),ue=require("./GraphContainer-d8A46BK2.cjs");function ce(y){const t=i.compilerRuntimeExports.c(24),{settings:a,graph:m,graphData:d,debugMode:S,graphDataConfiguration:n,readableHeader:E,updateFilters:I}=y;if(S&&(console.log(`Graph: ${m}`),console.log("Transformed data:",d),console.log("Settings:",a)),typeof d=="string"){const b=`flex my-0 mx-auto grow flex-col justify-center ${a?.width?"w-fit":"w-full"}`;let x;t[0]===Symbol.for("react.memo_cache_sentinel")?(x={height:"inherit"},t[0]=x):x=t[0];let c;t[1]!==d?(c=i.jsxRuntimeExports.jsx(W.j,{size:"sm",marginBottom:"none",className:"p-2 text-center text-accent-dark-red dark:text-accent-red",children:d}),t[1]=d,t[2]=c):c=t[2];let w;return t[3]!==b||t[4]!==c?(w=i.jsxRuntimeExports.jsx("div",{className:b,style:x,children:c}),t[3]=b,t[4]=c,t[5]=w):w=t[5],w}let v;t[6]===Symbol.for("react.memo_cache_sentinel")?(v={threeDGlobe:ne.ThreeDGlobe},t[6]=v):v=t[6];const O=v;let V;t[7]!==d||t[8]!==n||t[9]!==E||t[10]!==a||t[11]!==I?(V=b=>{switch(b){case"threeDGlobe":return{globeOffset:a?.globeOffset,collapseColorScaleByDefault:a?.collapseColorScaleByDefault,polygonAltitude:a?.polygonAltitude,highlightedIds:a?.highlightedIds,scale:a?.scale,theme:a?.theme,resetSelectionOnDoubleClick:a?.resetSelectionOnDoubleClick,graphTitle:a?.graphTitle,mapData:a?.mapData,graphDescription:a?.graphDescription,footNote:a?.footNote,width:a?.width,height:a?.height,sources:a?.sources,colorDomain:a?.colorDomain,colors:a?.colors,colorLegendTitle:Object.keys(a||{}).indexOf("colorLegendTitle")!==-1?a?.colorLegendTitle:g.getValues("x",n||[],E||[]),scaleType:a?.scaleType,data:d,centerPoint:a?.centerPoint,backgroundColor:a?.backgroundColor,mapNoDataColor:a?.mapNoDataColor,mapBorderColor:a?.mapBorderColor,relativeHeight:a?.relativeHeight,padding:a?.padding,tooltip:a?.tooltip,showColorScale:a?.showColorScale,graphID:a?.graphID,dataDownload:a?.dataDownload,mapProperty:a?.mapProperty,language:a?.language,minHeight:a?.minHeight,ariaLabel:a?.ariaLabel,onSeriesMouseClick:x=>{I?.(x.id)},detailsOnClick:a?.detailsOnClick,styles:a?.styles,classNames:a?.classNames,autoRotate:a?.autoRotate,globeMaterial:a?.globeMaterial,atmosphereColor:a?.atmosphereColor,enableZoom:a?.enableZoom,atmosphereAltitude:a?.atmosphereAltitude,globeCurvatureResolution:a?.globeCurvatureResolution,fogSettings:a?.fogSetting,lights:a?.lights,highlightedAltitude:a?.highlightedAltitude,selectedId:a?.selectedId};default:return{}}},t[7]=d,t[8]=n,t[9]=E,t[10]=a,t[11]=I,t[12]=V):V=t[12];const h=V,T=O[m];let p;t[13]!==h||t[14]!==m?(p=h(m),t[13]=h,t[14]=m,t[15]=p):p=t[15];const f=p,G=`grow my-0 mx-auto flex flex-col w-full justify-center ${a?.theme||"light"}`;let R;t[16]===Symbol.for("react.memo_cache_sentinel")?(R={minHeight:"inherit"},t[16]=R):R=t[16];let s;t[17]!==T||t[18]!==m||t[19]!==f?(s=T?i.jsxRuntimeExports.jsx(T,{...f}):i.jsxRuntimeExports.jsx(W.j,{size:"sm",marginBottom:"none",className:"p-2 text-center text-accent-dark-red dark:text-accent-red",children:`Invalid chart type: ${m}`}),t[17]=T,t[18]=m,t[19]=f,t[20]=s):s=t[20];let N;return t[21]!==G||t[22]!==s?(N=i.jsxRuntimeExports.jsx("div",{className:G,style:R,children:s}),t[21]=G,t[22]=s,t[23]=N):N=t[23],N}const L=(y,t)=>{const a=t?.map(m=>{const d=y?.findIndex(n=>n.chartConfigId===m.chartConfigId);if(d===-1)return{};const S=y[d]?.allowedColumnIds?.findIndex(n=>n.value===m.columnId);return S===-1?{}:y[d].allowedColumnIds[S].graphSettings||{}})||[];return Object.assign({},...a)};function de(y){const{graphSettings:t,dataSettings:a,filters:m,graphType:d,dataTransform:S,graphDataConfiguration:n,dataFilters:E,debugMode:I,dataSelectionOptions:v,advancedDataSelectionOptions:O,readableHeader:V,noOfFiltersPerRow:h=4,updateFilters:T,uiMode:p="normal",highlightDataPointSettings:f}=y,[G,R]=u.useState(void 0),[s,N]=u.useState(void 0),[b,x]=u.useState(n),[c,w]=u.useState({}),[$,X]=u.useState(void 0),[Y,_]=u.useState([]),M=u.useRef(null),U=u.useRef(n),[P,z]=u.useState([]),H={ignoreCase:!0,ignoreAccents:!0,trim:!0},B=u.useEffectEvent(()=>{const e=(m||[]).map(r=>({filter:r.column,label:r.label||`Filter by ${r.column}`,singleSelect:r.singleSelect,clearable:r.clearable,defaultValue:Q.transformDefaultValue(r.defaultValue),value:Q.transformDefaultValue(r.defaultValue),availableValues:J.getUniqValue(s,r.column).filter(l=>!r.excludeValues?.includes(`${l}`)).map(l=>({value:l,label:l})),allowSelectAll:r.allowSelectAll,width:r.width}));z(e)});u.useEffect(()=>{(async()=>{try{const r=a.dataURL?typeof a.dataURL=="string"?a.fileType==="json"?await A.fetchAndParseJSON(a.dataURL,a.columnsToArray,a.dataTransformation,I):a.fileType==="api"?await A.fetchAndTransformDataFromAPI(a.dataURL,a.apiHeaders,a.columnsToArray,a.dataTransformation,I):await A.fetchAndParseCSV(a.dataURL,a.dataTransformation,a.columnsToArray,I,a.delimiter,!0):await A.fetchAndParseMultipleDataSources(a.dataURL,a.idColumnTitle):await A.transformColumnsToArray(a.data,a.columnsToArray);N(r)}catch(r){console.error("Data fetching error:",r)}})(),B()},[a,I]),u.useEffect(()=>{B()},[m,s]);const ee=u.useEffectEvent(()=>{if(!s||P.length===0)R(s);else{const e=s.filter(r=>P.every(l=>l.value&&F.flattenDeep([l.value]).length>0?le.intersection(F.flattenDeep([r[l.filter]]),F.flattenDeep([l.value]).map(o=>o.value)).length>0:!0));R(e)}});u.useEffect(()=>{ee()},[P,s]),u.useEffect(()=>{v&&w(L(v,n))},[v,n]);const te=u.useEffectEvent(()=>{f?.column&&G&&_(J.getUniqValue(G,f.column).filter(e=>!f?.excludeValues?.includes(`${e}`)).map(e=>({value:e,label:e})))});u.useEffect(()=>{te()},[f]),u.useEffect(()=>{ie.isEqual(U.current,n)||(x(n),U.current=n)},[n]);const k=(e,r)=>{z(l=>l.map(o=>o.filter===e?{...o,value:r}:o))},ae=s?Z.transformDataForGraph(S?Z.transformDataForAggregation(K.filterData(s,E||[]),S.keyColumn,S.aggregationColumnsSetting):K.filterData(s,E||[]),d,b):void 0;return i.jsxRuntimeExports.jsx(ue.GraphContainer,{className:t?.classNames?.graphContainer,style:t?.styles?.graphContainer,id:t?.graphID,ref:M,"aria-label":t?.ariaLabel,backgroundColor:t?.backgroundColor??!1,theme:t?.theme||"light",language:t?.language||"en",width:t?.width,height:t?.height,padding:t?.padding,minHeight:t?.minHeight,relativeHeight:t?.relativeHeight,children:s||se.graphList.filter(e=>e.geoHubMapPresentation).map(e=>e.graphID).indexOf(d)!==-1?i.jsxRuntimeExports.jsxs(i.jsxRuntimeExports.Fragment,{children:[c?.graphTitle||c?.graphDescription||t?.graphTitle||t?.graphDescription||t?.graphDownload||t?.dataDownload?i.jsxRuntimeExports.jsx(re.GraphHeader,{styles:{title:c?.styles?.title||t?.styles?.title,description:c?.styles?.description||t?.styles?.description},classNames:{title:c?.classNames?.title||t?.classNames?.title,description:c?.classNames?.description||t?.classNames?.description},graphTitle:c?.graphTitle||t?.graphTitle,graphDescription:c?.graphDescription||t?.graphDescription,width:c?.width||t?.width,graphDownload:t?.graphDownload?M:void 0,dataDownload:t?.dataDownload&&s&&s.length>0?s:null}):null,P.length!==0||(v||[]).length!==0||(O||[]).length!==0||f?i.jsxRuntimeExports.jsxs("div",{className:"flex flex-wrap items-start gap-x-4 gap-y-0 w-full",children:[O?.map((e,r)=>i.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/h}% - ${(h-1)/h}rem)`,flexGrow:e.width?0:1,flexShrink:e.ui!=="radio"||e.width?0:1,minWidth:"240px"},className:"pb-4",children:[i.jsxRuntimeExports.jsx(g.b,{className:"mb-2",children:e.label||"Graph by"}),e.ui!=="radio"?i.jsxRuntimeExports.jsx(D.ja,{options:e.options.map(l=>({...l,value:l.label})),size:"sm",isClearable:!1,isSearchable:!0,variant:p,controlShouldRenderValue:!0,defaultValue:e.defaultValue?{...e.defaultValue,value:e.defaultValue?.label}:{...e.options[0],value:e.options[0].label},onChange:l=>{w(l?.graphSettings||{}),x(l?.dataConfiguration)}}):i.jsxRuntimeExports.jsx(g.ye,{defaultValue:e.defaultValue?.label||e.options[0].label,variant:p,onValueChange:l=>{const o=e.options[e.options.findIndex(j=>j.label===l)];w(o.graphSettings||{}),x(o.dataConfiguration)},children:e.options.map((l,o)=>i.jsxRuntimeExports.jsx(g.he,{label:l.label,value:l.label},o))})]},r)),v?.map((e,r)=>i.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/h}% - ${(h-1)/h}rem)`,flexGrow:e.width?0:1,flexShrink:e.ui!=="radio"||e.width?0:1,minWidth:"240px"},className:"pb-4",children:[i.jsxRuntimeExports.jsx(g.b,{className:"mb-2",children:e.label||`Visualize ${e.chartConfigId} by`}),g.checkIfMultiple(e.chartConfigId,b||[])?e.ui!=="radio"?i.jsxRuntimeExports.jsx(D.ja,{options:e.allowedColumnIds,size:"sm",isMulti:!0,isSearchable:!0,variant:p,controlShouldRenderValue:!0,defaultValue:n?n[n.findIndex(l=>l.chartConfigId===e.chartConfigId)].columnId.map(l=>e.allowedColumnIds[e.allowedColumnIds.findIndex(o=>o.value===l)]):void 0,filterOption:D.Du(H),onChange:l=>{const o={columnId:(l||[]).map(C=>C.value),chartConfigId:e.chartConfigId},j=b?.map(C=>C.chartConfigId===o.chartConfigId?o:C);x(j)}}):i.jsxRuntimeExports.jsx(g.$,{variant:p,defaultValue:n?n[n.findIndex(l=>l.chartConfigId===e.chartConfigId)].columnId.map(l=>e.allowedColumnIds[e.allowedColumnIds.findIndex(o=>o.value===l)]).map(l=>l.value):[],onValueChange:l=>{const o={columnId:l||[],chartConfigId:e.chartConfigId},j=b?.map(C=>C.chartConfigId===o.chartConfigId?o:C);x(j)},children:e.allowedColumnIds.map((l,o)=>i.jsxRuntimeExports.jsx(g.P,{label:l.label,value:l.label},o))}):e.ui!=="radio"?i.jsxRuntimeExports.jsx(D.ja,{options:e.allowedColumnIds,size:"sm",isClearable:!1,isSearchable:!0,variant:p,controlShouldRenderValue:!0,defaultValue:n?e.allowedColumnIds[e.allowedColumnIds.findIndex(l=>l.value===n[n.findIndex(o=>o.chartConfigId===e.chartConfigId)].columnId)]:void 0,onChange:l=>{const o={columnId:l?.value,chartConfigId:e.chartConfigId},j=b?.map(C=>C.chartConfigId===o.chartConfigId?o:C);w(L(v,j)),x(j)}}):i.jsxRuntimeExports.jsx(g.ye,{variant:p,defaultValue:n?e.allowedColumnIds[e.allowedColumnIds.findIndex(l=>l.value===n[n.findIndex(o=>o.chartConfigId===e.chartConfigId)].columnId)].label:"",onValueChange:l=>{const j={columnId:e.allowedColumnIds[e.allowedColumnIds.findIndex(q=>q.label===l)].value,chartConfigId:e.chartConfigId},C=b?.map(q=>q.chartConfigId===j.chartConfigId?j:q);w(L(v,C)),x(C)},children:e.allowedColumnIds.map((l,o)=>i.jsxRuntimeExports.jsx(g.he,{label:l.label,value:l.label},o))})]},r)),P?.map((e,r)=>i.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/h}% - ${(h-1)/h}rem)`,flexGrow:e.width?0:1,flexShrink:e.ui!=="radio"||e.width?0:1,minWidth:"240px"},className:"pb-4",children:[i.jsxRuntimeExports.jsx(g.b,{className:"mb-2",children:e.label}),e.singleSelect?e.ui!=="radio"?i.jsxRuntimeExports.jsx(D.ja,{options:e.availableValues,variant:p,isClearable:e.clearable===void 0?!0:e.clearable,isSearchable:!0,controlShouldRenderValue:!0,filterOption:D.Du(H),onChange:l=>{k(e.filter,l)},value:e.value,defaultValue:e.defaultValue}):i.jsxRuntimeExports.jsx(g.ye,{variant:p,defaultValue:e.defaultValue.value,onValueChange:l=>{k(e.filter,e.availableValues.filter(o=>o.value===l))},children:e.availableValues.map((l,o)=>i.jsxRuntimeExports.jsx(g.he,{label:`${l.label}`,value:`${l.value}`},o))}):i.jsxRuntimeExports.jsxs(i.jsxRuntimeExports.Fragment,{children:[e.ui!=="radio"?i.jsxRuntimeExports.jsx(D.ja,{options:e.availableValues,variant:p,size:"sm",isMulti:!0,isClearable:e.clearable===void 0?!0:e.clearable,isSearchable:!0,controlShouldRenderValue:!0,filterOption:D.Du(H),onChange:l=>{k(e.filter,l)},value:e.value,defaultValue:e.defaultValue}):i.jsxRuntimeExports.jsx(g.$,{variant:p,defaultValue:e.defaultValue?e.defaultValue.map(l=>`${l.value}`):[],value:e.value?e.value.map(l=>`${l.value}`):void 0,onValueChange:l=>{k(e.filter,e.availableValues.filter(o=>l.indexOf(`${o.value}`)!==-1))},children:e.availableValues.map((l,o)=>i.jsxRuntimeExports.jsx(g.P,{label:`${l.label}`,value:`${l.value}`},o))}),e.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:()=>{k(e.filter,e.availableValues)},children:"Select all options"}):null]})]},r)),f?i.jsxRuntimeExports.jsxs("div",{style:{width:f.width||`calc(${100/h}% - ${(h-1)/h}rem)`,flexGrow:f.width?0:1,flexShrink:0,minWidth:"240px"},className:"pb-4",children:[i.jsxRuntimeExports.jsx(g.b,{className:"mb-2",children:f.label||"Highlight data"}),i.jsxRuntimeExports.jsx(D.ja,{options:Y,variant:p,size:"sm",isMulti:!0,isClearable:!0,isSearchable:!0,controlShouldRenderValue:!0,filterOption:D.Du(H),onChange:e=>{X(e?.map(r=>r.value))},value:$?.map(e=>({label:e,value:e})),defaultValue:f.defaultValues?.map(e=>({label:e,value:e}))})]}):null]}):null,i.jsxRuntimeExports.jsx(ce,{graph:d,graphData:ae,graphDataConfiguration:b,debugMode:I,readableHeader:V||[],updateFilters:T,settings:{...t||{},...c,graphTitle:void 0,graphDescription:void 0,graphDownload:!1,dataDownload:!1,backgroundColor:void 0,padding:"0",width:void 0,height:void 0,relativeHeight:void 0,minHeight:void 0,theme:t?.theme,...$?{highlightedDataPoints:$,highlightedIds:$?.map(e=>`${e}`),highlightedLines:$?.map(e=>e)}:{}}})]}):i.jsxRuntimeExports.jsx("div",{className:"w-full flex justify-center p-4",children:i.jsxRuntimeExports.jsx(oe.w,{})})})}exports.SingleGraphDashboardThreeDGraphs=de;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("./index-CHPV5EwG-CTPQjnHt.cjs"),u=require("react"),le=require("./index-CyZ1lmi_.cjs"),F=require("./index-BS2TADPj.cjs"),ie=require("./index-DQA8q5sC.cjs"),D=require("./DropdownSelect-Doz3mCrM.cjs"),g=require("./checkIfMultiple-wg6hJLXy.cjs"),oe=require("./Spinner-CQZcjzwd.cjs"),W=require("./Typography-DX7PlgQU.cjs"),ne=require("./ThreeDGlobe.cjs"),A=require("./fetchAndParseData-l5HGMAEs.cjs"),Z=require("./transformDataForAggregation-CYoB5Xsk.cjs"),J=require("./getUniqValue-NX8DgwND.cjs"),re=require("./GraphHeader.cjs"),K=require("./filterData-T5DQBE9b.cjs"),se=require("./getGraphList-CA17dvFB.cjs"),Q=require("./transformDataForSelect-YmStusCI.cjs"),ue=require("./GraphContainer-d8A46BK2.cjs");function ce(y){const t=i.compilerRuntimeExports.c(24),{settings:a,graph:m,graphData:d,debugMode:S,graphDataConfiguration:n,readableHeader:E,updateFilters:I}=y;if(S&&(console.log(`Graph: ${m}`),console.log("Transformed data:",d),console.log("Settings:",a)),typeof d=="string"){const b=`flex my-0 mx-auto grow flex-col justify-center ${a?.width?"w-fit":"w-full"}`;let x;t[0]===Symbol.for("react.memo_cache_sentinel")?(x={height:"inherit"},t[0]=x):x=t[0];let c;t[1]!==d?(c=i.jsxRuntimeExports.jsx(W.j,{size:"sm",marginBottom:"none",className:"p-2 text-center text-accent-dark-red dark:text-accent-red",children:d}),t[1]=d,t[2]=c):c=t[2];let w;return t[3]!==b||t[4]!==c?(w=i.jsxRuntimeExports.jsx("div",{className:b,style:x,children:c}),t[3]=b,t[4]=c,t[5]=w):w=t[5],w}let v;t[6]===Symbol.for("react.memo_cache_sentinel")?(v={threeDGlobe:ne.ThreeDGlobe},t[6]=v):v=t[6];const O=v;let V;t[7]!==d||t[8]!==n||t[9]!==E||t[10]!==a||t[11]!==I?(V=b=>{switch(b){case"threeDGlobe":return{globeOffset:a?.globeOffset,collapseColorScaleByDefault:a?.collapseColorScaleByDefault,polygonAltitude:a?.polygonAltitude,highlightedIds:a?.highlightedIds,scale:a?.scale,theme:a?.theme,resetSelectionOnDoubleClick:a?.resetSelectionOnDoubleClick,graphTitle:a?.graphTitle,mapData:a?.mapData,graphDescription:a?.graphDescription,footNote:a?.footNote,width:a?.width,height:a?.height,sources:a?.sources,colorDomain:a?.colorDomain,colors:a?.colors,colorLegendTitle:Object.keys(a||{}).indexOf("colorLegendTitle")!==-1?a?.colorLegendTitle:g.getValues("x",n||[],E||[]),scaleType:a?.scaleType,data:d,centerPoint:a?.centerPoint,backgroundColor:a?.backgroundColor,mapNoDataColor:a?.mapNoDataColor,mapBorderColor:a?.mapBorderColor,relativeHeight:a?.relativeHeight,padding:a?.padding,tooltip:a?.tooltip,showColorScale:a?.showColorScale,graphID:a?.graphID,dataDownload:a?.dataDownload,mapProperty:a?.mapProperty,language:a?.language,minHeight:a?.minHeight,ariaLabel:a?.ariaLabel,onSeriesMouseClick:x=>{I?.(x.id)},detailsOnClick:a?.detailsOnClick,styles:a?.styles,classNames:a?.classNames,autoRotate:a?.autoRotate,globeMaterial:a?.globeMaterial,atmosphereColor:a?.atmosphereColor,enableZoom:a?.enableZoom,atmosphereAltitude:a?.atmosphereAltitude,globeCurvatureResolution:a?.globeCurvatureResolution,fogSettings:a?.fogSetting,lights:a?.lights,highlightedAltitude:a?.highlightedAltitude,selectedId:a?.selectedId};default:return{}}},t[7]=d,t[8]=n,t[9]=E,t[10]=a,t[11]=I,t[12]=V):V=t[12];const h=V,T=O[m];let p;t[13]!==h||t[14]!==m?(p=h(m),t[13]=h,t[14]=m,t[15]=p):p=t[15];const f=p,G=`grow my-0 mx-auto flex flex-col w-full justify-center ${a?.theme||"light"}`;let R;t[16]===Symbol.for("react.memo_cache_sentinel")?(R={minHeight:"inherit"},t[16]=R):R=t[16];let s;t[17]!==T||t[18]!==m||t[19]!==f?(s=T?i.jsxRuntimeExports.jsx(T,{...f}):i.jsxRuntimeExports.jsx(W.j,{size:"sm",marginBottom:"none",className:"p-2 text-center text-accent-dark-red dark:text-accent-red",children:`Invalid chart type: ${m}`}),t[17]=T,t[18]=m,t[19]=f,t[20]=s):s=t[20];let N;return t[21]!==G||t[22]!==s?(N=i.jsxRuntimeExports.jsx("div",{className:G,style:R,children:s}),t[21]=G,t[22]=s,t[23]=N):N=t[23],N}const L=(y,t)=>{const a=t?.map(m=>{const d=y?.findIndex(n=>n.chartConfigId===m.chartConfigId);if(d===-1)return{};const S=y[d]?.allowedColumnIds?.findIndex(n=>n.value===m.columnId);return S===-1?{}:y[d].allowedColumnIds[S].graphSettings||{}})||[];return Object.assign({},...a)};function de(y){const{graphSettings:t,dataSettings:a,filters:m,graphType:d,dataTransform:S,graphDataConfiguration:n,dataFilters:E,debugMode:I,dataSelectionOptions:v,advancedDataSelectionOptions:O,readableHeader:V,noOfFiltersPerRow:h=4,updateFilters:T,uiMode:p="normal",highlightDataPointSettings:f}=y,[G,R]=u.useState(void 0),[s,N]=u.useState(void 0),[b,x]=u.useState(n),[c,w]=u.useState({}),[$,X]=u.useState(void 0),[Y,_]=u.useState([]),M=u.useRef(null),U=u.useRef(n),[P,z]=u.useState([]),H={ignoreCase:!0,ignoreAccents:!0,trim:!0},B=u.useEffectEvent(()=>{const e=(m||[]).map(r=>({filter:r.column,label:r.label||`Filter by ${r.column}`,singleSelect:r.singleSelect,clearable:r.clearable,defaultValue:Q.transformDefaultValue(r.defaultValue),value:Q.transformDefaultValue(r.defaultValue),availableValues:J.getUniqValue(s,r.column).filter(l=>!r.excludeValues?.includes(`${l}`)).map(l=>({value:l,label:l})),allowSelectAll:r.allowSelectAll,width:r.width}));z(e)});u.useEffect(()=>{(async()=>{try{const r=a.dataURL?typeof a.dataURL=="string"?a.fileType==="json"?await A.fetchAndParseJSON(a.dataURL,a.columnsToArray,a.dataTransformation,I):a.fileType==="api"?await A.fetchAndTransformDataFromAPI(a.dataURL,a.apiHeaders,a.columnsToArray,a.dataTransformation,I):await A.fetchAndParseCSV(a.dataURL,a.dataTransformation,a.columnsToArray,I,a.delimiter,!0):await A.fetchAndParseMultipleDataSources(a.dataURL,a.idColumnTitle):await A.transformColumnsToArray(a.data,a.columnsToArray);N(r)}catch(r){console.error("Data fetching error:",r)}})(),B()},[a,I]),u.useEffect(()=>{B()},[m,s]);const ee=u.useEffectEvent(()=>{if(!s||P.length===0)R(s);else{const e=s.filter(r=>P.every(l=>l.value&&F.flattenDeep([l.value]).length>0?le.intersection(F.flattenDeep([r[l.filter]]),F.flattenDeep([l.value]).map(o=>o.value)).length>0:!0));R(e)}});u.useEffect(()=>{ee()},[P,s]),u.useEffect(()=>{v&&w(L(v,n))},[v,n]);const te=u.useEffectEvent(()=>{f?.column&&G&&_(J.getUniqValue(G,f.column).filter(e=>!f?.excludeValues?.includes(`${e}`)).map(e=>({value:e,label:e})))});u.useEffect(()=>{te()},[f]),u.useEffect(()=>{ie.isEqual(U.current,n)||(x(n),U.current=n)},[n]);const k=(e,r)=>{z(l=>l.map(o=>o.filter===e?{...o,value:r}:o))},ae=s?Z.transformDataForGraph(S?Z.transformDataForAggregation(K.filterData(s,E||[]),S.keyColumn,S.aggregationColumnsSetting):K.filterData(s,E||[]),d,b):void 0;return i.jsxRuntimeExports.jsx(ue.GraphContainer,{className:t?.classNames?.graphContainer,style:t?.styles?.graphContainer,id:t?.graphID,ref:M,"aria-label":t?.ariaLabel,backgroundColor:t?.backgroundColor??!1,theme:t?.theme||"light",language:t?.language||"en",width:t?.width,height:t?.height,padding:t?.padding,minHeight:t?.minHeight,relativeHeight:t?.relativeHeight,children:s||se.graphList.filter(e=>e.geoHubMapPresentation).map(e=>e.graphID).indexOf(d)!==-1?i.jsxRuntimeExports.jsxs(i.jsxRuntimeExports.Fragment,{children:[c?.graphTitle||c?.graphDescription||t?.graphTitle||t?.graphDescription||t?.graphDownload||t?.dataDownload?i.jsxRuntimeExports.jsx(re.GraphHeader,{styles:{title:c?.styles?.title||t?.styles?.title,description:c?.styles?.description||t?.styles?.description},classNames:{title:c?.classNames?.title||t?.classNames?.title,description:c?.classNames?.description||t?.classNames?.description},graphTitle:c?.graphTitle||t?.graphTitle,graphDescription:c?.graphDescription||t?.graphDescription,width:c?.width||t?.width,graphDownload:t?.graphDownload?M:void 0,dataDownload:t?.dataDownload&&s&&s.length>0?s:null}):null,P.length!==0||(v||[]).length!==0||(O||[]).length!==0||f?i.jsxRuntimeExports.jsxs("div",{className:"flex flex-wrap items-start gap-x-4 gap-y-0 w-full",children:[O?.map((e,r)=>i.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/h}% - ${(h-1)/h}rem)`,flexGrow:e.width?0:1,flexShrink:e.ui!=="radio"||e.width?0:1,minWidth:"240px"},className:"pb-4",children:[i.jsxRuntimeExports.jsx(g.b,{className:"mb-2",children:e.label||"Graph by"}),e.ui!=="radio"?i.jsxRuntimeExports.jsx(D.ja,{options:e.options.map(l=>({...l,value:l.label})),size:"sm",isClearable:!1,isSearchable:!0,variant:p,controlShouldRenderValue:!0,defaultValue:e.defaultValue?{...e.defaultValue,value:e.defaultValue?.label}:{...e.options[0],value:e.options[0].label},onChange:l=>{w(l?.graphSettings||{}),x(l?.dataConfiguration)}}):i.jsxRuntimeExports.jsx(g.ye,{defaultValue:e.defaultValue?.label||e.options[0].label,variant:p,onValueChange:l=>{const o=e.options[e.options.findIndex(j=>j.label===l)];w(o.graphSettings||{}),x(o.dataConfiguration)},children:e.options.map((l,o)=>i.jsxRuntimeExports.jsx(g.he,{label:l.label,value:l.label},o))})]},r)),v?.map((e,r)=>i.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/h}% - ${(h-1)/h}rem)`,flexGrow:e.width?0:1,flexShrink:e.ui!=="radio"||e.width?0:1,minWidth:"240px"},className:"pb-4",children:[i.jsxRuntimeExports.jsx(g.b,{className:"mb-2",children:e.label||`Visualize ${e.chartConfigId} by`}),g.checkIfMultiple(e.chartConfigId,b||[])?e.ui!=="radio"?i.jsxRuntimeExports.jsx(D.ja,{options:e.allowedColumnIds,size:"sm",isMulti:!0,isSearchable:!0,variant:p,controlShouldRenderValue:!0,defaultValue:n?n[n.findIndex(l=>l.chartConfigId===e.chartConfigId)].columnId.map(l=>e.allowedColumnIds[e.allowedColumnIds.findIndex(o=>o.value===l)]):void 0,filterOption:D.Du(H),onChange:l=>{const o={columnId:(l||[]).map(C=>C.value),chartConfigId:e.chartConfigId},j=b?.map(C=>C.chartConfigId===o.chartConfigId?o:C);x(j)}}):i.jsxRuntimeExports.jsx(g.$,{variant:p,defaultValue:n?n[n.findIndex(l=>l.chartConfigId===e.chartConfigId)].columnId.map(l=>e.allowedColumnIds[e.allowedColumnIds.findIndex(o=>o.value===l)]).map(l=>l.value):[],onValueChange:l=>{const o={columnId:l||[],chartConfigId:e.chartConfigId},j=b?.map(C=>C.chartConfigId===o.chartConfigId?o:C);x(j)},children:e.allowedColumnIds.map((l,o)=>i.jsxRuntimeExports.jsx(g.P,{label:l.label,value:l.label},o))}):e.ui!=="radio"?i.jsxRuntimeExports.jsx(D.ja,{options:e.allowedColumnIds,size:"sm",isClearable:!1,isSearchable:!0,variant:p,controlShouldRenderValue:!0,defaultValue:n?e.allowedColumnIds[e.allowedColumnIds.findIndex(l=>l.value===n[n.findIndex(o=>o.chartConfigId===e.chartConfigId)].columnId)]:void 0,onChange:l=>{const o={columnId:l?.value,chartConfigId:e.chartConfigId},j=b?.map(C=>C.chartConfigId===o.chartConfigId?o:C);w(L(v,j)),x(j)}}):i.jsxRuntimeExports.jsx(g.ye,{variant:p,defaultValue:n?e.allowedColumnIds[e.allowedColumnIds.findIndex(l=>l.value===n[n.findIndex(o=>o.chartConfigId===e.chartConfigId)].columnId)].label:"",onValueChange:l=>{const j={columnId:e.allowedColumnIds[e.allowedColumnIds.findIndex(q=>q.label===l)].value,chartConfigId:e.chartConfigId},C=b?.map(q=>q.chartConfigId===j.chartConfigId?j:q);w(L(v,C)),x(C)},children:e.allowedColumnIds.map((l,o)=>i.jsxRuntimeExports.jsx(g.he,{label:l.label,value:l.label},o))})]},r)),P?.map((e,r)=>i.jsxRuntimeExports.jsxs("div",{style:{width:e.width||`calc(${100/h}% - ${(h-1)/h}rem)`,flexGrow:e.width?0:1,flexShrink:e.ui!=="radio"||e.width?0:1,minWidth:"240px"},className:"pb-4",children:[i.jsxRuntimeExports.jsx(g.b,{className:"mb-2",children:e.label}),e.singleSelect?e.ui!=="radio"?i.jsxRuntimeExports.jsx(D.ja,{options:e.availableValues,variant:p,isClearable:e.clearable===void 0?!0:e.clearable,isSearchable:!0,controlShouldRenderValue:!0,filterOption:D.Du(H),onChange:l=>{k(e.filter,l)},value:e.value,defaultValue:e.defaultValue}):i.jsxRuntimeExports.jsx(g.ye,{variant:p,defaultValue:e.defaultValue.value,onValueChange:l=>{k(e.filter,e.availableValues.filter(o=>o.value===l))},children:e.availableValues.map((l,o)=>i.jsxRuntimeExports.jsx(g.he,{label:`${l.label}`,value:`${l.value}`},o))}):i.jsxRuntimeExports.jsxs(i.jsxRuntimeExports.Fragment,{children:[e.ui!=="radio"?i.jsxRuntimeExports.jsx(D.ja,{options:e.availableValues,variant:p,size:"sm",isMulti:!0,isClearable:e.clearable===void 0?!0:e.clearable,isSearchable:!0,controlShouldRenderValue:!0,filterOption:D.Du(H),onChange:l=>{k(e.filter,l)},value:e.value,defaultValue:e.defaultValue}):i.jsxRuntimeExports.jsx(g.$,{variant:p,defaultValue:e.defaultValue?e.defaultValue.map(l=>`${l.value}`):[],value:e.value?e.value.map(l=>`${l.value}`):void 0,onValueChange:l=>{k(e.filter,e.availableValues.filter(o=>l.indexOf(`${o.value}`)!==-1))},children:e.availableValues.map((l,o)=>i.jsxRuntimeExports.jsx(g.P,{label:`${l.label}`,value:`${l.value}`},o))}),e.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:()=>{k(e.filter,e.availableValues)},children:"Select all options"}):null]})]},r)),f?i.jsxRuntimeExports.jsxs("div",{style:{width:f.width||`calc(${100/h}% - ${(h-1)/h}rem)`,flexGrow:f.width?0:1,flexShrink:0,minWidth:"240px"},className:"pb-4",children:[i.jsxRuntimeExports.jsx(g.b,{className:"mb-2",children:f.label||"Highlight data"}),i.jsxRuntimeExports.jsx(D.ja,{options:Y,variant:p,size:"sm",isMulti:!0,isClearable:!0,isSearchable:!0,controlShouldRenderValue:!0,filterOption:D.Du(H),onChange:e=>{X(e?.map(r=>r.value))},value:$?.map(e=>({label:e,value:e})),defaultValue:f.defaultValues?.map(e=>({label:e,value:e}))})]}):null]}):null,i.jsxRuntimeExports.jsx(ce,{graph:d,graphData:ae,graphDataConfiguration:b,debugMode:I,readableHeader:V||[],updateFilters:T,settings:{...t||{},...c,graphTitle:void 0,graphDescription:void 0,graphDownload:!1,dataDownload:!1,backgroundColor:void 0,padding:"0",width:void 0,height:void 0,relativeHeight:void 0,minHeight:void 0,theme:t?.theme,...$?{highlightedDataPoints:$,highlightedIds:$?.map(e=>`${e}`),highlightedLines:$?.map(e=>e)}:{}}})]}):i.jsxRuntimeExports.jsx("div",{className:"w-full flex justify-center p-4",children:i.jsxRuntimeExports.jsx(oe.w,{})})})}exports.SingleGraphDashboardThreeDGraphs=de;
|
|
2
2
|
//# sourceMappingURL=SingleGraphDashboardThreeDGraphs.cjs.map
|
|
@@ -5,7 +5,7 @@ import { f as z } from "./index-EArKRVKg.js";
|
|
|
5
5
|
import { i as ce } from "./index-Bwrro8-q.js";
|
|
6
6
|
import { j as k, D as L } from "./DropdownSelect-BbdPQa2k.js";
|
|
7
7
|
import { g as he, b as M, y as U, h as B, c as ge, $ as X, P as Y } from "./checkIfMultiple-CIRtG0KE.js";
|
|
8
|
-
import { w as pe } from "./Spinner-
|
|
8
|
+
import { w as pe } from "./Spinner-DVBnY6Vg.js";
|
|
9
9
|
import { j as _ } from "./Typography-PxtFcnJb.js";
|
|
10
10
|
import { ThreeDGlobe as fe } from "./ThreeDGlobe.js";
|
|
11
11
|
import { f as me, a as Ce, b as be, c as ve, t as xe } from "./fetchAndParseData-BpqkBPQL.js";
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./index-CHPV5EwG-CTPQjnHt.cjs"),g=require("react"),c=require("./Spinner-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./index-CHPV5EwG-CTPQjnHt.cjs"),g=require("react"),c=require("./Spinner-CQZcjzwd.cjs"),p=require("./SingleGraphDashboardThreeDGraphs.cjs"),f=require("./fetchAndParseData-l5HGMAEs.cjs");function S(l){const t=s.compilerRuntimeExports.c(19),{config:a}=l,[e,d]=g.useState(void 0);let r,n;if(t[0]!==a?(r=()=>{(async()=>{if(typeof a=="string"){const h=await f.fetchAndParseJSON(a);d(h)}else d(a)})()},n=[a],t[0]=a,t[1]=r,t[2]=n):(r=t[1],n=t[2]),g.useEffect(r,n),!e){let i;return t[3]===Symbol.for("react.memo_cache_sentinel")?(i=s.jsxRuntimeExports.jsx("div",{className:"w-full flex justify-center p-4",children:s.jsxRuntimeExports.jsx(c.w,{})}),t[3]=i):i=t[3],i}let o;return t[4]!==e.advancedDataSelectionOptions||t[5]!==e.dataFilters||t[6]!==e.dataSelectionOptions||t[7]!==e.dataSettings||t[8]!==e.dataTransform||t[9]!==e.debugMode||t[10]!==e.filters||t[11]!==e.graphDataConfiguration||t[12]!==e.graphSettings||t[13]!==e.graphType||t[14]!==e.highlightDataPointSettings||t[15]!==e.noOfFiltersPerRow||t[16]!==e.readableHeader||t[17]!==e.uiMode?(o=s.jsxRuntimeExports.jsx(p.SingleGraphDashboardThreeDGraphs,{graphSettings:e.graphSettings,dataSettings:e.dataSettings,filters:e.filters,graphType:e.graphType,dataTransform:e.dataTransform,graphDataConfiguration:e.graphDataConfiguration,dataFilters:e.dataFilters,debugMode:e.debugMode,dataSelectionOptions:e.dataSelectionOptions,advancedDataSelectionOptions:e.advancedDataSelectionOptions,readableHeader:e.readableHeader,noOfFiltersPerRow:e.noOfFiltersPerRow,uiMode:e.uiMode,highlightDataPointSettings:e.highlightDataPointSettings}),t[4]=e.advancedDataSelectionOptions,t[5]=e.dataFilters,t[6]=e.dataSelectionOptions,t[7]=e.dataSettings,t[8]=e.dataTransform,t[9]=e.debugMode,t[10]=e.filters,t[11]=e.graphDataConfiguration,t[12]=e.graphSettings,t[13]=e.graphType,t[14]=e.highlightDataPointSettings,t[15]=e.noOfFiltersPerRow,t[16]=e.readableHeader,t[17]=e.uiMode,t[18]=o):o=t[18],o}exports.SingleGraphDashboardThreeDGraphsFromConfig=S;
|
|
2
2
|
//# sourceMappingURL=SingleGraphDashboardThreeDGraphsFromConfig.cjs.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { c as f, j as s } from "./index-CHPV5EwG-Curnpaqc.js";
|
|
2
2
|
import { useState as p, useEffect as h } from "react";
|
|
3
|
-
import { w as c } from "./Spinner-
|
|
3
|
+
import { w as c } from "./Spinner-DVBnY6Vg.js";
|
|
4
4
|
import { SingleGraphDashboardThreeDGraphs as S } from "./SingleGraphDashboardThreeDGraphs.js";
|
|
5
5
|
import { f as m } from "./fetchAndParseData-BpqkBPQL.js";
|
|
6
6
|
function F(g) {
|