import React, { useState } from "react"; import KueModal from "../modales/KueModal"; function Kue705FO({ isolationswert, // Übergabeparameter für den Isolationswert schleifenwiderstand, // Übergabeparameter für den Schleifenwiderstand modulName, // Übergabeparameter für den Modulnamen kueVersion = "V4.19", // Optionaler Parameter für die Version (Standardwert) kueOnline, // Array für den Modulstatus (1: Modul vorhanden, 0: kein Modul) slotIndex, // Der Index des Slots, für den die Anzeige gilt tdrLocation, // Wert für die TDR-Entfernung }) { const [activeButton, setActiveButton] = useState("Schleife"); const [displayText, setDisplayText] = useState("Schleifenwiderstand [kOhm]"); const [loading, setLoading] = useState(false); const [currentDisplayValue, setCurrentDisplayValue] = useState( schleifenwiderstand || "0" ); // Wert, der im unteren Display angezeigt wird //--Modales Fenster const [showModal, setShowModal] = useState(false); const handleOpenModal = () => { setShowModal(true); }; const handleCloseModal = () => { setShowModal(false); }; //---- // Funktion zum Wechseln der Buttons und Anpassen des Anzeigewerts const handleButtonClick = (button) => { if (button === "Schleife") { setActiveButton("Schleife"); setDisplayText("Schleifenwiderstand [kOhm]"); setCurrentDisplayValue(schleifenwiderstand || "0"); } else if (button === "TDR") { setActiveButton("TDR"); setDisplayText("Entfernung [Km]"); setCurrentDisplayValue(tdrLocation || "0"); } }; // Funktion für die TDR-Messung const goTDR = () => { let slot = slotIndex; // Verwende direkt slotIndex, da Slot 0 der erste Slot ist if (slot >= 32) { return; } let slotFormat = slot < 10 ? `0${slot}` : `${slot}`; const apiUrl = process.env.NEXT_PUBLIC_API_BASE_URL; setLoading(true); // Ladezustand setzen fetch( `${apiUrl}/CPL?Service/KUEdetailTDR.ACP&KTT${slotFormat}=1&slot=${slot}`, { method: "GET", } ) .then((response) => { if (response.ok) { console.log("TDR erfolgreich gestartet für Slot", slot); } else { console.error("Fehler beim Senden der TDR-Anfrage"); } }) .catch((error) => { console.error("Fehler:", error); }) .finally(() => setLoading(false)); // Ladezustand wieder deaktivieren }; // Funktion für die Schleifenmessung const goLoop = () => { let slot = slotIndex; // Verwende direkt slotIndex if (slot >= 32) { return; } let slotFormat = slot < 10 ? `0${slot}` : `${slot}`; const apiUrl = process.env.NEXT_PUBLIC_API_BASE_URL; setLoading(true); // Ladezustand setzen fetch( `${apiUrl}/CPL?Service/KUEdetail.HTML&KS_${slotFormat}=1&slot=${slot}`, { method: "GET", } ) .then((response) => { if (response.ok) { console.log("Schleifenmessung erfolgreich gestartet für Slot", slot); } else { console.error("Fehler beim Senden der Schleifen-Anfrage"); } }) .catch((error) => { console.error("Fehler:", error); }) .finally(() => setLoading(false)); // Ladezustand wieder deaktivieren }; // Überprüfe, ob ein Modul im Slot vorhanden ist const isModulPresent = kueOnline[slotIndex] === 1; // 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 } }; return (
{isModulPresent ? ( <>
{slotIndex}

KÜ705-FO

{/* Modal */}

Modul Einstellungen

Hier kannst du Einstellungen für {modulName} vornehmen.

Betrieb
Alarm
{isolationswert || ">200"}
ISO MOhm
{modulName || "Test1"}
{kueVersion}
{displayText} {/* Unterer Bereich, der den dynamischen Wert anzeigt */}

{currentDisplayValue}

{/* Buttons für Schleife und TDR */}
) : (

Kein Modul im Slot {slotIndex}

)}
); } export default Kue705FO;