fix song-info-request

This commit is contained in:
Araxeus
2021-11-22 18:20:12 +02:00
parent 185ebbf417
commit 92452f804f
2 changed files with 21 additions and 6 deletions

View File

@ -19,16 +19,24 @@ module.exports = () => {
apiEvent.detail.addEventListener('videodatachange', (name, _dataEvent) => { apiEvent.detail.addEventListener('videodatachange', (name, _dataEvent) => {
if (name !== 'dataloaded') return; if (name !== 'dataloaded') return;
video.dispatchEvent(srcChangedEvent); video.dispatchEvent(srcChangedEvent);
ipcRenderer.send("video-src-changed", JSON.stringify(apiEvent.detail.getPlayerResponse())); sendSongInfo();
}) })
for (const status of ['playing', 'pause']) {
video.addEventListener(status, sendSongInfo); video.addEventListener('pause', e => {
} ipcRenderer.send("playPaused", { isPaused: true, elapsedSeconds: Math.floor(e.target.currentTime) });
});
video.addEventListener('playing', e => {
if (e.target.currentTime > 0){
ipcRenderer.send("playPaused", { isPaused: false, elapsedSeconds: Math.floor(e.target.currentTime) });
}
});
function sendSongInfo() { function sendSongInfo() {
const data = apiEvent.detail.getPlayerResponse(); const data = apiEvent.detail.getPlayerResponse();
data.videoDetails.elapsedSeconds = Math.floor(video.currentTime); data.videoDetails.elapsedSeconds = Math.floor(video.currentTime);
data.videoDetails.isPaused = video.paused; data.videoDetails.isPaused = video.paused;
ipcRenderer.send("song-info-request", JSON.stringify(apiEvent.detail.getPlayerResponse())); ipcRenderer.send("video-src-changed", JSON.stringify(apiEvent.detail.getPlayerResponse()));
} }
}, { once: true, passive: true }); }, { once: true, passive: true });
}; };

View File

@ -86,12 +86,19 @@ const registerCallback = (callback) => {
const registerProvider = (win) => { const registerProvider = (win) => {
// This will be called when the song-info-front finds a new request with song data // This will be called when the song-info-front finds a new request with song data
ipcMain.on("song-info-request", async (_, responseText) => { ipcMain.on("video-src-changed", async (_, responseText) => {
await handleData(responseText, win); await handleData(responseText, win);
callbacks.forEach((c) => { callbacks.forEach((c) => {
c(songInfo); c(songInfo);
}); });
}); });
ipcMain.on("playPaused", (_, { isPaused, elapsedSeconds }) => {
songInfo.isPaused = isPaused;
songInfo.elapsedSeconds = elapsedSeconds;
callbacks.forEach((c) => {
c(songInfo);
});
})
}; };
const suffixesToRemove = [ const suffixesToRemove = [