// @flow strict import * as React from 'react'; //$FlowFixMe[untyped-import] import Highcharts from 'highcharts'; //$FlowFixMe[untyped-import] import highChartsMore from 'highcharts/highcharts-more'; //$FlowFixMe[untyped-import] import HighchartsReact from 'highcharts-react-official'; import type {ChartOptions, DataOptionsType} from '../../../types/charts'; import { getDataVizColor, getSpiderChartOptions, mergeChartUserOptions, } from '../../../utils/charts'; import classify from '../../../utils/classify'; import { type ChartWrapperClassNames, type ExportOptionType, ChartWrapper, } from '../ChartWrapper'; import css from './SpiderChart.module.css'; if ( !!highChartsMore && !!Highcharts && typeof highChartsMore === 'function' && typeof Highcharts === 'object' ) { highChartsMore(Highcharts); } export type ClassNames = $ReadOnly<{ ...ChartWrapperClassNames, highChart?: string, }>; export type SpiderSeriesItem = { name: string, data: DataOptionsType[], }; export type SpiderChartProps = { ...ChartOptions, isLoading?: boolean, classNames?: ClassNames, cardTitle?: React.Node, customExportOptions?: Array | null, headerActions?: React.Node, series: Array, hasEmptyData?: boolean, emptyText?: React.Node, ... }; export const SpiderChart = ({ isLoading, classNames, cardTitle, customExportOptions, headerActions, series, hasEmptyData, emptyText, ...userOptions }: SpiderChartProps): React.Node => { const chartRef = React.useRef(null); const spiderSeries = series.map((seriesItem, index) => ({ ...seriesItem, name: seriesItem.name, data: seriesItem.data, pointPlacement: 'on', color: getDataVizColor(index), })); const defaultSpiderChartOptions = getSpiderChartOptions(); //$FlowFixMe[cannot-spread-inexact] const chartOptions = mergeChartUserOptions(defaultSpiderChartOptions, { series: spiderSeries, ...userOptions, }); const {highChart, ...wrapperClassNames} = classNames || {}; return ( ); };