A userscript that toggles all expanders when one expander is shift-clicked
当前为
// ==UserScript==
// @name GitHub Toggle Expanders
// @version 1.0.3
// @description A userscript that toggles all expanders when one expander is shift-clicked
// @license https://creativecommons.org/licenses/by-sa/4.0/
// @namespace https://github.com/Mottie
// @include https://github.com/*
// @run-at document-idle
// @author Rob Garrison
// ==/UserScript==
/* jshint esnext:true, unused:true */
(() => {
"use strict";
function toggle(el) {
const state = closest(".commits-list-item, .js-details-container", el)
.classList.contains("open"),
// target buttons inside commits_bucket - fixes #8
selector = `.commits-listing .commits-list-item,
#commits_bucket .js-details-container`;
Array.from(document.querySelectorAll(selector)).forEach(el => {
el.classList.toggle("open", state);
});
}
function closest(selector, el) {
while (el && el.nodeType === 1) {
if (el.matches(selector)) {
return el;
}
el = el.parentNode;
}
return null;
}
document.body.addEventListener("click", event => {
const target = event.target;
if (
target && event.getModifierState("Shift") &&
target.matches(".ellipsis-expander")
) {
// give GitHub time to add the class
setTimeout(() => {
toggle(target);
}, 100);
}
});
})();