import { createContext, useContext, useEffect, useState, ReactNode } from "react"; import type { Session, User } from "@supabase/supabase-js"; import { supabase } from "@/integrations/supabase/client"; type AuthContextType = { user: User | null; session: Session | null; loading: boolean; signOut: () => Promise; }; const AuthContext = createContext({ user: null, session: null, loading: true, signOut: async () => {}, }); export function AuthProvider({ children }: { children: ReactNode }) { const [session, setSession] = useState(null); const [user, setUser] = useState(null); const [loading, setLoading] = useState(true); useEffect(() => { // Set up listener FIRST const { data: sub } = supabase.auth.onAuthStateChange((_event, sess) => { setSession(sess); setUser(sess?.user ?? null); }); // THEN fetch existing session supabase.auth.getSession().then(({ data: { session: sess } }) => { setSession(sess); setUser(sess?.user ?? null); setLoading(false); }); return () => sub.subscription.unsubscribe(); }, []); const signOut = async () => { await supabase.auth.signOut(); }; return ( {children} ); } export const useAuth = () => useContext(AuthContext);