Quick Reader for Pokepara

Remove <p>&nbsp;</p> from specific blog area on pokepara.jp

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey, Greasemonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Userscripts.

Чтобы установить этот скрипт, сначала вы должны установить расширение браузера, например Tampermonkey.

Чтобы установить этот скрипт, вы должны установить расширение — менеджер скриптов.

(у меня уже есть менеджер скриптов, дайте мне установить скрипт!)

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

(у меня уже есть менеджер стилей, дайте мне установить скрипт!)

// ==UserScript==
// @name         Quick Reader for Pokepara
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  Remove <p>&nbsp;</p> from specific blog area on pokepara.jp
// @author       Suniki
// @match        https://www.pokepara.jp/*
// @grant        none
// @license      GPL
// ==/UserScript==

(function () {
  "use strict";

  const targetSelector = "#galblog div.wrap div.blog";

  const applyShrinkStyle = (p) => {
    if (p.textContent.trim() === "") {
      p.style.lineHeight = "5%";
    }
  };

  const processParagraphs = (container) => {
    const paragraphs = container.querySelectorAll("p, div, span");
    paragraphs.forEach(applyShrinkStyle);
  };

  const initObserver = (targetNode) => {
    const observer = new MutationObserver((mutations) => {
      for (const mutation of mutations) {
        mutation.addedNodes.forEach((node) => {
          if (node.nodeType === Node.ELEMENT_NODE) {
            if (node.matches("p") || node.matches("div") || node.matches("span")) {
              applyShrinkStyle(node);
            } else if (node.querySelectorAll) {
              processParagraphs(node);
            }
          }
        });
      }
    });

    observer.observe(targetNode, {
      childList: true,
      subtree: true,
    });

    // 初期状態でも一度処理
    processParagraphs(targetNode);
  };

  const waitForTarget = () => {
    const el = document.querySelector(targetSelector);
    if (el) {
      initObserver(el);
    } else {
      // DOM にまだない場合は再試行
      const interval = setInterval(() => {
        const el = document.querySelector(targetSelector);
        if (el) {
          clearInterval(interval);
          initObserver(el);
        }
      }, 500);
    }
  };

  waitForTarget();
})();