import React, { createContext, useContext, useState, useEffect } from 'react';
const AuthContext = createContext();
export function useAuth() {
const context = useContext(AuthContext);
if (!context) {
throw new Error('useAuth must be used within an AuthProvider');
}
return context;
}
export function AuthProvider({ children }) {
const [token, setToken] = useState(localStorage.getItem('token'));
const [isAuthenticated, setIsAuthenticated] = useState(!!token);
useEffect(() => {
if (token) {
localStorage.setItem('token', token);
setIsAuthenticated(true);
} else {
localStorage.removeItem('token');
setIsAuthenticated(false);
}
}, [token]);
const login = (newToken) => {
setToken(newToken);
};
const logout = () => {
setToken(null);
};
return (
<AuthContext.Provider value={{ token, isAuthenticated, login, logout }}>
{children}
</AuthContext.Provider>
);
}