86 lines
2.8 KiB
TypeScript
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>
|
|
)
|
|
} |