YouTube - Pause background videos

Pause videos playing in other background tabs. When you start playback of a video in foreground tab, background playback will be paused.

Dovrai installare un'estensione come Tampermonkey, Greasemonkey o Violentmonkey per installare questo script.

You will need to install an extension such as Tampermonkey to install this script.

Dovrai installare un'estensione come Tampermonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Userscripts per installare questo script.

Dovrai installare un'estensione come ad esempio Tampermonkey per installare questo script.

Dovrai installare un gestore di script utente per installare questo script.

(Ho già un gestore di script utente, lasciamelo installare!)

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

(Ho già un gestore di stile utente, lasciamelo installare!)

// ==UserScript==
// @name         YouTube - Pause background videos
// @namespace    q1k
// @version      1.0.1
// @description  Pause videos playing in other background tabs. When you start playback of a video in foreground tab, background playback will be paused.
// @author       q1k
// @match        *://www.youtube.com/*
// @grant        none
// @run-at       document-start
// ==/UserScript==

function findElement(selector) {
    return new Promise(function(resolve) {
        if (document.querySelector(selector)) {
            return resolve(document.querySelector(selector));
        }
        const observer = new MutationObserver(function(mutations) {
            if (document.querySelector(selector)) {
                resolve(document.querySelector(selector));
                observer.disconnect();
            }
        });
        observer.observe(document, {
            childList: true,
            subtree: true
        });
    });
}

var video;
const channel = new BroadcastChannel("video-channel");

findElement("#player #movie_player video").then(function(el){
    video = el;
    /*if(!!(video.currentTime > 0 && !video.paused && !video.ended && video.readyState > 2)) {
        channel.postMessage("pause");
    }*/
    Object.defineProperty(el, 'isplaying', {
        get: function(){
            return !!(this.currentTime > 0 && !this.paused && !this.ended && this.readyState > 2);
        }
    });
    video.addEventListener("playing",function(){
        //start play, send pause
        if(document.hasFocus()){
            channel.postMessage("pause");
        }
    })
});

channel.addEventListener("message",function(ev){
    if(ev.data=="pause"){
        //received pause
        if(!document.hasFocus()){ //ignore if tab is active
            if(video.isplaying) {
                video.pause();
            }
        }
    }
});