fix mpris

This commit is contained in:
Araxeus
2021-11-10 00:53:44 +02:00
parent f40ed04899
commit ccfe7434bf
5 changed files with 113 additions and 50 deletions

View File

@ -0,0 +1,30 @@
const { ipcRenderer } = require("electron");
module.exports.seekTo = seekTo;
function seekTo(t) {
document.querySelector('video').currentTime = t;
}
module.exports.seek = seek;
function seek(o) {
document.querySelector('video').currentTime += o;
}
module.exports.setupSongControls = () => {
ipcRenderer.on("seekTo", async (_, t) => seekTo(t));
ipcRenderer.on("seek", async (_, t) => seek(t));
ipcRenderer.once("registerOnSeek", registerOnSeek)
};
async function registerOnSeek() {
const register = v => v.addEventListener('seeked', () => ipcRenderer.send('seeked', v.currentTime));
let video = document.querySelector('video');
if (video) {
register(video);
}
else {
document.addEventListener('apiLoaded', () => {
register(document.querySelector('video'))
}, { once: true, passive: true })
}
}

View File

@ -11,9 +11,19 @@ ipcRenderer.on("update-song-info", async (_, extractedSongInfo) => {
module.exports = () => {
document.addEventListener('apiLoaded', e => {
setupTimeChangeListener();
document.querySelector('video').addEventListener('loadedmetadata', () => {
const data = e.detail.getPlayerResponse();
ipcRenderer.send("song-info-request", JSON.stringify(data));
});
}, { once: true, passive: true })
};
function setupTimeChangeListener() {
const progressObserver = new MutationObserver(mutations => {
ipcRenderer.send('timeChanged', mutations[0].target.value);
global.songInfo.elapsedSeconds = mutations[0].target.value;
});
progressObserver.observe(document.querySelector('#progress-bar'), { attributeFilter: ["value"] })
}

View File

@ -45,6 +45,7 @@ const songInfo = {
songDuration: 0,
elapsedSeconds: 0,
url: "",
videoId: "",
};
const handleData = async (responseText, win) => {
@ -57,6 +58,7 @@ const handleData = async (responseText, win) => {
songInfo.image = await getImage(songInfo.imageSrc);
songInfo.uploadDate = data?.microformat?.microformatDataRenderer?.uploadDate;
songInfo.url = data?.microformat?.microformatDataRenderer?.urlCanonical?.split("&")[0];
songInfo.videoId = data?.videoDetails?.videoId;
// used for options.resumeOnStart
config.set("url", data?.microformat?.microformatDataRenderer?.urlCanonical);