Merge branch 'manifoldmarkets:main' into main

This commit is contained in:
marsteralex 2022-09-20 16:50:05 -07:00 committed by GitHub
commit f9870ba512
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 15 additions and 30 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 =
@ -47,9 +47,7 @@ export function ContractTabs(props: {
l.amount > 0 l.amount > 0
) )
// Load comments here, so the badge count will be correct const comments = useComments(contract.id) ?? props.comments
const updatedComments = useComments(contract.id)
const comments = updatedComments ?? props.comments
const betActivity = lps != null && ( const betActivity = lps != null && (
<ContractBetsActivity <ContractBetsActivity
@ -107,18 +105,10 @@ export function ContractTabs(props: {
return ( return (
<Tabs <Tabs
currentPageForAnalytics="contract" currentPageForAnalytics={'contract'}
tabs={[ tabs={[
{ { title: 'Comments', content: commentActivity },
title: 'Comments', { title: capitalize(PAST_BETS), content: betActivity },
content: commentActivity,
badge: `${comments.length}`,
},
{
title: capitalize(PAST_BETS),
content: betActivity,
badge: `${visibleBets.length + visibleLps.length}`,
},
...(!user || !userBets?.length ...(!user || !userBets?.length
? [] ? []
: [ : [

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 ? (

View File

@ -3,6 +3,7 @@ import { Col } from 'web/components/layout/col'
import { Page } from 'web/components/page' import { Page } from 'web/components/page'
import { Title } from 'web/components/title' import { Title } from 'web/components/title'
import { useProbChangesAlgolia } from 'web/hooks/use-prob-changes' import { useProbChangesAlgolia } from 'web/hooks/use-prob-changes'
import { useTracking } from 'web/hooks/use-tracking'
import { useUser } from 'web/hooks/use-user' import { useUser } from 'web/hooks/use-user'
export default function DailyMovers() { export default function DailyMovers() {
@ -10,6 +11,8 @@ export default function DailyMovers() {
const changes = useProbChangesAlgolia(user?.id ?? '') const changes = useProbChangesAlgolia(user?.id ?? '')
useTracking('view daily movers')
return ( return (
<Page> <Page>
<Col className="pm:mx-10 gap-4 sm:px-4 sm:pb-4"> <Col className="pm:mx-10 gap-4 sm:px-4 sm:pb-4">