E-Hentai PervertMonkey

Infinite scroll [optional], Filter by Title

スクリプトをインストールするには、Tampermonkey, GreasemonkeyViolentmonkey のような拡張機能のインストールが必要です。

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

スクリプトをインストールするには、TampermonkeyViolentmonkey のような拡張機能のインストールが必要です。

スクリプトをインストールするには、TampermonkeyUserscripts のような拡張機能のインストールが必要です。

このスクリプトをインストールするには、Tampermonkeyなどの拡張機能をインストールする必要があります。

このスクリプトをインストールするには、ユーザースクリプト管理ツールの拡張機能をインストールする必要があります。

(ユーザースクリプト管理ツールは設定済みなのでインストール!)

このスタイルをインストールするには、Stylusなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus などの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus tなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

(ユーザースタイル管理ツールは設定済みなのでインストール!)

作者のサイトでサポートを受ける。または、このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください
// ==UserScript==
// @name         E-Hentai PervertMonkey
// @namespace    pervertmonkey
// @version      1.0.0
// @author       violent-orangutan
// @description  Infinite scroll [optional], Filter by Title
// @license      MIT
// @icon         https://www.google.com/s2/favicons?sz=64&domain=e-hentai.org
// @homepage     https://github.com/smartacephale/sleazy-fork
// @homepageURL  https://github.com/smartacephale/sleazy-fork
// @source       github:smartacephale/sleazy-fork
// @supportURL   https://github.com/smartacephale/sleazy-fork/issues
// @match        https://*.e-hentai.org/*
// @require      https://cdn.jsdelivr.net/npm/[email protected]/dist/core/pervertmonkey.core.umd.js
// @require      data:application/javascript,var core = window.pervertmonkey.core || pervertmonkey.core; var utils = core;
// @grant        GM_addStyle
// @grant        unsafeWindow
// @run-at       document-idle
// ==/UserScript==

(function (core, utils) {
  'use strict';

  new core.RulesGlobal({
    thumbsSelector: ".gl1t",
    titleSelector: ".glname",
    containerSelectorLast: ".itg.gld",
    getThumbImgDataAttrSelector: "data-lazy-load",
    getThumbImgDataStrategy: "auto",
    paginationStrategyOptions: createPaginationStrategyOptions(),
    customDataSelectorFns: ["filterInclude", "filterExclude"],
    schemeOptions: ["Text Filter", "Badge", "Advanced"]
  });
  function createPaginationStrategyOptions() {
    let nextLink;
    function getPaginationUrlGenerator() {
      function getNextLink(doc = document) {
        return [...doc.querySelectorAll("a#dnext[href]")].pop()?.href;
      }
      const paginationUrlGenerator = async (_) => {
        if (!nextLink) {
          nextLink = getNextLink();
          return nextLink;
        }
        const doc = await utils.fetchHtml(nextLink);
        nextLink = getNextLink(doc);
        return nextLink;
      };
      return paginationUrlGenerator;
    }
    return {
      paginationSelector: ".searchnav + div + .searchnav",
      overwritePaginationLast: () => 9999999,
      getPaginationUrlGenerator
    };
  }
  function setThumbnailMode() {
    const IS_SEARCH_PAGE = /f_search/.test(location.search) || /^\/tag\//.test(location.pathname);
    if (!IS_SEARCH_PAGE) return;
    const selectInputT = document.querySelector("option[value=t]");
    if (selectInputT) {
      const select = selectInputT.parentElement;
      if (select.value === "t") return;
      select.value = "t";
      select.dispatchEvent(new Event("change"));
    }
  }
  setThumbnailMode();

})(core, utils);