deviceName in Header bekommt die Name und nicht mehr lädt.. oder unbekannt

This commit is contained in:
ISA
2024-10-30 07:54:07 +01:00
parent ce30d205bf
commit d151a3d1df

View File

@@ -1,4 +1,3 @@
// components/Header.jsx
"use client"; "use client";
import React, { useEffect, useState } from "react"; import React, { useEffect, useState } from "react";
import Image from "next/image"; import Image from "next/image";
@@ -10,19 +9,22 @@ function Header() {
const [cplStatus, setCplStatus] = useState("Lädt..."); const [cplStatus, setCplStatus] = useState("Lädt...");
const [showSettingsModal, setShowSettingsModal] = useState(false); const [showSettingsModal, setShowSettingsModal] = useState(false);
// Flag außerhalb des State-Managements, um die Ausgabe nur einmal zu loggen // Flag außerhalb der Funktion, um die Werte nur einmal zu setzen
let variablesLogged = false; let variablesLogged = false;
useEffect(() => { useEffect(() => {
const interval = setInterval(() => { const checkVariablesLoaded = async () => {
if (localStorage.getItem("variablesLoaded") === "true") { if (window.deviceName) {
// Lade die Werte nur, wenn die Variablen tatsächlich geladen wurden setStationsname(window.deviceName);
setStationsname(window.deviceName || "Unbekannt"); } else {
setCplStatus(window.hardware_version || "Unbekannt"); // Falls die Variablen noch nicht geladen sind, erneut prüfen nach 3000 ms
clearInterval(interval); // Beende das Intervall, sobald die Werte gesetzt sind await new Promise((resolve) => setTimeout(resolve, 3000));
checkVariablesLoaded(); // Erneut aufrufen, wenn noch nicht geladen
} }
}, 500); // Prüfe das Flag alle 500 ms };
return () => clearInterval(interval); checkVariablesLoaded(); // Startet die erste Überprüfung
// Kein Cleanup erforderlich, da `setTimeout` nur bei Bedarf ausgeführt wird
}, []); }, []);
const handleSettingsClick = () => setShowSettingsModal(true); const handleSettingsClick = () => setShowSettingsModal(true);