-
Notifications
You must be signed in to change notification settings - Fork 0
/
script.js
63 lines (52 loc) · 2 KB
/
script.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
// ==UserScript==
// @name Spotify Background Changer
// @namespace http://tampermonkey.net/
// @source https://github.com/IsaacShoebottom/SpotifyBackgroundSwitcher
// @version 0.1.5
// @description Changes the background of Spotify playlists and albums in a rainbow pattern
// @author Isaac Shoebottom
// @updateURL https://raw.githubusercontent.com/IsaacShoebottom/SpotifyBackgroundSwitcher/master/script.js
// @downloadURL https://raw.githubusercontent.com/IsaacShoebottom/SpotifyBackgroundSwitcher/master/script.js
// @match https://open.spotify.com/*
// @grant none
// ==/UserScript==
"use strict";
let background;
let colorInterval;
const selector = ".gHImFiUWOg93pvTefeAD.xYgjMpAjE5XT05aRIezb";
const timer = 16; //in milliseconds
const probeTimer = 500 //in milliseconds, timer for checking for selector
const difference = 60; //delta between the top and bottom
const start = {
intensity: 235,
darkness: 75,
};
// [r, g, b]
const color = [start.intensity, start.darkness, start.darkness];
let isIncrease = true;
let currentColor = 2;
function changeColor() {
if (color[currentColor] === (isIncrease ? start.intensity : start.darkness)) {
isIncrease = !isIncrease;
currentColor = (currentColor + 1) % 3;
} else {
color[currentColor] += isIncrease ? 1 : -1;
}
background.style.background = `linear-gradient(rgb(${color.join(",")}),rgba(${color.map(c => c - difference).join(",")}, 0.5)),var(--background-noise)`;
}
function probeBackground() {
console.log("Begin probing for background");
setInterval(() => {
const newBackground = document.querySelector(selector);
if (!newBackground) {
return;
}
if (newBackground !== background) {
console.log("Spotify background changed")
clearInterval(colorInterval);
colorInterval = setInterval(changeColor, timer)
background = newBackground;
}
}, probeTimer);
}
probeBackground();