fp/services/next/app/components/stream.tsx

86 lines
2.8 KiB
TypeScript

import { IStream } from "@futureporn/types";
import NotFound from "@/app/vt/[slug]/not-found";
import { LocalizedDate } from "./localized-date";
import Link from "next/link";
import ChaturbateIcon from "@/app/components/icons/chaturbate";
import FanslyIcon from "@/app/components/icons/fansly";
import Image from "next/legacy/image";
export interface IStreamProps {
stream: IStream;
}
export function Stream({ stream }: IStreamProps) {
if (!stream) return <NotFound></NotFound>
return (
<div className="box">
<pre>
<code>
{JSON.stringify(stream, null, 2)}
</code>
</pre>
{/* <h3 className="title is-3">Stream {stream.attributes.date}</h3> */}
</div>
)
}
export function StreamSummary ({ stream }: IStreamProps) {
if (!stream) return <NotFound></NotFound>
// return (
// <pre>
// <code>
// {JSON.stringify(stream, null, 2)}
// </code>
// </pre>
// )
const archiveStatus = stream.attributes.archiveStatus;
const archiveStatusClassName = (() => {
if (archiveStatus === 'missing') return 'is-danger';
if (archiveStatus === 'good') return 'is-success';
if (archiveStatus === 'issue') return 'is-warning';
})();
return (
<Link href={`/streams/${stream.uuid}`}>
<div className="columns">
{/* <pre>
<code>
{JSON.stringify(stream, null, 2)}
</code>
</pre> */}
<div className="column is-narrow">
<span className="icon image">
<Image
className='is-rounded'
src={stream.vtuber.image}
alt={stream.vtuber.display_name}
width={28}
height={18}
/>
</span>
</div>
<div className="column">
<span>{stream.vtuber.display_name}</span>
</div>
<div className="column">
<LocalizedDate date={new Date(stream.date)}/>
</div>
<div className="column">
{(stream.is_chaturbate_stream) && <ChaturbateIcon width={18} height={18} className='mr-2'></ChaturbateIcon>}
{(stream.is_fansly_stream) && <FanslyIcon width={18}></FanslyIcon>}
</div>
<div className="column">
<div className={`tag ${archiveStatusClassName}`}>{stream.archive_status}</div>
</div>
<div className="column">
<div className=""></div>
</div>
</div>
</Link>
)
}