Resolved market UI
This commit is contained in:
parent
fc954b6b4b
commit
212f79aac9
|
@ -33,18 +33,28 @@ import { firebaseLogin } from '../lib/firebase/users'
|
||||||
import { Bet } from '../../common/bet'
|
import { Bet } from '../../common/bet'
|
||||||
import { useAnswers } from '../hooks/use-answers'
|
import { useAnswers } from '../hooks/use-answers'
|
||||||
import { ResolveConfirmationButton } from './confirmation-button'
|
import { ResolveConfirmationButton } from './confirmation-button'
|
||||||
|
import { tradingAllowed } from '../lib/firebase/contracts'
|
||||||
|
import { OutcomeLabel } from './outcome-label'
|
||||||
|
|
||||||
export function AnswersPanel(props: {
|
export function AnswersPanel(props: {
|
||||||
contract: Contract<'MULTI'>
|
contract: Contract<'MULTI'>
|
||||||
answers: Answer[]
|
answers: Answer[]
|
||||||
}) {
|
}) {
|
||||||
const { contract } = props
|
const { contract } = props
|
||||||
|
const { creatorId, resolution } = contract
|
||||||
|
|
||||||
const answers = useAnswers(contract.id) ?? props.answers
|
const answers = useAnswers(contract.id) ?? props.answers
|
||||||
const sortedAnswers = _.sortBy(
|
const [chosenAnswer, otherAnswers] = _.partition(
|
||||||
answers,
|
answers,
|
||||||
(answer) => -1 * getOutcomeProbability(contract.totalShares, answer.id)
|
(answer) => answer.id === resolution
|
||||||
)
|
)
|
||||||
|
const sortedAnswers = [
|
||||||
|
...chosenAnswer,
|
||||||
|
..._.sortBy(
|
||||||
|
otherAnswers,
|
||||||
|
(answer) => -1 * getOutcomeProbability(contract.totalShares, answer.id)
|
||||||
|
),
|
||||||
|
]
|
||||||
|
|
||||||
const user = useUser()
|
const user = useUser()
|
||||||
|
|
||||||
|
@ -55,6 +65,11 @@ export function AnswersPanel(props: {
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Col className="gap-3">
|
<Col className="gap-3">
|
||||||
|
{resolution && (
|
||||||
|
<div>
|
||||||
|
Resolved to answer <OutcomeLabel outcome={resolution} />:
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
{sortedAnswers.map((answer) => (
|
{sortedAnswers.map((answer) => (
|
||||||
<AnswerItem
|
<AnswerItem
|
||||||
key={answer.id}
|
key={answer.id}
|
||||||
|
@ -66,9 +81,9 @@ export function AnswersPanel(props: {
|
||||||
/>
|
/>
|
||||||
))}
|
))}
|
||||||
|
|
||||||
<CreateAnswerInput contract={contract} />
|
{tradingAllowed(contract) && <CreateAnswerInput contract={contract} />}
|
||||||
|
|
||||||
{user?.id === contract.creatorId && (
|
{user?.id === creatorId && !resolution && (
|
||||||
<AnswerResolvePanel
|
<AnswerResolvePanel
|
||||||
contract={contract}
|
contract={contract}
|
||||||
resolveOption={resolveOption}
|
resolveOption={resolveOption}
|
||||||
|
@ -89,16 +104,27 @@ function AnswerItem(props: {
|
||||||
onChoose: () => void
|
onChoose: () => void
|
||||||
}) {
|
}) {
|
||||||
const { answer, contract, showChoice, isChosen, onChoose } = props
|
const { answer, contract, showChoice, isChosen, onChoose } = props
|
||||||
|
const { resolution, totalShares } = contract
|
||||||
const { username, avatarUrl, name, createdTime, number, text } = answer
|
const { username, avatarUrl, name, createdTime, number, text } = answer
|
||||||
|
|
||||||
const createdDate = dayjs(createdTime).format('MMM D')
|
const createdDate = dayjs(createdTime).format('MMM D')
|
||||||
const prob = getOutcomeProbability(contract.totalShares, answer.id)
|
const prob = getOutcomeProbability(totalShares, answer.id)
|
||||||
const probPercent = formatPercent(prob)
|
const probPercent = formatPercent(prob)
|
||||||
|
const wasResolvedTo = resolution === answer.id
|
||||||
|
|
||||||
const [isBetting, setIsBetting] = useState(false)
|
const [isBetting, setIsBetting] = useState(false)
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Col className="p-4 sm:flex-row bg-gray-50 rounded">
|
<Col
|
||||||
|
className={clsx(
|
||||||
|
'p-4 sm:flex-row rounded',
|
||||||
|
wasResolvedTo
|
||||||
|
? 'bg-green-50 mb-8'
|
||||||
|
: isChosen
|
||||||
|
? 'bg-green-50'
|
||||||
|
: 'bg-gray-50'
|
||||||
|
)}
|
||||||
|
>
|
||||||
<Col className="gap-3 flex-1">
|
<Col className="gap-3 flex-1">
|
||||||
<div>{text}</div>
|
<div>{text}</div>
|
||||||
|
|
||||||
|
@ -130,7 +156,14 @@ function AnswerItem(props: {
|
||||||
/>
|
/>
|
||||||
) : (
|
) : (
|
||||||
<Row className="self-end sm:self-start items-center gap-4">
|
<Row className="self-end sm:self-start items-center gap-4">
|
||||||
<div className="text-2xl text-green-500">{probPercent}</div>
|
<div
|
||||||
|
className={clsx(
|
||||||
|
'text-2xl',
|
||||||
|
tradingAllowed(contract) ? 'text-green-500' : 'text-gray-500'
|
||||||
|
)}
|
||||||
|
>
|
||||||
|
{probPercent}
|
||||||
|
</div>
|
||||||
{showChoice ? (
|
{showChoice ? (
|
||||||
<div className="form-control py-1">
|
<div className="form-control py-1">
|
||||||
<label className="cursor-pointer label gap-2">
|
<label className="cursor-pointer label gap-2">
|
||||||
|
@ -146,12 +179,19 @@ function AnswerItem(props: {
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
) : (
|
) : (
|
||||||
<BuyButton
|
<>
|
||||||
className="justify-end self-end flex-initial btn-md !px-8"
|
{tradingAllowed(contract) && (
|
||||||
onClick={() => {
|
<BuyButton
|
||||||
setIsBetting(true)
|
className="justify-end self-end flex-initial btn-md !px-8"
|
||||||
}}
|
onClick={() => {
|
||||||
/>
|
setIsBetting(true)
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
|
{wasResolvedTo && (
|
||||||
|
<div className="text-green-700 text-xl">Chosen</div>
|
||||||
|
)}
|
||||||
|
</>
|
||||||
)}
|
)}
|
||||||
</Row>
|
</Row>
|
||||||
)}
|
)}
|
||||||
|
@ -422,7 +462,7 @@ function AnswerResolvePanel(props: {
|
||||||
return (
|
return (
|
||||||
<Col className="gap-4 p-4 bg-gray-50 rounded">
|
<Col className="gap-4 p-4 bg-gray-50 rounded">
|
||||||
<div>Resolve your market</div>
|
<div>Resolve your market</div>
|
||||||
<Col className="sm:flex-row sm:items-center gap-2">
|
<Col className="sm:flex-row sm:items-center gap-4">
|
||||||
<ChooseCancelSelector
|
<ChooseCancelSelector
|
||||||
className="!flex-row flex-wrap items-center"
|
className="!flex-row flex-wrap items-center"
|
||||||
selected={resolveOption}
|
selected={resolveOption}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
export function OutcomeLabel(props: {
|
export function OutcomeLabel(props: {
|
||||||
outcome: 'YES' | 'NO' | 'CANCEL' | 'MKT'
|
outcome: 'YES' | 'NO' | 'CANCEL' | 'MKT' | string
|
||||||
}) {
|
}) {
|
||||||
const { outcome } = props
|
const { outcome } = props
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user