import React, { useState } from 'react' import Router from 'next/router' import { SparklesIcon, GlobeAltIcon } from '@heroicons/react/solid' import clsx from 'clsx' import _ from 'lodash' import { Contract } from '../lib/firebase/contracts' import { Page } from '../components/page' import { ActivityFeed, SummaryActivityFeed } from './activity' import { Comment } from '../lib/firebase/comments' import { Bet } 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 { Fold } from '../../common/fold' import { LoadingIndicator } from '../components/loading-indicator' import { Row } from '../components/layout/row' import { FastFoldFollowing } from '../components/fast-fold-following' import { getAllContractInfo, useExploreContracts, useFilterYourContracts, useFindActiveContracts, } from '../hooks/use-find-active-contracts' import { useGetRecentBets } from '../hooks/use-bets' import { usePropz } from '../hooks/use-propz' import { useActiveContracts } from '../hooks/use-contracts' export async function getStaticPropz() { const contractInfo = await getAllContractInfo() return { props: contractInfo, revalidate: 60, // regenerate after a minute } } const Home = (props: { contracts: Contract[] folds: Fold[] recentBets: Bet[] recentComments: Comment[] }) => { props = usePropz(getStaticPropz) ?? { contracts: [], folds: [], recentComments: [], } const { folds, recentComments } = props const user = useUser() const contracts = useActiveContracts() ?? props.contracts const { yourContracts, initialFollowedFoldSlugs } = useFilterYourContracts( user, folds, contracts ) const recentBets = useGetRecentBets() const { activeContracts, activeBets, activeComments } = useFindActiveContracts({ contracts: yourContracts, recentBets: recentBets ?? [], recentComments, }) const exploreContracts = useExploreContracts() const [feedMode, setFeedMode] = useState<'activity' | 'explore'>('activity') if (user === null) { Router.replace('/') return <> } return ( {initialFollowedFoldSlugs !== undefined && initialFollowedFoldSlugs.length === 0 && ( )}
setFeedMode('activity')} >
setFeedMode('explore')} >
{feedMode === 'activity' && (recentBets ? ( ) : ( ))} {feedMode === 'explore' && (exploreContracts ? ( ) : ( ))}
) } export default Home