mute spotify ads

Automatically mute Spotify ads.

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         mute spotify ads
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  Automatically mute Spotify ads.
// @author       crazy-cat-108
// @match https://open.spotify.com/*
// @license MIT
// ==/UserScript==

(function () {
    'use strict';
    
    const targetNode = document.body;

    const config = { attributes: true, childList: true, subtree: true };

    const observer = new MutationObserver(callback);

    observer.observe(targetNode, config);

    function callback(mutationList) {
        for (const mutation of mutationList) {
			const muteButton = document.querySelector('[data-testid="volume-bar-toggle-mute-button"]');
			const title = document.querySelector("title").textContent;
			if (title.includes("Spotify – Advertisement") && !muteButton?.hasAttribute("isMuted")) {
				muteButton.click();
				muteButton.setAttribute("isMuted", true);
			}
			if (!title.includes("Spotify – Advertisement") && muteButton?.hasAttribute("isMuted")) {
				muteButton.click();
				muteButton.removeAttribute("isMuted");
			}
        }
    }
    
})();