您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Adds a button to copy Roblox user ID or username on profile pages
// ==UserScript== // @name Roblox User ID And Username Copier // @namespace http://tampermonkey.net/ // @version 1.9 // @description Adds a button to copy Roblox user ID or username on profile pages // @match https://www.roblox.com/users/* // @grant none // @license MIT // ==/UserScript== (function() { 'use strict'; // Base64 encoded image for light mode const lightModeIconBase64 = '' // Base64 encoded image for dark mode const darkModeIconBase64 = '' // Function to check if dark mode is active function isDarkModeActive() { return document.body.classList.contains('dark-theme'); } // Function to get the appropriate icon based on the current theme function getIconBase64() { return isDarkModeActive() ? darkModeIconBase64 : lightModeIconBase64; } // Function to extract user ID from URL function getUserIdFromUrl() { const urlParts = window.location.pathname.split('/'); return urlParts[2]; } // Function to get username from the page function getUsername() { const usernameElement = document.querySelector('.profile-display-name'); if (usernameElement) { return usernameElement.textContent.replace('@', ''); } return ''; } // Function to copy text to clipboard function copyToClipboard(text) { const textarea = document.createElement('textarea'); textarea.value = text; document.body.appendChild(textarea); textarea.select(); document.execCommand('copy'); document.body.removeChild(textarea); } // Function to create a copy button with label function createCopyButton(iconAlt, labelText, copyFunction) { const container = document.createElement('div'); container.style.display = 'inline-block'; container.style.marginRight = '20px'; container.style.textAlign = 'center'; container.style.width = '80px'; // Fixed width for container const button = document.createElement('img'); button.src = getIconBase64(); button.alt = iconAlt; button.title = iconAlt; button.style.cursor = 'pointer'; button.style.display = 'block'; button.style.margin = '0 auto 5px'; button.style.padding = '2px'; button.style.borderRadius = '4px'; button.style.transition = 'background-color 0.3s'; button.width = 16; button.height = 16; button.onmouseover = function() { this.style.backgroundColor = 'rgba(2, 198, 219, 0.5)'; }; button.onmouseout = function() { this.style.backgroundColor = 'transparent'; }; button.onmousedown = function() { this.style.backgroundColor = 'transparent'; }; button.onmouseup = function() { this.style.backgroundColor = 'rgba(2, 198, 219, 0.5)'; }; button.onclick = function() { copyFunction(); showCopiedMessage(label, labelText); }; const label = document.createElement('div'); label.textContent = labelText; label.style.fontSize = '12px'; label.style.transition = 'color 0.3s'; label.style.whiteSpace = 'nowrap'; // Keep text on one line container.appendChild(button); container.appendChild(label); return container; } // Function to show "Copied!" message function showCopiedMessage(label, originalText) { const originalColor = label.style.color; label.textContent = "Copied!"; label.style.color = "green"; setTimeout(() => { label.textContent = originalText; label.style.color = originalColor; }, 500); // Changed to 2 seconds for quicker feedback } // Create and insert the buttons function createCopyButtons() { const buttonContainer = document.createElement('div'); buttonContainer.style.marginTop = '10px'; buttonContainer.style.display = 'flex'; buttonContainer.style.alignItems = 'flex-start'; const userIdButton = createCopyButton('Copy User ID', 'Copy UserId', function() { copyToClipboard(getUserIdFromUrl()); }); const usernameButton = createCopyButton('Copy Username', 'Copy Username', function() { copyToClipboard(getUsername()); }); buttonContainer.appendChild(userIdButton); buttonContainer.appendChild(usernameButton); const headerNames = document.querySelector('.header-names'); if (headerNames) { headerNames.appendChild(buttonContainer); } } // Function to update styles based on current theme function updateStyles() { const isDark = isDarkModeActive(); const labels = document.querySelectorAll('.header-names div[style*="font-size: 12px"]'); labels.forEach(label => { if (label.textContent !== "Copied!") { label.style.color = isDark ? 'white' : 'black'; } }); const buttons = document.querySelectorAll('.header-names img[alt^="Copy"]'); buttons.forEach(button => { button.src = getIconBase64(); }); } // Run the script createCopyButtons(); updateStyles(); // Update styles when theme changes const observer = new MutationObserver(function(mutations) { mutations.forEach(function(mutation) { if (mutation.type === "attributes" && mutation.attributeName === "class") { updateStyles(); } }); }); observer.observe(document.body, { attributes: true }); })();