51 lines
1.3 KiB
TypeScript
51 lines
1.3 KiB
TypeScript
import React from 'react'
|
|
import Router from 'next/router'
|
|
|
|
import { Contract, getHotContracts } from '../lib/firebase/contracts'
|
|
import { Page } from '../components/page'
|
|
import { FeedPromo } from '../components/feed-create'
|
|
import { Col } from '../components/layout/col'
|
|
import { useUser } from '../hooks/use-user'
|
|
import { ManifoldLogo } from '../components/nav/manifold-logo'
|
|
|
|
export async function getStaticProps() {
|
|
const hotContracts = (await getHotContracts().catch(() => [])) ?? []
|
|
|
|
return {
|
|
props: { hotContracts },
|
|
revalidate: 60, // regenerate after a minute
|
|
}
|
|
}
|
|
|
|
const Home = (props: { hotContracts: Contract[] }) => {
|
|
const { hotContracts } = props
|
|
|
|
const user = useUser()
|
|
|
|
if (user) {
|
|
Router.replace('/home')
|
|
return <></>
|
|
}
|
|
|
|
return (
|
|
<Page assertUser="signed-out">
|
|
<div className="px-4 pt-2 md:mt-0 lg:hidden">
|
|
<ManifoldLogo />
|
|
</div>
|
|
<Col className="items-center">
|
|
<Col className="max-w-3xl">
|
|
<FeedPromo hotContracts={hotContracts ?? []} />
|
|
{/* <p className="mt-6 text-gray-500">
|
|
View{' '}
|
|
<SiteLink href="/markets" className="font-bold text-gray-700">
|
|
all markets
|
|
</SiteLink>
|
|
</p> */}
|
|
</Col>
|
|
</Col>
|
|
</Page>
|
|
)
|
|
}
|
|
|
|
export default Home
|