您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Fixes the display of Apple Music page elements in LibreWolf when Dark Reader is installed. LibreWolf interferes with Dark Reader on some web pages elements due to the Resist Fingerprinting measures that it implements. This userscript itself will not undermine Resist Fingerprinting measures because it: does not access or expose sensitive browser APIs, only modifies CSS properties and shadow DOM elements for styling purposes, and avoids interacting with device-specific or identifying information.
当前为
- // ==UserScript==
- // @name Apple Music Dark Reader Fix for LibreWolf
- // @namespace http://tampermonkey.net/
- // @version 0.4
- // @icon https://ptpimg.me/3wphme.png
- // @description Fixes the display of Apple Music page elements in LibreWolf when Dark Reader is installed. LibreWolf interferes with Dark Reader on some web pages elements due to the Resist Fingerprinting measures that it implements. This userscript itself will not undermine Resist Fingerprinting measures because it: does not access or expose sensitive browser APIs, only modifies CSS properties and shadow DOM elements for styling purposes, and avoids interacting with device-specific or identifying information.
- // @match https://music.apple.com/*
- // @grant GM_addStyle
- // @license MIT
- // @run-at document-idle
- // ==/UserScript==
- (function() {
- 'use strict';
- // Apply general styles with GM_addStyle
- GM_addStyle(`
- :root {
- --systemPrimary: hsla(0,0%,100%,.92);
- --systemPrimary-vibrant: #f5f5f7;
- --systemPrimary-onLight: rgba(0,0,0,.88);
- --systemPrimary-onDark: hsla(0,0%,100%,.92);
- --systemSecondary: hsla(0,0%,100%,.64);
- --systemSecondary-vibrant: #a1a1a6;
- --systemSecondary-onLight: rgba(0,0,0,.56);
- --systemSecondary-onDark: hsla(0,0%,100%,.64);
- --systemTertiary: hsla(0,0%,100%,.4);
- --systemTertiary-vibrant: #6e6e73;
- --systemTertiary-onLight: rgba(0,0,0,.48);
- --systemTertiary-onDark: hsla(0,0%,100%,.4);
- --keyColor: #ff364c;
- --keyColor-rgb: 255,54,76;
- --keyColor-rollover: #ff8a9c;
- --keyColor-rollover-rgb: 255,138,156;
- --keyColor-pressed: #ff7183;
- --keyColor-pressed-rgb: 255,113,131;
- --keyColor-deepPressed: #ff8a9c;
- --keyColor-deepPressed-rgb: 255,138,156;
- --keyColor-disabled: rgba(255,54,76,.35);
- --musicKeyColor: #fa586a;
- --musicKeyColor-rollover: #ff8a9c;
- --musicKeyColor-pressed: #ff7183;
- --musicKeyColor-deepPressed: #ff8a9c;
- --musicKeyColor-disabled: rgba(255,54,76,.35);
- --keyColorBG: #d60017;
- --selectionColor: #a60012;
- --darkreader-bg--keyColorBG: #df1b30;
- }
- amp-chrome-player::before {
- --playerGradientTop: #fff0;
- --playerGradientBottom: #fff0;
- background-color: #2d2d2de0 !important
- }
- amp-chrome-player {
- --systemSecondary: #ffffffa3;
- --skip-control-color-hover: white;
- --chromeVolumeIcon: #fff6;
- --chromeVolumeTrack: #ffffff26;
- --chromeVolumeElapsed: #fff9;
- }
- amp-lcd {
- --lcd-artworkHoverBGColor: #121212e8;
- --playerMissingArtworkBg: #121212;
- --playerLCDBGFill: #4d4d4d;
- --systemSecondary: #ffffffa3;
- }
- `);
- function applyStylesInShadowRoot() {
- const chromePlayer = document.querySelector('amp-chrome-player');
- if (!chromePlayer || !chromePlayer.shadowRoot) return;
- const playbackControls = chromePlayer.shadowRoot.querySelector('apple-music-playback-controls');
- if (!playbackControls || !playbackControls.shadowRoot) return;
- // Add style to modify shadow DOM elements
- const style = document.createElement('style');
- style.textContent = `
- :host {
- --systemSecondary: #ffffffa3 !important;
- --systemPrimary-vibrant: white !important;
- }
- `;
- playbackControls.shadowRoot.appendChild(style);
- }
- // Monitor for changes to ensure styles are always applied
- const observer = new MutationObserver(() => {
- applyStylesInShadowRoot();
- });
- // Observe the player container for dynamic changes
- const playerContainer = document.querySelector('amp-chrome-player');
- if (playerContainer) {
- observer.observe(playerContainer, { childList: true, subtree: true });
- }
- // Initial call to apply styles after a delay
- setTimeout(applyStylesInShadowRoot, 400);
- })();