mirror of
https://github.com/th-ch/youtube-music.git
synced 2026-01-10 10:11:46 +00:00
93 lines
2.8 KiB
JavaScript
93 lines
2.8 KiB
JavaScript
const { notificationImage, icons } = require("./utils");
|
|
const getSongControls = require('../../providers/song-controls');
|
|
const notifier = require("node-notifier");
|
|
|
|
//store song controls reference on launch
|
|
let controls;
|
|
let onPause;
|
|
|
|
//Save controls and onPause option
|
|
module.exports.setupInteractive = (win, unpauseNotification) => {
|
|
const { playPause, next, previous } = getSongControls(win);
|
|
controls = { playPause, next, previous };
|
|
|
|
onPause = unpauseNotification;
|
|
}
|
|
|
|
//delete old notification
|
|
let toDelete;
|
|
function Delete() {
|
|
if (toDelete !== undefined) {
|
|
const removeNotif = Object.assign(toDelete, {
|
|
remove: toDelete.id
|
|
})
|
|
notifier.notify(removeNotif)
|
|
|
|
toDelete = undefined;
|
|
}
|
|
}
|
|
|
|
//New notification
|
|
module.exports.notifyInteractive = function sendToaster(songInfo) {
|
|
console.log("called toaster");
|
|
Delete();
|
|
console.log("deleted");
|
|
//download image and get path
|
|
let imgSrc = notificationImage(songInfo, true);
|
|
console.log("got image");
|
|
toDelete = {
|
|
//app id undefined - will break buttons
|
|
title: songInfo.title || "Playing",
|
|
message: songInfo.artist,
|
|
id: parseInt(Math.random() * 1000000, 10),
|
|
icon: imgSrc,
|
|
actions: [
|
|
icons.previous, // Previous
|
|
songInfo.isPaused ? icons.play : icons.pause,
|
|
icons.next // Next
|
|
],
|
|
sound: false,
|
|
};
|
|
console.log("sending notification");
|
|
//send notification
|
|
notifier.notify(
|
|
toDelete,
|
|
(err, data) => {
|
|
// Will also wait until notification is closed.
|
|
if (err) {
|
|
console.log(`ERROR = ${err}\n DATA = ${data}`);
|
|
}
|
|
switch (data) {
|
|
//buttons
|
|
case icons.previous.normalize():
|
|
controls.previous();
|
|
return;
|
|
case icons.next.normalize():
|
|
controls.next();
|
|
return;
|
|
case icons.play.normalize():
|
|
controls.playPause();
|
|
// dont delete notification on play/pause
|
|
toDelete = undefined;
|
|
//manually send notification if not sending automatically
|
|
if (!onPause) {
|
|
songInfo.isPaused = false;
|
|
sendToaster(songInfo);
|
|
}
|
|
return;
|
|
case icons.pause.normalize():
|
|
controls.playPause();
|
|
songInfo.isPaused = true;
|
|
toDelete = undefined;
|
|
sendToaster(songInfo);
|
|
return;
|
|
//Native datatype
|
|
case "dismissed":
|
|
case "timeout":
|
|
Delete();
|
|
}
|
|
}
|
|
|
|
);
|
|
}
|