您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
A userscript that adds a button to toggle the GitHub Wiki sidebar
当前为
// ==UserScript== // @name GitHub Toggle Wiki Sidebar // @version 1.0.15 // @description A userscript that adds a button to toggle the GitHub Wiki sidebar // @license MIT // @author Rob Garrison // @namespace https://github.com/Mottie // @include https://github.com/* // @run-at document-idle // @grant GM_addStyle // @grant GM_getValue // @grant GM_setValue // @require https://greatest.deepsurf.us/scripts/28721-mutations/code/mutations.js?version=634242 // @icon https://assets-cdn.github.com/pinned-octocat.svg // ==/UserScript== (() => { "use strict"; // disable click targeting of button SVG internals // classes "mr-1" = 4px & "mr-2" = 8px; silly GitHub GM_addStyle(` .ghtws-button > * { pointer-events: none; } .ghtws-button { margin-right: 6px; }` ); // sidebar state let isHidden = false; const toggleIcon = ` <svg class="octicon" xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16"> <path fill="none" stroke="currentColor" stroke-miterlimit="10" d="M.5 3.5h10v9H.5z"/> <path fill="currentColor" stroke="currentColor" stroke-miterlimit="10" d="M7 7.8l1.5-1.2V9zM10.5 3.5h5v9h-5v-9zm4.3 4.3l-4.3-3V11l4.3-3.2z"/> </svg>`; function addToggle() { if ($("#wiki-wrapper") && !$(".ghtws-button")) { let el = $(".gh-header-actions") || $(".gh-header-title"); const button = document.createElement("div"); button.className = "btn btn-sm tooltipped tooltipped-s ghtws-button"; button.innerHTML = toggleIcon; button.setAttribute("aria-label", "Toggle Sidebar"); if (el.nodeName === "H1") { // non-editable wiki pages button.style.float = "right"; el = el.parentNode; } // editable wikis have a "header-actions" area // prepend button el.insertBefore(button, el.childNodes[0]); if (isHidden) { toggleSidebar(); } } } function toggleSidebar() { const sidebar = $("#wiki-rightbar"), wrapper = sidebar && sidebar.parentNode; if (sidebar) { if (isHidden) { sidebar.style.display = "none"; wrapper.classList.remove("has-rightbar"); } else { sidebar.style.display = ""; wrapper.classList.add("has-rightbar"); } GM_setValue("sidebar-state", isHidden); } } function toggleEvent(event) { const target = event.target; if (target && target.classList.contains("ghtws-button")) { isHidden = !isHidden; toggleSidebar(); } } function $(selector, el) { return (el || document).querySelector(selector); } function init() { isHidden = GM_getValue("sidebar-state", false); $("body").addEventListener("click", toggleEvent); addToggle(); } document.addEventListener("ghmo:container", addToggle); init(); })();