Hide Mastodon posts that have a content warning

Versteckt Artikel-Tags mit einem Button mit der Klasse "spoiler-button__overlay"

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         Hide Mastodon posts that have a content warning
// @namespace    Mastodon
// @version      0.1
// @description  Versteckt Artikel-Tags mit einem Button mit der Klasse "spoiler-button__overlay"
// @license      MIT
// @match        https://norden.social/*
// @grant        none
// ==/UserScript==

(function() {
  'use strict';

  function hideSpoilers() {
    const articles = document.querySelectorAll('article'); // Alle <article>-Tags abrufen
    articles.forEach(article => {
      // check spoiler images
      const spoilerButtonImages = article.querySelector('button.spoiler-button__overlay');
      if (spoilerButtonImages) {
        // hide article
        article.style.display = 'none';
      } else {
        // check spoiler content
        const spoilerDiv = article.querySelector('div.status__content--with-spoiler');
        if (spoilerDiv) {
          // hide article
          article.style.display = 'none';
        }
      }
    });
  }

  // on page load
  hideSpoilers();

  // for dynamic changes
  const observer = new MutationObserver(hideSpoilers);
  observer.observe(document.body, { childList: true, subtree: true });
})();