您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Add keyboard shortcuts for adding and removing labels on GitHub
// ==UserScript== // @name GitHub Label Keyboard Shortcuts // @namespace https://intuitiveexplanations.com/ // @version 2.0.1 // @description Add keyboard shortcuts for adding and removing labels on GitHub // @author Radon Rosborough // @match https://github.com/* // @icon data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw== // @grant none // @license MIT // ==/UserScript== (function () { "use strict"; const tryUntilSuccess = (fn, totalTimeout, delay) => { return new Promise((resolve, reject) => { try { fn(); } catch (err) { if (totalTimeout <= 0) { reject(err); } else { setTimeout( () => tryUntilSuccess(fn, totalTimeout - delay, delay) .then(resolve) .catch(reject), delay, ); } return; } resolve(); }); }; const setLabelsMenuVisibility = (desiredState) => { if (document.getElementById("labels-select-menu").open !== desiredState) { document .getElementById("labels-select-menu") .querySelector("summary") .click(); } }; const setLabelPresence = (label, desiredState) => { const elt = document.querySelector( "form[aria-label='Apply labels'] label[data-prio-filter-value='waiting on response']", ); if (elt.getAttribute("aria-checked") !== "" + desiredState) { elt.click(); } }; const shortcuts = [ { matcher: (event) => { return ( event.key === ";" && event.altKey && !event.ctrlKey && !event.metaKey ); }, label: "waiting on response", desiredState: true, }, { matcher: (event) => { return ( event.key === ":" && event.altKey && !event.ctrlKey && !event.metaKey ); }, label: "waiting on response", desiredState: false, }, ]; document.addEventListener("keydown", (event) => { for (const shortcut of shortcuts) { if (shortcut.matcher(event)) { setLabelsMenuVisibility(true); tryUntilSuccess( () => setLabelPresence(shortcut.label, shortcut.desiredState), 1000, 10, ).then(() => { setLabelsMenuVisibility(false); window.scrollTo(0, document.body.scrollHeight); }); break; } } }); })();