2022-03-30 20:01:24 -07:00
|
|
|
import VisibilityBadge from "../badges/visibility-badge"
|
2022-11-13 23:02:31 -08:00
|
|
|
import { Text, Card, Divider, Button } from "@geist-ui/core/dist"
|
2022-11-12 01:28:06 -08:00
|
|
|
import FadeIn from "@components/fade-in"
|
2022-03-26 00:24:18 -07:00
|
|
|
import Trash from "@geist-ui/icons/trash"
|
2022-11-12 01:28:06 -08:00
|
|
|
import ExpirationBadge from "@components/badges/expiration-badge"
|
|
|
|
import CreatedAgoBadge from "@components/badges/created-ago-badge"
|
2022-04-01 22:55:27 -07:00
|
|
|
import Edit from "@geist-ui/icons/edit"
|
2022-11-11 23:59:33 -08:00
|
|
|
import { useRouter } from "next/navigation"
|
2022-04-09 17:48:19 -07:00
|
|
|
import Parent from "@geist-ui/icons/arrowUpCircle"
|
2022-04-01 22:55:27 -07:00
|
|
|
import styles from "./list-item.module.css"
|
2022-11-12 01:28:06 -08:00
|
|
|
import Link from "@components/link"
|
2022-11-11 23:59:33 -08:00
|
|
|
import type { PostWithFiles } from "@lib/server/prisma"
|
|
|
|
import type { PostVisibility } from "@lib/types"
|
|
|
|
import type { File } from "@lib/server/prisma"
|
2022-11-12 18:39:03 -08:00
|
|
|
import Tooltip from "@components/tooltip"
|
2022-11-13 23:02:31 -08:00
|
|
|
import Badge from "@components/badges/badge"
|
2022-03-09 17:11:37 -08:00
|
|
|
|
2022-03-26 00:05:05 -07:00
|
|
|
// TODO: isOwner should default to false so this can be used generically
|
2022-04-09 17:48:19 -07:00
|
|
|
const ListItem = ({
|
|
|
|
post,
|
|
|
|
isOwner = true,
|
|
|
|
deletePost
|
|
|
|
}: {
|
2022-11-09 23:11:36 -08:00
|
|
|
post: PostWithFiles
|
2022-04-09 17:48:19 -07:00
|
|
|
isOwner?: boolean
|
|
|
|
deletePost: () => void
|
|
|
|
}) => {
|
|
|
|
const router = useRouter()
|
2022-03-30 23:03:21 -07:00
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
const editACopy = () => {
|
|
|
|
router.push(`/new/from/${post.id}`)
|
|
|
|
}
|
2022-03-09 17:11:37 -08:00
|
|
|
|
2022-04-14 17:18:47 -07:00
|
|
|
const viewParentClick = () => {
|
2022-11-09 23:11:36 -08:00
|
|
|
router.push(`/post/${post.parentId}`)
|
2022-04-14 17:18:47 -07:00
|
|
|
}
|
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
return (
|
|
|
|
<FadeIn>
|
|
|
|
<li key={post.id}>
|
|
|
|
<Card style={{ overflowY: "scroll" }}>
|
|
|
|
<Card.Body>
|
2022-11-13 23:02:31 -08:00
|
|
|
<div className={styles.title}>
|
|
|
|
<h3 style={{ display: "inline-block" }}>
|
|
|
|
<Link
|
|
|
|
colored
|
|
|
|
style={{ marginRight: "var(--gap)" }}
|
|
|
|
href={`/post/${post.id}`}
|
|
|
|
>
|
|
|
|
{post.title}
|
|
|
|
</Link>
|
|
|
|
</h3>
|
2022-04-09 17:48:19 -07:00
|
|
|
{isOwner && (
|
|
|
|
<span className={styles.buttons}>
|
2022-11-09 23:11:36 -08:00
|
|
|
{post.parentId && (
|
2022-11-12 18:39:03 -08:00
|
|
|
<Tooltip content={"View parent"}>
|
2022-04-09 17:48:19 -07:00
|
|
|
<Button
|
|
|
|
auto
|
|
|
|
icon={<Parent />}
|
2022-04-14 17:18:47 -07:00
|
|
|
onClick={viewParentClick}
|
2022-04-09 17:48:19 -07:00
|
|
|
/>
|
|
|
|
</Tooltip>
|
|
|
|
)}
|
2022-11-12 18:39:03 -08:00
|
|
|
<Tooltip content={"Make a copy"}>
|
2022-04-09 17:48:19 -07:00
|
|
|
<Button auto iconRight={<Edit />} onClick={editACopy} />
|
|
|
|
</Tooltip>
|
2022-11-12 18:39:03 -08:00
|
|
|
<Tooltip content={"Delete"}>
|
2022-04-09 17:48:19 -07:00
|
|
|
<Button iconRight={<Trash />} onClick={deletePost} auto />
|
|
|
|
</Tooltip>
|
|
|
|
</span>
|
|
|
|
)}
|
2022-11-13 23:02:31 -08:00
|
|
|
</div>
|
2022-03-26 00:05:05 -07:00
|
|
|
|
2022-04-14 23:25:31 +02:00
|
|
|
{post.description && (
|
2022-11-13 23:02:31 -08:00
|
|
|
<p className={styles.oneline}>{post.description}</p>
|
2022-04-14 23:25:31 +02:00
|
|
|
)}
|
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
<div className={styles.badges}>
|
2022-11-09 23:11:36 -08:00
|
|
|
<VisibilityBadge visibility={post.visibility as PostVisibility} />
|
2022-04-09 17:48:19 -07:00
|
|
|
<Badge type="secondary">
|
|
|
|
{post.files?.length === 1
|
|
|
|
? "1 file"
|
|
|
|
: `${post.files?.length || 0} files`}
|
|
|
|
</Badge>
|
2022-11-13 23:02:31 -08:00
|
|
|
<CreatedAgoBadge createdAt={post.createdAt} />
|
2022-04-09 17:48:19 -07:00
|
|
|
<ExpirationBadge postExpirationDate={post.expiresAt} />
|
|
|
|
</div>
|
|
|
|
</Card.Body>
|
|
|
|
<Divider h="1px" my={0} />
|
|
|
|
<Card.Content>
|
2022-11-11 23:59:33 -08:00
|
|
|
{post?.files?.map((file: File) => {
|
2022-04-09 17:48:19 -07:00
|
|
|
return (
|
|
|
|
<div key={file.id}>
|
2022-11-08 00:23:28 -08:00
|
|
|
<Link colored href={`/post/${post.id}#${file.title}`}>
|
2022-04-09 17:48:19 -07:00
|
|
|
{file.title || "Untitled file"}
|
|
|
|
</Link>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
})}
|
|
|
|
</Card.Content>
|
|
|
|
</Card>
|
2022-11-11 23:59:33 -08:00
|
|
|
</li>
|
2022-04-09 17:48:19 -07:00
|
|
|
</FadeIn>
|
|
|
|
)
|
2022-03-09 17:11:37 -08:00
|
|
|
}
|
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
export default ListItem
|