fp/services/next/app/components/vtuber-card.tsx

44 lines
1.9 KiB
TypeScript
Raw Normal View History

2024-01-20 16:16:14 +00:00
import Link from "next/link";
2024-07-15 16:07:04 +00:00
import type { IVtuber } from '@futureporn/types';
2024-07-10 22:11:18 +00:00
import { getVodsForVtuber } from "@/app/lib/vods";
2024-06-13 02:54:44 +00:00
import Image from "next/legacy/image"
2024-07-10 22:11:18 +00:00
import NotFound from "@/app/vt/[slug]/not-found";
2024-01-20 16:16:14 +00:00
import ArchiveProgress from "./archive-progress";
export default async function VTuberCard(vtuber: IVtuber) {
2024-12-12 07:23:46 +00:00
const { id, slug, display_name, image_blur, image } = vtuber;
2025-01-11 03:10:04 +00:00
if (!image_blur) return <div className="column is-full-mobile is-half-tablet"><div className="card"><div className="card-content">This VTuberCard is missing image_blur</div></div></div>
2024-01-20 16:16:14 +00:00
const vods = await getVodsForVtuber(id)
if (!vods) return <NotFound></NotFound>
return (
<Link
href={"/vt/"+slug}
className="column is-full-mobile is-half-tablet"
>
<div className="card">
<div className="card-content">
<div className="media">
<div className="media-left">
<figure className="image is-48x48">
<Image
className="is-rounded"
src={image}
2024-12-12 07:23:46 +00:00
alt={display_name}
2024-06-13 01:38:11 +00:00
objectFit="cover"
2024-01-20 16:16:14 +00:00
placeholder="blur"
2024-12-12 07:23:46 +00:00
blurDataURL={image_blur}
2024-01-20 16:16:14 +00:00
width={48}
height={48}
/>
</figure>
</div>
<div className="media-content">
2024-12-12 07:23:46 +00:00
<p className="title is-4 mb-3">{display_name}</p>
2024-01-20 16:16:14 +00:00
<ArchiveProgress vtuber={vtuber}/>
</div>
</div>
</div>
</div>
</Link>
)
}