Files
CPLv4.0/pages/_app.tsx
ISA 959b0b1ec2 fix: Die Daten (.js) Kabelüberwachungsseite aktualisieren sich zwar alle paar Sekunden aber die Darstellung des BGT bleibt unverändert.
Bei der Kabelüberwachungsseite werden auch die analoge und digitale Eingänge geladen
2025-05-12 16:17:40 +02:00

81 lines
2.4 KiB
TypeScript

"use client";
// pages/_app.tsx
import { useEffect, useState } from "react";
import { Provider } from "react-redux";
import store, { useAppDispatch } from "../redux/store";
import { loadWindowVariables } from "../utils/loadWindowVariables";
import Header from "../components/header/Header";
import Navigation from "../components/navigation/Navigation";
import Footer from "../components/footer/Footer";
import { setKueData } from "../redux/slices/kueDataSlice";
import "../styles/globals.css";
import { AppProps } from "next/app";
function MyApp({ Component, pageProps }: AppProps) {
return (
<Provider store={store}>
<AppContent Component={Component} pageProps={pageProps} />
</Provider>
);
}
function AppContent({ Component, pageProps }: AppProps) {
const dispatch = useAppDispatch();
const [sessionExpired, setSessionExpired] = useState(false);
useEffect(() => {
let intervalId: NodeJS.Timeout;
const loadAndStoreVariables = async () => {
try {
const { variables, kueData } = await loadWindowVariables();
if (!variables) throw new Error("Sitzungsfehler");
// Nur auf kabelueberwachung.html Redux aktualisieren
if (window.location.pathname.includes("kabelueberwachung")) {
dispatch(setKueData(kueData));
}
setSessionExpired(false);
} catch (error) {
console.error("❌ Fehler beim Laden der Sitzung:", error);
setSessionExpired(true);
}
};
if (typeof window !== "undefined") {
loadAndStoreVariables();
// Nur auf kabelueberwachung.html regelmäßig aktualisieren
if (window.location.pathname.includes("kabelueberwachung")) {
intervalId = setInterval(loadAndStoreVariables, 10000);
}
return () => clearInterval(intervalId);
}
}, []);
return (
<div className="flex flex-col h-screen overflow-hidden">
<Header />
<div className="flex flex-grow w-full">
<Navigation className="w-56" />
<main className="w-full flex-grow">
{sessionExpired && (
<div className="bg-red-500 text-white p-4 text-center">
Ihre Sitzung ist abgelaufen oder die Verbindung ist
unterbrochen. Bitte laden Sie die Seite neu.
</div>
)}
<Component {...pageProps} />
</main>
</div>
<Footer />
</div>
);
}
export default MyApp;