Facebook DevTools Enabler

Restores right-click, context menu, and enables Eruda/dev tools on Facebook

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

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

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

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

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

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

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

Advertisement:

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

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

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

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

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

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

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

Advertisement:

// ==UserScript==
// @name         Facebook DevTools Enabler
// @namespace    http://tampermonkey.net
// @version      1.1
// @description  Restores right-click, context menu, and enables Eruda/dev tools on Facebook
// @match        https://*.facebook.com/*
// @run-at       document-start
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    // ==========================================
    // BLOCK RIGHT-CLICK PREVENTION
    // ==========================================
    
    // Store original addEventListener
    const originalAddEventListener = EventTarget.prototype.addEventListener;
    
    // Override addEventListener to block contextmenu prevention
    EventTarget.prototype.addEventListener = function(type, listener, options) {
        // Block contextmenu, selectstart, copy, cut, paste prevention
        const blockedEvents = ['contextmenu', 'selectstart', 'dragstart', 'copy', 'cut', 'paste'];
        
        if (blockedEvents.includes(type)) {
            console.log(`[DevTools Enabler] Blocked ${type} event listener`);
            return;
        }
        
        // Block keydown prevention for F12, Ctrl+Shift+I, etc.
        if (type === 'keydown' || type === 'keyup') {
            const wrappedListener = function(e) {
                // Allow dev tool shortcuts
                if (e.key === 'F12' || 
                    (e.ctrlKey && e.shiftKey && (e.key === 'I' || e.key === 'J' || e.key === 'C')) ||
                    (e.ctrlKey && e.key === 'U')) {
                    return;
                }
                return listener.call(this, e);
            };
            return originalAddEventListener.call(this, type, wrappedListener, options);
        }
        
        return originalAddEventListener.call(this, type, listener, options);
    };

    // ==========================================
    // REMOVE EXISTING BLOCKERS
    // ==========================================
    
    // Remove oncontextmenu, onselectstart, etc from document and body
    const removeBlockers = () => {
        if (document.documentElement) {
            document.documentElement.oncontextmenu = null;
            document.documentElement.onselectstart = null;
            document.documentElement.ondragstart = null;
        }
        if (document.body) {
            document.body.oncontextmenu = null;
            document.body.onselectstart = null;
            document.body.ondragstart = null;
        }
    };

    // Run immediately and on DOM ready
    removeBlockers();
    document.addEventListener('DOMContentLoaded', removeBlockers);

    // ==========================================
    // INJECT ERUDA (if not already loaded)
    // ==========================================
    
    const injectEruda = () => {
        if (window.eruda) return; // Already loaded
        
        const script = document.createElement('script');
        script.src = 'https://cdn.jsdelivr.net/npm/eruda';
        script.onload = () => {
            window.eruda.init({
                tool: ['console', 'elements', 'network', 'resources', 'info'],
                autoScale: true,
                defaults: { displaySize: 50 }
            });
            console.log('[DevTools Enabler] Eruda console initialized');
        };
        document.head.appendChild(script);
    };

    // ==========================================
    // BYPASS SECURITY POLICIES
    // ==========================================
    
    // Remove Content Security Policy restrictions
    const meta = document.createElement('meta');
    meta.httpEquiv = 'Content-Security-Policy';
    meta.content = "default-src * 'unsafe-inline' 'unsafe-eval' data: blob:; script-src * 'unsafe-inline' 'unsafe-eval'; style-src * 'unsafe-inline';";
    
    if (document.head) {
        document.head.appendChild(meta);
    } else {
        document.addEventListener('DOMContentLoaded', () => {
            document.head.appendChild(meta);
        });
    }

    // ==========================================
    // UNBLOCK DEV TOOLS SHORTCUTS
    // ==========================================
    
    window.addEventListener('keydown', (e) => {
        // Don't block F12 or Ctrl+Shift+I/J/C
        if (e.key === 'F12' || 
            (e.ctrlKey && e.shiftKey && ['I','J','C'].includes(e.key))) {
            e.stopImmediatePropagation();
        }
    }, true);

    // ==========================================
    // INIT
    // ==========================================
    
    console.log("[DevTools Enabler] Facebook restrictions bypassed");
    
    // Inject Eruda after a short delay to ensure page is ready
    setTimeout(injectEruda, 1000);
    
    // Re-apply blockers removal periodically
    setInterval(removeBlockers, 2000);

})();