manifold/web/components/contract/like-market-button.tsx

69 lines
1.8 KiB
TypeScript
Raw Normal View History

2022-10-01 20:06:09 +00:00
import React, { useMemo, useState } from 'react'
import { Contract } from 'common/contract'
import { User } from 'common/user'
import { useUserLikes } from 'web/hooks/use-likes'
import toast from 'react-hot-toast'
import { likeContract } from 'web/lib/firebase/likes'
import { LIKE_TIP_AMOUNT, TIP_UNDO_DURATION } from 'common/like'
import { firebaseLogin } from 'web/lib/firebase/users'
2022-08-31 15:27:37 +00:00
import { useMarketTipTxns } from 'web/hooks/use-tip-txns'
import { sum } from 'lodash'
import { TipButton } from './tip-button'
import { TipToast } from '../tipper'
export function LikeMarketButton(props: {
contract: Contract
user: User | null | undefined
}) {
const { contract, user } = props
2022-10-01 20:06:09 +00:00
2022-10-01 21:16:34 +00:00
const tips = useMarketTipTxns(contract.id)
2022-08-31 15:27:37 +00:00
const totalTipped = useMemo(() => {
return sum(tips.map((tip) => tip.amount))
}, [tips])
2022-10-01 20:06:09 +00:00
const likes = useUserLikes(user?.id)
2022-10-01 20:06:09 +00:00
const [isLiking, setIsLiking] = useState(false)
const userLikedContractIds = likes
?.filter((l) => l.type === 'contract')
.map((l) => l.id)
const onLike = async () => {
if (!user) return firebaseLogin()
2022-10-01 20:06:09 +00:00
setIsLiking(true)
const timeoutId = setTimeout(() => {
likeContract(user, contract).catch(() => setIsLiking(false))
}, 3000)
toast.custom(
() => (
<TipToast
userName={contract.creatorUsername}
onUndoClick={() => {
clearTimeout(timeoutId)
}}
/>
),
{ duration: TIP_UNDO_DURATION }
)
}
return (
<TipButton
onClick={onLike}
tipAmount={LIKE_TIP_AMOUNT}
totalTipped={totalTipped}
userTipped={
!!user &&
(isLiking ||
userLikedContractIds?.includes(contract.id) ||
(!likes && !!contract.likedByUserIds?.includes(user.id)))
}
2022-10-01 21:16:34 +00:00
disabled={contract.creatorId === user?.id}
/>
)
}