// ==UserScript== // @name GitHub的Commits记录相关的按钮外围加上黑色边框,并以蓝色字体和黄色背景高亮显示 // @name:en GitHub's Commits Related Button: Black Border & Blue Text on Yellow // @namespace http://tampermonkey.net/ // @version 0.2.6 // @description GitHub's Commits recording button is surrounded by a black border, displayed in blue font, and highlighted with a yellow background // @description:en GitHub's Commits recording button is surrounded by a black border, displayed in blue font, and highlighted with a yellow background // @author aspen138 // @match *://github.com/* // @icon  // @grant GM_addStyle // @license MIT // @downloadURL none // ==/UserScript== (function() { 'use strict'; // Add the custom styles GM_addStyle(` .custom-highlight { border: 2px solid black !important; background-color: yellow !important; color: blue !important; } `); // Function to check and apply styles to matching elements function applyCustomStyles() { // Select all span elements that could contain the text const spans = document.querySelectorAll('span[data-component="text"] span'); // Regular expression to match the pattern "number Commits" with commas for thousand separators const regex = /\b\d{1,3}(,\d{3})*\sCommits\b/; spans.forEach(span => { // If the span's text matches the pattern if (regex.test(span.textContent)) { // Add a custom class or directly apply styles here span.classList.add('custom-highlight'); } }); const buttons = document.querySelectorAll('a[id="browse-at-time-link"]'); console.log(buttons); const regex1= /\bBrowse files\b/; buttons.forEach(btn => { // If the span's text matches the pattern if (regex1.test(btn.innerText)) { // Add a custom class or directly apply styles here btn.classList.add('custom-highlight'); } }); } // MutationObserver to observe changes in the document const observer = new MutationObserver((mutations) => { mutations.forEach((mutation) => { if (mutation.addedNodes.length) { applyCustomStyles(); } }); }); // Configuration of the observer: const config = { childList: true, subtree: true }; // Start observing the body for added nodes observer.observe(document.body, config); // Initial application of the styles applyCustomStyles(); })();