Ucubesavar

Reddit ucubelerini savmak isteyenlere.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==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;
    };

})();