@undp/data-viz 2.0.9 → 2.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AreaChart.cjs +1 -1
- package/dist/AreaChart.d.ts +2 -0
- package/dist/AreaChart.js +4 -4
- package/dist/BarGraph.cjs +1 -1
- package/dist/BarGraph.cjs.map +1 -1
- package/dist/BarGraph.d.ts +2 -0
- package/dist/BarGraph.js +1699 -1577
- package/dist/BarGraph.js.map +1 -1
- package/dist/BasicStatCard.d.ts +2 -0
- package/dist/BeeSwarmChart.cjs +1 -1
- package/dist/BeeSwarmChart.cjs.map +1 -1
- package/dist/BeeSwarmChart.d.ts +2 -0
- package/dist/BeeSwarmChart.js +258 -267
- package/dist/BeeSwarmChart.js.map +1 -1
- package/dist/BiVariateChoroplethMap.cjs +1 -1
- package/dist/BiVariateChoroplethMap.cjs.map +1 -1
- package/dist/BiVariateChoroplethMap.d.ts +2 -0
- package/dist/BiVariateChoroplethMap.js +252 -245
- package/dist/BiVariateChoroplethMap.js.map +1 -1
- package/dist/BulletChart.cjs +1 -1
- package/dist/BulletChart.cjs.map +1 -1
- package/dist/BulletChart.d.ts +2 -0
- package/dist/BulletChart.js +566 -536
- package/dist/BulletChart.js.map +1 -1
- package/dist/ButterflyChart.cjs +1 -1
- package/dist/ButterflyChart.cjs.map +1 -1
- package/dist/ButterflyChart.d.ts +2 -0
- package/dist/ButterflyChart.js +388 -378
- package/dist/ButterflyChart.js.map +1 -1
- package/dist/ChoroplethMap.cjs +1 -1
- package/dist/ChoroplethMap.cjs.map +1 -1
- package/dist/ChoroplethMap.d.ts +2 -0
- package/dist/ChoroplethMap.js +297 -291
- package/dist/ChoroplethMap.js.map +1 -1
- package/dist/CirclePackingGraph.cjs +1 -1
- package/dist/CirclePackingGraph.d.ts +2 -0
- package/dist/CirclePackingGraph.js +1 -1
- package/dist/DataCards.d.ts +2 -0
- package/dist/DataCards.js +1 -1
- package/dist/DataTable.d.ts +2 -0
- package/dist/DetailsModal-0Ry5nXiC.js +32 -0
- package/dist/DetailsModal-0Ry5nXiC.js.map +1 -0
- package/dist/DetailsModal-BN0HDFlV.cjs +2 -0
- package/dist/DetailsModal-BN0HDFlV.cjs.map +1 -0
- package/dist/DifferenceLineChart.cjs +1 -1
- package/dist/DifferenceLineChart.d.ts +2 -0
- package/dist/DifferenceLineChart.js +4 -4
- package/dist/DonutChart.cjs +1 -1
- package/dist/DonutChart.cjs.map +1 -1
- package/dist/DonutChart.d.ts +2 -0
- package/dist/DonutChart.js +185 -190
- package/dist/DonutChart.js.map +1 -1
- package/dist/DotDensityMap.cjs +1 -1
- package/dist/DotDensityMap.cjs.map +1 -1
- package/dist/DotDensityMap.d.ts +2 -0
- package/dist/DotDensityMap.js +252 -244
- package/dist/DotDensityMap.js.map +1 -1
- package/dist/DualAxisLineChart.cjs +1 -1
- package/dist/DualAxisLineChart.d.ts +2 -0
- package/dist/DualAxisLineChart.js +4 -4
- package/dist/DumbbellChart.cjs +1 -1
- package/dist/DumbbellChart.cjs.map +1 -1
- package/dist/DumbbellChart.d.ts +2 -0
- package/dist/DumbbellChart.js +563 -525
- package/dist/DumbbellChart.js.map +1 -1
- package/dist/GeoHubCompareMaps.d.ts +2 -0
- package/dist/GeoHubMap.d.ts +2 -0
- package/dist/GeoHubMapWithLayerSelection.d.ts +2 -0
- package/dist/{GraphEl-BcKU0bG1.cjs → GraphEl-B16EYkko.cjs} +2 -2
- package/dist/{GraphEl-BcKU0bG1.cjs.map → GraphEl-B16EYkko.cjs.map} +1 -1
- package/dist/{GraphEl-CGq1EWRn.js → GraphEl-DEzobeOM.js} +3 -3
- package/dist/{GraphEl-CGq1EWRn.js.map → GraphEl-DEzobeOM.js.map} +1 -1
- package/dist/GriddedGraphs.cjs +1 -1
- package/dist/GriddedGraphs.cjs.map +1 -1
- package/dist/GriddedGraphs.d.ts +2 -0
- package/dist/GriddedGraphs.js +19 -19
- package/dist/GriddedGraphs.js.map +1 -1
- package/dist/GriddedGraphsFromConfig.d.ts +2 -0
- package/dist/HeatMap.cjs +1 -1
- package/dist/HeatMap.cjs.map +1 -1
- package/dist/HeatMap.d.ts +2 -0
- package/dist/HeatMap.js +112 -117
- package/dist/HeatMap.js.map +1 -1
- package/dist/Histogram.cjs +1 -1
- package/dist/Histogram.d.ts +2 -0
- package/dist/Histogram.js +3 -3
- package/dist/HybridMap.cjs +1 -1
- package/dist/HybridMap.cjs.map +1 -1
- package/dist/HybridMap.d.ts +2 -0
- package/dist/HybridMap.js +366 -359
- package/dist/HybridMap.js.map +1 -1
- package/dist/LineChartWithConfidenceInterval.cjs +1 -1
- package/dist/LineChartWithConfidenceInterval.d.ts +2 -0
- package/dist/LineChartWithConfidenceInterval.js +4 -4
- package/dist/{Modal-DGcuAHyK.js → Modal-bMQA6bL_.js} +5 -5
- package/dist/{Modal-DGcuAHyK.js.map → Modal-bMQA6bL_.js.map} +1 -1
- package/dist/MultiGraphDashboard.cjs +1 -1
- package/dist/MultiGraphDashboard.cjs.map +1 -1
- package/dist/MultiGraphDashboard.d.ts +2 -0
- package/dist/MultiGraphDashboard.js +10 -10
- package/dist/MultiGraphDashboard.js.map +1 -1
- package/dist/MultiGraphDashboardFromConfig.d.ts +2 -0
- package/dist/MultiGraphDashboardWideToLongFormat.d.ts +2 -0
- package/dist/MultiGraphDashboardWideToLongFormat.js +1 -1
- package/dist/MultiGraphDashboardWideToLongFormatFromConfig.d.ts +2 -0
- package/dist/MultiLineAltChart.cjs +1 -1
- package/dist/MultiLineAltChart.cjs.map +1 -1
- package/dist/MultiLineAltChart.d.ts +2 -0
- package/dist/MultiLineAltChart.js +453 -425
- package/dist/MultiLineAltChart.js.map +1 -1
- package/dist/MultiLineChart.cjs +1 -1
- package/dist/MultiLineChart.d.ts +2 -0
- package/dist/MultiLineChart.js +4 -4
- package/dist/ParetoChart.cjs +1 -1
- package/dist/ParetoChart.cjs.map +1 -1
- package/dist/ParetoChart.d.ts +2 -0
- package/dist/ParetoChart.js +188 -193
- package/dist/ParetoChart.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.cjs.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboard.d.ts +2 -0
- package/dist/PerformanceIntensiveMultiGraphDashboard.js +16 -16
- package/dist/PerformanceIntensiveMultiGraphDashboard.js.map +1 -1
- package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.d.ts +2 -0
- package/dist/PerformanceIntensiveScrollStory.d.ts +2 -0
- package/dist/RadarChart.cjs +1 -1
- package/dist/RadarChart.cjs.map +1 -1
- package/dist/RadarChart.d.ts +2 -0
- package/dist/RadarChart.js +158 -163
- package/dist/RadarChart.js.map +1 -1
- package/dist/SankeyChart.cjs +1 -1
- package/dist/SankeyChart.cjs.map +1 -1
- package/dist/SankeyChart.d.ts +2 -0
- package/dist/SankeyChart.js +172 -177
- package/dist/SankeyChart.js.map +1 -1
- package/dist/ScatterPlot.cjs +1 -1
- package/dist/ScatterPlot.cjs.map +1 -1
- package/dist/ScatterPlot.d.ts +2 -0
- package/dist/ScatterPlot.js +494 -483
- package/dist/ScatterPlot.js.map +1 -1
- package/dist/ScrollStory.d.ts +2 -0
- package/dist/SimpleLineChart.cjs +1 -1
- package/dist/SimpleLineChart.d.ts +2 -0
- package/dist/SimpleLineChart.js +4 -4
- package/dist/SingleGraphDashboard.cjs +1 -1
- package/dist/SingleGraphDashboard.cjs.map +1 -1
- package/dist/SingleGraphDashboard.d.ts +2 -0
- package/dist/SingleGraphDashboard.js +24 -24
- package/dist/SingleGraphDashboard.js.map +1 -1
- package/dist/SingleGraphDashboardFromConfig.d.ts +2 -0
- package/dist/SingleGraphDashboardGeoHubMaps.d.ts +2 -0
- package/dist/SingleGraphDashboardGeoHubMapsFromConfig.d.ts +2 -0
- package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.cjs.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphs.d.ts +2 -0
- package/dist/SingleGraphDashboardThreeDGraphs.js +46 -46
- package/dist/SingleGraphDashboardThreeDGraphs.js.map +1 -1
- package/dist/SingleGraphDashboardThreeDGraphsFromConfig.d.ts +2 -0
- package/dist/SlopeChart.cjs +1 -1
- package/dist/SlopeChart.cjs.map +1 -1
- package/dist/SlopeChart.d.ts +2 -0
- package/dist/SlopeChart.js +182 -187
- package/dist/SlopeChart.js.map +1 -1
- package/dist/SparkLine.cjs +1 -1
- package/dist/SparkLine.d.ts +2 -0
- package/dist/SparkLine.js +4 -4
- package/dist/StatCardFromData.d.ts +2 -0
- package/dist/StripChart.cjs +1 -1
- package/dist/StripChart.cjs.map +1 -1
- package/dist/StripChart.d.ts +2 -0
- package/dist/StripChart.js +249 -258
- package/dist/StripChart.js.map +1 -1
- package/dist/ThreeDGlobe.cjs +1 -1
- package/dist/ThreeDGlobe.cjs.map +1 -1
- package/dist/ThreeDGlobe.d.ts +2 -0
- package/dist/ThreeDGlobe.js +142 -147
- package/dist/ThreeDGlobe.js.map +1 -1
- package/dist/Tooltip-Dj5eVppQ.js +45 -0
- package/dist/Tooltip-Dj5eVppQ.js.map +1 -0
- package/dist/Tooltip-uUdw6wJL.cjs +2 -0
- package/dist/Tooltip-uUdw6wJL.cjs.map +1 -0
- package/dist/TreeMapGraph.cjs +1 -1
- package/dist/TreeMapGraph.cjs.map +1 -1
- package/dist/TreeMapGraph.d.ts +2 -0
- package/dist/TreeMapGraph.js +159 -164
- package/dist/TreeMapGraph.js.map +1 -1
- package/dist/Types.d.ts +2 -0
- package/dist/UnitChart.d.ts +2 -0
- package/dist/{band-CyHaVft5.js → band-DHUZ2X7J.js} +3 -3
- package/dist/{band-CyHaVft5.js.map → band-DHUZ2X7J.js.map} +1 -1
- package/dist/{checkIfMultiple-Y9iKaV_u.js → checkIfMultiple-CIRtG0KE.js} +2 -2
- package/dist/{checkIfMultiple-Y9iKaV_u.js.map → checkIfMultiple-CIRtG0KE.js.map} +1 -1
- package/dist/index-CF5hnGvG.cjs +2 -0
- package/dist/index-CF5hnGvG.cjs.map +1 -0
- package/dist/index-DPGq3eIL.js +330 -0
- package/dist/index-DPGq3eIL.js.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.js +1 -1
- package/dist/{init-BJFW6EwE.js → init-BhZylTFx.js} +3 -3
- package/dist/{init-BJFW6EwE.js.map → init-BhZylTFx.js.map} +1 -1
- package/dist/{linear-BwnDd9KF.js → linear-BqltdMeF.js} +2 -2
- package/dist/{linear-BwnDd9KF.js.map → linear-BqltdMeF.js.map} +1 -1
- package/dist/{ordinal-P77xw8aL.js → ordinal-BJ6O_LC5.js} +2 -2
- package/dist/{ordinal-P77xw8aL.js.map → ordinal-BJ6O_LC5.js.map} +1 -1
- package/dist/{pow-DE4c7dbW.js → pow-CM2aze4M.js} +3 -3
- package/dist/{pow-DE4c7dbW.js.map → pow-CM2aze4M.js.map} +1 -1
- package/dist/{threshold-Bgr20hik.js → threshold-DFfqcDMa.js} +2 -2
- package/dist/{threshold-Bgr20hik.js.map → threshold-DFfqcDMa.js.map} +1 -1
- package/dist/{time-DCCfQk3V.js → time-BUL-dwnK.js} +3 -3
- package/dist/{time-DCCfQk3V.js.map → time-BUL-dwnK.js.map} +1 -1
- package/package.json +4 -4
- package/dist/Tooltip-4dJo4_AF.cjs +0 -2
- package/dist/Tooltip-4dJo4_AF.cjs.map +0 -1
- package/dist/Tooltip-CwWUegPB.js +0 -43
- package/dist/Tooltip-CwWUegPB.js.map +0 -1
- package/dist/index-B2LQV7Tk.js +0 -335
- package/dist/index-B2LQV7Tk.js.map +0 -1
- package/dist/index-xRHRLDIp.cjs +0 -2
- package/dist/index-xRHRLDIp.cjs.map +0 -1
- package/dist/sort-BIvMlUH1.js +0 -34
- package/dist/sort-BIvMlUH1.js.map +0 -1
- package/dist/sort-O96oMZLb.cjs +0 -2
- package/dist/sort-O96oMZLb.cjs.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SingleGraphDashboardThreeDGraphs.cjs","sources":["../src/Components/Dashboard/PerformanceIntensive/ThreeDGraphEl.tsx","../src/Components/Dashboard/PerformanceIntensive/SingleGraphDashboardThreeDGraphs.tsx"],"sourcesContent":["import { P } from '@undp/design-system-react/Typography';\r\n\r\nimport { ThreeDGlobe } from '../../Graphs/Maps/ThreeDGlobe';\r\n\r\nimport { getValues } from '@/Utils/getValues';\r\nimport { GraphConfigurationDataType, GraphSettingsDataType, ThreeDGraphType } from '@/Types';\r\n\r\ninterface Props {\r\n graph: ThreeDGraphType;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n graphData: any;\r\n settings?: GraphSettingsDataType;\r\n debugMode?: boolean;\r\n graphDataConfiguration?: GraphConfigurationDataType[];\r\n readableHeader: {\r\n value: string;\r\n label: string;\r\n }[];\r\n updateFilters?: (_d: string) => void;\r\n}\r\n\r\nfunction ThreeDGraphEl(props: Props) {\r\n const {\r\n settings,\r\n graph,\r\n graphData,\r\n debugMode,\r\n graphDataConfiguration,\r\n readableHeader,\r\n updateFilters,\r\n } = props;\r\n if (debugMode) {\r\n // eslint-disable-next-line no-console\r\n console.log(`Graph: ${graph}`);\r\n // eslint-disable-next-line no-console\r\n console.log('Transformed data:', graphData);\r\n // eslint-disable-next-line no-console\r\n console.log('Settings:', settings);\r\n }\r\n if (typeof graphData === 'string')\r\n return (\r\n <div\r\n className={`flex my-0 mx-auto grow flex-col justify-center ${\r\n settings?.width ? 'w-fit' : 'w-full'\r\n }`}\r\n style={{ height: 'inherit' }}\r\n >\r\n <P\r\n size='sm'\r\n marginBottom='none'\r\n className='p-2 text-center text-accent-dark-red dark:text-accent-red'\r\n >\r\n {graphData}\r\n </P>\r\n </div>\r\n );\r\n const graphComponents: Record<ThreeDGraphType, React.ElementType | null> = {\r\n threeDGlobe: ThreeDGlobe,\r\n };\r\n const getGraphProps = (graphType: ThreeDGraphType) => {\r\n switch (graphType) {\r\n case 'threeDGlobe':\r\n return {\r\n globeOffset: settings?.globeOffset,\r\n collapseColorScaleByDefault: settings?.collapseColorScaleByDefault,\r\n polygonAltitude: settings?.polygonAltitude,\r\n highlightedIds: settings?.highlightedIds,\r\n scale: settings?.scale,\r\n theme: settings?.theme,\r\n resetSelectionOnDoubleClick: settings?.resetSelectionOnDoubleClick,\r\n graphTitle: settings?.graphTitle,\r\n mapData: settings?.mapData,\r\n graphDescription: settings?.graphDescription,\r\n footNote: settings?.footNote,\r\n width: settings?.width,\r\n height: settings?.height,\r\n sources: settings?.sources,\r\n colorDomain: settings?.colorDomain as string[] | number[],\r\n colors: settings?.colors as string[] | undefined,\r\n colorLegendTitle:\r\n Object.keys(settings || {}).indexOf('colorLegendTitle') !== -1\r\n ? settings?.colorLegendTitle\r\n : getValues('x', graphDataConfiguration || [], readableHeader || []),\r\n scaleType: settings?.scaleType,\r\n data: graphData,\r\n centerPoint: settings?.centerPoint,\r\n backgroundColor: settings?.backgroundColor,\r\n mapNoDataColor: settings?.mapNoDataColor,\r\n mapBorderColor: settings?.mapBorderColor,\r\n relativeHeight: settings?.relativeHeight,\r\n padding: settings?.padding,\r\n tooltip: settings?.tooltip,\r\n showColorScale: settings?.showColorScale,\r\n graphID: settings?.graphID,\r\n dataDownload: settings?.dataDownload,\r\n mapProperty: settings?.mapProperty,\r\n language: settings?.language,\r\n minHeight: settings?.minHeight,\r\n ariaLabel: settings?.ariaLabel,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick: (el: any) => {\r\n updateFilters?.(el.id);\r\n },\r\n detailsOnClick: settings?.detailsOnClick,\r\n styles: settings?.styles,\r\n classNames: settings?.classNames,\r\n autoRotate: settings?.autoRotate,\r\n globeMaterial: settings?.globeMaterial,\r\n atmosphereColor: settings?.atmosphereColor,\r\n enableZoom: settings?.enableZoom,\r\n atmosphereAltitude: settings?.atmosphereAltitude,\r\n globeCurvatureResolution: settings?.globeCurvatureResolution,\r\n fogSettings: settings?.fogSetting,\r\n lights: settings?.lights,\r\n highlightedAltitude: settings?.highlightedAltitude,\r\n selectedId: settings?.selectedId,\r\n };\r\n default:\r\n return {};\r\n }\r\n };\r\n const GraphComponent = graphComponents[graph];\r\n const graphProps = getGraphProps(graph);\r\n return (\r\n <div\r\n className={`grow my-0 mx-auto flex flex-col w-full justify-center ${settings?.theme || 'light'}`}\r\n style={{ minHeight: 'inherit' }}\r\n >\r\n {GraphComponent ? (\r\n <GraphComponent {...graphProps} />\r\n ) : (\r\n <P\r\n size='sm'\r\n marginBottom='none'\r\n className='p-2 text-center text-accent-dark-red dark:text-accent-red'\r\n >\r\n {`Invalid chart type: ${graph}`}\r\n </P>\r\n )}\r\n </div>\r\n );\r\n}\r\n\r\nexport default ThreeDGraphEl;\r\n","import { useEffect, useEffectEvent, useRef, useState } from 'react';\r\nimport intersection from 'lodash.intersection';\r\nimport flattenDeep from 'lodash.flattendeep';\r\nimport isEqual from 'fast-deep-equal';\r\nimport { createFilter, DropdownSelect } from '@undp/design-system-react/DropdownSelect';\r\nimport { CheckboxGroup, CheckboxGroupItem } from '@undp/design-system-react/CheckboxGroup';\r\nimport { RadioGroup, RadioGroupItem } from '@undp/design-system-react/RadioGroup';\r\nimport { Spinner } from '@undp/design-system-react/Spinner';\r\nimport { Label } from '@undp/design-system-react/Label';\r\n\r\nimport ThreeDGraphEl from './ThreeDGraphEl';\r\n\r\nimport {\r\n AdvancedDataSelectionDataType,\r\n AggregationSettingsDataType,\r\n DataFilterDataType,\r\n DataSelectionDataType,\r\n DataSettingsDataType,\r\n FilterSettingsDataType,\r\n FilterUiSettingsDataType,\r\n GraphConfigurationDataType,\r\n GraphSettingsDataType,\r\n HighlightDataPointSettingsDataType,\r\n ThreeDGraphType,\r\n} from '@/Types';\r\nimport {\r\n fetchAndParseCSV,\r\n fetchAndParseJSON,\r\n fetchAndParseMultipleDataSources,\r\n fetchAndTransformDataFromAPI,\r\n} from '@/Utils/fetchAndParseData';\r\nimport { transformDataForGraph } from '@/Utils/transformData/transformDataForGraph';\r\nimport { getUniqValue } from '@/Utils/getUniqValue';\r\nimport { transformDataForAggregation } from '@/Utils/transformData/transformDataForAggregation';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { filterData } from '@/Utils/transformData/filterData';\r\nimport { checkIfMultiple } from '@/Utils/checkIfMultiple';\r\nimport { transformColumnsToArray } from '@/Utils/transformData/transformColumnsToArray';\r\nimport { graphList } from '@/Utils/getGraphList';\r\nimport { transformDefaultValue } from '@/Utils/transformDataForSelect';\r\nimport { GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n graphSettings?: GraphSettingsDataType;\r\n readableHeader?: {\r\n value: string;\r\n label: string;\r\n }[];\r\n dataSettings: DataSettingsDataType;\r\n filters?: FilterUiSettingsDataType[];\r\n highlightDataPointSettings?: HighlightDataPointSettingsDataType;\r\n noOfFiltersPerRow?: number;\r\n graphType: ThreeDGraphType;\r\n dataTransform?: {\r\n keyColumn: string;\r\n aggregationColumnsSetting?: AggregationSettingsDataType[];\r\n };\r\n dataFilters?: DataFilterDataType[];\r\n graphDataConfiguration?: GraphConfigurationDataType[];\r\n dataSelectionOptions?: DataSelectionDataType[];\r\n advancedDataSelectionOptions?: AdvancedDataSelectionDataType[];\r\n debugMode?: boolean;\r\n uiMode?: 'light' | 'normal';\r\n updateFilters?: (_d: string) => void;\r\n}\r\n\r\nconst getGraphSettings = (\r\n dataSelectionOptions: DataSelectionDataType[],\r\n updatedConfig?: GraphConfigurationDataType[],\r\n) => {\r\n const updatedSettings =\r\n updatedConfig?.map(c => {\r\n const indx = dataSelectionOptions?.findIndex(opt => opt.chartConfigId === c.chartConfigId);\r\n if (indx === -1) return {};\r\n const allowedValIndx = dataSelectionOptions[indx]?.allowedColumnIds?.findIndex(\r\n col => col.value === c.columnId,\r\n );\r\n if (allowedValIndx === -1) return {};\r\n return dataSelectionOptions[indx].allowedColumnIds[allowedValIndx].graphSettings || {};\r\n }) || [];\r\n return Object.assign({}, ...updatedSettings);\r\n};\r\n\r\nexport function SingleGraphDashboardThreeDGraphs(props: Props) {\r\n const {\r\n graphSettings,\r\n dataSettings,\r\n filters,\r\n graphType,\r\n dataTransform,\r\n graphDataConfiguration,\r\n dataFilters,\r\n debugMode,\r\n dataSelectionOptions,\r\n advancedDataSelectionOptions,\r\n readableHeader,\r\n noOfFiltersPerRow = 4,\r\n updateFilters,\r\n uiMode = 'normal',\r\n highlightDataPointSettings,\r\n } = props;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [filteredData, setFilteredData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [data, setData] = useState<any>(undefined);\r\n const [graphConfig, setGraphConfig] = useState<GraphConfigurationDataType[] | undefined>(\r\n graphDataConfiguration,\r\n );\r\n const [advancedGraphSettings, setAdvancedGraphSettings] = useState<GraphSettingsDataType>({});\r\n const [highlightedDataPointList, setHighlightedDataPointList] = useState<\r\n (string | number)[] | undefined\r\n >(undefined);\r\n const [highlightedDataPointOptions, setHighlightedDataPointOption] = useState<\r\n { label: string | number; value: string | number }[]\r\n >([]);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n const prevGraphDataConfigRef = useRef<GraphConfigurationDataType[] | undefined>(\r\n graphDataConfiguration,\r\n );\r\n const [filterSettings, setFilterSettings] = useState<FilterSettingsDataType[]>([]);\r\n\r\n const filterConfig = {\r\n ignoreCase: true,\r\n ignoreAccents: true,\r\n trim: true,\r\n };\r\n\r\n const updateFiltersEvent = useEffectEvent(() => {\r\n const filterSettingsTemp = (filters || []).map(el => ({\r\n filter: el.column,\r\n label: el.label || `Filter by ${el.column}`,\r\n singleSelect: el.singleSelect,\r\n clearable: el.clearable,\r\n defaultValue: transformDefaultValue(el.defaultValue),\r\n value: transformDefaultValue(el.defaultValue),\r\n availableValues: getUniqValue(data, el.column)\r\n .filter(v => !el.excludeValues?.includes(`${v}`))\r\n .map(v => ({ value: v, label: v })),\r\n allowSelectAll: el.allowSelectAll,\r\n width: el.width,\r\n }));\r\n setFilterSettings(filterSettingsTemp);\r\n });\r\n useEffect(() => {\r\n const fetchData = async () => {\r\n try {\r\n const dataFromFile = dataSettings.dataURL\r\n ? typeof dataSettings.dataURL === 'string'\r\n ? dataSettings.fileType === 'json'\r\n ? await fetchAndParseJSON(\r\n dataSettings.dataURL,\r\n dataSettings.columnsToArray,\r\n dataSettings.dataTransformation,\r\n debugMode,\r\n )\r\n : dataSettings.fileType === 'api'\r\n ? await fetchAndTransformDataFromAPI(\r\n dataSettings.dataURL,\r\n dataSettings.apiHeaders,\r\n dataSettings.columnsToArray,\r\n dataSettings.dataTransformation,\r\n debugMode,\r\n )\r\n : await fetchAndParseCSV(\r\n dataSettings.dataURL,\r\n dataSettings.dataTransformation,\r\n dataSettings.columnsToArray,\r\n debugMode,\r\n dataSettings.delimiter,\r\n true,\r\n )\r\n : await fetchAndParseMultipleDataSources(\r\n dataSettings.dataURL,\r\n dataSettings.idColumnTitle,\r\n )\r\n : await transformColumnsToArray(dataSettings.data, dataSettings.columnsToArray);\r\n setData(dataFromFile);\r\n } catch (error) {\r\n console.error('Data fetching error:', error);\r\n }\r\n };\r\n fetchData();\r\n updateFiltersEvent();\r\n }, [dataSettings, debugMode]);\r\n\r\n useEffect(() => {\r\n updateFiltersEvent();\r\n }, [filters, data]);\r\n\r\n const filteredDataEvent = useEffectEvent(() => {\r\n if (!data || filterSettings.length === 0) setFilteredData(data);\r\n else {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const result = data.filter((item: any) =>\r\n filterSettings.every(filter =>\r\n filter.value && flattenDeep([filter.value]).length > 0\r\n ? intersection(\r\n flattenDeep([item[filter.filter]]),\r\n flattenDeep([filter.value]).map(el => el.value),\r\n ).length > 0\r\n : true,\r\n ),\r\n );\r\n setFilteredData(result);\r\n }\r\n });\r\n\r\n useEffect(() => {\r\n filteredDataEvent();\r\n }, [filterSettings, data]);\r\n\r\n useEffect(() => {\r\n if (dataSelectionOptions)\r\n // eslint-disable-next-line react-hooks/set-state-in-effect\r\n setAdvancedGraphSettings(getGraphSettings(dataSelectionOptions, graphDataConfiguration));\r\n }, [dataSelectionOptions, graphDataConfiguration]);\r\n\r\n const updateHighlightedDataPointOptions = useEffectEvent(() => {\r\n if (highlightDataPointSettings?.column && filteredData)\r\n setHighlightedDataPointOption(\r\n getUniqValue(filteredData, highlightDataPointSettings.column)\r\n .filter(v => !highlightDataPointSettings?.excludeValues?.includes(`${v}`))\r\n .map(d => ({ value: d, label: d })),\r\n );\r\n });\r\n\r\n useEffect(() => {\r\n updateHighlightedDataPointOptions();\r\n }, [highlightDataPointSettings]);\r\n\r\n useEffect(() => {\r\n if (!isEqual(prevGraphDataConfigRef.current, graphDataConfiguration)) {\r\n // eslint-disable-next-line react-hooks/set-state-in-effect\r\n setGraphConfig(graphDataConfiguration);\r\n prevGraphDataConfigRef.current = graphDataConfiguration;\r\n }\r\n }, [graphDataConfiguration]);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleFilterChange = (filter: string, values: any) => {\r\n setFilterSettings(prev => prev.map(f => (f.filter === filter ? { ...f, value: values } : f)));\r\n };\r\n\r\n const graphData = !data\r\n ? undefined\r\n : transformDataForGraph(\r\n dataTransform\r\n ? transformDataForAggregation(\r\n filterData(data, dataFilters || []),\r\n dataTransform.keyColumn,\r\n dataTransform.aggregationColumnsSetting,\r\n )\r\n : filterData(data, dataFilters || []),\r\n graphType,\r\n graphConfig,\r\n );\r\n return (\r\n <GraphContainer\r\n className={graphSettings?.classNames?.graphContainer}\r\n style={graphSettings?.styles?.graphContainer}\r\n id={graphSettings?.graphID}\r\n ref={graphParentDiv}\r\n aria-label={graphSettings?.ariaLabel}\r\n backgroundColor={graphSettings?.backgroundColor ?? false}\r\n theme={graphSettings?.theme || 'light'}\r\n language={graphSettings?.language || 'en'}\r\n width={graphSettings?.width}\r\n height={graphSettings?.height}\r\n padding={graphSettings?.padding}\r\n minHeight={graphSettings?.minHeight}\r\n relativeHeight={graphSettings?.relativeHeight}\r\n >\r\n {data ||\r\n graphList\r\n .filter(el => el.geoHubMapPresentation)\r\n .map(el => el.graphID)\r\n .indexOf(graphType) !== -1 ? (\r\n <>\r\n {advancedGraphSettings?.graphTitle ||\r\n advancedGraphSettings?.graphDescription ||\r\n graphSettings?.graphTitle ||\r\n graphSettings?.graphDescription ||\r\n graphSettings?.graphDownload ||\r\n graphSettings?.dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: advancedGraphSettings?.styles?.title || graphSettings?.styles?.title,\r\n description:\r\n advancedGraphSettings?.styles?.description || graphSettings?.styles?.description,\r\n }}\r\n classNames={{\r\n title: advancedGraphSettings?.classNames?.title || graphSettings?.classNames?.title,\r\n description:\r\n advancedGraphSettings?.classNames?.description ||\r\n graphSettings?.classNames?.description,\r\n }}\r\n graphTitle={advancedGraphSettings?.graphTitle || graphSettings?.graphTitle}\r\n graphDescription={\r\n advancedGraphSettings?.graphDescription || graphSettings?.graphDescription\r\n }\r\n width={advancedGraphSettings?.width || graphSettings?.width}\r\n graphDownload={graphSettings?.graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n graphSettings?.dataDownload && data ? (data.length > 0 ? data : null) : null\r\n }\r\n />\r\n ) : null}\r\n {filterSettings.length !== 0 ||\r\n (dataSelectionOptions || []).length !== 0 ||\r\n (advancedDataSelectionOptions || []).length !== 0 ||\r\n highlightDataPointSettings ? (\r\n <div className='flex flex-wrap items-start gap-x-4 gap-y-0 w-full'>\r\n {advancedDataSelectionOptions?.map((d, i) => (\r\n <div\r\n style={{\r\n width:\r\n d.width ||\r\n `calc(${100 / noOfFiltersPerRow}% - ${\r\n (noOfFiltersPerRow - 1) / noOfFiltersPerRow\r\n }rem)`,\r\n flexGrow: 1,\r\n flexShrink: d.ui !== 'radio' ? 0 : 1,\r\n minWidth: '240px',\r\n }}\r\n key={i}\r\n className='pb-4'\r\n >\r\n <Label className='mb-2'>{d.label || 'Graph by'}</Label>\r\n {d.ui !== 'radio' ? (\r\n <DropdownSelect\r\n options={d.options.map(opt => ({\r\n ...opt,\r\n value: opt.label,\r\n }))}\r\n size='sm'\r\n isClearable={false}\r\n isSearchable\r\n variant={uiMode}\r\n controlShouldRenderValue\r\n defaultValue={\r\n d.defaultValue\r\n ? {\r\n ...d.defaultValue,\r\n value: d.defaultValue?.label,\r\n }\r\n : {\r\n ...d.options[0],\r\n value: d.options[0].label,\r\n }\r\n }\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onChange={(el: any) => {\r\n setAdvancedGraphSettings(el?.graphSettings || {});\r\n setGraphConfig(el?.dataConfiguration);\r\n }}\r\n />\r\n ) : (\r\n <RadioGroup\r\n defaultValue={d.defaultValue?.label || d.options[0].label}\r\n variant={uiMode}\r\n onValueChange={el => {\r\n const selectedOption =\r\n d.options[d.options.findIndex(opt => opt.label === el)];\r\n setAdvancedGraphSettings(selectedOption.graphSettings || {});\r\n setGraphConfig(selectedOption.dataConfiguration);\r\n }}\r\n >\r\n {d.options.map((el, j) => (\r\n <RadioGroupItem label={el.label} value={el.label} key={j} />\r\n ))}\r\n </RadioGroup>\r\n )}\r\n </div>\r\n ))}\r\n {dataSelectionOptions?.map((d, i) => (\r\n <div\r\n style={{\r\n width:\r\n d.width ||\r\n `calc(${100 / noOfFiltersPerRow}% - ${\r\n (noOfFiltersPerRow - 1) / noOfFiltersPerRow\r\n }rem)`,\r\n flexGrow: 1,\r\n flexShrink: d.ui !== 'radio' ? 0 : 1,\r\n minWidth: '240px',\r\n }}\r\n key={i}\r\n className='pb-4'\r\n >\r\n <Label className='mb-2'>{d.label || `Visualize ${d.chartConfigId} by`}</Label>\r\n {!checkIfMultiple(d.chartConfigId, graphConfig || []) ? (\r\n d.ui !== 'radio' ? (\r\n <DropdownSelect\r\n options={d.allowedColumnIds}\r\n size='sm'\r\n isClearable={false}\r\n isSearchable\r\n variant={uiMode}\r\n controlShouldRenderValue\r\n defaultValue={\r\n graphDataConfiguration\r\n ? d.allowedColumnIds[\r\n d.allowedColumnIds.findIndex(\r\n j =>\r\n j.value ===\r\n (graphDataConfiguration[\r\n graphDataConfiguration.findIndex(\r\n el => el.chartConfigId === d.chartConfigId,\r\n )\r\n ].columnId as string),\r\n )\r\n ]\r\n : undefined\r\n }\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onChange={(el: any) => {\r\n const newGraphConfig = {\r\n columnId: el?.value as string,\r\n chartConfigId: d.chartConfigId,\r\n };\r\n const updatedConfig = graphConfig?.map(item =>\r\n item.chartConfigId === newGraphConfig.chartConfigId\r\n ? newGraphConfig\r\n : item,\r\n );\r\n setAdvancedGraphSettings(\r\n getGraphSettings(dataSelectionOptions, updatedConfig),\r\n );\r\n setGraphConfig(updatedConfig);\r\n }}\r\n />\r\n ) : (\r\n <RadioGroup\r\n variant={uiMode}\r\n defaultValue={\r\n graphDataConfiguration\r\n ? d.allowedColumnIds[\r\n d.allowedColumnIds.findIndex(\r\n j =>\r\n j.value ===\r\n (graphDataConfiguration[\r\n graphDataConfiguration.findIndex(\r\n el => el.chartConfigId === d.chartConfigId,\r\n )\r\n ].columnId as string),\r\n )\r\n ].label\r\n : ''\r\n }\r\n onValueChange={el => {\r\n const selectedOption =\r\n d.allowedColumnIds[\r\n d.allowedColumnIds.findIndex(opt => opt.label === el)\r\n ];\r\n const newGraphConfig = {\r\n columnId: selectedOption.value,\r\n chartConfigId: d.chartConfigId,\r\n };\r\n const updatedConfig = graphConfig?.map(item =>\r\n item.chartConfigId === newGraphConfig.chartConfigId\r\n ? newGraphConfig\r\n : item,\r\n );\r\n setAdvancedGraphSettings(\r\n getGraphSettings(dataSelectionOptions, updatedConfig),\r\n );\r\n setGraphConfig(updatedConfig);\r\n }}\r\n >\r\n {d.allowedColumnIds.map((el, j) => (\r\n <RadioGroupItem label={el.label} value={el.label} key={j} />\r\n ))}\r\n </RadioGroup>\r\n )\r\n ) : d.ui !== 'radio' ? (\r\n <DropdownSelect\r\n options={d.allowedColumnIds}\r\n size='sm'\r\n isMulti\r\n isSearchable\r\n variant={uiMode}\r\n controlShouldRenderValue\r\n defaultValue={\r\n graphDataConfiguration\r\n ? (\r\n graphDataConfiguration[\r\n graphDataConfiguration.findIndex(\r\n el => el.chartConfigId === d.chartConfigId,\r\n )\r\n ].columnId as string[]\r\n ).map(\r\n el =>\r\n d.allowedColumnIds[\r\n d.allowedColumnIds.findIndex(j => j.value === el)\r\n ],\r\n )\r\n : undefined\r\n }\r\n filterOption={createFilter(filterConfig)}\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onChange={(el: any) => {\r\n const newGraphConfig = {\r\n columnId: (el || []).map(\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n (item: any) => item.value,\r\n ) as string[],\r\n chartConfigId: d.chartConfigId,\r\n };\r\n const updatedConfig = graphConfig?.map(item =>\r\n item.chartConfigId === newGraphConfig.chartConfigId\r\n ? newGraphConfig\r\n : item,\r\n );\r\n setGraphConfig(updatedConfig);\r\n }}\r\n />\r\n ) : (\r\n <CheckboxGroup\r\n variant={uiMode}\r\n defaultValue={\r\n graphDataConfiguration\r\n ? (\r\n graphDataConfiguration[\r\n graphDataConfiguration.findIndex(\r\n el => el.chartConfigId === d.chartConfigId,\r\n )\r\n ].columnId as string[]\r\n )\r\n .map(\r\n el =>\r\n d.allowedColumnIds[\r\n d.allowedColumnIds.findIndex(j => j.value === el)\r\n ],\r\n )\r\n .map(el => el.value)\r\n : []\r\n }\r\n onValueChange={el => {\r\n const newGraphConfig = {\r\n columnId: el || [],\r\n chartConfigId: d.chartConfigId,\r\n };\r\n const updatedConfig = graphConfig?.map(item =>\r\n item.chartConfigId === newGraphConfig.chartConfigId\r\n ? newGraphConfig\r\n : item,\r\n );\r\n setGraphConfig(updatedConfig);\r\n }}\r\n >\r\n {d.allowedColumnIds.map((el, j) => (\r\n <CheckboxGroupItem label={el.label} value={el.label} key={j} />\r\n ))}\r\n </CheckboxGroup>\r\n )}\r\n </div>\r\n ))}\r\n {filterSettings?.map((d, i) => (\r\n <div\r\n style={{\r\n width:\r\n d.width ||\r\n `calc(${100 / noOfFiltersPerRow}% - ${\r\n (noOfFiltersPerRow - 1) / noOfFiltersPerRow\r\n }rem)`,\r\n flexGrow: 1,\r\n flexShrink: 0,\r\n minWidth: '240px',\r\n }}\r\n key={i}\r\n className='pb-4'\r\n >\r\n <Label className='mb-2'>{d.label}</Label>\r\n {d.singleSelect ? (\r\n d.ui !== 'radio' ? (\r\n <DropdownSelect\r\n options={d.availableValues}\r\n variant={uiMode}\r\n isClearable={d.clearable === undefined ? true : d.clearable}\r\n isSearchable\r\n controlShouldRenderValue\r\n filterOption={createFilter(filterConfig)}\r\n onChange={el => {\r\n handleFilterChange(d.filter, el);\r\n }}\r\n value={d.value}\r\n defaultValue={d.defaultValue}\r\n />\r\n ) : (\r\n <RadioGroup\r\n variant={uiMode}\r\n defaultValue={(d.defaultValue as { value: string; label: string }).value}\r\n onValueChange={el => {\r\n handleFilterChange(\r\n d.filter,\r\n d.availableValues.filter(v => v.value === el),\r\n );\r\n }}\r\n >\r\n {d.availableValues.map((el, j) => (\r\n <RadioGroupItem label={`${el.label}`} value={`${el.value}`} key={j} />\r\n ))}\r\n </RadioGroup>\r\n )\r\n ) : (\r\n <>\r\n {d.ui !== 'radio' ? (\r\n <DropdownSelect\r\n options={d.availableValues}\r\n variant={uiMode}\r\n size='sm'\r\n isMulti\r\n isClearable={d.clearable === undefined ? true : d.clearable}\r\n isSearchable\r\n controlShouldRenderValue\r\n filterOption={createFilter(filterConfig)}\r\n onChange={el => {\r\n handleFilterChange(d.filter, el);\r\n }}\r\n value={d.value}\r\n defaultValue={d.defaultValue}\r\n />\r\n ) : (\r\n <CheckboxGroup\r\n variant={uiMode}\r\n defaultValue={\r\n d.defaultValue\r\n ? (\r\n d.defaultValue as {\r\n value: string | number;\r\n label: string | number;\r\n }[]\r\n ).map(el => `${el.value}`)\r\n : []\r\n }\r\n value={\r\n d.value\r\n ? (\r\n d.value as {\r\n value: string | number;\r\n label: string | number;\r\n }[]\r\n ).map(el => `${el.value}`)\r\n : undefined\r\n }\r\n onValueChange={el => {\r\n handleFilterChange(\r\n d.filter,\r\n d.availableValues.filter(v => el.indexOf(`${v.value}`) !== -1),\r\n );\r\n }}\r\n >\r\n {d.availableValues.map((el, j) => (\r\n <CheckboxGroupItem\r\n label={`${el.label}`}\r\n value={`${el.value}`}\r\n key={j}\r\n />\r\n ))}\r\n </CheckboxGroup>\r\n )}\r\n {d.allowSelectAll ? (\r\n <button\r\n type='button'\r\n className='bg-transparent border-0 p-0 mt-2 cursor-pointer text-primary-blue-600 dark:text-primary-blue-400'\r\n onClick={() => {\r\n handleFilterChange(d.filter, d.availableValues);\r\n }}\r\n >\r\n Select all options\r\n </button>\r\n ) : null}\r\n </>\r\n )}\r\n </div>\r\n ))}\r\n {highlightDataPointSettings ? (\r\n <div\r\n style={{\r\n width:\r\n highlightDataPointSettings.width ||\r\n `calc(${100 / noOfFiltersPerRow}% - ${\r\n (noOfFiltersPerRow - 1) / noOfFiltersPerRow\r\n }rem)`,\r\n flexGrow: 1,\r\n flexShrink: 0,\r\n minWidth: '240px',\r\n }}\r\n className='pb-4'\r\n >\r\n <Label className='mb-2'>\r\n {highlightDataPointSettings.label || 'Highlight data'}\r\n </Label>\r\n <DropdownSelect\r\n options={highlightedDataPointOptions}\r\n variant={uiMode}\r\n size='sm'\r\n isMulti\r\n isClearable\r\n isSearchable\r\n controlShouldRenderValue\r\n filterOption={createFilter(filterConfig)}\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onChange={(el: any) => {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n setHighlightedDataPointList(el?.map((d: any) => d.value));\r\n }}\r\n value={highlightedDataPointList?.map(d => ({\r\n label: d,\r\n value: d,\r\n }))}\r\n defaultValue={highlightDataPointSettings.defaultValues?.map(d => ({\r\n label: d,\r\n value: d,\r\n }))}\r\n />\r\n </div>\r\n ) : null}\r\n </div>\r\n ) : null}\r\n <ThreeDGraphEl\r\n graph={graphType}\r\n graphData={graphData}\r\n graphDataConfiguration={graphConfig}\r\n debugMode={debugMode}\r\n readableHeader={readableHeader || []}\r\n updateFilters={updateFilters}\r\n settings={{\r\n ...(graphSettings || {}),\r\n ...advancedGraphSettings,\r\n graphTitle: undefined,\r\n graphDescription: undefined,\r\n graphDownload: false,\r\n dataDownload: false,\r\n backgroundColor: undefined,\r\n padding: '0',\r\n width: undefined,\r\n height: undefined,\r\n relativeHeight: undefined,\r\n minHeight: undefined,\r\n theme: graphSettings?.theme,\r\n ...(highlightedDataPointList\r\n ? {\r\n highlightedDataPoints: highlightedDataPointList,\r\n highlightedIds: highlightedDataPointList?.map(d => `${d}`),\r\n highlightedLines: highlightedDataPointList?.map(d => d),\r\n }\r\n : {}),\r\n }}\r\n />\r\n </>\r\n ) : (\r\n <div className='w-full flex justify-center p-4'>\r\n <Spinner />\r\n </div>\r\n )}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["ThreeDGraphEl","props","$","_c","settings","graph","graphData","debugMode","graphDataConfiguration","readableHeader","updateFilters","console","log","t0","width","t1","Symbol","for","height","t2","P","t3","threeDGlobe","ThreeDGlobe","graphComponents","graphType","globeOffset","collapseColorScaleByDefault","polygonAltitude","highlightedIds","scale","theme","resetSelectionOnDoubleClick","graphTitle","mapData","graphDescription","footNote","sources","colorDomain","colors","colorLegendTitle","Object","keys","indexOf","getValues","scaleType","data","centerPoint","backgroundColor","mapNoDataColor","mapBorderColor","relativeHeight","padding","tooltip","showColorScale","graphID","dataDownload","mapProperty","language","minHeight","ariaLabel","onSeriesMouseClick","el","id","detailsOnClick","styles","classNames","autoRotate","globeMaterial","atmosphereColor","enableZoom","atmosphereAltitude","globeCurvatureResolution","fogSettings","fogSetting","lights","highlightedAltitude","selectedId","getGraphProps","GraphComponent","graphProps","t4","t5","jsx","t6","getGraphSettings","dataSelectionOptions","updatedConfig","updatedSettings","map","c","indx","findIndex","opt","chartConfigId","allowedValIndx","allowedColumnIds","col","value","columnId","graphSettings","assign","SingleGraphDashboardThreeDGraphs","dataSettings","filters","dataTransform","dataFilters","advancedDataSelectionOptions","noOfFiltersPerRow","uiMode","highlightDataPointSettings","filteredData","setFilteredData","useState","undefined","setData","graphConfig","setGraphConfig","advancedGraphSettings","setAdvancedGraphSettings","highlightedDataPointList","setHighlightedDataPointList","highlightedDataPointOptions","setHighlightedDataPointOption","graphParentDiv","useRef","prevGraphDataConfigRef","filterSettings","setFilterSettings","filterConfig","ignoreCase","ignoreAccents","trim","updateFiltersEvent","useEffectEvent","filterSettingsTemp","filter","column","label","singleSelect","clearable","defaultValue","transformDefaultValue","availableValues","getUniqValue","v","excludeValues","includes","allowSelectAll","useEffect","dataFromFile","dataURL","fileType","fetchAndParseJSON","columnsToArray","dataTransformation","fetchAndTransformDataFromAPI","apiHeaders","fetchAndParseCSV","delimiter","fetchAndParseMultipleDataSources","idColumnTitle","transformColumnsToArray","error","fetchData","filteredDataEvent","length","result","item","every","flattenDeep","intersection","updateHighlightedDataPointOptions","d","isEqual","current","handleFilterChange","values","prev","f","transformDataForGraph","transformDataForAggregation","filterData","keyColumn","aggregationColumnsSetting","GraphContainer","graphContainer","graphList","geoHubMapPresentation","jsxs","Fragment","graphDownload","GraphHeader","title","description","i","flexGrow","flexShrink","ui","minWidth","Label","DropdownSelect","options","dataConfiguration","RadioGroup","selectedOption","j","RadioGroupItem","checkIfMultiple","createFilter","newGraphConfig","CheckboxGroup","CheckboxGroupItem","defaultValues","highlightedDataPoints","highlightedLines","Spinner"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"SingleGraphDashboardThreeDGraphs.cjs","sources":["../src/Components/Dashboard/PerformanceIntensive/ThreeDGraphEl.tsx","../src/Components/Dashboard/PerformanceIntensive/SingleGraphDashboardThreeDGraphs.tsx"],"sourcesContent":["import { P } from '@undp/design-system-react/Typography';\r\n\r\nimport { ThreeDGlobe } from '../../Graphs/Maps/ThreeDGlobe';\r\n\r\nimport { getValues } from '@/Utils/getValues';\r\nimport { GraphConfigurationDataType, GraphSettingsDataType, ThreeDGraphType } from '@/Types';\r\n\r\ninterface Props {\r\n graph: ThreeDGraphType;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n graphData: any;\r\n settings?: GraphSettingsDataType;\r\n debugMode?: boolean;\r\n graphDataConfiguration?: GraphConfigurationDataType[];\r\n readableHeader: {\r\n value: string;\r\n label: string;\r\n }[];\r\n updateFilters?: (_d: string) => void;\r\n}\r\n\r\nfunction ThreeDGraphEl(props: Props) {\r\n const {\r\n settings,\r\n graph,\r\n graphData,\r\n debugMode,\r\n graphDataConfiguration,\r\n readableHeader,\r\n updateFilters,\r\n } = props;\r\n if (debugMode) {\r\n // eslint-disable-next-line no-console\r\n console.log(`Graph: ${graph}`);\r\n // eslint-disable-next-line no-console\r\n console.log('Transformed data:', graphData);\r\n // eslint-disable-next-line no-console\r\n console.log('Settings:', settings);\r\n }\r\n if (typeof graphData === 'string')\r\n return (\r\n <div\r\n className={`flex my-0 mx-auto grow flex-col justify-center ${\r\n settings?.width ? 'w-fit' : 'w-full'\r\n }`}\r\n style={{ height: 'inherit' }}\r\n >\r\n <P\r\n size='sm'\r\n marginBottom='none'\r\n className='p-2 text-center text-accent-dark-red dark:text-accent-red'\r\n >\r\n {graphData}\r\n </P>\r\n </div>\r\n );\r\n const graphComponents: Record<ThreeDGraphType, React.ElementType | null> = {\r\n threeDGlobe: ThreeDGlobe,\r\n };\r\n const getGraphProps = (graphType: ThreeDGraphType) => {\r\n switch (graphType) {\r\n case 'threeDGlobe':\r\n return {\r\n globeOffset: settings?.globeOffset,\r\n collapseColorScaleByDefault: settings?.collapseColorScaleByDefault,\r\n polygonAltitude: settings?.polygonAltitude,\r\n highlightedIds: settings?.highlightedIds,\r\n scale: settings?.scale,\r\n theme: settings?.theme,\r\n resetSelectionOnDoubleClick: settings?.resetSelectionOnDoubleClick,\r\n graphTitle: settings?.graphTitle,\r\n mapData: settings?.mapData,\r\n graphDescription: settings?.graphDescription,\r\n footNote: settings?.footNote,\r\n width: settings?.width,\r\n height: settings?.height,\r\n sources: settings?.sources,\r\n colorDomain: settings?.colorDomain as string[] | number[],\r\n colors: settings?.colors as string[] | undefined,\r\n colorLegendTitle:\r\n Object.keys(settings || {}).indexOf('colorLegendTitle') !== -1\r\n ? settings?.colorLegendTitle\r\n : getValues('x', graphDataConfiguration || [], readableHeader || []),\r\n scaleType: settings?.scaleType,\r\n data: graphData,\r\n centerPoint: settings?.centerPoint,\r\n backgroundColor: settings?.backgroundColor,\r\n mapNoDataColor: settings?.mapNoDataColor,\r\n mapBorderColor: settings?.mapBorderColor,\r\n relativeHeight: settings?.relativeHeight,\r\n padding: settings?.padding,\r\n tooltip: settings?.tooltip,\r\n showColorScale: settings?.showColorScale,\r\n graphID: settings?.graphID,\r\n dataDownload: settings?.dataDownload,\r\n mapProperty: settings?.mapProperty,\r\n language: settings?.language,\r\n minHeight: settings?.minHeight,\r\n ariaLabel: settings?.ariaLabel,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick: (el: any) => {\r\n updateFilters?.(el.id);\r\n },\r\n detailsOnClick: settings?.detailsOnClick,\r\n styles: settings?.styles,\r\n classNames: settings?.classNames,\r\n autoRotate: settings?.autoRotate,\r\n globeMaterial: settings?.globeMaterial,\r\n atmosphereColor: settings?.atmosphereColor,\r\n enableZoom: settings?.enableZoom,\r\n atmosphereAltitude: settings?.atmosphereAltitude,\r\n globeCurvatureResolution: settings?.globeCurvatureResolution,\r\n fogSettings: settings?.fogSetting,\r\n lights: settings?.lights,\r\n highlightedAltitude: settings?.highlightedAltitude,\r\n selectedId: settings?.selectedId,\r\n };\r\n default:\r\n return {};\r\n }\r\n };\r\n const GraphComponent = graphComponents[graph];\r\n const graphProps = getGraphProps(graph);\r\n return (\r\n <div\r\n className={`grow my-0 mx-auto flex flex-col w-full justify-center ${settings?.theme || 'light'}`}\r\n style={{ minHeight: 'inherit' }}\r\n >\r\n {GraphComponent ? (\r\n <GraphComponent {...graphProps} />\r\n ) : (\r\n <P\r\n size='sm'\r\n marginBottom='none'\r\n className='p-2 text-center text-accent-dark-red dark:text-accent-red'\r\n >\r\n {`Invalid chart type: ${graph}`}\r\n </P>\r\n )}\r\n </div>\r\n );\r\n}\r\n\r\nexport default ThreeDGraphEl;\r\n","import { useEffect, useEffectEvent, useRef, useState } from 'react';\r\nimport intersection from 'lodash.intersection';\r\nimport flattenDeep from 'lodash.flattendeep';\r\nimport isEqual from 'fast-deep-equal';\r\nimport { createFilter, DropdownSelect } from '@undp/design-system-react/DropdownSelect';\r\nimport { CheckboxGroup, CheckboxGroupItem } from '@undp/design-system-react/CheckboxGroup';\r\nimport { RadioGroup, RadioGroupItem } from '@undp/design-system-react/RadioGroup';\r\nimport { Spinner } from '@undp/design-system-react/Spinner';\r\nimport { Label } from '@undp/design-system-react/Label';\r\n\r\nimport ThreeDGraphEl from './ThreeDGraphEl';\r\n\r\nimport {\r\n AdvancedDataSelectionDataType,\r\n AggregationSettingsDataType,\r\n DataFilterDataType,\r\n DataSelectionDataType,\r\n DataSettingsDataType,\r\n FilterSettingsDataType,\r\n FilterUiSettingsDataType,\r\n GraphConfigurationDataType,\r\n GraphSettingsDataType,\r\n HighlightDataPointSettingsDataType,\r\n ThreeDGraphType,\r\n} from '@/Types';\r\nimport {\r\n fetchAndParseCSV,\r\n fetchAndParseJSON,\r\n fetchAndParseMultipleDataSources,\r\n fetchAndTransformDataFromAPI,\r\n} from '@/Utils/fetchAndParseData';\r\nimport { transformDataForGraph } from '@/Utils/transformData/transformDataForGraph';\r\nimport { getUniqValue } from '@/Utils/getUniqValue';\r\nimport { transformDataForAggregation } from '@/Utils/transformData/transformDataForAggregation';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { filterData } from '@/Utils/transformData/filterData';\r\nimport { checkIfMultiple } from '@/Utils/checkIfMultiple';\r\nimport { transformColumnsToArray } from '@/Utils/transformData/transformColumnsToArray';\r\nimport { graphList } from '@/Utils/getGraphList';\r\nimport { transformDefaultValue } from '@/Utils/transformDataForSelect';\r\nimport { GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n graphSettings?: GraphSettingsDataType;\r\n readableHeader?: {\r\n value: string;\r\n label: string;\r\n }[];\r\n dataSettings: DataSettingsDataType;\r\n filters?: FilterUiSettingsDataType[];\r\n highlightDataPointSettings?: HighlightDataPointSettingsDataType;\r\n noOfFiltersPerRow?: number;\r\n graphType: ThreeDGraphType;\r\n dataTransform?: {\r\n keyColumn: string;\r\n aggregationColumnsSetting?: AggregationSettingsDataType[];\r\n };\r\n dataFilters?: DataFilterDataType[];\r\n graphDataConfiguration?: GraphConfigurationDataType[];\r\n dataSelectionOptions?: DataSelectionDataType[];\r\n advancedDataSelectionOptions?: AdvancedDataSelectionDataType[];\r\n debugMode?: boolean;\r\n uiMode?: 'light' | 'normal';\r\n updateFilters?: (_d: string) => void;\r\n}\r\n\r\nconst getGraphSettings = (\r\n dataSelectionOptions: DataSelectionDataType[],\r\n updatedConfig?: GraphConfigurationDataType[],\r\n) => {\r\n const updatedSettings =\r\n updatedConfig?.map(c => {\r\n const indx = dataSelectionOptions?.findIndex(opt => opt.chartConfigId === c.chartConfigId);\r\n if (indx === -1) return {};\r\n const allowedValIndx = dataSelectionOptions[indx]?.allowedColumnIds?.findIndex(\r\n col => col.value === c.columnId,\r\n );\r\n if (allowedValIndx === -1) return {};\r\n return dataSelectionOptions[indx].allowedColumnIds[allowedValIndx].graphSettings || {};\r\n }) || [];\r\n return Object.assign({}, ...updatedSettings);\r\n};\r\n\r\nexport function SingleGraphDashboardThreeDGraphs(props: Props) {\r\n const {\r\n graphSettings,\r\n dataSettings,\r\n filters,\r\n graphType,\r\n dataTransform,\r\n graphDataConfiguration,\r\n dataFilters,\r\n debugMode,\r\n dataSelectionOptions,\r\n advancedDataSelectionOptions,\r\n readableHeader,\r\n noOfFiltersPerRow = 4,\r\n updateFilters,\r\n uiMode = 'normal',\r\n highlightDataPointSettings,\r\n } = props;\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [filteredData, setFilteredData] = useState<any>(undefined);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const [data, setData] = useState<any>(undefined);\r\n const [graphConfig, setGraphConfig] = useState<GraphConfigurationDataType[] | undefined>(\r\n graphDataConfiguration,\r\n );\r\n const [advancedGraphSettings, setAdvancedGraphSettings] = useState<GraphSettingsDataType>({});\r\n const [highlightedDataPointList, setHighlightedDataPointList] = useState<\r\n (string | number)[] | undefined\r\n >(undefined);\r\n const [highlightedDataPointOptions, setHighlightedDataPointOption] = useState<\r\n { label: string | number; value: string | number }[]\r\n >([]);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n const prevGraphDataConfigRef = useRef<GraphConfigurationDataType[] | undefined>(\r\n graphDataConfiguration,\r\n );\r\n const [filterSettings, setFilterSettings] = useState<FilterSettingsDataType[]>([]);\r\n\r\n const filterConfig = {\r\n ignoreCase: true,\r\n ignoreAccents: true,\r\n trim: true,\r\n };\r\n\r\n const updateFiltersEvent = useEffectEvent(() => {\r\n const filterSettingsTemp = (filters || []).map(el => ({\r\n filter: el.column,\r\n label: el.label || `Filter by ${el.column}`,\r\n singleSelect: el.singleSelect,\r\n clearable: el.clearable,\r\n defaultValue: transformDefaultValue(el.defaultValue),\r\n value: transformDefaultValue(el.defaultValue),\r\n availableValues: getUniqValue(data, el.column)\r\n .filter(v => !el.excludeValues?.includes(`${v}`))\r\n .map(v => ({ value: v, label: v })),\r\n allowSelectAll: el.allowSelectAll,\r\n width: el.width,\r\n }));\r\n setFilterSettings(filterSettingsTemp);\r\n });\r\n useEffect(() => {\r\n const fetchData = async () => {\r\n try {\r\n const dataFromFile = dataSettings.dataURL\r\n ? typeof dataSettings.dataURL === 'string'\r\n ? dataSettings.fileType === 'json'\r\n ? await fetchAndParseJSON(\r\n dataSettings.dataURL,\r\n dataSettings.columnsToArray,\r\n dataSettings.dataTransformation,\r\n debugMode,\r\n )\r\n : dataSettings.fileType === 'api'\r\n ? await fetchAndTransformDataFromAPI(\r\n dataSettings.dataURL,\r\n dataSettings.apiHeaders,\r\n dataSettings.columnsToArray,\r\n dataSettings.dataTransformation,\r\n debugMode,\r\n )\r\n : await fetchAndParseCSV(\r\n dataSettings.dataURL,\r\n dataSettings.dataTransformation,\r\n dataSettings.columnsToArray,\r\n debugMode,\r\n dataSettings.delimiter,\r\n true,\r\n )\r\n : await fetchAndParseMultipleDataSources(\r\n dataSettings.dataURL,\r\n dataSettings.idColumnTitle,\r\n )\r\n : await transformColumnsToArray(dataSettings.data, dataSettings.columnsToArray);\r\n setData(dataFromFile);\r\n } catch (error) {\r\n console.error('Data fetching error:', error);\r\n }\r\n };\r\n fetchData();\r\n updateFiltersEvent();\r\n }, [dataSettings, debugMode]);\r\n\r\n useEffect(() => {\r\n updateFiltersEvent();\r\n }, [filters, data]);\r\n\r\n const filteredDataEvent = useEffectEvent(() => {\r\n if (!data || filterSettings.length === 0) setFilteredData(data);\r\n else {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const result = data.filter((item: any) =>\r\n filterSettings.every(filter =>\r\n filter.value && flattenDeep([filter.value]).length > 0\r\n ? intersection(\r\n flattenDeep([item[filter.filter]]),\r\n flattenDeep([filter.value]).map(el => el.value),\r\n ).length > 0\r\n : true,\r\n ),\r\n );\r\n setFilteredData(result);\r\n }\r\n });\r\n\r\n useEffect(() => {\r\n filteredDataEvent();\r\n }, [filterSettings, data]);\r\n\r\n useEffect(() => {\r\n if (dataSelectionOptions)\r\n // eslint-disable-next-line react-hooks/set-state-in-effect\r\n setAdvancedGraphSettings(getGraphSettings(dataSelectionOptions, graphDataConfiguration));\r\n }, [dataSelectionOptions, graphDataConfiguration]);\r\n\r\n const updateHighlightedDataPointOptions = useEffectEvent(() => {\r\n if (highlightDataPointSettings?.column && filteredData)\r\n setHighlightedDataPointOption(\r\n getUniqValue(filteredData, highlightDataPointSettings.column)\r\n .filter(v => !highlightDataPointSettings?.excludeValues?.includes(`${v}`))\r\n .map(d => ({ value: d, label: d })),\r\n );\r\n });\r\n\r\n useEffect(() => {\r\n updateHighlightedDataPointOptions();\r\n }, [highlightDataPointSettings]);\r\n\r\n useEffect(() => {\r\n if (!isEqual(prevGraphDataConfigRef.current, graphDataConfiguration)) {\r\n // eslint-disable-next-line react-hooks/set-state-in-effect\r\n setGraphConfig(graphDataConfiguration);\r\n prevGraphDataConfigRef.current = graphDataConfiguration;\r\n }\r\n }, [graphDataConfiguration]);\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const handleFilterChange = (filter: string, values: any) => {\r\n setFilterSettings(prev => prev.map(f => (f.filter === filter ? { ...f, value: values } : f)));\r\n };\r\n\r\n const graphData = !data\r\n ? undefined\r\n : transformDataForGraph(\r\n dataTransform\r\n ? transformDataForAggregation(\r\n filterData(data, dataFilters || []),\r\n dataTransform.keyColumn,\r\n dataTransform.aggregationColumnsSetting,\r\n )\r\n : filterData(data, dataFilters || []),\r\n graphType,\r\n graphConfig,\r\n );\r\n return (\r\n <GraphContainer\r\n className={graphSettings?.classNames?.graphContainer}\r\n style={graphSettings?.styles?.graphContainer}\r\n id={graphSettings?.graphID}\r\n ref={graphParentDiv}\r\n aria-label={graphSettings?.ariaLabel}\r\n backgroundColor={graphSettings?.backgroundColor ?? false}\r\n theme={graphSettings?.theme || 'light'}\r\n language={graphSettings?.language || 'en'}\r\n width={graphSettings?.width}\r\n height={graphSettings?.height}\r\n padding={graphSettings?.padding}\r\n minHeight={graphSettings?.minHeight}\r\n relativeHeight={graphSettings?.relativeHeight}\r\n >\r\n {data ||\r\n graphList\r\n .filter(el => el.geoHubMapPresentation)\r\n .map(el => el.graphID)\r\n .indexOf(graphType) !== -1 ? (\r\n <>\r\n {advancedGraphSettings?.graphTitle ||\r\n advancedGraphSettings?.graphDescription ||\r\n graphSettings?.graphTitle ||\r\n graphSettings?.graphDescription ||\r\n graphSettings?.graphDownload ||\r\n graphSettings?.dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: advancedGraphSettings?.styles?.title || graphSettings?.styles?.title,\r\n description:\r\n advancedGraphSettings?.styles?.description || graphSettings?.styles?.description,\r\n }}\r\n classNames={{\r\n title: advancedGraphSettings?.classNames?.title || graphSettings?.classNames?.title,\r\n description:\r\n advancedGraphSettings?.classNames?.description ||\r\n graphSettings?.classNames?.description,\r\n }}\r\n graphTitle={advancedGraphSettings?.graphTitle || graphSettings?.graphTitle}\r\n graphDescription={\r\n advancedGraphSettings?.graphDescription || graphSettings?.graphDescription\r\n }\r\n width={advancedGraphSettings?.width || graphSettings?.width}\r\n graphDownload={graphSettings?.graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n graphSettings?.dataDownload && data ? (data.length > 0 ? data : null) : null\r\n }\r\n />\r\n ) : null}\r\n {filterSettings.length !== 0 ||\r\n (dataSelectionOptions || []).length !== 0 ||\r\n (advancedDataSelectionOptions || []).length !== 0 ||\r\n highlightDataPointSettings ? (\r\n <div className='flex flex-wrap items-start gap-x-4 gap-y-0 w-full'>\r\n {advancedDataSelectionOptions?.map((d, i) => (\r\n <div\r\n style={{\r\n width:\r\n d.width ||\r\n `calc(${100 / noOfFiltersPerRow}% - ${\r\n (noOfFiltersPerRow - 1) / noOfFiltersPerRow\r\n }rem)`,\r\n flexGrow: d.width ? 0 : 1,\r\n flexShrink: d.ui !== 'radio' || d.width ? 0 : 1,\r\n minWidth: '240px',\r\n }}\r\n key={i}\r\n className='pb-4'\r\n >\r\n <Label className='mb-2'>{d.label || 'Graph by'}</Label>\r\n {d.ui !== 'radio' ? (\r\n <DropdownSelect\r\n options={d.options.map(opt => ({\r\n ...opt,\r\n value: opt.label,\r\n }))}\r\n size='sm'\r\n isClearable={false}\r\n isSearchable\r\n variant={uiMode}\r\n controlShouldRenderValue\r\n defaultValue={\r\n d.defaultValue\r\n ? {\r\n ...d.defaultValue,\r\n value: d.defaultValue?.label,\r\n }\r\n : {\r\n ...d.options[0],\r\n value: d.options[0].label,\r\n }\r\n }\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onChange={(el: any) => {\r\n setAdvancedGraphSettings(el?.graphSettings || {});\r\n setGraphConfig(el?.dataConfiguration);\r\n }}\r\n />\r\n ) : (\r\n <RadioGroup\r\n defaultValue={d.defaultValue?.label || d.options[0].label}\r\n variant={uiMode}\r\n onValueChange={el => {\r\n const selectedOption =\r\n d.options[d.options.findIndex(opt => opt.label === el)];\r\n setAdvancedGraphSettings(selectedOption.graphSettings || {});\r\n setGraphConfig(selectedOption.dataConfiguration);\r\n }}\r\n >\r\n {d.options.map((el, j) => (\r\n <RadioGroupItem label={el.label} value={el.label} key={j} />\r\n ))}\r\n </RadioGroup>\r\n )}\r\n </div>\r\n ))}\r\n {dataSelectionOptions?.map((d, i) => (\r\n <div\r\n style={{\r\n width:\r\n d.width ||\r\n `calc(${100 / noOfFiltersPerRow}% - ${\r\n (noOfFiltersPerRow - 1) / noOfFiltersPerRow\r\n }rem)`,\r\n flexGrow: d.width ? 0 : 1,\r\n flexShrink: d.ui !== 'radio' || d.width ? 0 : 1,\r\n minWidth: '240px',\r\n }}\r\n key={i}\r\n className='pb-4'\r\n >\r\n <Label className='mb-2'>{d.label || `Visualize ${d.chartConfigId} by`}</Label>\r\n {!checkIfMultiple(d.chartConfigId, graphConfig || []) ? (\r\n d.ui !== 'radio' ? (\r\n <DropdownSelect\r\n options={d.allowedColumnIds}\r\n size='sm'\r\n isClearable={false}\r\n isSearchable\r\n variant={uiMode}\r\n controlShouldRenderValue\r\n defaultValue={\r\n graphDataConfiguration\r\n ? d.allowedColumnIds[\r\n d.allowedColumnIds.findIndex(\r\n j =>\r\n j.value ===\r\n (graphDataConfiguration[\r\n graphDataConfiguration.findIndex(\r\n el => el.chartConfigId === d.chartConfigId,\r\n )\r\n ].columnId as string),\r\n )\r\n ]\r\n : undefined\r\n }\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onChange={(el: any) => {\r\n const newGraphConfig = {\r\n columnId: el?.value as string,\r\n chartConfigId: d.chartConfigId,\r\n };\r\n const updatedConfig = graphConfig?.map(item =>\r\n item.chartConfigId === newGraphConfig.chartConfigId\r\n ? newGraphConfig\r\n : item,\r\n );\r\n setAdvancedGraphSettings(\r\n getGraphSettings(dataSelectionOptions, updatedConfig),\r\n );\r\n setGraphConfig(updatedConfig);\r\n }}\r\n />\r\n ) : (\r\n <RadioGroup\r\n variant={uiMode}\r\n defaultValue={\r\n graphDataConfiguration\r\n ? d.allowedColumnIds[\r\n d.allowedColumnIds.findIndex(\r\n j =>\r\n j.value ===\r\n (graphDataConfiguration[\r\n graphDataConfiguration.findIndex(\r\n el => el.chartConfigId === d.chartConfigId,\r\n )\r\n ].columnId as string),\r\n )\r\n ].label\r\n : ''\r\n }\r\n onValueChange={el => {\r\n const selectedOption =\r\n d.allowedColumnIds[\r\n d.allowedColumnIds.findIndex(opt => opt.label === el)\r\n ];\r\n const newGraphConfig = {\r\n columnId: selectedOption.value,\r\n chartConfigId: d.chartConfigId,\r\n };\r\n const updatedConfig = graphConfig?.map(item =>\r\n item.chartConfigId === newGraphConfig.chartConfigId\r\n ? newGraphConfig\r\n : item,\r\n );\r\n setAdvancedGraphSettings(\r\n getGraphSettings(dataSelectionOptions, updatedConfig),\r\n );\r\n setGraphConfig(updatedConfig);\r\n }}\r\n >\r\n {d.allowedColumnIds.map((el, j) => (\r\n <RadioGroupItem label={el.label} value={el.label} key={j} />\r\n ))}\r\n </RadioGroup>\r\n )\r\n ) : d.ui !== 'radio' ? (\r\n <DropdownSelect\r\n options={d.allowedColumnIds}\r\n size='sm'\r\n isMulti\r\n isSearchable\r\n variant={uiMode}\r\n controlShouldRenderValue\r\n defaultValue={\r\n graphDataConfiguration\r\n ? (\r\n graphDataConfiguration[\r\n graphDataConfiguration.findIndex(\r\n el => el.chartConfigId === d.chartConfigId,\r\n )\r\n ].columnId as string[]\r\n ).map(\r\n el =>\r\n d.allowedColumnIds[\r\n d.allowedColumnIds.findIndex(j => j.value === el)\r\n ],\r\n )\r\n : undefined\r\n }\r\n filterOption={createFilter(filterConfig)}\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onChange={(el: any) => {\r\n const newGraphConfig = {\r\n columnId: (el || []).map(\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n (item: any) => item.value,\r\n ) as string[],\r\n chartConfigId: d.chartConfigId,\r\n };\r\n const updatedConfig = graphConfig?.map(item =>\r\n item.chartConfigId === newGraphConfig.chartConfigId\r\n ? newGraphConfig\r\n : item,\r\n );\r\n setGraphConfig(updatedConfig);\r\n }}\r\n />\r\n ) : (\r\n <CheckboxGroup\r\n variant={uiMode}\r\n defaultValue={\r\n graphDataConfiguration\r\n ? (\r\n graphDataConfiguration[\r\n graphDataConfiguration.findIndex(\r\n el => el.chartConfigId === d.chartConfigId,\r\n )\r\n ].columnId as string[]\r\n )\r\n .map(\r\n el =>\r\n d.allowedColumnIds[\r\n d.allowedColumnIds.findIndex(j => j.value === el)\r\n ],\r\n )\r\n .map(el => el.value)\r\n : []\r\n }\r\n onValueChange={el => {\r\n const newGraphConfig = {\r\n columnId: el || [],\r\n chartConfigId: d.chartConfigId,\r\n };\r\n const updatedConfig = graphConfig?.map(item =>\r\n item.chartConfigId === newGraphConfig.chartConfigId\r\n ? newGraphConfig\r\n : item,\r\n );\r\n setGraphConfig(updatedConfig);\r\n }}\r\n >\r\n {d.allowedColumnIds.map((el, j) => (\r\n <CheckboxGroupItem label={el.label} value={el.label} key={j} />\r\n ))}\r\n </CheckboxGroup>\r\n )}\r\n </div>\r\n ))}\r\n {filterSettings?.map((d, i) => (\r\n <div\r\n style={{\r\n width:\r\n d.width ||\r\n `calc(${100 / noOfFiltersPerRow}% - ${\r\n (noOfFiltersPerRow - 1) / noOfFiltersPerRow\r\n }rem)`,\r\n flexGrow: d.width ? 0 : 1,\r\n flexShrink: d.ui !== 'radio' || d.width ? 0 : 1,\r\n minWidth: '240px',\r\n }}\r\n key={i}\r\n className='pb-4'\r\n >\r\n <Label className='mb-2'>{d.label}</Label>\r\n {d.singleSelect ? (\r\n d.ui !== 'radio' ? (\r\n <DropdownSelect\r\n options={d.availableValues}\r\n variant={uiMode}\r\n isClearable={d.clearable === undefined ? true : d.clearable}\r\n isSearchable\r\n controlShouldRenderValue\r\n filterOption={createFilter(filterConfig)}\r\n onChange={el => {\r\n handleFilterChange(d.filter, el);\r\n }}\r\n value={d.value}\r\n defaultValue={d.defaultValue}\r\n />\r\n ) : (\r\n <RadioGroup\r\n variant={uiMode}\r\n defaultValue={(d.defaultValue as { value: string; label: string }).value}\r\n onValueChange={el => {\r\n handleFilterChange(\r\n d.filter,\r\n d.availableValues.filter(v => v.value === el),\r\n );\r\n }}\r\n >\r\n {d.availableValues.map((el, j) => (\r\n <RadioGroupItem label={`${el.label}`} value={`${el.value}`} key={j} />\r\n ))}\r\n </RadioGroup>\r\n )\r\n ) : (\r\n <>\r\n {d.ui !== 'radio' ? (\r\n <DropdownSelect\r\n options={d.availableValues}\r\n variant={uiMode}\r\n size='sm'\r\n isMulti\r\n isClearable={d.clearable === undefined ? true : d.clearable}\r\n isSearchable\r\n controlShouldRenderValue\r\n filterOption={createFilter(filterConfig)}\r\n onChange={el => {\r\n handleFilterChange(d.filter, el);\r\n }}\r\n value={d.value}\r\n defaultValue={d.defaultValue}\r\n />\r\n ) : (\r\n <CheckboxGroup\r\n variant={uiMode}\r\n defaultValue={\r\n d.defaultValue\r\n ? (\r\n d.defaultValue as {\r\n value: string | number;\r\n label: string | number;\r\n }[]\r\n ).map(el => `${el.value}`)\r\n : []\r\n }\r\n value={\r\n d.value\r\n ? (\r\n d.value as {\r\n value: string | number;\r\n label: string | number;\r\n }[]\r\n ).map(el => `${el.value}`)\r\n : undefined\r\n }\r\n onValueChange={el => {\r\n handleFilterChange(\r\n d.filter,\r\n d.availableValues.filter(v => el.indexOf(`${v.value}`) !== -1),\r\n );\r\n }}\r\n >\r\n {d.availableValues.map((el, j) => (\r\n <CheckboxGroupItem\r\n label={`${el.label}`}\r\n value={`${el.value}`}\r\n key={j}\r\n />\r\n ))}\r\n </CheckboxGroup>\r\n )}\r\n {d.allowSelectAll ? (\r\n <button\r\n type='button'\r\n className='bg-transparent border-0 p-0 mt-2 cursor-pointer text-primary-blue-600 dark:text-primary-blue-400'\r\n onClick={() => {\r\n handleFilterChange(d.filter, d.availableValues);\r\n }}\r\n >\r\n Select all options\r\n </button>\r\n ) : null}\r\n </>\r\n )}\r\n </div>\r\n ))}\r\n {highlightDataPointSettings ? (\r\n <div\r\n style={{\r\n width:\r\n highlightDataPointSettings.width ||\r\n `calc(${100 / noOfFiltersPerRow}% - ${\r\n (noOfFiltersPerRow - 1) / noOfFiltersPerRow\r\n }rem)`,\r\n flexGrow: highlightDataPointSettings.width ? 0 : 1,\r\n flexShrink: 0,\r\n minWidth: '240px',\r\n }}\r\n className='pb-4'\r\n >\r\n <Label className='mb-2'>\r\n {highlightDataPointSettings.label || 'Highlight data'}\r\n </Label>\r\n <DropdownSelect\r\n options={highlightedDataPointOptions}\r\n variant={uiMode}\r\n size='sm'\r\n isMulti\r\n isClearable\r\n isSearchable\r\n controlShouldRenderValue\r\n filterOption={createFilter(filterConfig)}\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onChange={(el: any) => {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n setHighlightedDataPointList(el?.map((d: any) => d.value));\r\n }}\r\n value={highlightedDataPointList?.map(d => ({\r\n label: d,\r\n value: d,\r\n }))}\r\n defaultValue={highlightDataPointSettings.defaultValues?.map(d => ({\r\n label: d,\r\n value: d,\r\n }))}\r\n />\r\n </div>\r\n ) : null}\r\n </div>\r\n ) : null}\r\n <ThreeDGraphEl\r\n graph={graphType}\r\n graphData={graphData}\r\n graphDataConfiguration={graphConfig}\r\n debugMode={debugMode}\r\n readableHeader={readableHeader || []}\r\n updateFilters={updateFilters}\r\n settings={{\r\n ...(graphSettings || {}),\r\n ...advancedGraphSettings,\r\n graphTitle: undefined,\r\n graphDescription: undefined,\r\n graphDownload: false,\r\n dataDownload: false,\r\n backgroundColor: undefined,\r\n padding: '0',\r\n width: undefined,\r\n height: undefined,\r\n relativeHeight: undefined,\r\n minHeight: undefined,\r\n theme: graphSettings?.theme,\r\n ...(highlightedDataPointList\r\n ? {\r\n highlightedDataPoints: highlightedDataPointList,\r\n highlightedIds: highlightedDataPointList?.map(d => `${d}`),\r\n highlightedLines: highlightedDataPointList?.map(d => d),\r\n }\r\n : {}),\r\n }}\r\n />\r\n </>\r\n ) : (\r\n <div className='w-full flex justify-center p-4'>\r\n <Spinner />\r\n </div>\r\n )}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["ThreeDGraphEl","props","$","_c","settings","graph","graphData","debugMode","graphDataConfiguration","readableHeader","updateFilters","console","log","t0","width","t1","Symbol","for","height","t2","P","t3","threeDGlobe","ThreeDGlobe","graphComponents","graphType","globeOffset","collapseColorScaleByDefault","polygonAltitude","highlightedIds","scale","theme","resetSelectionOnDoubleClick","graphTitle","mapData","graphDescription","footNote","sources","colorDomain","colors","colorLegendTitle","Object","keys","indexOf","getValues","scaleType","data","centerPoint","backgroundColor","mapNoDataColor","mapBorderColor","relativeHeight","padding","tooltip","showColorScale","graphID","dataDownload","mapProperty","language","minHeight","ariaLabel","onSeriesMouseClick","el","id","detailsOnClick","styles","classNames","autoRotate","globeMaterial","atmosphereColor","enableZoom","atmosphereAltitude","globeCurvatureResolution","fogSettings","fogSetting","lights","highlightedAltitude","selectedId","getGraphProps","GraphComponent","graphProps","t4","t5","jsx","t6","getGraphSettings","dataSelectionOptions","updatedConfig","updatedSettings","map","c","indx","findIndex","opt","chartConfigId","allowedValIndx","allowedColumnIds","col","value","columnId","graphSettings","assign","SingleGraphDashboardThreeDGraphs","dataSettings","filters","dataTransform","dataFilters","advancedDataSelectionOptions","noOfFiltersPerRow","uiMode","highlightDataPointSettings","filteredData","setFilteredData","useState","undefined","setData","graphConfig","setGraphConfig","advancedGraphSettings","setAdvancedGraphSettings","highlightedDataPointList","setHighlightedDataPointList","highlightedDataPointOptions","setHighlightedDataPointOption","graphParentDiv","useRef","prevGraphDataConfigRef","filterSettings","setFilterSettings","filterConfig","ignoreCase","ignoreAccents","trim","updateFiltersEvent","useEffectEvent","filterSettingsTemp","filter","column","label","singleSelect","clearable","defaultValue","transformDefaultValue","availableValues","getUniqValue","v","excludeValues","includes","allowSelectAll","useEffect","dataFromFile","dataURL","fileType","fetchAndParseJSON","columnsToArray","dataTransformation","fetchAndTransformDataFromAPI","apiHeaders","fetchAndParseCSV","delimiter","fetchAndParseMultipleDataSources","idColumnTitle","transformColumnsToArray","error","fetchData","filteredDataEvent","length","result","item","every","flattenDeep","intersection","updateHighlightedDataPointOptions","d","isEqual","current","handleFilterChange","values","prev","f","transformDataForGraph","transformDataForAggregation","filterData","keyColumn","aggregationColumnsSetting","GraphContainer","graphContainer","graphList","geoHubMapPresentation","jsxs","Fragment","graphDownload","GraphHeader","title","description","i","flexGrow","flexShrink","ui","minWidth","Label","DropdownSelect","options","dataConfiguration","RadioGroup","selectedOption","j","RadioGroupItem","checkIfMultiple","createFilter","newGraphConfig","CheckboxGroup","CheckboxGroupItem","defaultValues","highlightedDataPoints","highlightedLines","Spinner"],"mappings":"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"}
|
|
@@ -95,6 +95,7 @@ declare interface ClassNameObject {
|
|
|
95
95
|
regLine?: string;
|
|
96
96
|
dataCards?: string;
|
|
97
97
|
colorLegend?: string;
|
|
98
|
+
modal?: string;
|
|
98
99
|
}
|
|
99
100
|
|
|
100
101
|
declare interface ColumnConfigurationDataType {
|
|
@@ -593,6 +594,7 @@ declare interface StyleObject {
|
|
|
593
594
|
mouseOverLine?: React.CSSProperties;
|
|
594
595
|
regLine?: React.CSSProperties;
|
|
595
596
|
dataCards?: React.CSSProperties;
|
|
597
|
+
modal?: React.CSSProperties;
|
|
596
598
|
}
|
|
597
599
|
|
|
598
600
|
declare type ThreeDGraphType = 'threeDGlobe';
|
|
@@ -4,12 +4,12 @@ import { i as de } from "./index-BuwmuDFJ.js";
|
|
|
4
4
|
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
|
-
import { g as he, b as M, y as U, h as B, c as ge, $ as X, P as Y } from "./checkIfMultiple-
|
|
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
8
|
import { w as pe } from "./Spinner-D7rnnwnA.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";
|
|
12
|
-
import { a as
|
|
12
|
+
import { a as we, t as Ie } from "./transformDataForAggregation-DEU__LUl.js";
|
|
13
13
|
import { g as ee } from "./getUniqValue-DsqSii6M.js";
|
|
14
14
|
import { GraphHeader as De } from "./GraphHeader.js";
|
|
15
15
|
import { f as ae } from "./filterData-DsAiFzKY.js";
|
|
@@ -21,21 +21,21 @@ function Ve(D) {
|
|
|
21
21
|
settings: t,
|
|
22
22
|
graph: g,
|
|
23
23
|
graphData: d,
|
|
24
|
-
debugMode:
|
|
24
|
+
debugMode: I,
|
|
25
25
|
graphDataConfiguration: r,
|
|
26
26
|
readableHeader: V,
|
|
27
|
-
updateFilters:
|
|
27
|
+
updateFilters: w
|
|
28
28
|
} = D;
|
|
29
|
-
if (
|
|
29
|
+
if (I && (console.log(`Graph: ${g}`), console.log("Transformed data:", d), console.log("Settings:", t)), typeof d == "string") {
|
|
30
30
|
const m = `flex my-0 mx-auto grow flex-col justify-center ${t?.width ? "w-fit" : "w-full"}`;
|
|
31
|
-
let
|
|
32
|
-
a[0] === Symbol.for("react.memo_cache_sentinel") ? (
|
|
31
|
+
let f;
|
|
32
|
+
a[0] === Symbol.for("react.memo_cache_sentinel") ? (f = {
|
|
33
33
|
height: "inherit"
|
|
34
|
-
}, a[0] =
|
|
34
|
+
}, a[0] = f) : f = a[0];
|
|
35
35
|
let u;
|
|
36
36
|
a[1] !== d ? (u = /* @__PURE__ */ o.jsx(_, { size: "sm", marginBottom: "none", className: "p-2 text-center text-accent-dark-red dark:text-accent-red", children: d }), a[1] = d, a[2] = u) : u = a[2];
|
|
37
37
|
let x;
|
|
38
|
-
return a[3] !== m || a[4] !== u ? (x = /* @__PURE__ */ o.jsx("div", { className: m, style:
|
|
38
|
+
return a[3] !== m || a[4] !== u ? (x = /* @__PURE__ */ o.jsx("div", { className: m, style: f, children: u }), a[3] = m, a[4] = u, a[5] = x) : x = a[5], x;
|
|
39
39
|
}
|
|
40
40
|
let b;
|
|
41
41
|
a[6] === Symbol.for("react.memo_cache_sentinel") ? (b = {
|
|
@@ -43,7 +43,7 @@ function Ve(D) {
|
|
|
43
43
|
}, a[6] = b) : b = a[6];
|
|
44
44
|
const P = b;
|
|
45
45
|
let j;
|
|
46
|
-
a[7] !== d || a[8] !== r || a[9] !== V || a[10] !== t || a[11] !==
|
|
46
|
+
a[7] !== d || a[8] !== r || a[9] !== V || a[10] !== t || a[11] !== w ? (j = (m) => {
|
|
47
47
|
switch (m) {
|
|
48
48
|
case "threeDGlobe":
|
|
49
49
|
return {
|
|
@@ -80,8 +80,8 @@ function Ve(D) {
|
|
|
80
80
|
language: t?.language,
|
|
81
81
|
minHeight: t?.minHeight,
|
|
82
82
|
ariaLabel: t?.ariaLabel,
|
|
83
|
-
onSeriesMouseClick: (
|
|
84
|
-
|
|
83
|
+
onSeriesMouseClick: (f) => {
|
|
84
|
+
w?.(f.id);
|
|
85
85
|
},
|
|
86
86
|
detailsOnClick: t?.detailsOnClick,
|
|
87
87
|
styles: t?.styles,
|
|
@@ -100,17 +100,17 @@ function Ve(D) {
|
|
|
100
100
|
default:
|
|
101
101
|
return {};
|
|
102
102
|
}
|
|
103
|
-
}, a[7] = d, a[8] = r, a[9] = V, a[10] = t, a[11] =
|
|
103
|
+
}, a[7] = d, a[8] = r, a[9] = V, a[10] = t, a[11] = w, a[12] = j) : j = a[12];
|
|
104
104
|
const c = j, T = P[g];
|
|
105
105
|
let h;
|
|
106
106
|
a[13] !== c || a[14] !== g ? (h = c(g), a[13] = c, a[14] = g, a[15] = h) : h = a[15];
|
|
107
|
-
const
|
|
107
|
+
const p = h, N = `grow my-0 mx-auto flex flex-col w-full justify-center ${t?.theme || "light"}`;
|
|
108
108
|
let y;
|
|
109
109
|
a[16] === Symbol.for("react.memo_cache_sentinel") ? (y = {
|
|
110
110
|
minHeight: "inherit"
|
|
111
111
|
}, a[16] = y) : y = a[16];
|
|
112
112
|
let s;
|
|
113
|
-
a[17] !== T || a[18] !== g || a[19] !==
|
|
113
|
+
a[17] !== T || a[18] !== g || a[19] !== p ? (s = T ? /* @__PURE__ */ o.jsx(T, { ...p }) : /* @__PURE__ */ o.jsx(_, { size: "sm", marginBottom: "none", className: "p-2 text-center text-accent-dark-red dark:text-accent-red", children: `Invalid chart type: ${g}` }), a[17] = T, a[18] = g, a[19] = p, a[20] = s) : s = a[20];
|
|
114
114
|
let G;
|
|
115
115
|
return a[21] !== N || a[22] !== s ? (G = /* @__PURE__ */ o.jsx("div", { className: N, style: y, children: s }), a[21] = N, a[22] = s, a[23] = G) : G = a[23], G;
|
|
116
116
|
}
|
|
@@ -118,8 +118,8 @@ const W = (D, a) => {
|
|
|
118
118
|
const t = a?.map((g) => {
|
|
119
119
|
const d = D?.findIndex((r) => r.chartConfigId === g.chartConfigId);
|
|
120
120
|
if (d === -1) return {};
|
|
121
|
-
const
|
|
122
|
-
return
|
|
121
|
+
const I = D[d]?.allowedColumnIds?.findIndex((r) => r.value === g.columnId);
|
|
122
|
+
return I === -1 ? {} : D[d].allowedColumnIds[I].graphSettings || {};
|
|
123
123
|
}) || [];
|
|
124
124
|
return Object.assign({}, ...t);
|
|
125
125
|
};
|
|
@@ -129,18 +129,18 @@ function We(D) {
|
|
|
129
129
|
dataSettings: t,
|
|
130
130
|
filters: g,
|
|
131
131
|
graphType: d,
|
|
132
|
-
dataTransform:
|
|
132
|
+
dataTransform: I,
|
|
133
133
|
graphDataConfiguration: r,
|
|
134
134
|
dataFilters: V,
|
|
135
|
-
debugMode:
|
|
135
|
+
debugMode: w,
|
|
136
136
|
dataSelectionOptions: b,
|
|
137
137
|
advancedDataSelectionOptions: P,
|
|
138
138
|
readableHeader: j,
|
|
139
139
|
noOfFiltersPerRow: c = 4,
|
|
140
140
|
updateFilters: T,
|
|
141
141
|
uiMode: h = "normal",
|
|
142
|
-
highlightDataPointSettings:
|
|
143
|
-
} = D, [N, y] = S(void 0), [s, G] = S(void 0), [m,
|
|
142
|
+
highlightDataPointSettings: p
|
|
143
|
+
} = D, [N, y] = S(void 0), [s, G] = S(void 0), [m, f] = S(r), [u, x] = S({}), [O, le] = S(void 0), [ie, oe] = S([]), q = Q(null), Z = Q(r), [A, J] = S([]), R = {
|
|
144
144
|
ignoreCase: !0,
|
|
145
145
|
ignoreAccents: !0,
|
|
146
146
|
trim: !0
|
|
@@ -164,13 +164,13 @@ function We(D) {
|
|
|
164
164
|
$(() => {
|
|
165
165
|
(async () => {
|
|
166
166
|
try {
|
|
167
|
-
const n = t.dataURL ? typeof t.dataURL == "string" ? t.fileType === "json" ? await me(t.dataURL, t.columnsToArray, t.dataTransformation,
|
|
167
|
+
const n = t.dataURL ? typeof t.dataURL == "string" ? t.fileType === "json" ? await me(t.dataURL, t.columnsToArray, t.dataTransformation, w) : t.fileType === "api" ? await Ce(t.dataURL, t.apiHeaders, t.columnsToArray, t.dataTransformation, w) : await be(t.dataURL, t.dataTransformation, t.columnsToArray, w, t.delimiter, !0) : await ve(t.dataURL, t.idColumnTitle) : await xe(t.data, t.columnsToArray);
|
|
168
168
|
G(n);
|
|
169
169
|
} catch (n) {
|
|
170
170
|
console.error("Data fetching error:", n);
|
|
171
171
|
}
|
|
172
172
|
})(), K();
|
|
173
|
-
}, [t,
|
|
173
|
+
}, [t, w]), $(() => {
|
|
174
174
|
K();
|
|
175
175
|
}, [g, s]);
|
|
176
176
|
const re = E(() => {
|
|
@@ -186,22 +186,22 @@ function We(D) {
|
|
|
186
186
|
b && x(W(b, r));
|
|
187
187
|
}, [b, r]);
|
|
188
188
|
const ne = E(() => {
|
|
189
|
-
|
|
189
|
+
p?.column && N && oe(ee(N, p.column).filter((e) => !p?.excludeValues?.includes(`${e}`)).map((e) => ({
|
|
190
190
|
value: e,
|
|
191
191
|
label: e
|
|
192
192
|
})));
|
|
193
193
|
});
|
|
194
194
|
$(() => {
|
|
195
195
|
ne();
|
|
196
|
-
}, [
|
|
197
|
-
ce(Z.current, r) || (
|
|
196
|
+
}, [p]), $(() => {
|
|
197
|
+
ce(Z.current, r) || (f(r), Z.current = r);
|
|
198
198
|
}, [r]);
|
|
199
199
|
const H = (e, n) => {
|
|
200
200
|
J((l) => l.map((i) => i.filter === e ? {
|
|
201
201
|
...i,
|
|
202
202
|
value: n
|
|
203
203
|
} : i));
|
|
204
|
-
}, se = s ?
|
|
204
|
+
}, se = s ? we(I ? Ie(ae(s, V || []), I.keyColumn, I.aggregationColumnsSetting) : ae(s, V || []), d, m) : void 0;
|
|
205
205
|
return /* @__PURE__ */ o.jsx(Se, { className: a?.classNames?.graphContainer, style: a?.styles?.graphContainer, id: a?.graphID, ref: q, "aria-label": a?.ariaLabel, backgroundColor: a?.backgroundColor ?? !1, theme: a?.theme || "light", language: a?.language || "en", width: a?.width, height: a?.height, padding: a?.padding, minHeight: a?.minHeight, relativeHeight: a?.relativeHeight, children: s || ye.filter((e) => e.geoHubMapPresentation).map((e) => e.graphID).indexOf(d) !== -1 ? /* @__PURE__ */ o.jsxs(o.Fragment, { children: [
|
|
206
206
|
u?.graphTitle || u?.graphDescription || a?.graphTitle || a?.graphDescription || a?.graphDownload || a?.dataDownload ? /* @__PURE__ */ o.jsx(De, { styles: {
|
|
207
207
|
title: u?.styles?.title || a?.styles?.title,
|
|
@@ -210,11 +210,11 @@ function We(D) {
|
|
|
210
210
|
title: u?.classNames?.title || a?.classNames?.title,
|
|
211
211
|
description: u?.classNames?.description || a?.classNames?.description
|
|
212
212
|
}, graphTitle: u?.graphTitle || a?.graphTitle, graphDescription: u?.graphDescription || a?.graphDescription, width: u?.width || a?.width, graphDownload: a?.graphDownload ? q : void 0, dataDownload: a?.dataDownload && s && s.length > 0 ? s : null }) : null,
|
|
213
|
-
A.length !== 0 || (b || []).length !== 0 || (P || []).length !== 0 ||
|
|
213
|
+
A.length !== 0 || (b || []).length !== 0 || (P || []).length !== 0 || p ? /* @__PURE__ */ o.jsxs("div", { className: "flex flex-wrap items-start gap-x-4 gap-y-0 w-full", children: [
|
|
214
214
|
P?.map((e, n) => /* @__PURE__ */ o.jsxs("div", { style: {
|
|
215
215
|
width: e.width || `calc(${100 / c}% - ${(c - 1) / c}rem)`,
|
|
216
|
-
flexGrow: 1,
|
|
217
|
-
flexShrink: e.ui !== "radio" ? 0 : 1,
|
|
216
|
+
flexGrow: e.width ? 0 : 1,
|
|
217
|
+
flexShrink: e.ui !== "radio" || e.width ? 0 : 1,
|
|
218
218
|
minWidth: "240px"
|
|
219
219
|
}, className: "pb-4", children: [
|
|
220
220
|
/* @__PURE__ */ o.jsx(M, { className: "mb-2", children: e.label || "Graph by" }),
|
|
@@ -238,18 +238,18 @@ function We(D) {
|
|
|
238
238
|
value: e.options[0].label
|
|
239
239
|
},
|
|
240
240
|
onChange: (l) => {
|
|
241
|
-
x(l?.graphSettings || {}),
|
|
241
|
+
x(l?.graphSettings || {}), f(l?.dataConfiguration);
|
|
242
242
|
}
|
|
243
243
|
}
|
|
244
244
|
) : /* @__PURE__ */ o.jsx(U, { defaultValue: e.defaultValue?.label || e.options[0].label, variant: h, onValueChange: (l) => {
|
|
245
245
|
const i = e.options[e.options.findIndex((v) => v.label === l)];
|
|
246
|
-
x(i.graphSettings || {}),
|
|
246
|
+
x(i.graphSettings || {}), f(i.dataConfiguration);
|
|
247
247
|
}, children: e.options.map((l, i) => /* @__PURE__ */ o.jsx(B, { label: l.label, value: l.label }, i)) })
|
|
248
248
|
] }, n)),
|
|
249
249
|
b?.map((e, n) => /* @__PURE__ */ o.jsxs("div", { style: {
|
|
250
250
|
width: e.width || `calc(${100 / c}% - ${(c - 1) / c}rem)`,
|
|
251
|
-
flexGrow: 1,
|
|
252
|
-
flexShrink: e.ui !== "radio" ? 0 : 1,
|
|
251
|
+
flexGrow: e.width ? 0 : 1,
|
|
252
|
+
flexShrink: e.ui !== "radio" || e.width ? 0 : 1,
|
|
253
253
|
minWidth: "240px"
|
|
254
254
|
}, className: "pb-4", children: [
|
|
255
255
|
/* @__PURE__ */ o.jsx(M, { className: "mb-2", children: e.label || `Visualize ${e.chartConfigId} by` }),
|
|
@@ -272,7 +272,7 @@ function We(D) {
|
|
|
272
272
|
),
|
|
273
273
|
chartConfigId: e.chartConfigId
|
|
274
274
|
}, v = m?.map((C) => C.chartConfigId === i.chartConfigId ? i : C);
|
|
275
|
-
|
|
275
|
+
f(v);
|
|
276
276
|
}
|
|
277
277
|
}
|
|
278
278
|
) : /* @__PURE__ */ o.jsx(X, { variant: h, defaultValue: r ? r[r.findIndex((l) => l.chartConfigId === e.chartConfigId)].columnId.map((l) => e.allowedColumnIds[e.allowedColumnIds.findIndex((i) => i.value === l)]).map((l) => l.value) : [], onValueChange: (l) => {
|
|
@@ -280,7 +280,7 @@ function We(D) {
|
|
|
280
280
|
columnId: l || [],
|
|
281
281
|
chartConfigId: e.chartConfigId
|
|
282
282
|
}, v = m?.map((C) => C.chartConfigId === i.chartConfigId ? i : C);
|
|
283
|
-
|
|
283
|
+
f(v);
|
|
284
284
|
}, children: e.allowedColumnIds.map((l, i) => /* @__PURE__ */ o.jsx(Y, { label: l.label, value: l.label }, i)) }) : e.ui !== "radio" ? /* @__PURE__ */ o.jsx(
|
|
285
285
|
k,
|
|
286
286
|
{
|
|
@@ -296,7 +296,7 @@ function We(D) {
|
|
|
296
296
|
columnId: l?.value,
|
|
297
297
|
chartConfigId: e.chartConfigId
|
|
298
298
|
}, v = m?.map((C) => C.chartConfigId === i.chartConfigId ? i : C);
|
|
299
|
-
x(W(b, v)),
|
|
299
|
+
x(W(b, v)), f(v);
|
|
300
300
|
}
|
|
301
301
|
}
|
|
302
302
|
) : /* @__PURE__ */ o.jsx(U, { variant: h, defaultValue: r ? e.allowedColumnIds[e.allowedColumnIds.findIndex((l) => l.value === r[r.findIndex((i) => i.chartConfigId === e.chartConfigId)].columnId)].label : "", onValueChange: (l) => {
|
|
@@ -304,13 +304,13 @@ function We(D) {
|
|
|
304
304
|
columnId: e.allowedColumnIds[e.allowedColumnIds.findIndex((F) => F.label === l)].value,
|
|
305
305
|
chartConfigId: e.chartConfigId
|
|
306
306
|
}, C = m?.map((F) => F.chartConfigId === v.chartConfigId ? v : F);
|
|
307
|
-
x(W(b, C)),
|
|
307
|
+
x(W(b, C)), f(C);
|
|
308
308
|
}, children: e.allowedColumnIds.map((l, i) => /* @__PURE__ */ o.jsx(B, { label: l.label, value: l.label }, i)) })
|
|
309
309
|
] }, n)),
|
|
310
310
|
A?.map((e, n) => /* @__PURE__ */ o.jsxs("div", { style: {
|
|
311
311
|
width: e.width || `calc(${100 / c}% - ${(c - 1) / c}rem)`,
|
|
312
|
-
flexGrow: 1,
|
|
313
|
-
flexShrink: 0,
|
|
312
|
+
flexGrow: e.width ? 0 : 1,
|
|
313
|
+
flexShrink: e.ui !== "radio" || e.width ? 0 : 1,
|
|
314
314
|
minWidth: "240px"
|
|
315
315
|
}, className: "pb-4", children: [
|
|
316
316
|
/* @__PURE__ */ o.jsx(M, { className: "mb-2", children: e.label }),
|
|
@@ -329,13 +329,13 @@ function We(D) {
|
|
|
329
329
|
}, children: "Select all options" }) : null
|
|
330
330
|
] })
|
|
331
331
|
] }, n)),
|
|
332
|
-
|
|
333
|
-
width:
|
|
334
|
-
flexGrow: 1,
|
|
332
|
+
p ? /* @__PURE__ */ o.jsxs("div", { style: {
|
|
333
|
+
width: p.width || `calc(${100 / c}% - ${(c - 1) / c}rem)`,
|
|
334
|
+
flexGrow: p.width ? 0 : 1,
|
|
335
335
|
flexShrink: 0,
|
|
336
336
|
minWidth: "240px"
|
|
337
337
|
}, className: "pb-4", children: [
|
|
338
|
-
/* @__PURE__ */ o.jsx(M, { className: "mb-2", children:
|
|
338
|
+
/* @__PURE__ */ o.jsx(M, { className: "mb-2", children: p.label || "Highlight data" }),
|
|
339
339
|
/* @__PURE__ */ o.jsx(
|
|
340
340
|
k,
|
|
341
341
|
{
|
|
@@ -354,7 +354,7 @@ function We(D) {
|
|
|
354
354
|
label: e,
|
|
355
355
|
value: e
|
|
356
356
|
})),
|
|
357
|
-
defaultValue:
|
|
357
|
+
defaultValue: p.defaultValues?.map((e) => ({
|
|
358
358
|
label: e,
|
|
359
359
|
value: e
|
|
360
360
|
}))
|
|
@@ -362,7 +362,7 @@ function We(D) {
|
|
|
362
362
|
)
|
|
363
363
|
] }) : null
|
|
364
364
|
] }) : null,
|
|
365
|
-
/* @__PURE__ */ o.jsx(Ve, { graph: d, graphData: se, graphDataConfiguration: m, debugMode:
|
|
365
|
+
/* @__PURE__ */ o.jsx(Ve, { graph: d, graphData: se, graphDataConfiguration: m, debugMode: w, readableHeader: j || [], updateFilters: T, settings: {
|
|
366
366
|
...a || {},
|
|
367
367
|
...u,
|
|
368
368
|
graphTitle: void 0,
|