import React, { useEffect, useState } from 'react' import Router from 'next/router' import _ from 'lodash' import { Contract, listAllContracts } from '../lib/firebase/contracts' import { Page } from '../components/page' import { ActivityFeed, findActiveContracts } from './activity' import { Comment, listAllComments } from '../lib/firebase/comments' import { Bet, listAllBets } from '../lib/firebase/bets' import FeedCreate from '../components/feed-create' import { Spacer } from '../components/layout/spacer' import { Col } from '../components/layout/col' import { useUser } from '../hooks/use-user' import { useContracts } from '../hooks/use-contracts' import { listAllFolds } from '../lib/firebase/folds' import { Fold } from '../../common/fold' import { filterDefined } from '../../common/util/array' import { useUserBetContracts } from '../hooks/use-user-bets' import { LoadingIndicator } from '../components/loading-indicator' import { FoldTagList } from '../components/tags-list' import { SearchIcon } from '@heroicons/react/outline' import { Row } from '../components/layout/row' import { SparklesIcon } from '@heroicons/react/solid' import { useFollowedFolds } from '../hooks/use-fold' export async function getStaticProps() { const [contracts, folds] = await Promise.all([ listAllContracts().catch((_) => []), listAllFolds().catch(() => []), ]) return { props: { contracts, folds, }, revalidate: 60, // regenerate after a minute } } const Home = (props: { contracts: Contract[]; folds: Fold[] }) => { const { folds } = props const user = useUser() const contracts = useContracts() ?? props.contracts const followedFoldIds = useFollowedFolds(user) const followedFolds = filterDefined( (followedFoldIds ?? []).map((id) => folds.find((fold) => fold.id === id)) ) const tagSet = new Set( _.flatten(followedFolds.map((fold) => fold.lowercaseTags)) ) const yourBetContractIds = useUserBetContracts(user?.id) const yourBetContracts = yourBetContractIds ? new Set(yourBetContractIds) : undefined const feedContracts = followedFoldIds && yourBetContracts ? contracts.filter( (contract) => contract.lowercaseTags.some((tag) => tagSet.has(tag)) || yourBetContracts.has(contract.id) ) : undefined const feedContractsKey = feedContracts?.map(({ id }) => id).join(',') const [feedBets, setFeedBets] = useState() const [feedComments, setFeedComments] = useState() useEffect(() => { if (feedContracts) { Promise.all( feedContracts.map((contract) => listAllBets(contract.id)) ).then(setFeedBets) Promise.all( feedContracts.map((contract) => listAllComments(contract.id)) ).then(setFeedComments) } // eslint-disable-next-line react-hooks/exhaustive-deps }, [feedContractsKey]) const oneDayMS = 24 * 60 * 60 * 1000 const recentBets = feedBets && feedBets.flat().filter((bet) => bet.createdTime > Date.now() - oneDayMS) const activeContracts = feedContracts && feedComments && recentBets && findActiveContracts(feedContracts, feedComments.flat(), recentBets, 365) const contractBets = activeContracts ? activeContracts.map( (contract) => feedBets[feedContracts.indexOf(contract)] ) : [] const contractComments = activeContracts ? activeContracts.map( (contract) => feedComments[feedContracts.indexOf(contract)] ) : [] if (user === null) { Router.replace('/') return <> } return ( {activeContracts ? ( ) : ( )} ) } export default Home