Website/context/UserContext.tsx

49 lines
1.2 KiB
TypeScript
Raw Normal View History

2024-08-29 13:20:28 +00:00
import { getCookie } from '@/utils/cookies';
import getConfig from 'next/config';
import { createContext, useContext, useEffect, useState } from 'react';
interface UserContextType {
user: any;
isLoggedIn: boolean;
}
const UserContext = createContext<UserContextType>({ user: null, isLoggedIn: false });
export const UserProvider = ({ children }: { children: React.ReactNode }) => {
const [ user, setUser ] = useState(null);
const [ isLoggedIn, setIsLoggedIn ] = useState(false);
const { publicRuntimeConfig } = getConfig();
useEffect(() => {
const fetchUser = async () => {
const sessionCookie = getCookie('session');
if (sessionCookie) {
setIsLoggedIn(true);
try {
const res = await fetch('/api/v1/user/@me');
if (res.ok) {
const userData = await res.json();
setUser(userData);
}
} catch (error) {
console.error('Error fetching user data:', error);
}
}
};
fetchUser();
}, []);
return (
<UserContext.Provider value={{ user, isLoggedIn }}>
{children}
</UserContext.Provider>
);
};
export const useUser = () => useContext(UserContext);