Improve graph for resolved bets

This commit is contained in:
jahooma 2021-12-16 00:44:04 -06:00
parent 5d2e81f982
commit 8abbc34652
2 changed files with 15 additions and 14 deletions

View File

@ -7,7 +7,7 @@ import { Contract } from '../lib/firebase/contracts'
export function ContractProbGraph(props: { contract: Contract }) { export function ContractProbGraph(props: { contract: Contract }) {
const { contract } = props const { contract } = props
const { id, seedAmounts } = contract const { id, seedAmounts, resolutionTime } = contract
let bets = useBets(id) let bets = useBets(id)
if (bets === 'loading') bets = [] if (bets === 'loading') bets = []
@ -21,29 +21,30 @@ export function ContractProbGraph(props: { contract: Contract }) {
].map((time) => new Date(time)) ].map((time) => new Date(time))
const probs = [seedProb, ...bets.map((bet) => bet.probAfter)] const probs = [seedProb, ...bets.map((bet) => bet.probAfter)]
// Add a fake datapoint in future so the line continues horizontally const latestTime = dayjs(resolutionTime ? resolutionTime : Date.now())
// to the right.
times.push(dayjs().add(1, 'day').toDate()) if (!resolutionTime) {
probs.push(probs[probs.length - 1]) // Add a fake datapoint in future so the line continues horizontally
// to the right.
times.push(latestTime.add(1, 'day').toDate())
probs.push(probs[probs.length - 1])
}
const points = probs.map((prob, i) => ({ x: times[i], y: prob * 100 })) const points = probs.map((prob, i) => ({ x: times[i], y: prob * 100 }))
const data = [{ id: 'Yes', data: points, color: '#11b981' }] const data = [{ id: 'Yes', data: points, color: '#11b981' }]
const lessThanAWeek =
times[times.length - 1].getTime() - times[0].getTime() <
1000 * 60 * 60 * 24 * 7
const yTickValues = [0, 25, 50, 75, 100] const yTickValues = [0, 25, 50, 75, 100]
const { width } = useWindowSize() const { width } = useWindowSize()
const numXTickValues = !width || width < 800 ? 4 : 8 const numXTickValues = !width || width < 800 ? 2 : 5
const now = dayjs() const hoursAgo = latestTime.subtract(5, 'hours')
const hoursAgo = now.subtract(8, 'hours')
const startDate = dayjs(times[0]).isBefore(hoursAgo) const startDate = dayjs(times[0]).isBefore(hoursAgo)
? times[0] ? times[0]
: hoursAgo.toDate() : hoursAgo.toDate()
const lessThanAWeek = dayjs(startDate).add(1, 'week').isAfter(latestTime)
return ( return (
<div className="w-full" style={{ height: 400 }}> <div className="w-full" style={{ height: 400 }}>
<ResponsiveLine <ResponsiveLine
@ -58,7 +59,7 @@ export function ContractProbGraph(props: { contract: Contract }) {
xScale={{ xScale={{
type: 'time', type: 'time',
min: startDate, min: startDate,
max: now.toDate(), max: latestTime.toDate(),
}} }}
xFormat={(d) => formatTime(+d.valueOf(), lessThanAWeek)} xFormat={(d) => formatTime(+d.valueOf(), lessThanAWeek)}
axisBottom={{ axisBottom={{

View File

@ -33,7 +33,7 @@ export type Contract = {
closeTime?: number // When no more trading is allowed closeTime?: number // When no more trading is allowed
isResolved: boolean isResolved: boolean
resolutionTime?: 10293849 // When the contract creator resolved the market; 0 if unresolved resolutionTime?: number // When the contract creator resolved the market; 0 if unresolved
resolution?: 'YES' | 'NO' | 'CANCEL' // Chosen by creator; must be one of outcomes resolution?: 'YES' | 'NO' | 'CANCEL' // Chosen by creator; must be one of outcomes
} }