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();
})();