import React from 'react' import { tradingAllowed } from 'web/lib/firebase/contracts' import { Col } from '../layout/col' import { ContractProbGraph } from './contract-prob-graph' import { useUser } from 'web/hooks/use-user' import { Row } from '../layout/row' import { Linkify } from '../linkify' import { BinaryResolutionOrChance, FreeResponseResolutionOrChance, NumericResolutionOrExpectation, PseudoNumericResolutionOrExpectation, } from './contract-card' import { Bet } from 'common/bet' import BetButton from '../bet-button' import { AnswersGraph } from '../answers/answers-graph' import { Contract, BinaryContract, CPMMContract, CPMMBinaryContract, FreeResponseContract, MultipleChoiceContract, NumericContract, PseudoNumericContract, } from 'common/contract' import { ContractDetails, ExtraMobileContractDetails } from './contract-details' import { NumericGraph } from './numeric-graph' import { QuickBetButtons } from 'web/components/contract/quick-bet-button' const OverviewQuestion = (props: { text: string }) => ( ) const BetWidget = (props: { contract: CPMMContract }) => { const { contract } = props const user = useUser() return ( {contract.outcomeType === 'BINARY' && user && QuickBetButtons({ contract: contract as CPMMBinaryContract, user: user, side: 'NO', className: 'self-end min-w-[60px]', })} {contract.outcomeType === 'BINARY' && user && QuickBetButtons({ contract: contract as CPMMBinaryContract, user: user, side: 'YES', className: 'self-end min-w-[60px]', })} {!user && (
(with play money!)
)}
) } const NumericOverview = (props: { contract: NumericContract }) => { const { contract } = props return ( ) } const BinaryOverview = (props: { contract: BinaryContract; bets: Bet[] }) => { const { contract, bets } = props return ( {tradingAllowed(contract) && ( )} ) } const ChoiceOverview = (props: { contract: FreeResponseContract | MultipleChoiceContract bets: Bet[] }) => { const { contract, bets } = props const { question, resolution } = contract return ( {resolution && ( )} ) } const PseudoNumericOverview = (props: { contract: PseudoNumericContract bets: Bet[] }) => { const { contract, bets } = props return ( {tradingAllowed(contract) && } ) } export const ContractOverview = (props: { contract: Contract bets: Bet[] }) => { const { contract, bets } = props switch (contract.outcomeType) { case 'BINARY': return case 'NUMERIC': return case 'PSEUDO_NUMERIC': return case 'FREE_RESPONSE': case 'MULTIPLE_CHOICE': return } }