您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
This userscript removes the "Only you can see your full profile [...]" infobox on your Github profile page.
// ==UserScript== // @name Remove Private Profile Notice for github.com // @description This userscript removes the "Only you can see your full profile [...]" infobox on your Github profile page. // @author ths197 // @license BSD-3-Clause // @namespace https://gist.github.com/ths197 // @include https://github.com // @include https://github.com/* // @noframes // @run-at document-start // @version 0.0.1.20250509081337 // ==/UserScript== "use strict"; // conditions const isOnLoginUsersHomePage = () => document.body.classList.contains("mine"); var state = undefined; const isChanged = () => !state?.isConnected; // getting and removing const getUserProfileFrame = () => document.getElementById("user-profile-frame"); //contents do change on some navigations const findAndRemoveNotice = function (node) { const links = Array.from(node.getElementsByTagName("a")); const anyPreviewLink = links.find(function (node) { const url = new URL(node.href); return ( url.pathname === window.location.pathname && new URLSearchParams(url.search).has("preview", "true") ); }); anyPreviewLink?.parentElement.parentElement.remove(); }; const getControlElement = (userProfileFrame) => userProfileFrame.childNodes[1]; // div, gets replaced on navigation by the webapp // applying const applyChanges = function () { if (isOnLoginUsersHomePage()) { const userProfileFrame = getUserProfileFrame(); if (userProfileFrame != null) { state = getControlElement(userProfileFrame); if (state != null) { findAndRemoveNotice(state); } } } }; // setting stuff up (boring) const innerObserver = new MutationObserver(function () { if (isChanged()) { applyChanges(); } }); const outerObserver = new MutationObserver(function () { if (isChanged()) { applyChanges(); attachInnerObserver(); } }); const attachInnerObserver = function () { const userProfileFrame = getUserProfileFrame(); if (userProfileFrame != null) { innerObserver.observe(userProfileFrame, { subtree: false, childList: true, }); } }; const attachOuterObserver = () => outerObserver.observe(document.body, { subtree: false, childList: true }); const init = function () { applyChanges(); attachOuterObserver(); attachInnerObserver(); }; if (document.readyState === "loading") { document.addEventListener("DOMContentLoaded", init); } else { init(); }