import { ipcRenderer } from 'electron'; import is from 'electron-is'; import type { SongInfo } from '../../providers/song-info'; export default () => { const setLyrics = (lyricsContainer: Element, lyrics: string | null) => { lyricsContainer.innerHTML = `
${lyrics?.replaceAll(/\r\n|\r|\n/g, '
') ?? 'Could not retrieve lyrics from genius'}
`; if (lyrics) { const footer = lyricsContainer.querySelector('.footer'); if (footer) { footer.textContent = 'Source: Genius'; } } }; let unregister: (() => void) | null = null; ipcRenderer.on('update-song-info', (_, extractedSongInfo: SongInfo) => { unregister?.(); setTimeout(async () => { const tabList = document.querySelectorAll('tp-yt-paper-tab'); const tabs = { upNext: tabList[0], lyrics: tabList[1], discover: tabList[2], }; // Check if disabled if (!tabs.lyrics?.hasAttribute('disabled')) return; const lyrics = await ipcRenderer.invoke( 'search-genius-lyrics', extractedSongInfo, ) as string | null; if (!lyrics) { // Delete previous lyrics if tab is open and couldn't get new lyrics tabs.upNext.click(); return; } if (is.dev()) { console.log('Fetched lyrics from Genius'); } const tryToInjectLyric = (callback?: () => void) => { const lyricsContainer = document.querySelector( '[page-type="MUSIC_PAGE_TYPE_TRACK_LYRICS"] > ytmusic-message-renderer', ); if (lyricsContainer) { callback?.(); setLyrics(lyricsContainer, lyrics); applyLyricsTabState(); } }; const applyLyricsTabState = () => { if (lyrics) { tabs.lyrics.removeAttribute('disabled'); tabs.lyrics.removeAttribute('aria-disabled'); } else { tabs.lyrics.setAttribute('disabled', ''); tabs.lyrics.setAttribute('aria-disabled', ''); } }; const lyricsTabHandler = () => { const tabContainer = document.querySelector('ytmusic-tab-renderer'); if (!tabContainer) return; const observer = new MutationObserver((_, observer) => { tryToInjectLyric(() => observer.disconnect()); }); observer.observe(tabContainer, { attributes: true, childList: true, subtree: true, }); }; applyLyricsTabState(); tabs.discover.addEventListener('click', applyLyricsTabState); tabs.lyrics.addEventListener('click', lyricsTabHandler); tabs.upNext.addEventListener('click', applyLyricsTabState); tryToInjectLyric(); unregister = () => { tabs.discover.removeEventListener('click', applyLyricsTabState); tabs.lyrics.removeEventListener('click', lyricsTabHandler); tabs.upNext.removeEventListener('click', applyLyricsTabState); }; }, 500); }); };