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({ 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 ( {children} ); }; export const useUser = () => useContext(UserContext);