ai-tube / src /app /state /userCurrentUser.ts
jbilcke-hf's picture
jbilcke-hf HF staff
we can now post comments
38d787b
raw
history blame
1.22 kB
import { useEffect, useTransition } from "react"
import { UserInfo } from "@/types"
import { useStore } from "./useStore"
import { useLocalStorage } from "usehooks-ts"
import { localStorageKeys } from "./localStorageKeys"
import { defaultSettings } from "./defaultSettings"
import { getCurrentUser } from "../server/actions/users"
export function useCurrentUser(): UserInfo | undefined {
const [_pending, startTransition] = useTransition()
const currentUser = useStore(s => s.currentUser)
const setCurrentUser = useStore(s => s.setCurrentUser)
const [huggingfaceApiKey] = useLocalStorage<string>(
localStorageKeys.huggingfaceApiKey,
defaultSettings.huggingfaceApiKey
)
useEffect(() => {
startTransition(async () => {
// no key
if (!huggingfaceApiKey) {
setCurrentUser(undefined)
return
}
// already logged-in
if (currentUser?.id) {
return
}
try {
const user = await getCurrentUser(huggingfaceApiKey)
setCurrentUser(user)
} catch (err) {
console.error("failed to log in:", err)
setCurrentUser(undefined)
}
})
}, [huggingfaceApiKey, currentUser?.id])
return currentUser
}