import React, { useEffect, useRef } from "react"; import { useSelector } from "react-redux"; import { RootState } from "../../../redux/store"; import Chart from "chart.js/auto"; import "chartjs-adapter-date-fns"; import { parseISO } from "date-fns"; const TDRChart: React.FC = () => { const chartRef = useRef(null); const chartInstance = useRef(null); const chartData = useSelector((state: RootState) => state.chartData.data); useEffect(() => { if (chartRef.current && chartData.length > 0) { if (chartInstance.current) { chartInstance.current.destroy(); } const ctx = chartRef.current.getContext("2d"); if (ctx) { chartInstance.current = new Chart(ctx, { type: "line", data: { labels: chartData.map((entry) => parseISO(entry.timestamp)), datasets: [ { label: "Isolationswiderstand (MOhm)", data: chartData.map((entry) => entry.isolation ?? 0), borderColor: "rgba(0, 123, 255, 1)", backgroundColor: "rgba(0, 123, 255, 0.2)", tension: 0.1, }, ], }, options: { responsive: true, maintainAspectRatio: false, scales: { x: { type: "time", time: { unit: "hour", tooltipFormat: "dd.MM.yyyy HH:mm", }, title: { display: true, text: "Zeit" }, }, y: { title: { display: true, text: "MOhm" }, min: 0, max: Math.max(...chartData.map((entry) => entry.isolation ?? 1)) + 10, }, }, }, }); } } return () => { if (chartInstance.current) { chartInstance.current.destroy(); chartInstance.current = null; } }; }, [chartData]); return ; }; export default TDRChart;