您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
add notifications dropdown to reddit
当前为
// ==UserScript== // @name Reddit notifications dropdown // @namespace https://greasyfork.org/users/821661 // @version 1.0.4 // @description add notifications dropdown to reddit // @author hdyzen // @require https://update.greasyfork.org/scripts/526417/1666689/USToolkit.js // @match https://www.reddit.com/* // @run-at document-start // @grant GM_addStyle // @icon https://www.google.com/s2/favicons?domain=www.reddit.com/&sz=64 // @license GPL-3.0-only // ==/UserScript== function initializeDropdown() { addMainStyles(); const notificationDropdown = createIframeNotifications(); UST.onElement("#notifications-inbox-button", (button) => { if (button.contains(notificationDropdown)) { return; } setupEventListeners(button); insertDropdown(button, notificationDropdown); }); } function handleIframeMode() { addIframeStyles(); setupIframeLinkHandler(); } function createIframeNotifications() { const iframe = document.createElement("iframe"); iframe.id = "notifications-dropdown"; iframe.src = "https://www.reddit.com/notifications?dropdown=true"; return iframe; } function insertDropdown(button, dropdown) { button.appendChild(dropdown); } function setupEventListeners(button) { button.addEventListener("click", (event) => { event.preventDefault(); event.stopPropagation() event.stopImmediatePropagation() button.classList.toggle("dropdown-visible"); }); } function addMainStyles() { GM_addStyle(` #notifications-inbox-button { overflow: visible !important; position: relative !important; } #notifications-dropdown { display: none; margin-inline: 1rem; position: absolute; top: 100%; right: 0; z-index: 99999999; height: clamp(5rem, 35rem, calc(100vh - var(--shreddit-header-height, 56px))); border: 1px solid var(--color-inverted-neutral-content); border-radius: 1rem; box-shadow: var(--elevation-md); } .dropdown-visible #notifications-dropdown { display: block; } `); } function addIframeStyles() { GM_addStyle(` *:not(:has(notifications-main-manager), notifications-main-manager, notifications-main-manager *), notifications-main-manager h1 { display: none !important; } shreddit-app { padding: 0 !important; } shreddit-app[devicetype="mobile"] { margin-inline: 1rem; } `); } function setupIframeLinkHandler() { document.addEventListener("click", (event) => { const targetA = event.target.closest("a[href]"); if (targetA) { event.preventDefault(); window.open(targetA.href, "_blank"); } }); } if (unsafeWindow.location.search.includes("dropdown=true")) { handleIframeMode(); } else { initializeDropdown(); }