import React, { useEffect, useState } from "react"; import classnames from "classnames"; import HighchartsReact from "highcharts-react-official"; import highchartsMore from "highcharts/highcharts-more"; import { highchartsTheme } from "../pb_dashboard/pbChartsLightTheme"; import { highchartsDarkTheme } from "../pb_dashboard/pbChartsDarkTheme"; import mapColors from "../pb_dashboard/pbChartsColorsHelper"; import { globalProps } from "../utilities/globalProps"; import { buildAriaProps, buildDataProps } from "../utilities/props"; type CircleChartProps = { align?: "left" | "right" | "center", aria: { [key: string]: string }, chartData?: [], children?: Node, className?: string, colors?: string[], dark?: Boolean, data?: Object, dataLabelHtml?: string, dataLabels?: boolean, height?: string, id?: string, innerSize?: "sm" | "md" | "lg" | "none", legend?: boolean, maxPointSize?: number, minPointSize?: number, rounded?: boolean, startAngle?: number, style?: string, title?: string, tooltipHtml: string, useHtml?: boolean, zMin?: number, layout?: "horizontal" | "vertical" | "proximate", verticalAlign?: "top" | "middle" | "bottom", x?: number, y?: number, borderColor?: string, borderWidth?: number, }; // Adjust Circle Chart Block Kit Dimensions to Match the Chart for Centering const alignBlockElement = (event: any) => { const itemToMove = document.querySelector( `#wrapper-circle-chart-${event.target.renderTo.id} .pb-circle-chart-block` ) as HTMLElement; const chartContainer = document.querySelector(`#${event.target.renderTo.id}`); if (itemToMove !== null) { itemToMove.style.height = `${event.target.chartHeight}px`; itemToMove.style.width = `${event.target.chartWidth}px`; chartContainer.firstChild.before(itemToMove); } }; const CircleChart = ({ align = "center", aria = {}, rounded = false, borderColor = rounded ? null : "", borderWidth = rounded ? 20 : null, chartData, children, className, colors = [], dark = false, data = {}, dataLabelHtml = "
{point.name}
", dataLabels = false, height, id, innerSize = "md", legend = false, maxPointSize = null, minPointSize = null, startAngle = null, style = "pie", title, tooltipHtml, useHtml = false, zMin = null, layout = "horizontal", verticalAlign = "bottom", x = 0, y = 0, ...props }: CircleChartProps) => { const ariaProps = buildAriaProps(aria); const dataProps = buildDataProps(data); const innerSizes = { sm: "35%", md: "50%", lg: "85%", none: "0%" }; const innerSizeFormat = (size: "sm" | "md" | "lg" | "none") => innerSizes[size]; const [options, setOptions] = useState({}); const [isHighchartsLoaded, setIsHighchartsLoaded] = useState(false); useEffect(() => { const formattedChartData = chartData.map((obj: any) => { obj.y = obj.value; delete obj.value; return obj; }); const staticOptions = { title: { text: title, }, chart: { height: height, type: style, events: { render: (event: any) => alignBlockElement(event), redraw: (event: any) => alignBlockElement(event), }, }, legend: { align: align, verticalAlign: verticalAlign, layout: layout, x: x, y: y, }, plotOptions: { pie: { colors: colors.length > 0 ? mapColors(colors) : highchartsTheme.colors, dataLabels: { enabled: dataLabels, connectorShape: "straight", connectorWidth: 3, format: dataLabelHtml, }, showInLegend: legend, }, }, series: [ { minPointSize: minPointSize, maxPointSize: maxPointSize, innerSize: borderWidth == 20 ? "100%" : innerSizeFormat(innerSize), data: formattedChartData, zMin: zMin, startAngle: startAngle, borderWidth: borderWidth, borderColor: borderColor, }, ], credits: false, }; setOptions({ ...staticOptions }); const interval = setInterval(() => { if (window.Highcharts) { clearInterval(interval) dark ? window.Highcharts.setOptions(highchartsDarkTheme) : window.Highcharts.setOptions(highchartsTheme) highchartsMore(window.Highcharts); window.Highcharts.setOptions({ tooltip: { headerFormat: null, pointFormat: tooltipHtml ? tooltipHtml : '{point.name}: ' + "{point.y}", useHTML: useHtml, }, }); setIsHighchartsLoaded(true) } }, 0) }, [chartData]); return ( <> {children ? (
{ isHighchartsLoaded && }
{children}
) : ( isHighchartsLoaded && )} ); }; export default CircleChart;