Files
traque/traque-front/context/adminConnexionContext.jsx
2024-03-26 14:35:10 +01:00

40 lines
1.1 KiB
JavaScript

"use client";
import { createContext, useContext, useEffect, useMemo, useState } from "react";
import { useSocket } from "./socketContext";
import { useSocketListener } from "@/hook/useSocketListener";
import { useLocalStorage } from "@/hook/useLocalStorage";
const adminContext = createContext();
const AdminConnexionProvider = ({ children }) => {
const [loggedIn, setLoggedIn] = useState(false);
const [savedPassword, setSavedPassword] = useLocalStorage("admin_password", null);
const { adminSocket } = useSocket();
useEffect(() => {
if (savedPassword && !loggedIn) {
adminSocket.emit("login", savedPassword);
}
}, [savedPassword]);
function login(password) {
setSavedPassword(password)
}
useSocketListener(adminSocket, "login_response", setLoggedIn);
const value = useMemo(() => ({ login, loggedIn }), [loggedIn]);
return (
<adminContext.Provider value={value}>
{children}
</adminContext.Provider>
);
}
function useAdminConnexion() {
return useContext(adminContext);
}
export { AdminConnexionProvider, useAdminConnexion };