refactor: clean up parser and tests (#387)

* tests: improve coverage

* refactor: clean up nodes

* chore: lint

* feat(parser): ignore `BrandVideoShelf`

Seems to be used for ads.

* feat(parser): ignore `BrandVideoSingleton` too
This commit is contained in:
LuanRT
2023-04-23 06:37:33 -03:00
committed by GitHub
parent f66f0bd656
commit 257bd475a0
358 changed files with 2823 additions and 3126 deletions

View File

@@ -1,25 +1,22 @@
import Parser from '../index.js';
import { YTNode } from '../helpers.js';
import Parser, { type RawNode } from '../index.js';
import Menu from './menus/Menu.js';
import Text from './misc/Text.js';
import Thumbnail from './misc/Thumbnail.js';
import Menu from './menus/Menu.js';
class MusicVisualHeader extends YTNode {
export default class MusicVisualHeader extends YTNode {
static type = 'MusicVisualHeader';
title;
thumbnails;
menu;
foreground_thumbnails;
title: Text;
thumbnail: Thumbnail[];
menu: Menu | null;
foreground_thumbnail: Thumbnail[];
constructor(data: any) {
constructor(data: RawNode) {
super();
this.title = new Text(data.title);
this.thumbnails = data.thumbnail ? Thumbnail.fromResponse(data.thumbnail.musicThumbnailRenderer?.thumbnail) : [];
this.thumbnail = data.thumbnail ? Thumbnail.fromResponse(data.thumbnail.musicThumbnailRenderer?.thumbnail) : [];
this.menu = Parser.parseItem(data.menu, Menu);
this.foreground_thumbnails = data.foregroundThumbnail ? Thumbnail.fromResponse(data.foregroundThumbnail.musicThumbnailRenderer?.thumbnail) : [];
this.foreground_thumbnail = data.foregroundThumbnail ? Thumbnail.fromResponse(data.foregroundThumbnail.musicThumbnailRenderer?.thumbnail) : [];
}
}
export default MusicVisualHeader;
}