mirror of
https://github.com/A-Star100/simpliplay-desktop.git
synced 2025-09-17 22:29:38 +00:00
Update renderer.js
This commit is contained in:
parent
e516ca2606
commit
8aeaef9724
@ -1,4 +1,8 @@
|
|||||||
let mediaElement = document.getElementById("mediaPlayer");
|
let mediaElement = document.getElementById("mediaPlayer");
|
||||||
|
let midiPlayerElement = document.getElementById("midiPlayer");
|
||||||
|
let midiVisualizerElement = document.getElementById("myVisualizer");
|
||||||
|
|
||||||
|
mediaElement.style.display = 'flex';
|
||||||
|
|
||||||
|
|
||||||
function loadMedia(fileURL) {
|
function loadMedia(fileURL) {
|
||||||
@ -34,6 +38,14 @@ function isSafeURL(fileURL) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function isMidi(fileURL) {
|
||||||
|
try {
|
||||||
|
const url = new URL(fileURL);
|
||||||
|
return (url.toLowerCase().endsWith('.mid') || url.toLowerCase().endsWith('.midi'))
|
||||||
|
} catch (error) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// ✅ Listen for "play-media" event from main process securely
|
// ✅ Listen for "play-media" event from main process securely
|
||||||
window.electron.receive("play-media", (fileURL) => {
|
window.electron.receive("play-media", (fileURL) => {
|
||||||
@ -43,4 +55,19 @@ window.electron.receive("play-media", (fileURL) => {
|
|||||||
} else {
|
} else {
|
||||||
console.warn("Blocked unsafe media URL:", fileURL);
|
console.warn("Blocked unsafe media URL:", fileURL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (isMidi(fileURL)) {
|
||||||
|
midiPlayerElement.src = fileURL;
|
||||||
|
midiPlayerElement.style.display = 'flex';
|
||||||
|
midiPlayerVisualizer.style.display = 'flex';
|
||||||
|
mediaElement.style.display = 'none';
|
||||||
|
mediaElement.pause();
|
||||||
|
if (autoplayCheckbox && autoplayCheckbox.checked) {
|
||||||
|
midiPlayerElement.play().catch(error => console.warn("Playback issue:", error));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
midiPlayerElement.style.display = 'none';
|
||||||
|
midiPlayerVisualizer.style.display = 'none';
|
||||||
|
mediaElement.style.display = 'flex';
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user