import clsx from 'clsx' import dayjs from 'dayjs' import React, { useEffect, useState } from 'react' import { LinkIcon, SwitchVerticalIcon } from '@heroicons/react/outline' import { Col } from '../layout/col' import { Row } from '../layout/row' import { Title } from '../title' import { User } from 'common/user' import { Modal } from 'web/components/layout/modal' import { Button } from '../button' import { createChallenge, getChallengeUrl } from 'web/lib/firebase/challenges' import { BinaryContract } from 'common/contract' import { SiteLink } from 'web/components/site-link' import { formatMoney } from 'common/util/format' import { NoLabel, YesLabel } from '../outcome-label' import { QRCode } from '../qr-code' import { copyToClipboard } from 'web/lib/util/copy' import toast from 'react-hot-toast' type challengeInfo = { amount: number expiresTime: number | null message: string outcome: 'YES' | 'NO' | number acceptorAmount: number } export function CreateChallengeButton(props: { user: User | null | undefined contract: BinaryContract }) { const { user, contract } = props const [open, setOpen] = useState(false) const [challengeSlug, setChallengeSlug] = useState('') return ( <> setOpen(newOpen)} size={'sm'}> {/*// add a sign up to challenge button?*/} {user && ( { const challenge = await createChallenge({ creator: user, creatorAmount: newChallenge.amount, expiresTime: newChallenge.expiresTime, message: newChallenge.message, acceptorAmount: newChallenge.acceptorAmount, outcome: newChallenge.outcome, contract: contract, }) challenge && setChallengeSlug(getChallengeUrl(challenge)) }} challengeSlug={challengeSlug} /> )} setOpen(true)} className="btn btn-outline mb-4 max-w-xs whitespace-nowrap normal-case" > Challenge a friend > ) } function CreateChallengeForm(props: { user: User contract: BinaryContract onCreate: (m: challengeInfo) => Promise challengeSlug: string }) { const { user, onCreate, contract, challengeSlug } = props const [isCreating, setIsCreating] = useState(false) const [finishedCreating, setFinishedCreating] = useState(false) const [error, setError] = useState('') const [editingAcceptorAmount, setEditingAcceptorAmount] = useState(false) const defaultExpire = 'week' const defaultMessage = `${user.name} is challenging you to a bet! Do you think ${contract.question}` const [challengeInfo, setChallengeInfo] = useState({ expiresTime: dayjs().add(2, defaultExpire).valueOf(), outcome: 'YES', amount: 100, acceptorAmount: 100, message: defaultMessage, }) useEffect(() => { setError('') }, [challengeInfo]) return ( <> {!finishedCreating && ( { e.preventDefault() if (user.balance < challengeInfo.amount) { setError('You do not have enough mana to create this challenge') return } setIsCreating(true) onCreate(challengeInfo).finally(() => setIsCreating(false)) setFinishedCreating(true) }} > You'll bet: M$ setChallengeInfo((m: challengeInfo) => { return { ...m, amount: parseInt(e.target.value), acceptorAmount: editingAcceptorAmount ? m.acceptorAmount : parseInt(e.target.value), } }) } /> on {challengeInfo.outcome === 'YES' ? : } setChallengeInfo((m: challengeInfo) => { return { ...m, outcome: m.outcome === 'YES' ? 'NO' : 'YES', } }) } > If they bet: {editingAcceptorAmount ? ( M$ setChallengeInfo((m: challengeInfo) => { return { ...m, acceptorAmount: parseInt(e.target.value), } }) } /> ) : ( {formatMoney(challengeInfo.acceptorAmount)} )} on {challengeInfo.outcome === 'YES' ? : } {!editingAcceptorAmount && ( setEditingAcceptorAmount(!editingAcceptorAmount)} > Edit )} Continue {error} )} {finishedCreating && ( <> Share the challenge using the link. { copyToClipboard(challengeSlug) toast('Link copied to clipboard!') }} className={'btn btn-outline mb-4 whitespace-nowrap normal-case'} > Copy link See your other challenges > )} > ) }