import { ipcRenderer } from 'electron'; import is from 'electron-is'; export default () => { ipcRenderer.on('update-song-info', (_, extractedSongInfo: string) => 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; } let hasLyrics = true; const lyrics = await ipcRenderer.invoke( 'search-genius-lyrics', extractedSongInfo, ) as string; if (!lyrics) { // Delete previous lyrics if tab is open and couldn't get new lyrics checkLyricsContainer(() => { hasLyrics = false; setTabsOnclick(undefined); }); return; } if (is.dev()) { console.log('Fetched lyrics from Genius'); } enableLyricsTab(); setTabsOnclick(enableLyricsTab); checkLyricsContainer(); const lyricsTabHandler = () => { const tabContainer = document.querySelector('ytmusic-tab-renderer'); if (tabContainer) { const observer = new MutationObserver((_, observer) => { checkLyricsContainer(() => observer.disconnect()); }); observer.observe(tabContainer, { attributes: true, childList: true, subtree: true, }); } }; tabs.lyrics.addEventListener('click', lyricsTabHandler); function checkLyricsContainer(callback = () => { }) { const lyricsContainer = document.querySelector( '[page-type="MUSIC_PAGE_TYPE_TRACK_LYRICS"] > ytmusic-message-renderer', ); if (lyricsContainer) { callback(); setLyrics(lyricsContainer); } } function setLyrics(lyricsContainer: Element) { lyricsContainer.innerHTML = `