69 lines
1.7 KiB
TypeScript
69 lines
1.7 KiB
TypeScript
import { useState, useEffect } from 'react'
|
|
import { PrivateUser, User } from 'common/user'
|
|
import {
|
|
getUser,
|
|
listenForAllUsers,
|
|
listenForPrivateUsers,
|
|
} from 'web/lib/firebase/users'
|
|
import { groupBy, sortBy, difference } from 'lodash'
|
|
import { getContractsOfUserBets } from 'web/lib/firebase/bets'
|
|
import { useFollows } from './use-follows'
|
|
import { useUser } from './use-user'
|
|
|
|
export const useUsers = () => {
|
|
const [users, setUsers] = useState<User[]>([])
|
|
|
|
useEffect(() => {
|
|
listenForAllUsers(setUsers)
|
|
}, [])
|
|
|
|
return users
|
|
}
|
|
|
|
export const useUserById = (userId?: string) => {
|
|
const [user, setUser] = useState<User | undefined>(undefined)
|
|
|
|
useEffect(() => {
|
|
if (userId) {
|
|
getUser(userId).then(setUser)
|
|
}
|
|
}, [userId])
|
|
|
|
return user
|
|
}
|
|
|
|
export const usePrivateUsers = () => {
|
|
const [users, setUsers] = useState<PrivateUser[]>([])
|
|
|
|
useEffect(() => {
|
|
listenForPrivateUsers(setUsers)
|
|
}, [])
|
|
|
|
return users
|
|
}
|
|
|
|
export const useDiscoverUsers = (userId: string | null | undefined) => {
|
|
const [discoverUserIds, setDiscoverUserIds] = useState<string[]>([])
|
|
|
|
useEffect(() => {
|
|
if (userId)
|
|
getContractsOfUserBets(userId).then((contracts) => {
|
|
const creatorCounts = Object.entries(
|
|
groupBy(contracts, 'creatorId')
|
|
).map(([id, contracts]) => [id, contracts.length] as const)
|
|
|
|
const topCreatorIds = sortBy(creatorCounts, ([_, i]) => i)
|
|
.map(([id]) => id)
|
|
.reverse()
|
|
|
|
setDiscoverUserIds(topCreatorIds)
|
|
})
|
|
}, [userId])
|
|
|
|
const user = useUser()
|
|
const followedUserIds = useFollows(user?.id)
|
|
const nonSuggestions = [user?.id ?? '', ...(followedUserIds ?? [])]
|
|
|
|
return difference(discoverUserIds, nonSuggestions).slice(0, 50)
|
|
}
|