"use client"; // components/modules/Kue705FO.jsx import React, { useState, useEffect } from "react"; import ReactModal from "react-modal"; import Chart from "chart.js/auto"; import { useSelector } from "react-redux"; import KueModal from "../modales/KueModal"; import "bootstrap-icons/font/bootstrap-icons.css"; // Import Bootstrap Icons function Kue705FO({ isolationswert, schleifenwiderstand, modulName, kueOnline, slotIndex, tdrLocation, alarmStatus, }) { const [kueVersion, setKueVersion] = useState("V4.19"); const [currentAlarmStatus, setCurrentAlarmStatus] = useState(false); const [currentModulName, setCurrentModulName] = useState(modulName); const [activeButton, setActiveButton] = useState("Schleife"); const [loopTitleText, setloopTitleText] = useState( "Schleifenwiderstand [kOhm]" ); const [isoDisplayText, setIsoDisplayText] = useState("Aderbruch"); const [groundFaultDisplayText, setGroundFaultDisplayText] = useState("Erdschluss"); const [loopFaultDisplayText, setLoopFaultDisplayText] = useState("Schleifenfehler"); const [isoFaultDisplayText, setIsoFaultDisplayText] = useState("Isolationsfehler"); const [isoGreaterThan200, setIsoGreaterThan200] = useState(">200 MOhm"); const [loading, setLoading] = useState(false); const [currentDisplayValue, setCurrentDisplayValue] = useState( schleifenwiderstand || "0" ); const [showModal, setShowModal] = useState(false); const [showChartModal, setShowChartModal] = useState(false); const [chartData, setChartData] = useState(null); // Redux-Variablen abrufen const { kuePSTmMinus96V, kueCableBreak, kueGroundFault, kueAlarm1, kueAlarm2, kueOverflow, kueVersion: reduxKueVersion, tdrActive, } = useSelector((state) => state.variables); const handleOpenModal = () => setShowModal(true); const handleCloseModal = () => setShowModal(false); const handleOpenChartModal = () => { setShowChartModal(true); if (activeButton === "TDR") { loadTDRChartData(); } else { loadLoopChartData(); } }; const handleButtonClick = (button) => { if (button === "Schleife") { setActiveButton("Schleife"); setloopTitleText("Schleifenwiderstand [kOhm]"); setCurrentDisplayValue(schleifenwiderstand || "0"); } else if (button === "TDR") { setActiveButton("TDR"); setloopTitleText("Entfernung [Km]"); setCurrentDisplayValue(tdrLocation || "0"); } }; // Funktion für die Schleifenmessung const goLoop = () => { let slot = slotIndex; if (slot >= 32) { return; } let slotFormat = slot < 10 ? `0${slot}` : `${slot}`; setLoading(true); // Setze den Ladezustand auf true alert(`Schleifenmessung wird für Slot ${slot + 1} gestartet...`); fetch(`/CPL?Service/KUEdetail.HTML&KS_${slotFormat}=1&slot=${slot}`, { method: "GET", }) .then((response) => { if (response.ok) { alert(`Schleifenmessung erfolgreich gestartet für Slot ${slot + 1}`); console.log("Schleifenmessung erfolgreich gestartet für Slot", slot); } else { alert("Fehler beim Starten der Schleifenmessung."); console.error("Fehler beim Senden der Schleifen-Anfrage"); } }) .catch((error) => { alert("Ein Fehler ist aufgetreten."); console.error("Fehler:", error); }) .finally(() => setLoading(false)); // Ladezustand zurücksetzen }; // Funktion für die TDR-Messung const goTDR = () => { //------------------------------------------------- /* const [isClient, setIsClient] = useState(false); useEffect(() => { // This will only run in the client/browser, not on the server setIsClient(true); }, []); if (!isClient) { return null; // or a loading spinner } */ //------------------------------------------------- let slot = slotIndex; if (slot >= 32) { return; } let slotFormat = slot < 10 ? `0${slot}` : `${slot}`; setLoading(true); alert(`TDR wird für Slot ${slot + 1} gestartet...`); fetch(`/CPL?Service/KUEdetailTDR.ACP&KTT${slotFormat}=1&slot=${slot}`, { method: "GET", }) .then((response) => { if (response.ok) { alert(`TDR erfolgreich gestartet für Slot ${slot + 1}`); console.log("TDR erfolgreich gestartet für Slot", slot + 1); } else { console.error("Fehler beim Senden der TDR-Anfrage"); } }) .catch((error) => { console.error("Fehler:", error); }) .finally(() => setLoading(false)); }; // Bestimme, welche Funktion ausgeführt wird, basierend auf dem aktiven Button const handleRefreshClick = () => { if (activeButton === "Schleife") { goLoop(); // Wenn Schleife aktiv ist, starte goLoop } else if (activeButton === "TDR") { goTDR(); // Wenn TDR aktiv ist, starte goTDR } }; const handleCloseChartModal = () => setShowChartModal(false); const loadTDRChartData = () => { const slot = slotIndex; const environment = process.env.NODE_ENV || "production"; const fileData = environment === "production" ? `/CPL?/CPL/lastTDR/slot${slot}.json` : `/CPLmockData/lastTDR/slot${slot}.json`; fetch(fileData) .then((response) => response.json()) .then((data) => { setChartData(data); createTDRChart(data); }) .catch((error) => console.error("Fehler beim Laden der TDR-Messkurvendaten:", error) ); }; const loadLoopChartData = () => { const slot = slotIndex; const environment = process.env.NODE_ENV || "production"; const fileData = environment === "production" ? `/CPL?/CPL/4000values/slot${slot}.json` : `/CPLmockData/4000values/slot${slot}.json`; fetch(fileData) .then((response) => response.json()) .then((data) => { setChartData(data); createChart(data, "Schleifenmesskurve"); }) .catch((error) => console.error("Fehler beim Laden der Schleifenmesskurvendaten:", error) ); }; const createChart = (data) => { const ctx = document.getElementById("myChart").getContext("2d"); new Chart(ctx, { type: "line", data: { labels: data .map((row) => new Date(row.t).toLocaleString("de-DE")) .reverse(), datasets: [ { label: "Isolationswiderstand (MOhm)", data: data.map((row) => row.m).reverse(), borderColor: "#00AEEF", fill: false, yAxisID: "y", }, { label: "Schleifenwiderstand (kOhm)", data: data.map((row) => row.n).reverse(), borderColor: "black", fill: false, yAxisID: "y1", }, ], }, options: { scales: { y: { type: "linear", position: "left", title: { display: true, text: "MOhm" }, }, y1: { type: "linear", position: "right", title: { display: true, text: "kOhm" }, }, }, }, }); }; useEffect(() => { const updateAlarmStatus = () => { const alarmStatus = (kueAlarm1 && kueAlarm1[slotIndex]) || (kueAlarm2 && kueAlarm2[slotIndex]) || (kueCableBreak && kueCableBreak[slotIndex]) || (kueGroundFault && kueGroundFault[slotIndex]); setCurrentAlarmStatus(alarmStatus); }; updateAlarmStatus(); const interval = setInterval(updateAlarmStatus, 10000); return () => clearInterval(interval); }, [slotIndex, kueAlarm1, kueAlarm2, kueCableBreak, kueGroundFault]); useEffect(() => { const updateDisplay = () => { if (kuePSTmMinus96V?.[slotIndex] === 1) { setCurrentDisplayValue("PST-M prüfen"); return; } if (kueCableBreak?.[slotIndex] === 1) { setCurrentDisplayValue(isoDisplayText); return; } if (kueGroundFault?.[slotIndex] === 1) { setCurrentDisplayValue(groundFaultDisplayText); return; } if (kueAlarm1?.[slotIndex] === 1) { setCurrentDisplayValue(isoFaultDisplayText); return; } if (kueAlarm2?.[slotIndex] === 1) { setCurrentDisplayValue(loopFaultDisplayText); return; } if (kueOverflow?.[slotIndex] === 1) { setCurrentDisplayValue(isoGreaterThan200); return; } setCurrentDisplayValue(isolationswert); }; updateDisplay(); const interval = setInterval(updateDisplay, 5000); return () => clearInterval(interval); }, [ slotIndex, isolationswert, kuePSTmMinus96V, kueCableBreak, kueGroundFault, kueAlarm1, kueAlarm2, kueOverflow, ]); useEffect(() => { if (reduxKueVersion?.[slotIndex]) { setKueVersion("V" + reduxKueVersion[slotIndex] / 100); } }, [slotIndex, reduxKueVersion]); return (
{schleifenwiderstand + " KOhm"}
Kein Modul im Slot {slotIndex + 1}