import Parser, { RawNode } from '../index.js'; import Text from './misc/Text.js'; import Thumbnail from './misc/Thumbnail.js'; import NavigationEndpoint from './NavigationEndpoint.js'; import Author from './misc/Author.js'; import type Menu from './menus/Menu.js'; import { YTNode } from '../helpers.js'; class GridVideo extends YTNode { static type = 'GridVideo'; id: string; title: Text; thumbnails: Thumbnail[]; thumbnail_overlays; rich_thumbnail; published: Text; duration: Text | null; author: Author; views: Text; short_view_count: Text; endpoint: NavigationEndpoint; menu: Menu | null; constructor(data: RawNode) { super(); const length_alt = data.thumbnailOverlays.find((overlay: any) => overlay.hasOwnProperty('thumbnailOverlayTimeStatusRenderer'))?.thumbnailOverlayTimeStatusRenderer; this.id = data.videoId; this.title = new Text(data.title); this.thumbnails = Thumbnail.fromResponse(data.thumbnail); this.thumbnail_overlays = Parser.parseArray(data.thumbnailOverlays); this.rich_thumbnail = data.richThumbnail && Parser.parseItem(data.richThumbnail); this.published = new Text(data.publishedTimeText); this.duration = data.lengthText ? new Text(data.lengthText) : length_alt?.text ? new Text(length_alt.text) : null; this.author = data.shortBylineText && new Author(data.shortBylineText, data.ownerBadges); this.views = new Text(data.viewCountText); this.short_view_count = new Text(data.shortViewCountText); this.endpoint = new NavigationEndpoint(data.navigationEndpoint); this.menu = Parser.parseItem(data.menu); } } export default GridVideo;