2022-11-11 23:59:33 -08:00
|
|
|
"use client"
|
|
|
|
|
2022-11-12 00:58:21 -08:00
|
|
|
import DocumentComponent from "./view-document"
|
2022-03-21 20:30:45 -07:00
|
|
|
|
2022-04-01 16:26:42 -07:00
|
|
|
import { useEffect, useState } from "react"
|
2022-11-11 23:59:33 -08:00
|
|
|
import { useRouter } from "next/navigation"
|
2022-04-12 16:48:12 -07:00
|
|
|
import PasswordModalPage from "./password-modal-wrapper"
|
2022-11-14 01:28:40 -08:00
|
|
|
import { File, PostWithFilesAndAuthor } from "@lib/server/prisma"
|
2022-03-21 20:30:45 -07:00
|
|
|
|
2022-03-22 20:06:15 -07:00
|
|
|
type Props = {
|
2022-11-14 01:28:40 -08:00
|
|
|
post: string | PostWithFilesAndAuthor
|
2022-04-12 16:48:12 -07:00
|
|
|
isProtected?: boolean
|
2022-11-11 23:59:33 -08:00
|
|
|
isAuthor?: boolean
|
2022-03-21 20:30:45 -07:00
|
|
|
}
|
|
|
|
|
2022-11-11 23:59:33 -08:00
|
|
|
const PostPage = ({ post: initialPost, isProtected, isAuthor }: Props) => {
|
2022-11-14 01:28:40 -08:00
|
|
|
const [post, setPost] = useState<PostWithFilesAndAuthor>(
|
|
|
|
typeof initialPost === "string" ? JSON.parse(initialPost) : initialPost
|
2022-04-09 17:48:19 -07:00
|
|
|
)
|
2022-11-29 22:10:51 -08:00
|
|
|
|
2022-04-12 16:48:12 -07:00
|
|
|
const router = useRouter()
|
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
useEffect(() => {
|
|
|
|
if (post.expiresAt) {
|
2022-11-14 01:28:40 -08:00
|
|
|
if (new Date(post.expiresAt) < new Date()) {
|
|
|
|
if (!isAuthor) {
|
|
|
|
router.push("/expired")
|
|
|
|
}
|
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
const expirationDate = new Date(post.expiresAt ? post.expiresAt : "")
|
2022-11-14 01:28:40 -08:00
|
|
|
if (!isAuthor && expirationDate < new Date()) {
|
|
|
|
router.push("/expired")
|
|
|
|
}
|
|
|
|
|
|
|
|
let interval: NodeJS.Timer | null = null
|
|
|
|
if (post.expiresAt) {
|
|
|
|
interval = setInterval(() => {
|
|
|
|
const expirationDate = new Date(
|
|
|
|
post.expiresAt ? post.expiresAt : ""
|
|
|
|
)
|
|
|
|
if (expirationDate < new Date()) {
|
|
|
|
if (!isAuthor) {
|
|
|
|
router.push("/expired")
|
|
|
|
}
|
|
|
|
clearInterval(interval!)
|
|
|
|
}
|
|
|
|
}, 4000)
|
|
|
|
}
|
|
|
|
return () => {
|
|
|
|
if (interval) clearInterval(interval)
|
|
|
|
}
|
|
|
|
}
|
2022-04-09 17:48:19 -07:00
|
|
|
}
|
2022-11-14 01:28:40 -08:00
|
|
|
}, [isAuthor, post.expiresAt, router])
|
2022-04-09 17:48:19 -07:00
|
|
|
|
2022-11-29 22:10:51 -08:00
|
|
|
if (isProtected) {
|
|
|
|
return <PasswordModalPage setPost={setPost} postId={post.id} />
|
|
|
|
}
|
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
return (
|
2022-11-11 19:17:44 -08:00
|
|
|
<>
|
2022-11-12 16:06:23 -08:00
|
|
|
{post.files?.map(({ id, content, title, html }: File) => (
|
2022-11-11 23:59:33 -08:00
|
|
|
<DocumentComponent
|
|
|
|
key={id}
|
|
|
|
title={title}
|
|
|
|
initialTab={"preview"}
|
|
|
|
id={id}
|
|
|
|
content={content}
|
2022-11-12 16:06:23 -08:00
|
|
|
preview={html}
|
2022-11-11 23:59:33 -08:00
|
|
|
/>
|
|
|
|
))}
|
2022-12-04 01:31:51 -08:00
|
|
|
|
2022-11-11 19:17:44 -08:00
|
|
|
</>
|
2022-04-09 17:48:19 -07:00
|
|
|
)
|
2022-03-21 20:30:45 -07:00
|
|
|
}
|
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
export default PostPage
|