-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathbackspacePanelNav.uc.js
72 lines (70 loc) · 2.66 KB
/
backspacePanelNav.uc.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
// ==UserScript==
// @name Backspace Panel Navigation
// @version 1.1.4
// @author aminomancer
// @homepageURL https://github.com/aminomancer
// @description Press backspace to navigate back/forward in popup panels.
// @downloadURL https://cdn.jsdelivr.net/gh/aminomancer/uc.css.js@master/JS/backspacePanelNav.uc.js
// @updateURL https://cdn.jsdelivr.net/gh/aminomancer/uc.css.js@master/JS/backspacePanelNav.uc.js
// @license This Source Code Form is subject to the terms of the Creative Commons Attribution-NonCommercial-ShareAlike International License, v. 4.0. If a copy of the CC BY-NC-SA 4.0 was not distributed with this file, You can obtain one at http://creativecommons.org/licenses/by-nc-sa/4.0/ or send a letter to Creative Commons, PO Box 1866, Mountain View, CA 94042, USA.
// ==/UserScript==
(function () {
function init() {
const pc = Object.getPrototypeOf(PanelView.forNode(PanelUI.mainView));
function isNavigableWithTabOnly(element) {
let tag = element.localName;
return (
tag == "menulist" ||
tag == "select" ||
tag == "radiogroup" ||
tag == "input" ||
tag == "textarea" ||
// Allow tab to reach embedded documents.
tag == "browser" ||
tag == "iframe" ||
// This is currently needed for the unified extensions panel to allow
// users to use up/down arrow to more quickly move between the extension
// items. See Bug 1784118
element.dataset?.navigableWithTabOnly === "true"
);
}
eval(
`pc.keyNavigation = function ${pc.keyNavigation
.toSource()
.replace(/^\(/, "")
.replace(/\)$/, "")
.replace(/^keyNavigation\s*/, "")
.replace(/^function\s*/, "")
.replace(/#isNavigableWithTabOnly/, isNavigableWithTabOnly)
.replace(
/(case \"ArrowLeft\"\:)/,
`case "Backspace":
if (tabOnly() || isContextMenuOpen()) {
break;
}
stop();
if (PanelMultiView.forNode(this.node.panelMultiView).openViews.length > 1) {
this.node.panelMultiView.goBack();
} else {
PanelMultiView.forNode(this.node.panelMultiView)?._panel.hidePopup(true);
}
break;
$1`
)}`
);
}
if (gBrowserInit.delayedStartupFinished) {
init();
} else {
let delayedListener = (subject, topic) => {
if (topic == "browser-delayed-startup-finished" && subject == window) {
Services.obs.removeObserver(delayedListener, topic);
init();
}
};
Services.obs.addObserver(
delayedListener,
"browser-delayed-startup-finished"
);
}
})();