manifold/web/hooks/use-contracts.ts

86 lines
2.2 KiB
TypeScript
Raw Normal View History

import { useFirestoreQueryData } from '@react-query-firebase/firestore'
import { useEffect, useState } from 'react'
2022-01-05 06:32:52 +00:00
import {
Contract,
listenForActiveContracts,
2022-01-05 06:32:52 +00:00
listenForContracts,
listenForHotContracts,
listenForInactiveContracts,
listenForNewContracts,
getUserBetContracts,
getUserBetContractsQuery,
listAllContracts,
} from 'web/lib/firebase/contracts'
import { QueryClient, useQueryClient } from 'react-query'
2022-09-08 21:59:05 +00:00
import { MINUTE_MS } from 'common/util/time'
export const useContracts = () => {
const [contracts, setContracts] = useState<Contract[] | undefined>()
useEffect(() => {
return listenForContracts(setContracts)
}, [])
return contracts
}
2022-01-05 06:32:52 +00:00
const q = new QueryClient()
export const getCachedContracts = async () =>
q.fetchQuery(['contracts'], () => listAllContracts(1000), {
staleTime: Infinity,
})
export const useActiveContracts = () => {
const [activeContracts, setActiveContracts] = useState<
Contract[] | undefined
>()
const [newContracts, setNewContracts] = useState<Contract[] | undefined>()
useEffect(() => {
return listenForActiveContracts(setActiveContracts)
}, [])
useEffect(() => {
return listenForNewContracts(setNewContracts)
}, [])
if (!activeContracts || !newContracts) return undefined
return [...activeContracts, ...newContracts]
}
export const useInactiveContracts = () => {
const [contracts, setContracts] = useState<Contract[] | undefined>()
useEffect(() => {
return listenForInactiveContracts(setContracts)
}, [])
return contracts
}
2022-01-05 06:32:52 +00:00
export const useHotContracts = () => {
const [hotContracts, setHotContracts] = useState<Contract[] | undefined>()
2022-01-05 06:32:52 +00:00
useEffect(() => listenForHotContracts(setHotContracts), [])
2022-01-05 06:32:52 +00:00
return hotContracts
2022-01-05 06:32:52 +00:00
}
export const usePrefetchUserBetContracts = (userId: string) => {
const queryClient = useQueryClient()
2022-09-08 21:59:05 +00:00
return queryClient.prefetchQuery(
['contracts', 'bets', userId],
() => getUserBetContracts(userId),
{ staleTime: 5 * MINUTE_MS }
)
}
export const useUserBetContracts = (userId: string) => {
const result = useFirestoreQueryData(
['contracts', 'bets', userId],
getUserBetContractsQuery(userId)
)
return result.data
}