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:
ISA
2024-11-18 07:58:55 +01:00
parent 92d1310bca
commit ade87db2cf
2 changed files with 17 additions and 14 deletions

View File

@@ -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);
} }
} }
}, []); }, []);

View File

@@ -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") {