// ==UserScript== // @name Copy RSS Feed // @name:zh 复制RSS地址 // @description Automatically detect and quickly display the RSS subscription information of the current website for easy copying. // @description:zh 自动检测并快捷展示当前网站的 RSS 订阅信息,方便复制(Copy RSS Feed) // @author Wilsonyiyi // @namespace https://github.com/wilsonyiyi // @icon  // @match *://*/* // @grant GM_setClipboard // @grant GM_addStyle // @license GPL3.0 // @version 1.0.1 // @downloadURL none // ==/UserScript== (function() { 'use strict'; GM_addStyle(` #__wilsonyiyi__rss-float-container { position: fixed; right: -30px; top: 30%; height: 40px; z-index: 9999; display: flex; align-items: center; transition: all 0.3s ease; overflow: visible; } #__wilsonyiyi__rss-float-container:hover { right: 0; } #__wilsonyiyi__rss-float-btn { width: 40px; height: 40px; background: #ff9800; border-top-left-radius: 20px; border-bottom-left-radius: 20px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2); cursor: pointer; display: flex; justify-content: center; align-items: center; user-select: none; position: relative; } #__wilsonyiyi__rss-float-btn:hover { background: #ff7d00; } #__wilsonyiyi__rss-float-btn svg { width: 24px; height: 24px; fill: white; } #__wilsonyiyi__rss-label { height: 40px; line-height: 40px; background: #ff9800; color: white; font-family: Arial, sans-serif; font-size: 14px; padding: 0 15px; white-space: nowrap; max-width: 0; overflow: hidden; transition: max-width 0.3s ease; cursor: pointer; } #__wilsonyiyi__rss-float-container:hover #__wilsonyiyi__rss-label { max-width: 200px; } #__wilsonyiyi__rss-close-btn { width: 40px; height: 40px; background: #ff9800; display: flex; justify-content: center; align-items: center; cursor: pointer; max-width: 0; overflow: hidden; transition: max-width 0.3s ease; } #__wilsonyiyi__rss-float-container:hover #__wilsonyiyi__rss-close-btn { max-width: 40px; } #__wilsonyiyi__rss-close-btn svg { width: 16px; height: 16px; fill: white; min-width: 16px; } #__wilsonyiyi__rss-toast { position: fixed; top: 20px; left: 50%; transform: translateX(-50%); background: rgba(0, 0, 0, 0.7); color: white; padding: 10px 20px; border-radius: 5px; z-index: 10000; font-family: Arial, sans-serif; font-size: 14px; opacity: 0; transition: opacity 0.3s ease; } #__wilsonyiyi__rss-toast.show { opacity: 1; } `); const findRssLinks = () => { const links = document.querySelectorAll('link[type="application/rss+xml"], link[type="application/atom+xml"]'); return Array.from(links).map(link => link.href); }; const createFloatButton = (rssLink) => { const container = document.createElement('div'); container.id = '__wilsonyiyi__rss-float-container'; const button = document.createElement('div'); button.id = '__wilsonyiyi__rss-float-btn'; button.innerHTML = ''; const label = document.createElement('div'); label.id = '__wilsonyiyi__rss-label'; label.textContent = 'Copy RSS Feed'; const closeBtn = document.createElement('div'); closeBtn.id = '__wilsonyiyi__rss-close-btn'; closeBtn.innerHTML = ''; container.appendChild(button); container.appendChild(label); container.appendChild(closeBtn); document.body.appendChild(container); const copyRssLink = () => { GM_setClipboard(rssLink); showToast('🎉 Copied 🎉'); }; button.addEventListener('click', copyRssLink); label.addEventListener('click', copyRssLink); closeBtn.addEventListener('click', (e) => { e.stopPropagation(); container.style.display = 'none'; }); return container; }; const createToast = () => { const toast = document.createElement('div'); toast.id = '__wilsonyiyi__rss-toast'; document.body.appendChild(toast); return toast; }; const showToast = (message) => { const toast = document.getElementById('__wilsonyiyi__rss-toast') || createToast(); toast.textContent = message; toast.classList.add('show'); setTimeout(() => { toast.classList.remove('show'); }, 2000); }; const init = () => { const rssLinks = findRssLinks(); if (rssLinks.length > 0) { createFloatButton(rssLinks[0]); createToast(); } }; window.addEventListener('load', init); })();