Trades page: Wait for all bets / contract data to load with loading indicator

This commit is contained in:
James Grugett 2022-02-20 22:26:22 -06:00
parent 561a7e2c75
commit 793742b499

View File

@ -34,6 +34,7 @@ import { sellBet } from '../lib/firebase/api-call'
import { ConfirmationButton } from './confirmation-button' import { ConfirmationButton } from './confirmation-button'
import { OutcomeLabel, YesLabel, NoLabel } from './outcome-label' import { OutcomeLabel, YesLabel, NoLabel } from './outcome-label'
import { filterDefined } from '../../common/util/array' import { filterDefined } from '../../common/util/array'
import { LoadingIndicator } from './loading-indicator'
type BetSort = 'newest' | 'profit' | 'resolved' | 'value' type BetSort = 'newest' | 'profit' | 'resolved' | 'value'
@ -41,28 +42,29 @@ export function BetsList(props: { user: User }) {
const { user } = props const { user } = props
const bets = useUserBets(user.id) const bets = useUserBets(user.id)
const [contracts, setContracts] = useState<Contract[]>([]) const [contracts, setContracts] = useState<Contract[] | undefined>()
const [sort, setSort] = useState<BetSort>('value') const [sort, setSort] = useState<BetSort>('value')
useEffect(() => { useEffect(() => {
const loadedBets = bets ? bets : [] if (bets) {
const contractIds = _.uniq(loadedBets.map((bet) => bet.contractId)) const contractIds = _.uniq(bets.map((bet) => bet.contractId))
let disposed = false let disposed = false
Promise.all(contractIds.map((id) => getContractFromId(id))).then( Promise.all(contractIds.map((id) => getContractFromId(id))).then(
(contracts) => { (contracts) => {
if (!disposed) setContracts(filterDefined(contracts)) if (!disposed) setContracts(filterDefined(contracts))
}
)
return () => {
disposed = true
} }
)
return () => {
disposed = true
} }
}, [bets]) }, [bets])
if (!bets) { if (!bets || !contracts) {
return <></> return <LoadingIndicator />
} }
if (bets.length === 0) if (bets.length === 0)