// components/main/kabelueberwachung/kue705FO/Charts/TDRChart/TDRChart.tsx import React, { useEffect, useRef } from "react"; import { useSelector } from "react-redux"; import { Chart, registerables } from "chart.js"; import "chartjs-adapter-date-fns"; const TDRChart: React.FC = () => { const chartRef = useRef(null); const chartInstance = useRef(null); // TDR-Daten aus dem Redux Store selektieren const chartData = useSelector((state: any) => state.tdrData.data); useEffect(() => { // Importiere und registriere das Zoom-Plugin innerhalb des useEffect-Hooks import("chartjs-plugin-zoom").then((zoomPlugin) => { Chart.register(...registerables, zoomPlugin.default); 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: { datasets: [ { label: "TDR Entfernung (km)", data: chartData, borderColor: "rgba(255, 99, 132, 1)", backgroundColor: "rgba(255, 99, 132, 0.2)", tension: 0.1, parsing: { xAxisKey: "t", // Schlüssel für den Zeitstempel yAxisKey: "m", // Schlüssel für den Messwert }, }, ], }, options: { responsive: true, maintainAspectRatio: false, scales: { x: { type: "linear", // Lineare Skalierung für numerische Daten title: { display: true, text: "Entfernung (m)", }, }, y: { title: { display: true, text: "Pegel", }, }, }, plugins: { zoom: { pan: { enabled: true, mode: "xy", }, zoom: { wheel: { enabled: true, }, pinch: { enabled: true, }, mode: "xy", }, }, }, }, }); } } }); }, [chartData]); return (
); }; export default TDRChart;