import { useFirestoreQueryData } from '@react-query-firebase/firestore' import { useEffect, useState } from 'react' import { Bet, getUserBetsQuery, listenForUserContractBets, } from 'web/lib/firebase/bets' export const useUserBets = (userId: string) => { const result = useFirestoreQueryData( ['bets', userId], getUserBetsQuery(userId), { subscribe: true, includeMetadataChanges: true }, // Temporary workaround for react-query bug: // https://github.com/invertase/react-query-firebase/issues/25 { refetchOnMount: 'always' } ) return result.data } export const useUserContractBets = ( userId: string | undefined, contractId: string | undefined ) => { const [bets, setBets] = useState(undefined) useEffect(() => { if (userId && contractId) return listenForUserContractBets(userId, contractId, setBets) }, [userId, contractId]) return bets } export const useGetUserBetContractIds = (userId: string | undefined) => { const [contractIds, setContractIds] = useState() useEffect(() => { if (userId) { const key = `user-bet-contractIds-${userId}` const userBetContractJson = localStorage.getItem(key) if (userBetContractJson) { setContractIds(JSON.parse(userBetContractJson)) } } }, [userId]) return contractIds }