44 lines
1.9 KiB
TypeScript
44 lines
1.9 KiB
TypeScript
import Link from "next/link";
|
|
import type { IVtuber } from '@futureporn/types';
|
|
import { getVodsForVtuber } from "@/app/lib/vods";
|
|
import Image from "next/legacy/image"
|
|
import NotFound from "@/app/vt/[slug]/not-found";
|
|
import ArchiveProgress from "./archive-progress";
|
|
|
|
export default async function VTuberCard(vtuber: IVtuber) {
|
|
const { id, slug, display_name, image_blur, image } = vtuber;
|
|
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>
|
|
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}
|
|
alt={display_name}
|
|
objectFit="cover"
|
|
placeholder="blur"
|
|
blurDataURL={image_blur}
|
|
width={48}
|
|
height={48}
|
|
/>
|
|
</figure>
|
|
</div>
|
|
<div className="media-content">
|
|
<p className="title is-4 mb-3">{display_name}</p>
|
|
<ArchiveProgress vtuber={vtuber}/>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</Link>
|
|
)
|
|
} |