您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Extract and display magnet links with a single click
// ==UserScript== // @name Magnet Link Extractor // @namespace http://tampermonkey.net/ // @version 1.2 // @description Extract and display magnet links with a single click // @note v1.2 updates: // @note - The icon now only appears on pages with magnet links; // @note - Clicking the magnet icon automatically copies all detected magnet links to the clipboard. No additional action is required; // @note - The panel now features a selectable design with checkboxes for better user control. // @match *://*/* // @grant GM_addStyle // @run-at document-end // @license MIT // ==/UserScript== (function () { 'use strict'; // Add CSS GM_addStyle(` #magnet-icon { position: fixed; top: 50px; right: 5px; width: 25px; height: 25px; background: url('') no-repeat center center; background-size: cover; cursor: grab; z-index: 1000; display: none; /* Start hidden */ } #magnet-popup { display: none; position: fixed; bottom: 80px; right: 20px; width: 300px; max-height: 400px; background: white; border: 1px solid #ccc; box-shadow: 0px 0px 10px rgba(0,0,0,0.1); overflow-y: auto; z-index: 1001; padding: 10px; } #select-options { display: flex; justify-content: space-between; margin-bottom: 10px; } .button-group { display: flex; gap: 3px; /* Adjust this value to change button spacing */ } button { cursor: pointer; padding: 4px 8px; /* Adjust padding for button size */ border: none; border-radius: 3px; font-size: 12px; /* Adjust font size */ } #select-all-btn { background: #4CAF50; color: white; } #select-none-btn { background: #f44336; color: white; } #copy-selected-btn { background: #2196F3; color: white; margin-left: auto; /* Move to the right */ } #copy-feedback { font-size: 12px; color: green; margin-bottom: 0px; /* Space between feedback and links */ text-align: center; display: none; font-weight: normal; } .magnet-count { text-align: left; /* Align the count to the left */ font-size: 12px; /* Adjust the text size */ color: #666; /* Set the color */ margin-top: 2px; /* Add spacing above the count */ margin-bottom: 5px; /* Add spacing below the count */ } .magnet-item { display: flex; align-items: center; /* Center-align the checkbox and label */ margin: 0; /* Reset margins */ font-family: sans-serif; /* Unified font */ font-size: 12px; /* Adjust text size */ font-weight: normal; /* Ensure the text is not bold */ text-decoration: none; color: #333; /* Unified color */ white-space: nowrap; /* Prevent line breaking */ } .magnet-checkbox { appearance: auto; /* Ensure the checkbox retains its native appearance */ margin-right: 8px; /* Space between checkbox and label */ width: 16px; /* Optional: Set a consistent width */ height: 16px; /* Optional: Set a consistent height */ vertical-align: middle; } .magnet-item label { margin-left: 2px; /* Space between checkbox and link text */ font-family: sans-serif; /* Set desired font */ font-size: 12px; /* Unified size */ font-weight: normal; /* Ensure normal weight */ color: #333; /* Unified color */ white-space: nowrap; /* Prevent line breaking */ line-height: 16px; /* Match the checkbox height */ } `); // Create the floating icon const icon = document.createElement('div'); icon.id = 'magnet-icon'; document.body.appendChild(icon); // Create the popup const popup = document.createElement('div'); popup.id = 'magnet-popup'; popup.innerHTML = ` <div id="select-options" class="button-group"> <button id="select-all-btn">All</button> <button id="select-none-btn">None</button> <div id="copy-feedback" style="flex: 1; text-align: center; display: none;">Links copied!</div> <button id="copy-selected-btn">Copy</button> </div> <div class="magnet-count">Counts: <span id="magnet-count">0</span></div> <div id="magnet-list"></div> `; document.body.appendChild(popup); // Extract magnet links function extractMagnetLinks() { const links = new Set(); document.querySelectorAll('a[href^="magnet:?xt="]').forEach(link => { if (link.href.startsWith('magnet:?xt=')) { links.add(link.href); } }); const magnetList = document.getElementById('magnet-list'); magnetList.innerHTML = ''; // Clear existing content Array.from(links).forEach((magnet, index) => { const item = document.createElement('div'); item.className = 'magnet-item'; item.innerHTML = ` <input type="checkbox" class="magnet-checkbox" id="magnet-${index}" data-magnet="${magnet}" checked> <label for="magnet-${index}" title="${magnet}">${magnet}</label> `; magnetList.appendChild(item); }); const linkCount = links.size; document.getElementById('magnet-count').textContent = linkCount; // Show the icon only if links are found if (linkCount > 0) { icon.style.display = 'block'; } else { icon.style.display = 'none'; } } // Handle Select All button document.getElementById('select-all-btn').addEventListener('click', () => { document.querySelectorAll('.magnet-checkbox').forEach(cb => cb.checked = true); }); // Handle Select None button document.getElementById('select-none-btn').addEventListener('click', () => { document.querySelectorAll('.magnet-checkbox').forEach(cb => cb.checked = false); }); // Copy selected magnets document.getElementById('copy-selected-btn').addEventListener('click', () => { const selectedLinks = Array.from(document.querySelectorAll('.magnet-checkbox:checked')) .map(cb => cb.dataset.magnet) .join('\n'); if (selectedLinks) { navigator.clipboard.writeText(selectedLinks).then(() => { const feedback = document.getElementById('copy-feedback'); feedback.style.display = 'block'; setTimeout(() => feedback.style.display = 'none', 2500); }).catch(err => { console.error('Failed to copy text: ', err); }); } }); // Popup visibility state let isPopupVisible = false; // Show or hide popup on icon click icon.addEventListener('click', () => { isPopupVisible = !isPopupVisible; popup.style.display = isPopupVisible ? 'block' : 'none'; if (isPopupVisible) { extractMagnetLinks(); // Default to select all links and copy them document.querySelectorAll('.magnet-checkbox').forEach(cb => cb.checked = true); document.getElementById('copy-selected-btn').click(); } }); // Make the icon draggable let isDragging = false; let offsetX, offsetY; icon.addEventListener('mousedown', (e) => { isDragging = true; offsetX = e.clientX - parseInt(window.getComputedStyle(icon).left || '0'); offsetY = e.clientY - parseInt(window.getComputedStyle(icon).top || '0'); icon.style.cursor = 'grabbing'; document.addEventListener('mousemove', onMouseMove); document.addEventListener('mouseup', onMouseUp); }); function onMouseMove(e) { if (isDragging) { const newX = e.clientX - offsetX; const newY = e.clientY - offsetY; // Keep icon within viewport bounds const maxX = window.innerWidth - icon.offsetWidth; const maxY = window.innerHeight - icon.offsetHeight; icon.style.left = Math.min(Math.max(0, newX), maxX) + 'px'; icon.style.top = Math.min(Math.max(0, newY), maxY) + 'px'; } } function onMouseUp() { isDragging = false; icon.style.cursor = 'grab'; document.removeEventListener('mousemove', onMouseMove); document.removeEventListener('mouseup', onMouseUp); } // Initial extraction extractMagnetLinks(); })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址