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
}
}