show author username and profile icon on individual video page

This commit is contained in:
MarconLP 2023-04-12 20:58:58 +02:00
parent 082148e0c0
commit 173f1d976d
No known key found for this signature in database
GPG key ID: F4CAFFDFA3451D5E
3 changed files with 44 additions and 4 deletions

View file

@ -32,6 +32,12 @@ const config = {
port: '', port: '',
pathname: '/**', pathname: '/**',
}, },
{
protocol: 'https',
hostname: '*.githubusercontent.com',
port: '',
pathname: '/**',
},
], ],
}, },
}; };

View file

@ -5,6 +5,7 @@ import { api } from "~/utils/api";
import ReactPlayer from "react-player"; import ReactPlayer from "react-player";
import { useRouter } from "next/router"; import { useRouter } from "next/router";
import Link from "next/link"; import Link from "next/link";
import Image from "next/image";
const VideoList: NextPage = () => { const VideoList: NextPage = () => {
const router = useRouter(); const router = useRouter();
@ -52,11 +53,8 @@ const VideoList: NextPage = () => {
</span> </span>
</div> </div>
</div> </div>
<div className="flex h-full w-full grow flex-col items-center justify-start gap-12 overflow-auto bg-[#fbfbfb]"> <div className="flex h-full w-full grow flex-col items-center justify-start overflow-auto bg-[#fbfbfb]">
<div className="flex aspect-video max-h-[1160px] w-full justify-center bg-black"> <div className="flex aspect-video max-h-[1160px] w-full justify-center bg-black">
{/*{true ? (*/}
{/* <div className="aspect-video w-[80%] animate-pulse bg-slate-200 bg-white"></div>*/}
{/*) : null}*/}
{video?.video?.video_url && ( {video?.video?.video_url && (
<ReactPlayer <ReactPlayer
width="100%" width="100%"
@ -66,6 +64,39 @@ const VideoList: NextPage = () => {
/> />
)} )}
</div> </div>
<div className="mb-10 mt-4 w-full max-w-[1800px] pl-[24px]">
<div>
{video?.video?.title ? (
<span className="text-[18px] text-lg font-medium">
{video?.video?.title}
</span>
) : (
<div className="h-6 w-[300px] animate-pulse rounded bg-slate-200"></div>
)}
</div>
<div className="mt-2 flex flex-row items-center">
{!isLoading ? (
<>
<div className="h-10 w-10 overflow-hidden rounded-full">
<Image
width={40}
height={40}
src={video?.video?.user?.image ?? ""}
alt="profile photo"
/>
</div>
<span className="ml-3 font-medium">
{video?.video?.user?.name}
</span>
</>
) : (
<>
<div className="h-10 w-10 animate-pulse overflow-hidden rounded-full bg-red-400 bg-slate-200"></div>
<div className="ml-3 h-4 w-[100px] animate-pulse rounded bg-slate-200 font-medium"></div>
</>
)}
</div>
</div>
</div> </div>
</main> </main>
</> </>

View file

@ -24,6 +24,9 @@ export const videoRouter = createTRPCRouter({
where: { where: {
id: input.videoId, id: input.videoId,
}, },
include: {
user: true,
},
}); });
if (video?.userId !== ctx.session.user.id) { if (video?.userId !== ctx.session.user.id) {