Skip to content

Commit

Permalink
fix(LockupView): Add overlay nodes used by VIDEO views
Browse files Browse the repository at this point in the history
  • Loading branch information
LuanRT committed Jan 25, 2025
1 parent 3ffdee9 commit 424c653
Show file tree
Hide file tree
Showing 6 changed files with 63 additions and 5 deletions.
18 changes: 18 additions & 0 deletions src/parser/classes/ThumbnailBottomOverlayView.ts
Original file line number Diff line number Diff line change
@@ -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);
}
}
15 changes: 15 additions & 0 deletions src/parser/classes/ThumbnailHoverOverlayToggleActionsView.ts
Original file line number Diff line number Diff line change
@@ -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);
}
}
4 changes: 2 additions & 2 deletions src/parser/classes/ThumbnailOverlayBadgeView.ts
Original file line number Diff line number Diff line change
Expand Up @@ -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();
Expand Down
13 changes: 13 additions & 0 deletions src/parser/classes/ThumbnailOverlayProgressBarView.ts
Original file line number Diff line number Diff line change
@@ -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;
}
}
15 changes: 12 additions & 3 deletions src/parser/classes/ThumbnailView.ts
Original file line number Diff line number Diff line change
@@ -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;
Expand All @@ -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,
Expand Down
3 changes: 3 additions & 0 deletions src/parser/nodes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -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';
Expand All @@ -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';
Expand Down

0 comments on commit 424c653

Please sign in to comment.