Greasy Fork

Greasy Fork is available in English.

dlsite简繁申请检测

点击右下角按钮启动 强烈建议!!进入页面等待数秒再点击!最好是等封面全都加载完!不然会导致结果错误 如果不放心可以抽查几个检查 出现bug刷新页面后重新尝试

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         dlsite简繁申请检测
// @namespace    http://tampermonkey.net/
// @version      1.0.4
// @description  点击右下角按钮启动 强烈建议!!进入页面等待数秒再点击!最好是等封面全都加载完!不然会导致结果错误 如果不放心可以抽查几个检查 出现bug刷新页面后重新尝试
// @author       feiyu
// @match        *www.dlsite.com/home/works/translatable*
// @match        *www.dlsite.com/maniax/works/translatable*
// @match        *www.dlsite.com/girls/works/translatable*
// @match        *www.dlsite.com/bl/works/translatable*
// @icon         
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    //创建并添加固定位置按钮
    const button = document.createElement('button');
    button.id = 'fixedButton';
    button.innerText = '简繁申请检测 建议进入页面等待数秒最好封面全部加载后点击';
    button.style.position = 'fixed';
    button.style.bottom = '10px';
    button.style.right = '10px';
    button.style.padding = '10px 20px';
    button.style.backgroundColor = '#007bff';
    button.style.color = 'white';
    button.style.border = 'none';
    button.style.borderRadius = '5px';
    button.style.cursor = 'pointer';
    button.style.zIndex = '1000';
    document.body.appendChild(button);

    //按钮点击事件处理
    button.addEventListener('click', async function() {
    const tableDataArray = []//所有的申请情况表格数组
    const buttons = document.querySelectorAll('.reception_status_btn');

    //点击按钮展开表格 收集申请情况 暂定一秒点二十次左右
    await Promise.all(Array.from(buttons).map(async (button, index) => {
        return new Promise(resolve => {
            setTimeout(() => {
                //点击申请中按钮
                button.click();

                setTimeout(() => {
                    //申请情况表格元素
                    const table = button.closest('li').querySelector('.translation_table');

                    //数据收集到数组中
                    if (table) {
                        const rows = table.querySelectorAll('tr');
                        const tableData = [];
                        rows.forEach(row => {
                            const cells = row.querySelectorAll('th, td');
                            const rowData = Array.from(cells).map(cell => cell.textContent.trim());
                            tableData.push(rowData);
                        });

                        tableDataArray.push(tableData);
                    }
                    resolve();
                }, 20);//等待秒数
            }, index * 30);//点击速度
        });
    }));

    console.log(tableDataArray)

    //获取所有li元素
    const liElements = document.querySelectorAll('.n_worklist .search_result_img_box_inner');

    //遍历数据数组
    tableDataArray.forEach((item, index) => {

        //获取简繁数组数据
        const sc = item.find(row => row[0] === "简体中文");
        const tc = item.find(row => row[0] === "繁体中文");

        //是否满足条件
        if (sc && tc) {
            // 检查简繁的申请和发售是否为0
            const simplifiedZero = sc[1] === "0" && sc[2] === "0";
            const traditionalZero = tc[1] === "0" && tc[2] === "0";

            if (simplifiedZero && traditionalZero) {
                //获取对应的li中的img
                const img = liElements[index].querySelector('.work_img_main .search_img.work_thumb a img');
                if (img) {
                    //替换img变文字
                    const parent = img.parentElement; //a标签
                    parent.innerHTML = '<div style="display: flex; font-size:20px; justify-content: center; align-items: center; height: 100%; color: aqua; font-weight: bold;">简繁均无人申请</div>';
                }
            }
        }
    });

    });
})();