import { getUrl, getNextVod, getPreviousVod, getLocalizedDate } from '@/app/lib/vods'; import { IVod } from '@/app/lib/vods'; import Link from 'next/link'; import { VideoInteractive } from './video-interactive'; import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; import { faChevronLeft, faChevronRight, faGlobe, faImage, faLink } from "@fortawesome/free-solid-svg-icons"; import { notFound } from 'next/navigation'; import { IpfsCid } from './ipfs-cid'; import LinkableHeading from './linkable-heading'; import Image from "next/legacy/image"; import Thumbnail from './thumbnail'; export function getVodTitle(vod: IVod): string { // console.log('lets getVodTitle, ey?') // console.log(JSON.stringify(vod, null, 2)) return vod.title || vod.announce_title || `VOD ${vod.id}` // return vod.title || vod.announceTitle || (vod?.date2 && vod?.vtuber?.display_name) ? `${vod.vtuber.display_name} ${vod.date_2}` : `VOD ${vod.id}`; } export function buildMuxUrl(playbackId: string, token: string) { return `https://stream.mux.com/${playbackId}.m3u8?token=${token}` } export function buildMuxSignedPlaybackId(playbackId: string, token: string) { return `${playbackId}?token=${token}` } export function buildMuxThumbnailUrl(playbackId: string, token: string) { return `https://image.mux.com/${playbackId}/storyboard.vtt?token=${token}` } export default async function VodPage({vod}: { vod: IVod }) { if (!vod) notFound(); if (!vod.vtuber) { throw new Error(`vod.vtuber was falsy.`) } const slug = vod.vtuber.slug; const previousVod = await getPreviousVod(vod); const nextVod = await getNextVod(vod); // return
{JSON.stringify(previousVod, null, 2)}
// return {slug} VOD @todo previousVod={previousVod.title} nextVod={nextVod?.title}
return ({JSON.stringify(vod, null, 2)}
*/}
{(vod.thumbnail) && (