Date docs
This commit is contained in:
parent
a12ed78813
commit
1e3e931d16
|
@ -9,4 +9,11 @@ export type Post = {
|
||||||
slug: string
|
slug: string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export type DateDoc = Post & {
|
||||||
|
bounty: number
|
||||||
|
birthday: number
|
||||||
|
profilePicUrl: string
|
||||||
|
type: 'date-doc'
|
||||||
|
}
|
||||||
|
|
||||||
export const MAX_POST_TITLE_LENGTH = 480
|
export const MAX_POST_TITLE_LENGTH = 480
|
||||||
|
|
|
@ -6,8 +6,8 @@ import {
|
||||||
updateDoc,
|
updateDoc,
|
||||||
where,
|
where,
|
||||||
} from 'firebase/firestore'
|
} from 'firebase/firestore'
|
||||||
import { Post } from 'common/post'
|
import { DateDoc, Post } from 'common/post'
|
||||||
import { coll, getValue, listenForValue } from './utils'
|
import { coll, getValue, getValues, listenForValue } from './utils'
|
||||||
|
|
||||||
export const posts = coll<Post>('posts')
|
export const posts = coll<Post>('posts')
|
||||||
|
|
||||||
|
@ -44,3 +44,8 @@ export async function listPosts(postIds?: string[]) {
|
||||||
if (postIds === undefined) return []
|
if (postIds === undefined) return []
|
||||||
return Promise.all(postIds.map(getPost))
|
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