ai-tube / src /app /music /page.tsx
jbilcke-hf's picture
jbilcke-hf HF staff
working on some new features
3d4392e
import { AppQueryProps } from "@/types/general"
import { Main } from "../main"
import { getVideos } from "../api/actions/ai-tube-hf/getVideos"
import { getVideo } from "../api/actions/ai-tube-hf/getVideo"
import { Metadata } from "next"
// https://nextjs.org/docs/pages/building-your-application/optimizing/fonts
export async function generateMetadata(
{ params, searchParams: { m: mediaId } }: AppQueryProps,
// parent: ResolvingMetadata
): Promise<Metadata> {
// read route params
const metadataBase = new URL('https://huggingface.co/spaces/jbilcke-hf/ai-tube')
try {
const publicTrack = await getVideo({ videoId: mediaId, neverThrow: true })
if (!publicTrack) {
throw new Error("Video not found")
}
const openGraph = {
// 'music.song' | 'music.album' | 'music.playlist' | 'music.radio_station'
// | 'profile' | 'website' | 'video.tv_show' | 'video.other' | 'video.movie' | 'video.episode';
type: "music.song",
duration: publicTrack.duration,
// albums?: null | string | URL | OGAlbum | Array<string | URL | OGAlbum>;
musicians: [publicTrack.channel.label, "AI (MusicGen)"],
// url: "https://example.com",
title: `${publicTrack.channel.label} - ${publicTrack.label}` || "", // put the video title here
description: publicTrack.description || "", // put the vide description here
siteName: "AiTube Music",
images: [
`https://huggingface.co/datasets/jbilcke-hf/ai-tube-index/resolve/main/videos/${publicTrack.id}.webp`
],
audio: [
{
"url": publicTrack.assetUrl
}
]
}
return {
title: `${publicTrack.label} - AiTube Music`,
metadataBase,
openGraph,
}
} catch (err) {
return {
title: "AiTube Music",
metadataBase,
openGraph: {
type: "website",
// url: "https://example.com",
title: "AiTube Music", // put the video title here
description: "", // put the vide description here
siteName: "AiTube Music",
videos: [],
images: [],
},
}
}
}
export default async function MusicPage({ searchParams: { m: mediaId } }: AppQueryProps) {
const publicTracks = await getVideos({
sortBy: "date",
mandatoryTags: ["music"],
maxNbMedias: 25,
neverThrow: true,
})
// at some point we will probably migrate to a getMedia({ mediaId }) instead
const publicTrack = await getVideo({
videoId: mediaId,
neverThrow: true
})
return (<Main publicTracks={publicTracks} publicTrack={publicTrack} />)
}