'use client' import { useSession } from 'next-auth/react' import { useEffect } from 'react' import useUserStore from '../store/userStore' export const AuthProvider = ({ children }: { children: React.ReactNode }) => { const { data: session } = useSession() const { setUser, setAuthenticated } = useUserStore() useEffect(() => { const fetchUserData = async () => { if (!session?.accessToken) { setUser(null) setAuthenticated(false) return } const API_URL = process.env.NEXT_PUBLIC_API_URL try { const response = await fetch(`${API_URL}/account/user/`, { headers: { Authorization: `Bearer ${session.accessToken}`, 'Content-Type': 'application/json', }, }) if (!response.ok) { const errorText = await response.text() console.error('Error response:', errorText) throw new Error(`Error fetching user data: ${response.status} ${errorText}`) } const userData = await response.json() setUser({ id: userData.id, name: userData.name || session.user.name || '', surname: userData.surname || '', email: userData.email || session.user.email || '', image: userData.image, account_type: userData.account_type, login: userData.login, uuid: userData.uuid, }) setAuthenticated(true) } catch (error) { console.error('Error in fetchUserData:', error) } } fetchUserData() }, [session, setUser, setAuthenticated]) return <>{children} }