米游社刷新提醒工具

用于米游社电脑网页的攻略、甲板、候车室、酒馆、咖啡馆、律所、学园、ACG模块的最新发帖页面自动页内刷新的工具,可以检索关键词并发声提醒你,用于获得最新一手的消息进行回复或处理。可以设置正则表达式检索和刷新时间间隔。

目前为 2024-08-06 提交的版本。查看 最新版本

// ==UserScript==
// @name         米游社刷新提醒工具
// @namespace    https://gf.qytechs.cn/users/1345081
// @version      0.1
// @description  用于米游社电脑网页的攻略、甲板、候车室、酒馆、咖啡馆、律所、学园、ACG模块的最新发帖页面自动页内刷新的工具,可以检索关键词并发声提醒你,用于获得最新一手的消息进行回复或处理。可以设置正则表达式检索和刷新时间间隔。
// @icon         
// @author       zhangqiang
// @license      MIT
// @match        https://www.miyoushe.com/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    // 音效URL
    const soundUrl = "https://uploadstatic.mihoyo.com/ys-obc/2022/05/12/8797197/429281fded26a537aa7c33319fa6e388_172369884487879995.mp3";

    // 创建设置表单的容器
    const settingsContainer = document.createElement('div');
    settingsContainer.style.position = 'fixed';
    settingsContainer.style.right = '20px';
    settingsContainer.style.bottom = '50px';
    settingsContainer.style.backgroundColor = 'white';
    settingsContainer.style.padding = '10px';
    settingsContainer.style.borderRadius = '5px';
    settingsContainer.style.boxShadow = '0 0 10px rgba(0,0,0,0.5)';
    settingsContainer.style.zIndex = '9999'; // 确保表单在顶层
    settingsContainer.style.width = '200px'; // 调整容器宽度
    document.body.appendChild(settingsContainer);

    // 创建表单
    const settingsForm = document.createElement('form');
    settingsForm.style.display = 'flex'; // 使用Flexbox布局
    settingsForm.style.flexDirection = 'column'; // 垂直排列子元素
    settingsContainer.appendChild(settingsForm);

    // 创建关键词输入框
    const keywordInput = document.createElement('input');
    keywordInput.type = 'text';
    keywordInput.placeholder = '输入关键词,用逗号分隔';
    keywordInput.style.width = '100%'; // 使输入框宽度适应容器
    keywordInput.style.marginBottom = '10px';
    settingsForm.appendChild(keywordInput);

    // 创建时间间隔输入框
    const intervalInput = document.createElement('input');
    intervalInput.type = 'number';
    intervalInput.placeholder = '15 second';
    intervalInput.style.width = '90px'; // 设置宽度以显示三位数
    intervalInput.style.marginBottom = '10px';
    settingsForm.appendChild(intervalInput);

    // 创建正则表达式勾选框和标签
    const regexContainer = document.createElement('div');
    regexContainer.style.display = 'flex'; // 使用Flexbox使勾选框和标签在同一行
    regexContainer.style.alignItems = 'center'; // 垂直居中对齐

    const regexCheckbox = document.createElement('input');
    regexCheckbox.type = 'checkbox';
    regexCheckbox.id = 'regexCheckbox';
    regexCheckbox.style.marginRight = '5px'; // 右侧留点空间给标签

    const regexLabel = document.createElement('label');
    regexLabel.htmlFor = 'regexCheckbox';
    regexLabel.textContent = '使用正则表达式';

    regexContainer.appendChild(regexCheckbox);
    regexContainer.appendChild(regexLabel);
    settingsForm.appendChild(regexContainer); // 将整个容器添加到表单中


    // 创建开始按钮
    const startButton = document.createElement('button');
    startButton.type = 'button';
    startButton.textContent = '开始自动刷新';
    startButton.style.width = '100%';
    startButton.style.backgroundColor = '#007bff';
    startButton.style.color = 'white';
    startButton.style.padding = '10px';
    startButton.style.border = 'none';
    startButton.style.borderRadius = '5px';
    startButton.style.cursor = 'pointer';
    settingsForm.appendChild(startButton);

    let intervalId = null;
    let isRunning = false;
    let keywords = [];
    let intervalTime = 15000; // 默认时间间隔为15秒
    let useRegex = false; // 默认不使用正则表达式

    // 更新设置
    const updateSettings = () => {
        keywords = keywordInput.value.split(',');
        intervalTime = parseInt(intervalInput.value, 10) * 1000 || 10000;
        useRegex = regexCheckbox.checked;
    };

    // 检查关键词是否存在(根据是否使用正则表达式)
    const checkKeywords = (bodyText) => {
        for (const keyword of keywords) {
            if (useRegex) {
                const regexPattern = new RegExp(keyword.trim(), 'i'); // 'i' 表示不区分大小写
                if (regexPattern.test(bodyText)) {
                    return true;
                }
            } else {
                if (bodyText.includes(keyword.trim())) {
                    return true;
                }
            }
        }
        return false;
    };

    startButton.addEventListener('click', function() {
        updateSettings();

        if (isRunning) {
            clearInterval(intervalId);
            startButton.textContent = '开始自动刷新';
            isRunning = false;
        } else {
            intervalId = setInterval(() => {
                const latestPostButton = document.querySelector('.mhy-tab__label');
                if (latestPostButton && latestPostButton.textContent === '最新发帖') {
                    latestPostButton.click();
                }

                // 检查页面是否包含关键词
                const bodyText = document.body.textContent;
                if (checkKeywords(bodyText)) {
                    clearInterval(intervalId);
                    isRunning = false;
                    startButton.textContent = '开始自动刷新';

                    // 播放音效
                    const audio = new Audio(soundUrl);
                    audio.play();
                }
            }, intervalTime);
            startButton.textContent = '停止自动刷新';
            isRunning = true;
        }
    });
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址