Trades page: Wait for all bets / contract data to load with loading indicator
This commit is contained in:
parent
561a7e2c75
commit
793742b499
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user