Ucubesavar

Reddit ucubelerini savmak isteyenlere.

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

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

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

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

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

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

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

Advertisement:

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

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

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

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

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

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

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

Advertisement:

// ==UserScript==
// @name         Ucubesavar
// @namespace    http://tampermonkey.net/
// @version      1.0
// @description  Reddit ucubelerini savmak isteyenlere.
// @match        *://*.reddit.com/*
// @grant        none
// @run-at       document-start
// @license MIT
// ==/UserScript==


(function() {
    'use strict';

    const ENGELLENECEK_KULLANICILAR = [
        "birisi",
        "baskasi",
        "birbaskasi"
    ];


    if (ENGELLENECEK_KULLANICILAR.length === 0) return;


    const globalCssSelectors = ENGELLENECEK_KULLANICILAR.map(user => `
        article:has(shreddit-post[author="${user}"]),
        article:has(shreddit-post[author="${user}"]) + hr,
        shreddit-post[author="${user}"],
        shreddit-comment[author="${user}"],
        [data-author="${user}"],
        [author="${user}"]
    `).join(',\n');

    const globalCSS = `
        ${globalCssSelectors} {
            display: none !important;
            visibility: hidden !important;
            height: 0 !important;
            margin: 0 !important;
            padding: 0 !important;
            opacity: 0 !important;
            border: none !important;
            pointer-events: none !important;
        }
    `;


    const chatCssSelectors = ENGELLENECEK_KULLANICILAR.map(user => `
        div.room-message[aria-label^="${user} "]
    `).join(',\n');

    const chatCSS = `
        ${chatCssSelectors} {
            display: none !important;
            height: 0 !important;
            margin: 0 !important;
            padding: 0 !important;
            border: none !important;
            visibility: hidden !important;
        }
    `;

    const injectGlobalStyles = () => {
        const styleEl = document.createElement('style');
        styleEl.textContent = globalCSS;
        document.head.appendChild(styleEl);
    };


    if (document.head) {
        injectGlobalStyles();
    } else {
        document.addEventListener("DOMContentLoaded", injectGlobalStyles);
    }

    const originalAttachShadow = Element.prototype.attachShadow;

    Element.prototype.attachShadow = function(init) {
        const shadowRoot = originalAttachShadow.call(this, init);

        if (this.tagName === 'RS-TIMELINE-EVENT') {
            const shadowStyle = document.createElement('style');
            shadowStyle.textContent = chatCSS;
            shadowRoot.appendChild(shadowStyle);
        }

        return shadowRoot;
    };

})();