import format from 'date-fns/format'; import { FC, useRef } from 'react'; import { DownloadOutlined } from '@ant-design/icons'; import { Chart as ChartJS, CategoryScale, LinearScale, PointElement, LineElement, Title, Tooltip, Legend, LogarithmicScale, ChartOptions, } from 'chart.js'; import { Line } from 'react-chartjs-2'; import { Button } from 'antd'; ChartJS.register( CategoryScale, LogarithmicScale, LinearScale, PointElement, LineElement, Title, Tooltip, Legend, ); interface TimedValue { time: Date; value: number; pointStyle?: boolean | string; pointRadius?: number; } export type ChartProps = { data?: TimedValue[]; title?: string; color: string; unit: string; yFlipped?: boolean; yLogarithmic?: boolean; dataCollections?: any[]; minYValue?: number; yStepSize?: number; }; function createGraphDataset(dataArray) { const dataValues = {}; dataArray.forEach(item => { const dateObject = new Date(item.time); const dateString = format(dateObject, 'H:mma'); dataValues[dateString] = item.value; }); return dataValues; } export const Chart: FC = ({ data, title, color, unit, dataCollections, yFlipped, yLogarithmic, minYValue, yStepSize = 0, }) => { const renderData = []; const chartRef = useRef(null); const downloadChart = () => { if (chartRef.current) { const link = document.createElement('a'); link.download = 'chart.png'; link.href = chartRef.current.canvas.toDataURL(); link.click(); } }; if (data && data.length > 0) { renderData.push({ id: title, label: title, backgroundColor: color, borderColor: color, borderWidth: 3, data: createGraphDataset(data), }); } dataCollections.forEach(collection => { renderData.push({ id: collection.name, label: collection.name, data: createGraphDataset(collection.data), backgroundColor: collection.color, borderColor: collection.color, borderWidth: 3, pointStyle: collection.pointStyle || 'circle', radius: collection.pointRadius || 1, }); }); const options = { responsive: true, clip: false, scales: { y: { type: yLogarithmic ? ('logarithmic' as const) : ('linear' as const), reverse: yFlipped, min: minYValue, ticks: { stepSize: yStepSize, }, title: { display: true, text: unit, }, }, }, }; return (
} height="70vh" />
); }; Chart.defaultProps = { dataCollections: [], data: [], title: '', yFlipped: false, yLogarithmic: false, };