"use client"; import { useEffect, useState } from "react"; import { createClient, isSupabaseConfigured } from "@/lib/supabase/client"; import Link from "next/link"; import type { User } from "@supabase/supabase-js"; interface Profile { display_name?: string | null; total_cost_usd?: number; budget_cap_usd?: number; daily_used?: number; daily_quota?: number; } export function AuthBar() { const [user, setUser] = useState(null); const [profile, setProfile] = useState(null); const [loaded, setLoaded] = useState(false); useEffect(() => { if (!isSupabaseConfigured()) { setLoaded(true); return; } const supabase = createClient(); supabase.auth.getUser().then(({ data }) => { setUser(data.user); setLoaded(true); if (data.user) { fetch("/api/me") .then((r) => (r.ok ? r.json() : null)) .then((d) => setProfile(d?.profile ?? null)) .catch(() => {}); } }); const { data: sub } = supabase.auth.onAuthStateChange((_e, session) => { setUser(session?.user ?? null); }); return () => sub.subscription.unsubscribe(); }, []); if (!loaded) return null; if (!isSupabaseConfigured()) { return (
auth: disabled (dev)
); } if (!user) { return ( sign in ); } return (
{profile && (
{profile.display_name ?? user.email}
${(profile.total_cost_usd ?? 0).toFixed(2)} / ${(profile.budget_cap_usd ?? 0).toFixed(2)} ยท{" "} {profile.daily_used ?? 0}/{profile.daily_quota ?? 0} msgs today
)}
); }