sorry for doing this.
This commit is contained in:
parent
5fc82a8bc7
commit
b3db294485
106 changed files with 86 additions and 259 deletions
148
oldshit/resources/js/MusicKitInterop.js
Normal file
148
oldshit/resources/js/MusicKitInterop.js
Normal file
|
@ -0,0 +1,148 @@
|
|||
// preload.js
|
||||
const electron = require('electron');
|
||||
|
||||
|
||||
|
||||
let cache = {playParams: {id: 0}, status: null, remainingTime: 0},
|
||||
playbackCache = {status: null, time: Date.now()};
|
||||
|
||||
const MusicKitInterop = {
|
||||
init: function () {
|
||||
const self = this;
|
||||
MusicKit.getInstance().addEventListener(MusicKit.Events.playbackStateDidChange, () => {
|
||||
/** wsapi */
|
||||
ipcRenderer.send('wsapi-updatePlaybackState', self.getAttributes());
|
||||
/** wsapi */
|
||||
|
||||
if (MusicKitInterop.filterTrack(MusicKitInterop.getAttributes(), true, false)) {
|
||||
global.ipcRenderer.send('playbackStateDidChange', MusicKitInterop.getAttributes())
|
||||
if (typeof _plugins != "undefined") {
|
||||
_plugins.execute("OnPlaybackStateChanged", {Attributes: MusicKitInterop.getAttributes()})
|
||||
}
|
||||
const nowPlayingItem = MusicKit.getInstance().nowPlayingItem;
|
||||
if (typeof nowPlayingItem != "undefined") {
|
||||
if (nowPlayingItem["type"] === "musicVideo") {
|
||||
document.querySelector(`.web-chrome`).setAttribute('style', 'height: 20px !important');
|
||||
document.querySelector(`#MVLyricsBox`).style.display = 'block';
|
||||
} else {
|
||||
document.querySelector(`.web-chrome`).setAttribute('style', 'height: 55px !important');
|
||||
if (nowPlayingItem["type"] !== "song"){
|
||||
document.querySelector(`.web-chrome__grid-container`).setAttribute('style', 'margin: 15px auto 0')
|
||||
} else {
|
||||
document.querySelector(`.web-chrome__grid-container`).setAttribute('style', 'margin: dsds');}
|
||||
document.querySelector(`#MVLyricsBox`).style.display = 'none';
|
||||
}
|
||||
}
|
||||
} else {
|
||||
document.querySelector(`.web-chrome`).setAttribute('style', 'height: 55px !important');
|
||||
document.querySelector(`#MVLyricsBox`).style.display = 'none';
|
||||
try {
|
||||
const nowPlayingItem = MusicKit.getInstance().nowPlayingItem;
|
||||
if (typeof nowPlayingItem != "undefined") {
|
||||
if (nowPlayingItem["type"] === "musicVideo") {
|
||||
document.querySelector(`.web-chrome`).setAttribute('style', 'height: 20px !important');
|
||||
document.querySelector(`#MVLyricsBox`).style.display = 'block';
|
||||
} else {
|
||||
document.querySelector(`.web-chrome`).setAttribute('style', 'height: 55px !important');
|
||||
if (nowPlayingItem["type"] !== "song"){
|
||||
document.querySelector(`.web-chrome__grid-container`).setAttribute('style', 'margin: 15px auto 0')
|
||||
} else {
|
||||
document.querySelector(`.web-chrome__grid-container`).setAttribute('style', 'margin: dsds');}
|
||||
document.querySelector(`#MVLyricsBox`).style.display = 'none';
|
||||
}
|
||||
}
|
||||
} catch (e) {
|
||||
console.error(e);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
/** wsapi */
|
||||
MusicKit.getInstance().addEventListener(MusicKit.Events.playbackTimeDidChange, () => {
|
||||
ipcRenderer.send('wsapi-updatePlaybackState', self.getAttributes());
|
||||
});
|
||||
/** wsapi */
|
||||
|
||||
MusicKit.getInstance().addEventListener(MusicKit.Events.nowPlayingItemDidChange, () => {
|
||||
if (MusicKitInterop.filterTrack(MusicKitInterop.getAttributes(), false, true)) {
|
||||
global.ipcRenderer.send('nowPlayingItemDidChange', MusicKitInterop.getAttributes());
|
||||
AMStyling.updateMeta()
|
||||
}
|
||||
});
|
||||
|
||||
MusicKit.getInstance().addEventListener(MusicKit.Events.authorizationStatusDidChange, () => {
|
||||
global.ipcRenderer.send('authorizationStatusDidChange', MusicKit.getInstance().authorizationStatus)
|
||||
})
|
||||
|
||||
MusicKit.getInstance().addEventListener(MusicKit.Events.mediaPlaybackError, (e) => {
|
||||
console.warn(`[mediaPlaybackError] ${e}`);
|
||||
})
|
||||
},
|
||||
|
||||
getAttributes: function () {
|
||||
const mk = MusicKit.getInstance();
|
||||
const nowPlayingItem = mk.nowPlayingItem;
|
||||
const isPlayingExport = mk.isPlaying;
|
||||
const remainingTimeExport = mk.currentPlaybackTimeRemaining;
|
||||
const attributes = (nowPlayingItem != null ? nowPlayingItem.attributes : {});
|
||||
|
||||
attributes.status = isPlayingExport ? isPlayingExport : false;
|
||||
attributes.name = attributes.name ? attributes.name : 'No Title Found';
|
||||
attributes.artwork = attributes.artwork ? attributes.artwork : {url: ''};
|
||||
attributes.artwork.url = attributes.artwork.url ? attributes.artwork.url : '';
|
||||
attributes.playParams = attributes.playParams ? attributes.playParams : {id: 'no-id-found'};
|
||||
attributes.playParams.id = attributes.playParams.id ? attributes.playParams.id : 'no-id-found';
|
||||
attributes.albumName = attributes.albumName ? attributes.albumName : '';
|
||||
attributes.artistName = attributes.artistName ? attributes.artistName : '';
|
||||
attributes.genreNames = attributes.genreNames ? attributes.genreNames : [];
|
||||
attributes.remainingTime = remainingTimeExport ? (remainingTimeExport * 1000) : 0;
|
||||
attributes.durationInMillis = attributes.durationInMillis ? attributes.durationInMillis : 0;
|
||||
attributes.startTime = Date.now();
|
||||
attributes.endTime = Math.round((attributes.playParams.id === cache.playParams.id ? (Date.now() + attributes.remainingTime) : (attributes.startTime + attributes.durationInMillis)));
|
||||
attributes.endTime = attributes.endTime ? attributes.endTime : Date.now();
|
||||
attributes.volume = mk.volume;
|
||||
attributes.shuffleMode = mk.shuffleMode;
|
||||
attributes.repeatMode = mk.repeatMode;
|
||||
attributes.autoplayEnabled = mk.autoplayEnabled;
|
||||
return attributes
|
||||
},
|
||||
|
||||
filterTrack: function (a, playbackCheck, mediaCheck) {
|
||||
if (a.title === "No Title Found" || a.playParams.id === "no-id-found") {
|
||||
return;
|
||||
} else if (mediaCheck && a.playParams.id === cache.playParams.id) {
|
||||
return;
|
||||
} else if (playbackCheck && a.status === playbackCache.status) {
|
||||
return;
|
||||
} else if (playbackCheck && !a.status && a.remainingTime === playbackCache.time) { /* Pretty much have to do this to prevent multiple runs when a song starts playing */
|
||||
return;
|
||||
}
|
||||
cache = a;
|
||||
if (playbackCheck) playbackCache = {status: a.status, time: a.remainingTime};
|
||||
return true;
|
||||
},
|
||||
|
||||
pausePlay: function () {
|
||||
if (MusicKit.getInstance().isPlaying) {
|
||||
MusicKit.getInstance().pause();
|
||||
} else if (MusicKit.getInstance().nowPlayingItem != null) {
|
||||
MusicKit.getInstance().play().then(r => console.log(`[MusicKitInterop] Playing ${r}`));
|
||||
}
|
||||
},
|
||||
|
||||
nextTrack: function () {
|
||||
MusicKit.getInstance().skipToNextItem().then(r => console.log(`[MusicKitInterop] Skipping to Next ${r}`));
|
||||
},
|
||||
|
||||
previousTrack: function () {
|
||||
MusicKit.getInstance().skipToPreviousItem().then(r => console.log(`[MusicKitInterop] Skipping to Previous ${r}`));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
process.once('loaded', () => {
|
||||
global.ipcRenderer = electron.ipcRenderer;
|
||||
global.MusicKitInterop = MusicKitInterop;
|
||||
});
|
||||
// MusicKit.getInstance().addEventListener( MusicKit.Events.queueItemsDidChange,logIt );
|
||||
// MusicKit.getInstance().addEventListener( MusicKit.Events.queuePositionDidChange, logIt );
|
Loading…
Add table
Add a link
Reference in a new issue