mirror of
https://github.com/th-ch/youtube-music.git
synced 2026-01-11 18:41:47 +00:00
fix: fixed an issue where the album name was missing (#1334)
This commit is contained in:
@ -5,6 +5,7 @@ import { getImage, SongInfo } from './song-info';
|
|||||||
|
|
||||||
import { YoutubePlayer } from '../types/youtube-player';
|
import { YoutubePlayer } from '../types/youtube-player';
|
||||||
import { GetState } from '../types/datahost-get-state';
|
import { GetState } from '../types/datahost-get-state';
|
||||||
|
import { VideoDataChangeValue } from '../types/player-api-events';
|
||||||
|
|
||||||
let songInfo: SongInfo = {} as SongInfo;
|
let songInfo: SongInfo = {} as SongInfo;
|
||||||
export const getSongInfo = () => songInfo;
|
export const getSongInfo = () => songInfo;
|
||||||
@ -107,18 +108,22 @@ export default () => {
|
|||||||
pause: (e: Event) => playPausedHandler(e, 'pause'),
|
pause: (e: Event) => playPausedHandler(e, 'pause'),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const waitingEvent = new Set<string>();
|
||||||
// Name = "dataloaded" and abit later "dataupdated"
|
// Name = "dataloaded" and abit later "dataupdated"
|
||||||
apiEvent.detail.addEventListener('videodatachange', (name: string) => {
|
apiEvent.detail.addEventListener('videodatachange', (name: string, videoData) => {
|
||||||
if (name !== 'dataloaded') {
|
if (name === 'dataupdated' && waitingEvent.has(videoData.videoId)) {
|
||||||
return;
|
waitingEvent.delete(videoData.videoId);
|
||||||
}
|
sendSongInfo(videoData);
|
||||||
const video = $<HTMLVideoElement>('video');
|
} else if (name === 'dataloaded') {
|
||||||
video?.dispatchEvent(srcChangedEvent);
|
const video = $<HTMLVideoElement>('video');
|
||||||
|
video?.dispatchEvent(srcChangedEvent);
|
||||||
|
|
||||||
for (const status of ['playing', 'pause'] as const) { // for fix issue that pause event not fired
|
for (const status of ['playing', 'pause'] as const) { // for fix issue that pause event not fired
|
||||||
video?.addEventListener(status, playPausedHandlers[status]);
|
video?.addEventListener(status, playPausedHandlers[status]);
|
||||||
|
}
|
||||||
|
|
||||||
|
waitingEvent.add(videoData.videoId);
|
||||||
}
|
}
|
||||||
setTimeout(sendSongInfo, 200);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
const video = $('video')!;
|
const video = $('video')!;
|
||||||
@ -126,16 +131,10 @@ export default () => {
|
|||||||
video.addEventListener(status, playPausedHandlers[status]);
|
video.addEventListener(status, playPausedHandlers[status]);
|
||||||
}
|
}
|
||||||
|
|
||||||
function sendSongInfo() {
|
function sendSongInfo(videoData: VideoDataChangeValue) {
|
||||||
const data = apiEvent.detail.getPlayerResponse();
|
const data = apiEvent.detail.getPlayerResponse();
|
||||||
|
|
||||||
for (const e of $$<HTMLAnchorElement>('.byline.ytmusic-player-bar > .yt-simple-endpoint')) {
|
data.videoDetails.album = videoData?.Hd?.playerOverlays?.playerOverlayRenderer?.browserMediaSession?.browserMediaSessionRenderer?.album.runs?.at(0)?.text;
|
||||||
if (e.href?.includes('browse/FEmusic_library_privately_owned_release') || e.href?.includes('browse/MPREb')) {
|
|
||||||
data.videoDetails.album = e.textContent;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
data.videoDetails.elapsedSeconds = 0;
|
data.videoDetails.elapsedSeconds = 0;
|
||||||
data.videoDetails.isPaused = false;
|
data.videoDetails.isPaused = false;
|
||||||
ipcRenderer.send('video-src-changed', data);
|
ipcRenderer.send('video-src-changed', data);
|
||||||
|
|||||||
@ -1,15 +1,262 @@
|
|||||||
|
export interface AlbumDetails {
|
||||||
|
responseContext: ResponseContext;
|
||||||
|
contents: Contents;
|
||||||
|
currentVideoEndpoint: CurrentVideoEndpoint;
|
||||||
|
trackingParams: string;
|
||||||
|
playerOverlays: PlayerOverlays;
|
||||||
|
videoReporting: VideoReporting;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Contents {
|
||||||
|
singleColumnMusicWatchNextResultsRenderer: SingleColumnMusicWatchNextResultsRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface SingleColumnMusicWatchNextResultsRenderer {
|
||||||
|
tabbedRenderer: TabbedRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface TabbedRenderer {
|
||||||
|
watchNextTabbedResultsRenderer: WatchNextTabbedResultsRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface WatchNextTabbedResultsRenderer {
|
||||||
|
tabs: Tab[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Tab {
|
||||||
|
tabRenderer: TabRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface TabRenderer {
|
||||||
|
title: string;
|
||||||
|
content?: Content;
|
||||||
|
trackingParams: string;
|
||||||
|
endpoint?: Endpoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Content {
|
||||||
|
musicQueueRenderer: MusicQueueRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface MusicQueueRenderer {
|
||||||
|
hack: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Endpoint {
|
||||||
|
clickTrackingParams: string;
|
||||||
|
browseEndpoint: BrowseEndpoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface BrowseEndpoint {
|
||||||
|
browseId: string;
|
||||||
|
browseEndpointContextSupportedConfigs: BrowseEndpointContextSupportedConfigs;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface BrowseEndpointContextSupportedConfigs {
|
||||||
|
browseEndpointContextMusicConfig: BrowseEndpointContextMusicConfig;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface BrowseEndpointContextMusicConfig {
|
||||||
|
pageType: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface CurrentVideoEndpoint {
|
||||||
|
clickTrackingParams: string;
|
||||||
|
watchEndpoint: WatchEndpoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface WatchEndpoint {
|
||||||
|
videoId: string;
|
||||||
|
playlistId: string;
|
||||||
|
index: number;
|
||||||
|
playlistSetVideoId: string;
|
||||||
|
loggingContext: LoggingContext;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface LoggingContext {
|
||||||
|
vssLoggingContext: VssLoggingContext;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface VssLoggingContext {
|
||||||
|
serializedContextData: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface PlayerOverlays {
|
||||||
|
playerOverlayRenderer: PlayerOverlayRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface PlayerOverlayRenderer {
|
||||||
|
actions: PlayerOverlayRendererAction[];
|
||||||
|
browserMediaSession: BrowserMediaSession;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface PlayerOverlayRendererAction {
|
||||||
|
likeButtonRenderer: LikeButtonRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface LikeButtonRenderer {
|
||||||
|
target: Target;
|
||||||
|
likeStatus: string;
|
||||||
|
trackingParams: string;
|
||||||
|
likesAllowed: boolean;
|
||||||
|
serviceEndpoints: ServiceEndpoint[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface ServiceEndpoint {
|
||||||
|
clickTrackingParams: string;
|
||||||
|
likeEndpoint: LikeEndpoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface LikeEndpoint {
|
||||||
|
status: string;
|
||||||
|
target: Target;
|
||||||
|
actions?: LikeEndpointAction[];
|
||||||
|
likeParams?: string;
|
||||||
|
dislikeParams?: string;
|
||||||
|
removeLikeParams?: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface LikeEndpointAction {
|
||||||
|
clickTrackingParams: string;
|
||||||
|
musicLibraryStatusUpdateCommand: MusicLibraryStatusUpdateCommand;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface MusicLibraryStatusUpdateCommand {
|
||||||
|
libraryStatus: string;
|
||||||
|
addToLibraryFeedbackToken: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Target {
|
||||||
|
videoId: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface BrowserMediaSession {
|
||||||
|
browserMediaSessionRenderer: BrowserMediaSessionRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface BrowserMediaSessionRenderer {
|
||||||
|
album: Title;
|
||||||
|
thumbnailDetails: ThumbnailDetails;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Title {
|
||||||
|
runs: TitleRun[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface TitleRun {
|
||||||
|
text: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface ThumbnailDetails {
|
||||||
|
thumbnails: Thumbnail[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Thumbnail {
|
||||||
|
url: string;
|
||||||
|
width: number;
|
||||||
|
height: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface ResponseContext {
|
||||||
|
serviceTrackingParams: ServiceTrackingParam[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface ServiceTrackingParam {
|
||||||
|
service: string;
|
||||||
|
params: Param[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Param {
|
||||||
|
key: string;
|
||||||
|
value: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface VideoReporting {
|
||||||
|
reportFormModalRenderer: ReportFormModalRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface ReportFormModalRenderer {
|
||||||
|
optionsSupportedRenderers: OptionsSupportedRenderers;
|
||||||
|
trackingParams: string;
|
||||||
|
title: Title;
|
||||||
|
submitButton: Button;
|
||||||
|
cancelButton: Button;
|
||||||
|
footer: Footer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Button {
|
||||||
|
buttonRenderer: ButtonRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface ButtonRenderer {
|
||||||
|
style: string;
|
||||||
|
isDisabled: boolean;
|
||||||
|
text: Title;
|
||||||
|
trackingParams: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Footer {
|
||||||
|
runs: FooterRun[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface FooterRun {
|
||||||
|
text: string;
|
||||||
|
navigationEndpoint?: NavigationEndpoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface NavigationEndpoint {
|
||||||
|
clickTrackingParams: string;
|
||||||
|
urlEndpoint: URLEndpoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface URLEndpoint {
|
||||||
|
url: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface OptionsSupportedRenderers {
|
||||||
|
optionsRenderer: OptionsRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface OptionsRenderer {
|
||||||
|
items: Item[];
|
||||||
|
trackingParams: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Item {
|
||||||
|
optionSelectableItemRenderer: OptionSelectableItemRenderer;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface OptionSelectableItemRenderer {
|
||||||
|
text: Title;
|
||||||
|
trackingParams: string;
|
||||||
|
submitEndpoint: SubmitEndpoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface SubmitEndpoint {
|
||||||
|
clickTrackingParams: string;
|
||||||
|
flagEndpoint: FlagEndpoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface FlagEndpoint {
|
||||||
|
flagAction: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export type VideoDataChangeValue = Record<string, unknown> & {
|
||||||
|
videoId: string
|
||||||
|
title: string
|
||||||
|
author: string
|
||||||
|
|
||||||
|
Hd?: AlbumDetails
|
||||||
|
|
||||||
|
playlistId: string
|
||||||
|
isUpcoming: boolean
|
||||||
|
loading: boolean
|
||||||
|
|
||||||
|
lengthSeconds: number
|
||||||
|
};
|
||||||
|
|
||||||
export interface PlayerAPIEvents {
|
export interface PlayerAPIEvents {
|
||||||
videodatachange: {
|
videodatachange: {
|
||||||
value: Record<string, unknown> & {
|
value: VideoDataChangeValue
|
||||||
videoId: string
|
|
||||||
title: string
|
|
||||||
author: string
|
|
||||||
|
|
||||||
playlistId: string
|
|
||||||
isUpcoming: boolean
|
|
||||||
loading: boolean
|
|
||||||
|
|
||||||
lengthSeconds: number
|
|
||||||
}
|
|
||||||
} & ({ name: 'dataloaded' } | { name: 'dataupdated ' })
|
} & ({ name: 'dataloaded' } | { name: 'dataupdated ' })
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user