Bet panel: Quick vs Limit pill buttons. Also, pill buttons for Yes vs No.
This commit is contained in:
parent
98192ee580
commit
9240cd3d1c
|
@ -8,7 +8,6 @@ import { CPMMBinaryContract, PseudoNumericContract } from 'common/contract'
|
||||||
import { Col } from './layout/col'
|
import { Col } from './layout/col'
|
||||||
import { Row } from './layout/row'
|
import { Row } from './layout/row'
|
||||||
import { Spacer } from './layout/spacer'
|
import { Spacer } from './layout/spacer'
|
||||||
import { YesNoSelector } from './yes-no-selector'
|
|
||||||
import {
|
import {
|
||||||
formatMoney,
|
formatMoney,
|
||||||
formatMoneyWithDecimals,
|
formatMoneyWithDecimals,
|
||||||
|
@ -41,6 +40,7 @@ import { removeUndefinedProps } from 'common/util/object'
|
||||||
import { useUnfilledBets } from 'web/hooks/use-bets'
|
import { useUnfilledBets } from 'web/hooks/use-bets'
|
||||||
import { LimitBets } from './limit-bets'
|
import { LimitBets } from './limit-bets'
|
||||||
import { BucketInput } from './bucket-input'
|
import { BucketInput } from './bucket-input'
|
||||||
|
import { PillButton } from './buttons/pill-button'
|
||||||
|
|
||||||
export function BetPanel(props: {
|
export function BetPanel(props: {
|
||||||
contract: CPMMBinaryContract | PseudoNumericContract
|
contract: CPMMBinaryContract | PseudoNumericContract
|
||||||
|
@ -54,10 +54,6 @@ export function BetPanel(props: {
|
||||||
const { sharesOutcome } = useSaveBinaryShares(contract, userBets)
|
const { sharesOutcome } = useSaveBinaryShares(contract, userBets)
|
||||||
|
|
||||||
const [isLimitOrder, setIsLimitOrder] = useState(false)
|
const [isLimitOrder, setIsLimitOrder] = useState(false)
|
||||||
const toggleLimitOrder = () => {
|
|
||||||
setIsLimitOrder(!isLimitOrder)
|
|
||||||
track('toggle limit order')
|
|
||||||
}
|
|
||||||
|
|
||||||
const showLimitOrders =
|
const showLimitOrders =
|
||||||
(isLimitOrder && unfilledBets.length > 0) || yourUnfilledBets.length > 0
|
(isLimitOrder && unfilledBets.length > 0) || yourUnfilledBets.length > 0
|
||||||
|
@ -71,21 +67,33 @@ export function BetPanel(props: {
|
||||||
/>
|
/>
|
||||||
<Col
|
<Col
|
||||||
className={clsx(
|
className={clsx(
|
||||||
'relative rounded-b-md bg-white px-8 py-6',
|
'relative rounded-b-md bg-white px-6 py-6',
|
||||||
!sharesOutcome && 'rounded-t-md',
|
!sharesOutcome && 'rounded-t-md',
|
||||||
className
|
className
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
<Row className="align-center justify-between">
|
<Row className="align-center mb-4 justify-between">
|
||||||
<div className="mb-6 text-2xl">
|
<div className="text-4xl">Bet</div>
|
||||||
{isLimitOrder ? <>Limit order</> : <>Place your bet</>}
|
<Row className="mt-2 items-center gap-2">
|
||||||
</div>
|
<PillButton
|
||||||
<button
|
selected={!isLimitOrder}
|
||||||
className="btn btn-ghost btn-sm text-sm normal-case"
|
onSelect={() => {
|
||||||
onClick={toggleLimitOrder}
|
setIsLimitOrder(false)
|
||||||
>
|
track('select quick order')
|
||||||
<SwitchHorizontalIcon className="inline h-6 w-6" />
|
}}
|
||||||
</button>
|
>
|
||||||
|
Quick
|
||||||
|
</PillButton>
|
||||||
|
<PillButton
|
||||||
|
selected={isLimitOrder}
|
||||||
|
onSelect={() => {
|
||||||
|
setIsLimitOrder(true)
|
||||||
|
track('select limit order')
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
Limit
|
||||||
|
</PillButton>
|
||||||
|
</Row>
|
||||||
</Row>
|
</Row>
|
||||||
|
|
||||||
<BuyPanel
|
<BuyPanel
|
||||||
|
@ -287,13 +295,26 @@ function BuyPanel(props: {
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<YesNoSelector
|
<div className="my-3 text-left text-sm text-gray-500">Direction</div>
|
||||||
className="mb-4"
|
<Row className="mb-4 items-center gap-2">
|
||||||
btnClassName="flex-1"
|
<PillButton
|
||||||
selected={betChoice}
|
selected={betChoice === 'YES'}
|
||||||
onSelect={(choice) => onBetChoice(choice)}
|
onSelect={() => onBetChoice('YES')}
|
||||||
isPseudoNumeric={isPseudoNumeric}
|
big
|
||||||
/>
|
color="bg-primary"
|
||||||
|
>
|
||||||
|
{isPseudoNumeric ? 'Higher' : 'Yes'}
|
||||||
|
</PillButton>
|
||||||
|
<PillButton
|
||||||
|
selected={betChoice === 'NO'}
|
||||||
|
onSelect={() => onBetChoice('NO')}
|
||||||
|
big
|
||||||
|
color="bg-red-400"
|
||||||
|
>
|
||||||
|
{isPseudoNumeric ? 'Lower' : 'No'}
|
||||||
|
</PillButton>
|
||||||
|
</Row>
|
||||||
|
|
||||||
<div className="my-3 text-left text-sm text-gray-500">Amount</div>
|
<div className="my-3 text-left text-sm text-gray-500">Amount</div>
|
||||||
<BuyAmountInput
|
<BuyAmountInput
|
||||||
inputClassName="w-full max-w-none"
|
inputClassName="w-full max-w-none"
|
||||||
|
|
27
web/components/buttons/pill-button.tsx
Normal file
27
web/components/buttons/pill-button.tsx
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
import clsx from 'clsx'
|
||||||
|
import { ReactNode } from 'react'
|
||||||
|
|
||||||
|
export function PillButton(props: {
|
||||||
|
selected: boolean
|
||||||
|
onSelect: () => void
|
||||||
|
color?: string
|
||||||
|
big?: boolean
|
||||||
|
children: ReactNode
|
||||||
|
}) {
|
||||||
|
const { children, selected, onSelect, color, big } = props
|
||||||
|
|
||||||
|
return (
|
||||||
|
<button
|
||||||
|
className={clsx(
|
||||||
|
'cursor-pointer select-none rounded-full',
|
||||||
|
selected
|
||||||
|
? ['text-white', color ?? 'bg-gray-700']
|
||||||
|
: 'bg-gray-100 hover:bg-gray-200',
|
||||||
|
big ? 'px-8 py-2' : 'px-3 py-1.5 text-sm'
|
||||||
|
)}
|
||||||
|
onClick={onSelect}
|
||||||
|
>
|
||||||
|
{children}
|
||||||
|
</button>
|
||||||
|
)
|
||||||
|
}
|
|
@ -5,68 +5,6 @@ import { Col } from './layout/col'
|
||||||
import { Row } from './layout/row'
|
import { Row } from './layout/row'
|
||||||
import { resolution } from 'common/contract'
|
import { resolution } from 'common/contract'
|
||||||
|
|
||||||
export function YesNoSelector(props: {
|
|
||||||
selected?: 'YES' | 'NO'
|
|
||||||
onSelect: (selected: 'YES' | 'NO') => void
|
|
||||||
className?: string
|
|
||||||
btnClassName?: string
|
|
||||||
replaceYesButton?: React.ReactNode
|
|
||||||
replaceNoButton?: React.ReactNode
|
|
||||||
isPseudoNumeric?: boolean
|
|
||||||
}) {
|
|
||||||
const {
|
|
||||||
selected,
|
|
||||||
onSelect,
|
|
||||||
className,
|
|
||||||
btnClassName,
|
|
||||||
replaceNoButton,
|
|
||||||
replaceYesButton,
|
|
||||||
isPseudoNumeric,
|
|
||||||
} = props
|
|
||||||
|
|
||||||
const commonClassNames =
|
|
||||||
'inline-flex items-center justify-center rounded-3xl border-2 p-2'
|
|
||||||
|
|
||||||
return (
|
|
||||||
<Row className={clsx('space-x-3', className)}>
|
|
||||||
{replaceYesButton ? (
|
|
||||||
replaceYesButton
|
|
||||||
) : (
|
|
||||||
<button
|
|
||||||
className={clsx(
|
|
||||||
commonClassNames,
|
|
||||||
'hover:bg-primary-focus border-primary hover:border-primary-focus hover:text-white',
|
|
||||||
selected == 'YES'
|
|
||||||
? 'bg-primary text-white'
|
|
||||||
: 'text-primary bg-transparent',
|
|
||||||
btnClassName
|
|
||||||
)}
|
|
||||||
onClick={() => onSelect('YES')}
|
|
||||||
>
|
|
||||||
{isPseudoNumeric ? 'HIGHER' : 'YES'}
|
|
||||||
</button>
|
|
||||||
)}
|
|
||||||
{replaceNoButton ? (
|
|
||||||
replaceNoButton
|
|
||||||
) : (
|
|
||||||
<button
|
|
||||||
className={clsx(
|
|
||||||
commonClassNames,
|
|
||||||
'border-red-400 hover:border-red-500 hover:bg-red-500 hover:text-white',
|
|
||||||
selected == 'NO'
|
|
||||||
? 'bg-red-400 text-white'
|
|
||||||
: 'bg-transparent text-red-400',
|
|
||||||
btnClassName
|
|
||||||
)}
|
|
||||||
onClick={() => onSelect('NO')}
|
|
||||||
>
|
|
||||||
{isPseudoNumeric ? 'LOWER' : 'NO'}
|
|
||||||
</button>
|
|
||||||
)}
|
|
||||||
</Row>
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
export function YesNoCancelSelector(props: {
|
export function YesNoCancelSelector(props: {
|
||||||
selected: resolution | undefined
|
selected: resolution | undefined
|
||||||
onSelect: (selected: resolution) => void
|
onSelect: (selected: resolution) => void
|
||||||
|
|
Loading…
Reference in New Issue
Block a user