import clsx from 'clsx' import { useEffect, useRef, useState } from 'react' import Textarea from 'react-expanding-textarea' import { Answer } from '../../common/answer' import { Contract } from '../../common/contract' import { AmountInput } from './amount-input' import { Col } from './layout/col' import { createAnswer, placeBet } from '../lib/firebase/api-call' import { Row } from './layout/row' import { Avatar } from './avatar' import { SiteLink } from './site-link' import { DateTimeTooltip } from './datetime-tooltip' import dayjs from 'dayjs' import { BuyButton } from './yes-no-selector' import { Spacer } from './layout/spacer' import { formatMoney, formatPercent, formatWithCommas, } from '../../common/util/format' import { InfoTooltip } from './info-tooltip' import { useUser } from '../hooks/use-user' import { getProbabilityAfterBet, getOutcomeProbability, calculateShares, } from '../../common/calculate' import { firebaseLogin } from '../lib/firebase/users' export function AnswersPanel(props: { contract: Contract<'MULTI'> answers: Answer[] }) { const { contract, answers } = props return ( {answers.map((answer) => ( ))} ) } function AnswerItem(props: { answer: Answer; contract: Contract<'MULTI'> }) { const { answer, contract } = props const { username, avatarUrl, name, createdTime } = answer const createdDate = dayjs(createdTime).format('MMM D') const [isBetting, setIsBetting] = useState(false) return (
{answer.text}
{name}
{createdDate}
{ setIsBetting(true) }} /> {isBetting && } ) } function AnswerBetPanel(props: { answer: Answer contract: Contract<'MULTI'> }) { const { answer, contract } = props const { id: answerId } = answer const user = useUser() const [betAmount, setBetAmount] = useState(undefined) const [error, setError] = useState() const [isSubmitting, setIsSubmitting] = useState(false) const [wasSubmitted, setWasSubmitted] = useState(false) const inputRef = useRef(null) useEffect(() => { inputRef.current && inputRef.current.focus() }, []) function onBetChange(newAmount: number | undefined) { setWasSubmitted(false) setBetAmount(newAmount) } async function submitBet() { if (!user || !betAmount) return if (user.balance < betAmount) { setError('Insufficient balance') return } setError(undefined) setIsSubmitting(true) const result = await placeBet({ amount: betAmount, outcome: answerId, contractId: contract.id, }).then((r) => r.data as any) console.log('placed bet. Result:', result) if (result?.status === 'success') { setIsSubmitting(false) setWasSubmitted(true) setBetAmount(undefined) } else { setError(result?.error || 'Error placing bet') setIsSubmitting(false) } } const betDisabled = isSubmitting || !betAmount || error const initialProb = getOutcomeProbability(contract.totalShares, answer.id) const resultProb = getProbabilityAfterBet( contract.totalShares, answerId, betAmount ?? 0 ) const shares = calculateShares(contract.totalShares, betAmount ?? 0, answerId) const currentPayout = betAmount ? 0 : // calculatePayoutAfterCorrectBet(contract, { // outcome: answerId, // amount: betAmount, // shares, // } as Bet) 0 const currentReturn = betAmount ? (currentPayout - betAmount) / betAmount : 0 const currentReturnPercent = (currentReturn * 100).toFixed() + '%' return (
Amount
Implied probability
{formatPercent(initialProb)}
{formatPercent(resultProb)}
Potential payout
{formatMoney(currentPayout)}   (+{currentReturnPercent})
{user ? ( ) : ( )} {wasSubmitted &&
Trade submitted!
} ) } function CreateAnswerInput(props: { contract: Contract<'MULTI'> }) { const { contract } = props const [text, setText] = useState('') const [betAmount, setBetAmount] = useState(10) const [amountError, setAmountError] = useState() const [isSubmitting, setIsSubmitting] = useState(false) const canSubmit = text && betAmount && !amountError && !isSubmitting const submitAnswer = async () => { if (canSubmit) { setIsSubmitting(true) console.log('submitting', { text, betAmount }) const result = await createAnswer({ contractId: contract.id, text, amount: betAmount, }).then((r) => r.data) console.log('submit complte', result) setIsSubmitting(false) if (result.status === 'success') { setText('') setBetAmount(10) setAmountError(undefined) } } } return (
Add your answer