auto-audio-recorder/extension-firefox/content.js

119 lines
4.3 KiB
JavaScript
Raw Normal View History

2019-09-19 03:05:44 +00:00
// See https://stackoverflow.com/questions/105034/create-guid-uuid-in-javascript
function uuidv4() {
return ([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g, c =>
(c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16)
);
}
function onNewSong(song) {
browser.runtime.sendMessage(JSON.stringify({ type: 'new-song', song: song }));
}
function onUpdateSong(song) {
browser.runtime.sendMessage(JSON.stringify({ type: 'update-song', song: song }));
}
function onAdvertisement() {
browser.runtime.sendMessage(JSON.stringify({ type: 'advertisement' }));
}
function onHeartbeat() {
browser.runtime.sendMessage(JSON.stringify({ type: 'heartbeat' }));
}
let song = { name: '', artists: [] };
// Initial Song Data
function getNameElement() { return document.querySelector('.Root__now-playing-bar .now-playing-bar-container div.track-info__name span a'); }
function getArtistElements() { return document.querySelectorAll('.Root__now-playing-bar .now-playing-bar-container div.track-info__artists span a'); }
function getAlbumArtElement() { return document.querySelector('.Root__now-playing-bar .now-playing-bar-container .cover-art .cover-art-image'); }
// After album is loaded
function getDurationElement() { return document.querySelector('.Root__now-playing-bar .now-playing-bar .playback-bar .playback-bar__progress-time:last-child'); }
function getAlbumNameElement() { return document.querySelector('.TrackListHeader .mo-info-name'); }
function getAlbumArtFullElement() { return document.querySelector('.TrackListHeader .cover-art .cover-art-image'); }
function checkSong() {
let nameElement = getNameElement();
let artistsElement = getArtistElements();
let albumArtElement = getAlbumArtElement();
let name = null;
let artists = [];
let albumArtLink = null;
name = nameElement ? nameElement.innerText : 'Unknown Name';
if (
name == 'Advertisement' ||
document.title.toLowerCase().indexOf('advertisement') != -1 ||
document.title.toLowerCase().indexOf('spotify') != -1
) {
console.log('advertisement');
onAdvertisement();
return;
}
for (let i = 0; i < artistsElement.length; ++i) {
let artistElement = artistsElement[i];
artists.push(artistElement.innerText);
}
2019-09-30 14:31:20 +00:00
let albumArtStyle = albumArtElement.getAttribute('style');
albumArt = albumArtStyle.substring('background-image: url("'.length, albumArtStyle.length - '");'.length);
2019-09-19 03:05:44 +00:00
if (name != song.name || artists.join(', ') != song.artists.join(', ')) {
2019-09-30 14:31:20 +00:00
console.log('name: ' + name);
console.log('artists: ' + artists.join(', '));
console.log('album art style: ' + albumArtStyle);
2019-09-19 03:05:44 +00:00
// new song
song = {
guid: uuidv4(),
name: name,
artists: artists,
album: {
name: 'Unknown Album',
2019-09-30 14:31:20 +00:00
art: albumArt
2019-09-19 03:05:44 +00:00
}
};
console.log('new song', song);
onNewSong(song);
// Click the album link
nameElement.click();
setTimeout(() => {
let durationElement = getDurationElement();
let albumNameElement = getAlbumNameElement();
let albumArtFullElement = getAlbumArtFullElement();
let duration = durationElement ? durationElement.innerText : null;
if (duration) {
let s = duration.split(':');
duration = parseInt(s[0]) * 60 + parseInt(s[1]);
}
let albumName = albumNameElement ? albumNameElement.getAttribute('title') : 'Unknown Album';
2019-09-30 14:31:20 +00:00
let albumArtFullStyle = albumArtFullElement.getAttribute('style');
console.log('album art full style: ' + albumArtFullStyle);
let albumArtFull = albumArtFullStyle.substring('background-image: url("'.length, albumArtFullStyle.length - 3);
2019-09-19 03:05:44 +00:00
song.duration = duration;
song.album.name = albumName;
2019-09-30 14:31:20 +00:00
song.album.artFull = albumArtFull;
2019-09-19 03:05:44 +00:00
onUpdateSong(song);
}, 5000); // give 5 seconds to load
}
}
console.log('Spotify Song Data Sender Extension Running');
// Send heartbeats every 3 seconds as soon as the content script is loaded
setInterval(() => { onHeartbeat(); }, 3000);
onHeartbeat();
// Check for new songs every 300 ms
setInterval(() => { checkSong(); }, 300);