CoastalCommitsPastes/client/app/components/post-list/list-item.tsx

114 lines
2.9 KiB
TypeScript
Raw Normal View History

import VisibilityBadge from "../badges/visibility-badge"
2022-11-12 01:28:06 -08:00
import FadeIn from "@components/fade-in"
import ExpirationBadge from "@components/badges/expiration-badge"
import CreatedAgoBadge from "@components/badges/created-ago-badge"
import { useRouter } from "next/navigation"
import styles from "./list-item.module.css"
2022-11-12 01:28:06 -08:00
import Link from "@components/link"
import type { PostWithFiles } from "@lib/server/prisma"
import type { File } from "@lib/server/prisma"
2022-11-12 18:39:03 -08:00
import Tooltip from "@components/tooltip"
import Badge from "@components/badges/badge"
import Card from "@components/card"
import Button from "@components/button"
import { ArrowUpCircle, Edit, Trash } from "react-feather"
2022-03-09 17:11:37 -08: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-04-09 17:48:19 -07:00
const editACopy = () => {
router.push(`/new/from/${post.id}`)
}
2022-03-09 17:11:37 -08:00
const viewParentClick = () => {
2022-11-09 23:11:36 -08:00
router.push(`/post/${post.parentId}`)
}
2022-04-09 17:48:19 -07:00
return (
<FadeIn>
<li key={post.id}>
<Card style={{ overflowY: "scroll" }}>
<>
<div className={styles.title}>
<h3 style={{ display: "inline-block", margin: 0 }}>
<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
iconRight={<ArrowUpCircle />}
onClick={viewParentClick}
height={38}
2022-04-09 17:48:19 -07:00
/>
</Tooltip>
)}
2022-11-12 18:39:03 -08:00
<Tooltip content={"Make a copy"}>
2022-11-17 22:36:53 -08:00
<Button
iconRight={<Edit />}
onClick={editACopy}
height={38}
/>
2022-04-09 17:48:19 -07:00
</Tooltip>
2022-11-12 18:39:03 -08:00
<Tooltip content={"Delete"}>
2022-11-17 22:36:53 -08:00
<Button
iconRight={<Trash />}
onClick={deletePost}
height={38}
/>
2022-04-09 17:48:19 -07:00
</Tooltip>
</span>
)}
</div>
{post.description && (
<p className={styles.oneline}>{post.description}</p>
)}
2022-04-09 17:48:19 -07:00
<div className={styles.badges}>
2022-11-14 18:39:42 -08:00
<VisibilityBadge visibility={post.visibility} />
2022-04-09 17:48:19 -07:00
<Badge type="secondary">
{post.files?.length === 1
? "1 file"
: `${post.files?.length || 0} files`}
</Badge>
<CreatedAgoBadge createdAt={post.createdAt} />
2022-04-09 17:48:19 -07:00
<ExpirationBadge postExpirationDate={post.expiresAt} />
</div>
</>
<hr />
<>
{post?.files?.map((file: File) => {
2022-04-09 17:48:19 -07:00
return (
<div key={file.id}>
<Link colored href={`/post/${post.id}#${file.title}`}>
2022-04-09 17:48:19 -07:00
{file.title || "Untitled file"}
</Link>
</div>
)
})}
</>
2022-04-09 17:48:19 -07:00
</Card>
</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