manifold/web/hooks/use-contracts.ts

133 lines
3.5 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,
listenForContracts,
listenForHotContracts,
listenForInactiveContracts,
getUserBetContracts,
getUserBetContractsQuery,
listAllContracts,
} from 'web/lib/firebase/contracts'
import { QueryClient, useQuery, useQueryClient } from 'react-query'
import { MINUTE_MS, sleep } from 'common/util/time'
2022-10-01 01:07:49 +00:00
import {
dailyScoreIndex,
newIndex,
trendingIndex,
} from 'web/lib/service/algolia'
import { CPMMBinaryContract } from 'common/contract'
import { zipObject } from 'lodash'
export const useContracts = () => {
const [contracts, setContracts] = useState<Contract[] | undefined>()
useEffect(() => {
return listenForContracts(setContracts)
}, [])
return contracts
}
2022-01-05 06:32:52 +00:00
2022-10-01 01:07:49 +00:00
export const useTrendingContracts = (maxContracts: number) => {
const { data } = useQuery(['trending-contracts', maxContracts], () =>
trendingIndex.search<CPMMBinaryContract>('', {
facetFilters: ['isResolved:false', 'visibility:public'],
2022-10-01 01:07:49 +00:00
hitsPerPage: maxContracts,
})
)
if (!data) return undefined
return data.hits
}
export const useNewContracts = (maxContracts: number) => {
const { data } = useQuery(['newest-contracts', maxContracts], () =>
newIndex.search<CPMMBinaryContract>('', {
facetFilters: ['isResolved:false', 'visibility:public'],
2022-10-01 01:07:49 +00:00
hitsPerPage: maxContracts,
})
)
if (!data) return undefined
return data.hits
}
export const useContractsByDailyScoreNotBetOn = (
userId: string | null | undefined,
maxContracts: number
) => {
const { data } = useQuery(['daily-score', userId, maxContracts], () =>
dailyScoreIndex.search<CPMMBinaryContract>('', {
facetFilters: [
'isResolved:false',
'visibility:public',
`uniqueBettors:-${userId}`,
],
2022-10-01 01:07:49 +00:00
hitsPerPage: maxContracts,
})
)
if (!userId || !data) return undefined
return data.hits.filter((c) => c.dailyScore)
}
export const useContractsByDailyScoreGroups = (
groupSlugs: string[] | undefined
) => {
const { data } = useQuery(['daily-score', groupSlugs], () =>
Promise.all(
(groupSlugs ?? []).map((slug) =>
dailyScoreIndex.search<CPMMBinaryContract>('', {
2022-10-01 01:07:49 +00:00
facetFilters: ['isResolved:false', `groupLinks.slug:${slug}`],
})
)
)
)
if (!groupSlugs || !data || data.length !== groupSlugs.length)
return undefined
return zipObject(
groupSlugs,
data.map((d) => d.hits.filter((c) => c.dailyScore))
)
}
const q = new QueryClient()
export const getCachedContracts = async () =>
q.fetchQuery(['contracts'], () => listAllContracts(1000), {
staleTime: Infinity,
})
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],
() => sleep(1000).then(() => getUserBetContracts(userId)),
2022-09-08 21:59:05 +00:00
{ staleTime: 5 * MINUTE_MS }
)
}
export const useUserBetContracts = (userId: string) => {
const result = useFirestoreQueryData(
['contracts', 'bets', userId],
getUserBetContractsQuery(userId)
)
return result.data
}