deviceName in Header bekommt die Name und nicht mehr lädt.. oder unbekannt
This commit is contained in:
@@ -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);
|
||||||
|
|||||||
Reference in New Issue
Block a user