mirror of
https://github.com/VueTubeApp/VueTube
synced 2024-11-16 00:15:08 +00:00
51 lines
1.3 KiB
Vue
51 lines
1.3 KiB
Vue
<template>
|
|
<base-video-renderer
|
|
:vidId="video.videoId"
|
|
:thumbnails="video.thumbnail.thumbnails"
|
|
:thumbnailOverlayStyle="thumbnailOverlayStyle"
|
|
:thumbnailOverlayText="thumbnailOverlayText"
|
|
:channelUrl="
|
|
$rendererUtils.getNavigationEndpoints(
|
|
video.shortBylineText.runs[0].navigationEndpoint
|
|
)
|
|
"
|
|
:channelIcon="video.channelThumbnail.thumbnails[0].url"
|
|
:titles="video.title.runs"
|
|
:bottomText="parseBottom(video)"
|
|
>
|
|
</base-video-renderer>
|
|
</template>
|
|
|
|
<script>
|
|
import baseVideoRenderer from "~/components/UtilRenderers/baseVideoRenderer.vue";
|
|
export default {
|
|
props: ["video"],
|
|
|
|
components: {
|
|
baseVideoRenderer,
|
|
},
|
|
|
|
computed: {
|
|
thumbnailOverlayText() {
|
|
return this.video.thumbnailOverlays[0]?.thumbnailOverlayTimeStatusRenderer
|
|
?.text.runs[0].text;
|
|
},
|
|
thumbnailOverlayStyle() {
|
|
return this.video.thumbnailOverlays[0]?.thumbnailOverlayTimeStatusRenderer
|
|
?.style;
|
|
},
|
|
},
|
|
|
|
methods: {
|
|
parseBottom(video) {
|
|
const bottomText = [
|
|
video.shortBylineText?.runs[0].text,
|
|
video.shortViewCountText?.runs[0].text,
|
|
];
|
|
if (video.publishedTimeText?.runs[0].text)
|
|
bottomText.push(video.publishedTimeText?.runs[0].text);
|
|
return bottomText.join(" · ");
|
|
},
|
|
},
|
|
};
|
|
</script>
|