Bypass Fullscreen e Focus

Inganna il controllo dello schermo intero e del focus

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램을 설치해야 합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

Advertisement:

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

Advertisement:

// ==UserScript==
// @name         Bypass Fullscreen e Focus
// @namespace    http://tampermonkey.net/
// @version      2.1
// @description  Inganna il controllo dello schermo intero e del focus
// @match        *://*/*
// @run-at       document-start
// @grant        none
// @license MIT
// ==/UserScript==

(function() {
    'use strict';

    // --- 1. BYPASS VISIBILITA' E FOCUS ---
    Object.defineProperty(document, 'visibilityState', { get: () => 'visible' });
    Object.defineProperty(document, 'hidden', { get: () => false });

    const blockFocusEvents = (e) => {
        e.stopImmediatePropagation();
        e.preventDefault();
    };

    window.addEventListener('visibilitychange', blockFocusEvents, true);
    document.addEventListener('visibilitychange', blockFocusEvents, true);
    window.addEventListener('blur', blockFocusEvents, true);
    document.addEventListener('blur', blockFocusEvents, true);


    // --- 2. BYPASS SCHERMO INTERO ---
    // Creiamo un finto elemento da restituire quando il sito chiede se siamo in Fullscreen
    const mockFullscreenElement = document.documentElement;

    const fullscreenProps = [
        'fullscreenElement',
        'webkitFullscreenElement',
        'mozFullScreenElement',
        'msFullscreenElement'
    ];

    // Sovrascriviamo le proprietà in modo che non restituiscano mai "null"
    fullscreenProps.forEach(prop => {
        Object.defineProperty(document, prop, {
            get: () => mockFullscreenElement,
            configurable: true
        });
    });

    // Blocchiamo gli eventi di cambio schermo intero
    const blockFullscreenEvents = (e) => {
        e.stopImmediatePropagation();
        // Nota: non usiamo preventDefault() qui perché l'azione di base (uscire) è forzata dal browser
    };

    const fullscreenEvents = [
        'fullscreenchange',
        'webkitfullscreenchange',
        'mozfullscreenchange',
        'MSFullscreenChange'
    ];

    fullscreenEvents.forEach(evt => {
        document.addEventListener(evt, blockFullscreenEvents, true);
        window.addEventListener(evt, blockFullscreenEvents, true);
    });

})();