Add ante and close date to make predictions
This commit is contained in:
parent
08eac5b0ef
commit
6525ffc6c3
|
@ -1,6 +1,9 @@
|
||||||
import clsx from 'clsx'
|
import clsx from 'clsx'
|
||||||
|
import dayjs from 'dayjs'
|
||||||
import Link from 'next/link'
|
import Link from 'next/link'
|
||||||
import { useState } from 'react'
|
import { useState } from 'react'
|
||||||
|
import { AmountInput } from '../components/amount-input'
|
||||||
|
import { InfoTooltip } from '../components/info-tooltip'
|
||||||
|
|
||||||
import { Col } from '../components/layout/col'
|
import { Col } from '../components/layout/col'
|
||||||
import { Row } from '../components/layout/row'
|
import { Row } from '../components/layout/row'
|
||||||
|
@ -100,6 +103,14 @@ export default function MakePredictions() {
|
||||||
const [isSubmitting, setIsSubmitting] = useState(false)
|
const [isSubmitting, setIsSubmitting] = useState(false)
|
||||||
const [createdContracts, setCreatedContracts] = useState<Contract[]>([])
|
const [createdContracts, setCreatedContracts] = useState<Contract[]>([])
|
||||||
|
|
||||||
|
const [ante, setAnte] = useState<number | undefined>(100)
|
||||||
|
const [anteError, setAnteError] = useState<string | undefined>()
|
||||||
|
// By default, close the market a week from today
|
||||||
|
const weekFromToday = dayjs().add(7, 'day').format('YYYY-MM-DDT23:59')
|
||||||
|
const [closeDate, setCloseDate] = useState<undefined | string>(weekFromToday)
|
||||||
|
|
||||||
|
const closeTime = closeDate ? dayjs(closeDate).valueOf() : undefined
|
||||||
|
|
||||||
const bulkPlaceholder = `e.g.
|
const bulkPlaceholder = `e.g.
|
||||||
${TEST_VALUE}
|
${TEST_VALUE}
|
||||||
...
|
...
|
||||||
|
@ -138,6 +149,8 @@ ${TEST_VALUE}
|
||||||
question: prediction.question,
|
question: prediction.question,
|
||||||
description: prediction.description,
|
description: prediction.description,
|
||||||
initialProb: prediction.initialProb,
|
initialProb: prediction.initialProb,
|
||||||
|
ante,
|
||||||
|
closeTime,
|
||||||
}).then((r) => (r.data as any).contract)
|
}).then((r) => (r.data as any).contract)
|
||||||
|
|
||||||
setCreatedContracts((prev) => [...prev, contract])
|
setCreatedContracts((prev) => [...prev, contract])
|
||||||
|
@ -173,7 +186,7 @@ ${TEST_VALUE}
|
||||||
|
|
||||||
<div className="form-control w-full">
|
<div className="form-control w-full">
|
||||||
<label className="label">
|
<label className="label">
|
||||||
<span className="label-text">Tags</span>
|
<span className="label-text">Description</span>
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
<input
|
<input
|
||||||
|
@ -185,6 +198,42 @@ ${TEST_VALUE}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div className="form-control items-start mb-1">
|
||||||
|
<label className="label gap-2 mb-1">
|
||||||
|
<span>Market close</span>
|
||||||
|
<InfoTooltip text="Trading will be halted after this time (local timezone)." />
|
||||||
|
</label>
|
||||||
|
<input
|
||||||
|
type="datetime-local"
|
||||||
|
className="input input-bordered"
|
||||||
|
onClick={(e) => e.stopPropagation()}
|
||||||
|
onChange={(e) => setCloseDate(e.target.value || '')}
|
||||||
|
min={Date.now()}
|
||||||
|
disabled={isSubmitting}
|
||||||
|
value={closeDate}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<Spacer h={4} />
|
||||||
|
|
||||||
|
<div className="form-control items-start mb-1">
|
||||||
|
<label className="label gap-2 mb-1">
|
||||||
|
<span>Market ante</span>
|
||||||
|
<InfoTooltip
|
||||||
|
text={`Subsidize your market to encourage trading. Ante bets are set to match your initial probability.
|
||||||
|
You earn ${0.01 * 100}% of trading volume.`}
|
||||||
|
/>
|
||||||
|
</label>
|
||||||
|
<AmountInput
|
||||||
|
amount={ante}
|
||||||
|
minimumAmount={10}
|
||||||
|
onChange={setAnte}
|
||||||
|
error={anteError}
|
||||||
|
setError={setAnteError}
|
||||||
|
disabled={isSubmitting}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
{predictions.length > 0 && (
|
{predictions.length > 0 && (
|
||||||
<div>
|
<div>
|
||||||
<Spacer h={4} />
|
<Spacer h={4} />
|
||||||
|
@ -226,3 +275,13 @@ ${TEST_VALUE}
|
||||||
</Page>
|
</Page>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Given a date string like '2022-04-02',
|
||||||
|
// return the time just before midnight on that date (in the user's local time), as millis since epoch
|
||||||
|
function dateToMillis(date: string) {
|
||||||
|
return dayjs(date)
|
||||||
|
.set('hour', 23)
|
||||||
|
.set('minute', 59)
|
||||||
|
.set('second', 59)
|
||||||
|
.valueOf()
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user