feat: Entfernen der Redux-Abhängigkeit für Admin-Login in der Header-Komponente
- Redux-State durch lokalen useState für `isAdminLoggedIn` ersetzt. - Token-Validierung über sessionStorage mit useEffect hinzugefügt. - Alle Redux-Selectoren entfernt und unnötige Importe bereinigt. - Verbesserte Fehlerbehandlung bei der Token-Verarbeitung, um Abstürze zu vermeiden. - Logout-Funktionalität vereinfacht, indem sessionStorage direkt geleert wird.
This commit is contained in:
@@ -4,33 +4,36 @@ import Image from "next/image";
|
|||||||
import { useRouter } from "next/router";
|
import { useRouter } from "next/router";
|
||||||
import "bootstrap-icons/font/bootstrap-icons.css";
|
import "bootstrap-icons/font/bootstrap-icons.css";
|
||||||
import SettingsModal from "./modales/settingsModal/SettingsModal";
|
import SettingsModal from "./modales/settingsModal/SettingsModal";
|
||||||
import { useSelector } from "react-redux";
|
|
||||||
|
|
||||||
function Header() {
|
function Header() {
|
||||||
const isAdminLoggedIn = useSelector((state) => state.auth.isAdminLoggedIn);
|
|
||||||
const router = useRouter();
|
const router = useRouter();
|
||||||
const deviceName = useSelector((state) => state.variables.deviceName);
|
|
||||||
const [showSettingsModal, setShowSettingsModal] = useState(false);
|
const [showSettingsModal, setShowSettingsModal] = useState(false);
|
||||||
//const [isAdminLoggedIn, setIsAdminLoggedIn] = useState(false);
|
const [isAdminLoggedIn, setIsAdminLoggedIn] = useState(false); // Lokaler Zustand
|
||||||
|
const deviceName = "Station XY"; // Dummy-Daten, da Redux entfernt wurde
|
||||||
|
|
||||||
const handleSettingsClick = () => setShowSettingsModal(true);
|
const handleSettingsClick = () => setShowSettingsModal(true);
|
||||||
const handleCloseSettingsModal = () => setShowSettingsModal(false);
|
const handleCloseSettingsModal = () => setShowSettingsModal(false);
|
||||||
const handleLogout = () => {
|
const handleLogout = () => {
|
||||||
localStorage.removeItem("token"); // Token entfernen beim Abmelden
|
sessionStorage.removeItem("token"); // Token entfernen beim Abmelden
|
||||||
//setIsAdminLoggedIn(false);
|
setIsAdminLoggedIn(false); // Admin-Status zurücksetzen
|
||||||
window.location.href = "/offline.html";
|
window.location.href = "/offline.html";
|
||||||
};
|
};
|
||||||
|
|
||||||
// Funktion, um den Token-Status zu prüfen
|
// Funktion, um den Token-Status zu prüfen
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const token = localStorage.getItem("token");
|
const token = sessionStorage.getItem("token");
|
||||||
if (token) {
|
if (token) {
|
||||||
const { exp } = JSON.parse(atob(token));
|
try {
|
||||||
if (Date.now() < exp) {
|
const { exp } = JSON.parse(atob(token));
|
||||||
//setIsAdminLoggedIn(true);
|
if (Date.now() < exp) {
|
||||||
} else {
|
setIsAdminLoggedIn(true); // Admin eingeloggt
|
||||||
localStorage.removeItem("token"); // Entferne abgelaufenen Token
|
} else {
|
||||||
//setIsAdminLoggedIn(false);
|
sessionStorage.removeItem("token"); // Entferne abgelaufenen Token
|
||||||
|
setIsAdminLoggedIn(false);
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Fehler beim Verarbeiten des Tokens:", error);
|
||||||
|
setIsAdminLoggedIn(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}, []);
|
}, []);
|
||||||
|
|||||||
@@ -97,7 +97,7 @@ function KueModal({ showModal, onClose, slot, onModulNameChange }) {
|
|||||||
}, [showModal]); // nur von showModal abhängig ansonsten wird alle 10 Sekunden die Werte zurückgesetzt in Modal
|
}, [showModal]); // nur von showModal abhängig ansonsten wird alle 10 Sekunden die Werte zurückgesetzt in Modal
|
||||||
//------------------------------------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------------------------------------
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const token = localStorage.getItem("token");
|
const token = sessionStorage.getItem("token");
|
||||||
if (token) {
|
if (token) {
|
||||||
const decoded = decodeToken(token);
|
const decoded = decodeToken(token);
|
||||||
if (decoded && decoded.role === "Admin") {
|
if (decoded && decoded.role === "Admin") {
|
||||||
|
|||||||
Reference in New Issue
Block a user