Reddit Bypass Enhancer

Bypass the "open in app prompt", unblur NSFW content and thumbnails, remove the blur from community highlight cards, and remove image darkening and scrims on Reddit automatically without opening the post on unblur click. Also unblurs specific image elements.

当前为 2025-01-17 提交的版本,查看 最新版本

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         Reddit Bypass Enhancer
// @namespace    https://greasyfork.org/en/users/1030895-universedev
// @version      1.7
// @description  Bypass the "open in app prompt", unblur NSFW content and thumbnails, remove the blur from community highlight cards, and remove image darkening and scrims on Reddit automatically without opening the post on unblur click. Also unblurs specific image elements.
// @author       UniverseDev
// @license      GPL-3.0-or-later
// @match        https://www.reddit.com/*
// @match        https://sh.reddit.com/*
// @grant        none
// @run-at       document-start
// @noframes
// ==/UserScript==
'use strict';

(function () {
    function queryElementsDeep(selector) {
        const foundElements = [];

        const lightDomElements = document.querySelectorAll(selector);
        if (lightDomElements.length > 0) {
            foundElements.push(...lightDomElements);
        }

        const allElements = document.querySelectorAll('*');
        for (const el of allElements) {
            if (el.shadowRoot) {
                const shadowElements = el.shadowRoot.querySelectorAll(selector);
                if (shadowElements.length > 0) {
                    foundElements.push(...shadowElements);
                }
            }
        }
        return foundElements;
    }

    const NSFW_MODAL_TAG = 'shreddit-async-loader';
    const NSFW_MODAL_ATTR = 'bundlename';
    const BLURRED_TAG = 'shreddit-blurred-container';
    const PROMPT_SELECTOR = 'xpromo-nsfw-blocking-container';
    const THUMBNAIL_BLUR_SELECTOR = '.thumbnail-blur';
    const BLURRED_CLICKED_CLASS = 'rbe-unblurred';
    const COMMUNITY_HIGHLIGHT_CARD_SELECTOR = 'community-highlight-card';
    const THUMBNAIL_IMAGE_SELECTOR = 'a.block.w-100.h-100 > img.mb-0.h-full.w-full.object-cover';
    const THUMBNAIL_SHADOW_SELECTOR = '.thumbnail-shadow';
    const MEDIA_BACKGROUND_SELECTOR = '.bg-media-background';
    const BLURRED_SPAN_SELECTOR = 'span.inner.blurred';
    const SCRIM_SELECTOR = '.absolute.top-0.left-0.w-full.h-full.bg-scrim';

    function removeNSFWBlock() {
        const nsfwModal = document.querySelector(`${NSFW_MODAL_TAG}[${NSFW_MODAL_ATTR}*="nsfw_blocking_modal"]`);
        if (nsfwModal) nsfwModal.remove();

        const prompt = document.querySelector(`${PROMPT_SELECTOR} > *`)?.shadowRoot?.querySelector('.prompt');
        if (prompt) prompt.remove();

        const blurredContainers = document.querySelectorAll(BLURRED_TAG);
        blurredContainers.forEach(container => {
            if (container.shadowRoot?.innerHTML && !container.classList.contains(BLURRED_CLICKED_CLASS)) {
                const firstChild = container.firstElementChild;
                if (firstChild) {
                    firstChild.addEventListener('click', function(event) {
                        event.preventDefault();
                        event.stopPropagation();
                        container.classList.add(BLURRED_CLICKED_CLASS);
                    }, { once: true });
                    firstChild.click();
                } else {
                    container.classList.add(BLURRED_CLICKED_CLASS);
                }
            }
        });

        const thumbnailBlurElements = document.querySelectorAll(THUMBNAIL_BLUR_SELECTOR);
        thumbnailBlurElements.forEach(el => {
            el.classList.remove('thumbnail-blur');
        });

        const cards = document.querySelectorAll(COMMUNITY_HIGHLIGHT_CARD_SELECTOR);
        cards.forEach(card => {
            card.removeAttribute('blurred');
        });

        const thumbnailImage = document.querySelector(THUMBNAIL_IMAGE_SELECTOR);
        if (thumbnailImage) {
            thumbnailImage.style.filter = '';
        }

        const thumbnailShadow = document.querySelector(THUMBNAIL_SHADOW_SELECTOR);
        if (thumbnailShadow) {
            thumbnailShadow.remove();
        }

        const mediaBackground = document.querySelector(MEDIA_BACKGROUND_SELECTOR);
        if (mediaBackground) {
            mediaBackground.style.backgroundColor = 'transparent';
        }

        const blurredSpanElements = queryElementsDeep(BLURRED_SPAN_SELECTOR);
        if (blurredSpanElements.length > 0) {
            blurredSpanElements.forEach(span => {
                span.style.filter = '';
            });
        }

        const scrimElements = queryElementsDeep(SCRIM_SELECTOR);
        if (scrimElements.length > 0) {
            scrimElements.forEach(scrim => {
                scrim.remove();
            });
        }

        const imagesToUnblur = document.querySelectorAll('img.mb-0.h-full.w-full.object-cover');
        imagesToUnblur.forEach(img => {
            img.style.removeProperty('filter');
        });
    }

    const observer = new MutationObserver(() => {
        removeNSFWBlock();
    });

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

    removeNSFWBlock();

    setTimeout(removeNSFWBlock, 100);

    const shredditCheckInterval = setInterval(() => {
        if (!document.querySelector('shreddit-app')) {
            observer.disconnect();
            clearInterval(shredditCheckInterval);
        }
    }, 5000);
})();