798253f887
* Challenge bets * Store avatar url * Fix before and after probs * Check balance before creation * Calculate winning shares * pretty * Change winning value * Set shares to equal each other * Fix share challenge link * pretty * remove lib refs * Probability of bet is set to market * Remove peer pill * Cleanup * Button on contract page * don't show challenge if not binary or if resolved * challenge button (WIP) * fix accept challenge: don't change pool/probability * Opengraph preview [WIP] * elim lib * Edit og card props * Change challenge text * New card gen attempt * Get challenge on server * challenge button styling * Use env domain * Remove other window ref * Use challenge creator as avatar * Remove user name * Remove s from property, replace prob with outcome * challenge form * share text * Add in challenge parts to template and url * Challenge url params optional * Add challenge params to parse request * Parse please * Don't remove prob * Challenge card styling * Challenge card styling * Challenge card styling * Challenge card styling * Challenge card styling * Challenge card styling * Challenge card styling * Challenge card styling * Add to readme about how to dev og-image * Add emojis * button: gradient background, 2xl size * beautify accept bet screen * update question button * Add separate challenge template * Accepted challenge sharing card, fix accept bet call * accept challenge button * challenge winner page * create challenge screen * Your outcome/cost=> acceptorOutcome/cost * New create challenge panel * Fix main merge * Add challenge slug to bet and filter by it * Center title * Add helper text * Add FAQ section * Lint * Columnize the user areas in preview link too * Absolutely position * Spacing * Orientation * Restyle challenges list, cache contract name * Make copying easy on mobile * Link spacing * Fix spacing * qr codes! * put your challenges first * eslint * Changes to contract buttons and create challenge modal * Change titles around for current bet * Add back in contract title after winning * Cleanup * Add challenge enabled flag * Spacing of switch button * Put sharing qr code in modal Co-authored-by: mantikoros <sgrugett@gmail.com>
52 lines
1.3 KiB
TypeScript
52 lines
1.3 KiB
TypeScript
import { useContext, useEffect, useState } from 'react'
|
|
import { useFirestoreDocumentData } from '@react-query-firebase/firestore'
|
|
import { QueryClient } from 'react-query'
|
|
|
|
import { doc, DocumentData, where } from 'firebase/firestore'
|
|
import { PrivateUser } from 'common/user'
|
|
import {
|
|
getUser,
|
|
listenForPrivateUser,
|
|
User,
|
|
users,
|
|
} from 'web/lib/firebase/users'
|
|
import { AuthContext } from 'web/components/auth-context'
|
|
|
|
export const useUser = () => {
|
|
return useContext(AuthContext)
|
|
}
|
|
|
|
export const usePrivateUser = (userId?: string) => {
|
|
const [privateUser, setPrivateUser] = useState<
|
|
PrivateUser | null | undefined
|
|
>(undefined)
|
|
|
|
useEffect(() => {
|
|
if (userId) return listenForPrivateUser(userId, setPrivateUser)
|
|
}, [userId])
|
|
|
|
return privateUser
|
|
}
|
|
|
|
export const useUserById = (userId = '_') => {
|
|
const result = useFirestoreDocumentData<DocumentData, User>(
|
|
['users', userId],
|
|
doc(users, userId),
|
|
{ subscribe: true, includeMetadataChanges: true }
|
|
)
|
|
|
|
if (userId === '_') return undefined
|
|
|
|
return result.isLoading ? undefined : result.data
|
|
}
|
|
|
|
const queryClient = new QueryClient()
|
|
|
|
export const prefetchUser = (userId: string) => {
|
|
queryClient.prefetchQuery(['users', userId], () => getUser(userId))
|
|
}
|
|
|
|
export const prefetchUsers = (userIds: string[]) => {
|
|
userIds.forEach(prefetchUser)
|
|
}
|