Date docs
This commit is contained in:
parent
a12ed78813
commit
1e3e931d16
|
@ -9,4 +9,11 @@ export type Post = {
|
|||
slug: string
|
||||
}
|
||||
|
||||
export type DateDoc = Post & {
|
||||
bounty: number
|
||||
birthday: number
|
||||
profilePicUrl: string
|
||||
type: 'date-doc'
|
||||
}
|
||||
|
||||
export const MAX_POST_TITLE_LENGTH = 480
|
||||
|
|
|
@ -6,8 +6,8 @@ import {
|
|||
updateDoc,
|
||||
where,
|
||||
} from 'firebase/firestore'
|
||||
import { Post } from 'common/post'
|
||||
import { coll, getValue, listenForValue } from './utils'
|
||||
import { DateDoc, Post } from 'common/post'
|
||||
import { coll, getValue, getValues, listenForValue } from './utils'
|
||||
|
||||
export const posts = coll<Post>('posts')
|
||||
|
||||
|
@ -44,3 +44,8 @@ export async function listPosts(postIds?: string[]) {
|
|||
if (postIds === undefined) return []
|
||||
return Promise.all(postIds.map(getPost))
|
||||
}
|
||||
|
||||
export async function getDateDocs() {
|
||||
const q = query(posts, where('type', '==', 'date-doc'))
|
||||
return getValues<DateDoc>(q)
|
||||
}
|
||||
|
|
68
web/pages/date/index.tsx
Normal file
68
web/pages/date/index.tsx
Normal file
|
@ -0,0 +1,68 @@
|
|||
import { Page } from 'web/components/page'
|
||||
import { PlusCircleIcon } from '@heroicons/react/outline'
|
||||
|
||||
import { getDateDocs } from 'web/lib/firebase/posts'
|
||||
import { DateDoc } from 'common/post'
|
||||
import { Title } from 'web/components/title'
|
||||
import { Spacer } from 'web/components/layout/spacer'
|
||||
import { Content } from 'web/components/editor'
|
||||
import { Col } from 'web/components/layout/col'
|
||||
import { useUser } from 'web/hooks/use-user'
|
||||
import { Row } from 'web/components/layout/row'
|
||||
import { Button } from 'web/components/button'
|
||||
import { SiteLink } from 'web/components/site-link'
|
||||
|
||||
export async function getStaticProps() {
|
||||
const dateDocs = await getDateDocs()
|
||||
|
||||
return {
|
||||
props: {
|
||||
dateDocs,
|
||||
},
|
||||
|
||||
revalidate: 60, // regenerate after a minute
|
||||
}
|
||||
}
|
||||
|
||||
export default function DatePage(props: { dateDocs: DateDoc[] }) {
|
||||
const { dateDocs } = props
|
||||
const user = useUser()
|
||||
|
||||
return (
|
||||
<Page>
|
||||
<div className="mx-auto w-full max-w-3xl ">
|
||||
<Row className="items-center justify-between">
|
||||
<Title className="!my-0 px-2 text-blue-400" text="Date docs" />
|
||||
<SiteLink href="/date/create" className="!no-underline">
|
||||
<Button className="flex flex-row gap-1" color="blue">
|
||||
<PlusCircleIcon
|
||||
className={'h-5 w-5 flex-shrink-0 text-white'}
|
||||
aria-hidden="true"
|
||||
/>
|
||||
New
|
||||
</Button>
|
||||
</SiteLink>
|
||||
</Row>
|
||||
<Spacer h={2} />
|
||||
<Col className="gap-4">
|
||||
{dateDocs.map((dateDoc) => (
|
||||
<DateDoc key={dateDoc.id} dateDoc={dateDoc} />
|
||||
))}
|
||||
</Col>
|
||||
</div>
|
||||
</Page>
|
||||
)
|
||||
}
|
||||
|
||||
function DateDoc(props: { dateDoc: DateDoc }) {
|
||||
const { dateDoc } = props
|
||||
const { content } = dateDoc
|
||||
|
||||
return (
|
||||
<div className="rounded-lg bg-white px-6 py-4 sm:py-0">
|
||||
<div className="form-control w-full py-2">
|
||||
<Content content={content} />
|
||||
</div>
|
||||
</div>
|
||||
)
|
||||
}
|
Loading…
Reference in New Issue
Block a user