import _ from 'lodash' import { ContractsGrid, SearchableGrid } from '../components/contracts-list' import { Spacer } from '../components/layout/spacer' import { Page } from '../components/page' import { Title } from '../components/title' import { useContracts, useHotContracts } from '../hooks/use-contracts' import { useQueryAndSortParams } from '../hooks/use-sort-and-query-params' import { Contract, getHotContracts, listAllContracts, } from '../lib/firebase/contracts' export async function getStaticProps() { const [contracts, hotContractIds] = await Promise.all([ listAllContracts().catch((_) => []), getHotContracts().catch(() => []), ]) return { props: { contracts, hotContractIds, }, revalidate: 60, // regenerate after a minute } } export default function Markets(props: { contracts: Contract[] hotContractIds: string[] }) { const contracts = useContracts() const { query, setQuery, sort, setSort } = useQueryAndSortParams() const hotContractIds = useHotContracts() const readyHotContractIds = hotContractIds === 'loading' ? props.hotContractIds : hotContractIds const readyContracts = contracts === 'loading' ? props.contracts : contracts const hotContracts = readyHotContractIds.map( (hotId) => _.find(readyContracts, (contract) => contract.id === hotId) as Contract ) return ( <Page> <div className="w-full bg-indigo-50 border-2 border-indigo-100 p-6 rounded-lg shadow-md"> <Title className="mt-0" text="🔥 Markets" /> <ContractsGrid contracts={hotContracts} /> </div> <Spacer h={10} /> {(props.contracts || contracts !== 'loading') && ( <SearchableGrid contracts={readyContracts} query={query} setQuery={setQuery} sort={sort} setSort={setSort} /> )} </Page> ) }