Don't always require tips to render comments (#898)

This commit is contained in:
Marshall Polaris 2022-09-20 15:58:47 -07:00 committed by GitHub
parent be4def49a2
commit 8870f0d356
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 8 additions and 16 deletions

View File

@ -5,7 +5,6 @@ import { Contract } from 'common/contract'
import { formatMoney } from 'common/util/format' import { formatMoney } from 'common/util/format'
import { groupBy, mapValues, sumBy, sortBy, keyBy } from 'lodash' import { groupBy, mapValues, sumBy, sortBy, keyBy } from 'lodash'
import { useState, useMemo, useEffect } from 'react' import { useState, useMemo, useEffect } from 'react'
import { CommentTipMap } from 'web/hooks/use-tip-txns'
import { listUsers, User } from 'web/lib/firebase/users' import { listUsers, User } from 'web/lib/firebase/users'
import { FeedBet } from '../feed/feed-bets' import { FeedBet } from '../feed/feed-bets'
import { FeedComment } from '../feed/feed-comments' import { FeedComment } from '../feed/feed-comments'
@ -66,9 +65,8 @@ export function ContractTopTrades(props: {
contract: Contract contract: Contract
bets: Bet[] bets: Bet[]
comments: ContractComment[] comments: ContractComment[]
tips: CommentTipMap
}) { }) {
const { contract, bets, comments, tips } = props const { contract, bets, comments } = props
const commentsById = keyBy(comments, 'id') const commentsById = keyBy(comments, 'id')
const betsById = keyBy(bets, 'id') const betsById = keyBy(bets, 'id')
@ -105,7 +103,6 @@ export function ContractTopTrades(props: {
<FeedComment <FeedComment
contract={contract} contract={contract}
comment={commentsById[topCommentId]} comment={commentsById[topCommentId]}
tips={tips[topCommentId]}
/> />
</div> </div>
<Spacer h={16} /> <Spacer h={16} />

View File

@ -11,9 +11,9 @@ import { ContractBetsTable, BetsSummary } from '../bets-list'
import { Spacer } from '../layout/spacer' import { Spacer } from '../layout/spacer'
import { Tabs } from '../layout/tabs' import { Tabs } from '../layout/tabs'
import { Col } from '../layout/col' import { Col } from '../layout/col'
import { CommentTipMap } from 'web/hooks/use-tip-txns'
import { useComments } from 'web/hooks/use-comments' import { useComments } from 'web/hooks/use-comments'
import { useLiquidity } from 'web/hooks/use-liquidity' import { useLiquidity } from 'web/hooks/use-liquidity'
import { useTipTxns } from 'web/hooks/use-tip-txns'
import { capitalize } from 'lodash' import { capitalize } from 'lodash'
import { import {
DEV_HOUSE_LIQUIDITY_PROVIDER_ID, DEV_HOUSE_LIQUIDITY_PROVIDER_ID,
@ -26,12 +26,12 @@ export function ContractTabs(props: {
user: User | null | undefined user: User | null | undefined
bets: Bet[] bets: Bet[]
comments: ContractComment[] comments: ContractComment[]
tips: CommentTipMap
}) { }) {
const { contract, user, bets, tips } = props const { contract, user, bets } = props
const { outcomeType } = contract const { outcomeType } = contract
const isMobile = useIsMobile() const isMobile = useIsMobile()
const tips = useTipTxns({ contractId: contract.id })
const lps = useLiquidity(contract.id) const lps = useLiquidity(contract.id)
const userBets = const userBets =

View File

@ -106,7 +106,7 @@ export function FeedAnswerCommentGroup(props: {
indent={true} indent={true}
contract={contract} contract={contract}
comment={comment} comment={comment}
tips={tips[comment.id]} tips={tips[comment.id] ?? {}}
onReplyClick={scrollAndOpenReplyInput} onReplyClick={scrollAndOpenReplyInput}
/> />
))} ))}

View File

@ -47,7 +47,7 @@ export function FeedCommentThread(props: {
indent={commentIdx != 0} indent={commentIdx != 0}
contract={contract} contract={contract}
comment={comment} comment={comment}
tips={tips[comment.id]} tips={tips[comment.id] ?? {}}
onReplyClick={scrollAndOpenReplyInput} onReplyClick={scrollAndOpenReplyInput}
/> />
))} ))}
@ -74,7 +74,7 @@ export function FeedCommentThread(props: {
export function FeedComment(props: { export function FeedComment(props: {
contract: Contract contract: Contract
comment: ContractComment comment: ContractComment
tips: CommentTips tips?: CommentTips
indent?: boolean indent?: boolean
onReplyClick?: (comment: ContractComment) => void onReplyClick?: (comment: ContractComment) => void
}) { }) {
@ -170,7 +170,7 @@ export function FeedComment(props: {
smallImage smallImage
/> />
<Row className="mt-2 items-center gap-6 text-xs text-gray-500"> <Row className="mt-2 items-center gap-6 text-xs text-gray-500">
<Tipper comment={comment} tips={tips ?? {}} /> {tips && <Tipper comment={comment} tips={tips} />}
{onReplyClick && ( {onReplyClick && (
<button <button
className="font-bold hover:underline" className="font-bold hover:underline"

View File

@ -31,7 +31,6 @@ import { useBets } from 'web/hooks/use-bets'
import { CPMMBinaryContract } from 'common/contract' import { CPMMBinaryContract } from 'common/contract'
import { AlertBox } from 'web/components/alert-box' import { AlertBox } from 'web/components/alert-box'
import { useTracking } from 'web/hooks/use-tracking' import { useTracking } from 'web/hooks/use-tracking'
import { useTipTxns } from 'web/hooks/use-tip-txns'
import { useSaveReferral } from 'web/hooks/use-save-referral' import { useSaveReferral } from 'web/hooks/use-save-referral'
import { User } from 'common/user' import { User } from 'common/user'
import { ContractComment } from 'common/comment' import { ContractComment } from 'common/comment'
@ -196,8 +195,6 @@ export function ContractPageContent(
[bets] [bets]
) )
const tips = useTipTxns({ contractId: contract.id })
const [showConfetti, setShowConfetti] = useState(false) const [showConfetti, setShowConfetti] = useState(false)
useEffect(() => { useEffect(() => {
@ -278,7 +275,6 @@ export function ContractPageContent(
contract={contract} contract={contract}
bets={bets} bets={bets}
comments={comments} comments={comments}
tips={tips}
/> />
</div> </div>
<Spacer h={12} /> <Spacer h={12} />
@ -289,7 +285,6 @@ export function ContractPageContent(
contract={contract} contract={contract}
user={user} user={user}
bets={bets} bets={bets}
tips={tips}
comments={comments} comments={comments}
/> />
{!user ? ( {!user ? (