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