Remove gradient elements from the media control overlay on Max.com

Remove the annoying gradient element from the control overlay which is shown on a mouse movement

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         Remove gradient elements from the media control overlay on Max.com
// @namespace    http://tampermonkey.net/
// @version      1.2
// @description  Remove the annoying gradient element from the control overlay which is shown on a mouse movement
// @author       Behike
// @match        *://play.max.com/video/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=max.com
// @grant window.onurlchange
// @license MIT
// ==/UserScript==

(function() {
    'use strict';

    if (window.onurlchange === null) {
        window.addEventListener('urlchange', (info) => waitAndRemove());
    }
})();

function waitAndRemove() {
    waitForElm("[class^='BottomGradient-Beam-Web-Ent']").then((elm) => {
        console.log(elm);
        console.log('Bottom gradient element removed.');
        elm.remove()
    });
    waitForElm("[class^='TopGradient-Beam-Web-Ent']").then((elm) => {
        console.log(elm);
        console.log('Top gradient element removed.');
        elm.remove()
    });
}

function waitForElm(selector) {
    return new Promise(resolve => {
        if (document.querySelector(selector)) {
            return resolve(document.querySelector(selector));
        }

        const observer = new MutationObserver(mutations => {
            if (document.querySelector(selector)) {
                observer.disconnect();
                resolve(document.querySelector(selector));
            }
        });

        observer.observe(document.body, {
            childList: true,
            subtree: true
        });
    });
}