Make tags page filter on server side (#108)
This commit is contained in:
parent
760681f958
commit
2ddd95e904
|
@ -115,6 +115,18 @@ export async function listContracts(creatorId: string): Promise<Contract[]> {
|
||||||
return snapshot.docs.map((doc) => doc.data() as Contract)
|
return snapshot.docs.map((doc) => doc.data() as Contract)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export async function listTaggedContractsCaseInsensitive(
|
||||||
|
tag: string
|
||||||
|
): Promise<Contract[]> {
|
||||||
|
const q = query(
|
||||||
|
contractCollection,
|
||||||
|
where('lowercaseTags', 'array-contains', tag.toLowerCase()),
|
||||||
|
orderBy('createdTime', 'desc')
|
||||||
|
)
|
||||||
|
const snapshot = await getDocs(q)
|
||||||
|
return snapshot.docs.map((doc) => doc.data() as Contract)
|
||||||
|
}
|
||||||
|
|
||||||
export async function listAllContracts(): Promise<Contract[]> {
|
export async function listAllContracts(): Promise<Contract[]> {
|
||||||
const q = query(contractCollection, orderBy('createdTime', 'desc'))
|
const q = query(contractCollection, orderBy('createdTime', 'desc'))
|
||||||
const snapshot = await getDocs(q)
|
const snapshot = await getDocs(q)
|
||||||
|
|
|
@ -1,39 +1,33 @@
|
||||||
|
import { useEffect, useState } from 'react'
|
||||||
import { useRouter } from 'next/router'
|
import { useRouter } from 'next/router'
|
||||||
import { SearchableGrid } from '../../components/contract/contracts-list'
|
import { SearchableGrid } from '../../components/contract/contracts-list'
|
||||||
import { Page } from '../../components/page'
|
import { Page } from '../../components/page'
|
||||||
import { Title } from '../../components/title'
|
import { Title } from '../../components/title'
|
||||||
import { useContracts } from '../../hooks/use-contracts'
|
import { useContracts } from '../../hooks/use-contracts'
|
||||||
import { Contract, listAllContracts } from '../../lib/firebase/contracts'
|
import {
|
||||||
|
Contract,
|
||||||
export async function getStaticProps() {
|
listTaggedContractsCaseInsensitive,
|
||||||
const contracts = await listAllContracts().catch((_) => [])
|
} from '../../lib/firebase/contracts'
|
||||||
return {
|
|
||||||
props: {
|
|
||||||
contracts,
|
|
||||||
},
|
|
||||||
|
|
||||||
revalidate: 60, // regenerate after a minute
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export async function getStaticPaths() {
|
|
||||||
return { paths: [], fallback: 'blocking' }
|
|
||||||
}
|
|
||||||
|
|
||||||
export default function TagPage(props: { contracts: Contract[] }) {
|
export default function TagPage(props: { contracts: Contract[] }) {
|
||||||
const router = useRouter()
|
const router = useRouter()
|
||||||
const { tag } = router.query as { tag: string }
|
const { tag } = router.query as { tag: string }
|
||||||
|
|
||||||
const contracts = useContracts()
|
// mqp: i wrote this in a panic to make the page literally work at all so if you
|
||||||
|
// want to e.g. listen for new contracts you may want to fix it up
|
||||||
|
const [contracts, setContracts] = useState<Contract[] | 'loading'>('loading')
|
||||||
|
useEffect(() => {
|
||||||
|
if (tag != null) {
|
||||||
|
listTaggedContractsCaseInsensitive(tag).then(setContracts)
|
||||||
|
}
|
||||||
|
}, [tag])
|
||||||
|
|
||||||
const taggedContracts = (contracts ?? props.contracts).filter((contract) =>
|
if (contracts === 'loading') return <></>
|
||||||
contract.lowercaseTags.includes(tag.toLowerCase())
|
|
||||||
)
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Page>
|
<Page>
|
||||||
<Title text={`#${tag}`} />
|
<Title text={`#${tag}`} />
|
||||||
<SearchableGrid contracts={taggedContracts} />
|
<SearchableGrid contracts={contracts} />
|
||||||
</Page>
|
</Page>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user