// ==UserScript== // @name Danryoku搜索框 // @namespace https://viayoo.com/st7tgk // @version 1.1 // @description 为 Danryoku 提供黑色风格悬浮搜索与网页加载跳动球动画 // @author Via // @match *://danryoku.com/* // @run-at document-start // @icon  // @grant none // @license MIT // ==/UserScript== (function() { 'use strict'; const injectStyles = () => { if (document.getElementById('search-widget-styles')) return; const style = document.createElement('style'); style.id = 'search-widget-styles'; style.textContent = ` #custom-loading-overlay{position:fixed;inset:0;background:transparent;display:flex;align-items:center;justify-content:center;z-index:999999;transition:opacity .5s ease;pointer-events:none} .cute-ball{width:50px;height:50px;background:#333;border-radius:50%;animation:bounce 0.6s infinite alternate;box-shadow:0 20px 20px rgba(0,0,0,0.15);pointer-events:auto;cursor:pointer} @keyframes bounce{from{transform:translateY(0) scaleX(1)}to{transform:translateY(-40px) scaleX(0.9)}} .search-widget-btn{position:fixed;bottom:100px;right:20px;width:62px;height:62px;border-radius:50%;background:#1a1a1a;box-shadow:0 8px 32px rgba(0,0,0,0.4);border:1px solid rgba(255,255,255,0.1);cursor:pointer;z-index:9999;display:flex !important;align-items:center !important;justify-content:center !important;transition:transform 0.4s cubic-bezier(0.2, 0, 0.2, 1), opacity 0.3s ease;backdrop-filter:blur(12px);padding:0 !important;margin:0 !important;outline:none;will-change:transform, opacity} .search-widget-btn.hidden-btn{transform:translateY(150px) scale(0.5);opacity:0;pointer-events:none} .search-widget-btn:active{transform:scale(0.9)} .search-widget-icon{width:36px !important;height:36px !important;display:block !important} .search-widget-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.6);z-index:10000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(10px)} .search-widget-box{background:#181818;border-radius:24px;padding:28px;box-shadow:0 25px 50px -12px rgba(0,0,0,0.5);border:1px solid rgba(255,255,255,0.08);width:85%;max-width:420px;transform:scale(0.9);opacity:0;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1)} .search-widget-box.active{transform:scale(1);opacity:1} .search-widget-input{width:100%;padding:14px 20px;border-radius:12px;border:1px solid #333;font-size:16px;outline:none;background:#0d0d0d;color:#fff;box-sizing:border-box} .search-widget-submit{margin-top:20px;width:100%;padding:14px;border-radius:12px;background:#fff;color:#000;border:none;font-size:15px;font-weight:bold;cursor:pointer;transition:opacity 0.3s} @media(max-width:768px){.search-widget-btn{width:56px;height:56px;bottom:85px;right:15px}.search-widget-icon{width:30px !important;height:30px !important}} `; document.head.appendChild(style); }; let isInjected = false; const init = () => { if (isInjected || !document.documentElement) return; isInjected = true; injectStyles(); if (!document.getElementById('custom-loading-overlay')) { const loader = document.createElement('div'); loader.id = 'custom-loading-overlay'; loader.innerHTML = '
'; document.documentElement.appendChild(loader); const removeLoader = () => { loader.style.opacity = '0'; setTimeout(() => loader.remove(), 500); }; window.addEventListener('load', removeLoader, { once: true }); loader.onclick = removeLoader; } const injectSearch = () => { if (!document.body || document.querySelector('.search-widget-btn')) return; const btn = document.createElement('button'); btn.className = 'search-widget-btn'; btn.innerHTML = ``; const modal = document.createElement('div'); modal.className = 'search-widget-modal'; modal.innerHTML = `
`; document.body.appendChild(btn); document.body.appendChild(modal); const box = modal.querySelector('.search-widget-box'); const input = modal.querySelector('.search-widget-input'); const submit = modal.querySelector('.search-widget-submit'); const toggleModal = (show) => { if (show) { modal.style.display = 'flex'; setTimeout(() => { box.classList.add('active'); input.focus(); }, 10); } else { box.classList.remove('active'); setTimeout(() => modal.style.display = 'none', 300); } }; const performSearch = () => { const query = input.value.trim(); if (query) window.location.href = `https://danryoku.com/?s=${encodeURIComponent(query)}`; }; btn.onclick = (e) => { e.preventDefault(); toggleModal(true); }; modal.onclick = (e) => { if (e.target === modal) toggleModal(false); }; submit.onclick = performSearch; input.onkeydown = (e) => { if (e.key === 'Enter') performSearch(); }; let lastY = window.scrollY; let touchStartY = 0; const handleVisual = (delta) => { if (delta > 40) btn.classList.add('hidden-btn'); else if (delta < -80) btn.classList.remove('hidden-btn'); }; window.addEventListener('scroll', () => { const currY = window.scrollY; handleVisual(currY - lastY); lastY = currY; }, { passive: true }); window.addEventListener('touchstart', (e) => { touchStartY = e.touches[0].pageY; }, { passive: true }); window.addEventListener('touchmove', (e) => { const deltaY = touchStartY - e.touches[0].pageY; handleVisual(deltaY); }, { passive: true }); }; injectSearch(); if (!document.body) { const bodyObserver = new MutationObserver(() => { if (document.body) { injectSearch(); bodyObserver.disconnect(); } }); bodyObserver.observe(document.documentElement, { childList: true }); } }; init(); document.addEventListener('DOMContentLoaded', init); })();