SoundCloud Hide Reposts (OBSOLETE)

Remove reposts from your SoundCloud stream. Loosely based off of ABS's "SoundCloud Hide Reposts" script (v1.2), modified to work with Chrome > v127.0.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name SoundCloud Hide Reposts (OBSOLETE)
// @namespace http://axelsparkster.gg
// @version 1.0
// @author Axel Sparkster
// @description Remove reposts from your SoundCloud stream. Loosely based off of ABS's "SoundCloud Hide Reposts" script (v1.2), modified to work with Chrome > v127.0.
// @match *://soundcloud.com/feed
// @license MIT
// ==/UserScript==

console.log("Starting SoundCloud repost hide tool.");

function startMain() {
    // Observe #content for any changes.
    var target = document.querySelector("#content")

    // Observe it for the direct children and all descendants of the node.
    var config = { childList: true, subtree: true };

    // Upon a change, check to see if the item is a repost, and remove it from the tree if so.
    var observer = new MutationObserver(mutations => {
        for(const mutation of mutations) {
            for(const addedNode of mutation.addedNodes) {
                if(addedNode.className === "soundList__item") {
                    if (addedNode.getElementsByClassName("sc-ministats-reposts").length > 0)
                    {
                        addedNode.remove();
                        console.log(addedNode);
                    }
                }
            }
        }
    });

    // Start observing #content.
    observer.observe(target, config);
}
startMain();