fix(LockupView): Add overlay nodes used by VIDEO views

This commit is contained in:
Luan
2025-01-25 11:59:17 -03:00
parent 3ffdee9554
commit 424c65356c
6 changed files with 63 additions and 5 deletions

View File

@@ -0,0 +1,18 @@
import type { ObservedArray } from '../helpers.js';
import { YTNode } from '../helpers.js';
import { Parser, type RawNode } from '../index.js';
import ThumbnailBadgeView from './ThumbnailBadgeView.js';
import ThumbnailOverlayProgressBarView from './ThumbnailOverlayProgressBarView.js';
export default class ThumbnailBottomOverlayView extends YTNode {
static type = 'ThumbnailBottomOverlayView';
public progress_bar: ThumbnailOverlayProgressBarView | null;
public badges: ObservedArray<ThumbnailBadgeView>;
constructor(data: RawNode) {
super();
this.progress_bar = Parser.parseItem(data.progressBar, ThumbnailOverlayProgressBarView);
this.badges = Parser.parseArray(data.badges, ThumbnailBadgeView);
}
}

View File

@@ -0,0 +1,15 @@
import type { ObservedArray } from '../helpers.js';
import { YTNode } from '../helpers.js';
import { Parser, type RawNode } from '../index.js';
import ToggleButtonView from './ToggleButtonView.js';
export default class ThumbnailHoverOverlayToggleActionsView extends YTNode {
static type = 'ThumbnailHoverOverlayToggleActionsView';
public buttons: ObservedArray<ToggleButtonView>;
constructor(data: RawNode) {
super();
this.buttons = Parser.parseArray(data.buttons, ToggleButtonView);
}
}

View File

@@ -5,8 +5,8 @@ import ThumbnailBadgeView from './ThumbnailBadgeView.js';
export default class ThumbnailOverlayBadgeView extends YTNode {
static type = 'ThumbnailOverlayBadgeView';
badges: ThumbnailBadgeView[];
position: string;
public badges: ThumbnailBadgeView[];
public position: string;
constructor(data: RawNode) {
super();

View File

@@ -0,0 +1,13 @@
import { YTNode } from '../helpers.js';
import { type RawNode } from '../index.js';
export default class ThumbnailOverlayProgressBarView extends YTNode {
static type = 'ThumbnailOverlayProgressBarView';
public start_percent: number;
constructor(data: RawNode) {
super();
this.start_percent = data.startPercent;
}
}

View File

@@ -1,8 +1,11 @@
import type { ObservedArray } from '../helpers.js';
import { YTNode } from '../helpers.js';
import { Parser, type RawNode } from '../index.js';
import ThumbnailHoverOverlayView from './ThumbnailHoverOverlayView.js';
import ThumbnailOverlayBadgeView from './ThumbnailOverlayBadgeView.js';
import Thumbnail from './misc/Thumbnail.js';
import ThumbnailHoverOverlayToggleActionsView from './ThumbnailHoverOverlayToggleActionsView.js';
import ThumbnailBottomOverlayView from './ThumbnailBottomOverlayView.js';
export type ThumbnailBackgroundColor = {
light_theme: number;
@@ -13,15 +16,21 @@ export default class ThumbnailView extends YTNode {
static type = 'ThumbnailView';
public image: Thumbnail[];
public overlays: (ThumbnailOverlayBadgeView | ThumbnailHoverOverlayView)[];
public overlays: ObservedArray<
ThumbnailHoverOverlayToggleActionsView | ThumbnailBottomOverlayView |
ThumbnailOverlayBadgeView | ThumbnailHoverOverlayView
>;
public background_color?: ThumbnailBackgroundColor;
constructor(data: RawNode) {
super();
this.image = Thumbnail.fromResponse(data.image);
this.overlays = Parser.parseArray(data.overlays, [ ThumbnailOverlayBadgeView, ThumbnailHoverOverlayView ]);
this.overlays = Parser.parseArray(data.overlays, [
ThumbnailHoverOverlayToggleActionsView, ThumbnailBottomOverlayView,
ThumbnailOverlayBadgeView, ThumbnailHoverOverlayView
]);
if ('backgroundColor' in data) {
this.background_color = {
light_theme: data.backgroundColor.lightTheme,

View File

@@ -455,6 +455,8 @@ export { default as TextFieldView } from './classes/TextFieldView.js';
export { default as TextHeader } from './classes/TextHeader.js';
export { default as ThirdPartyShareTargetSection } from './classes/ThirdPartyShareTargetSection.js';
export { default as ThumbnailBadgeView } from './classes/ThumbnailBadgeView.js';
export { default as ThumbnailBottomOverlayView } from './classes/ThumbnailBottomOverlayView.js';
export { default as ThumbnailHoverOverlayToggleActionsView } from './classes/ThumbnailHoverOverlayToggleActionsView.js';
export { default as ThumbnailHoverOverlayView } from './classes/ThumbnailHoverOverlayView.js';
export { default as ThumbnailLandscapePortrait } from './classes/ThumbnailLandscapePortrait.js';
export { default as ThumbnailOverlayBadgeView } from './classes/ThumbnailOverlayBadgeView.js';
@@ -466,6 +468,7 @@ export { default as ThumbnailOverlayLoadingPreview } from './classes/ThumbnailOv
export { default as ThumbnailOverlayNowPlaying } from './classes/ThumbnailOverlayNowPlaying.js';
export { default as ThumbnailOverlayPinking } from './classes/ThumbnailOverlayPinking.js';
export { default as ThumbnailOverlayPlaybackStatus } from './classes/ThumbnailOverlayPlaybackStatus.js';
export { default as ThumbnailOverlayProgressBarView } from './classes/ThumbnailOverlayProgressBarView.js';
export { default as ThumbnailOverlayResumePlayback } from './classes/ThumbnailOverlayResumePlayback.js';
export { default as ThumbnailOverlaySidePanel } from './classes/ThumbnailOverlaySidePanel.js';
export { default as ThumbnailOverlayTimeStatus } from './classes/ThumbnailOverlayTimeStatus.js';