WebUI: use native event listeners for keyboard events

PR #21924.
This commit is contained in:
Chocobo1 2024-12-02 13:41:19 +08:00 committed by GitHub
parent e8d8de8f19
commit 2d1c4fc809
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
24 changed files with 273 additions and 366 deletions

View file

@ -139,28 +139,25 @@ window.qBittorrent.Search ??= (() => {
}, window.qBittorrent.Misc.FILTER_INPUT_DELAY);
});
new Keyboard({
defaultEventType: "keydown",
events: {
"Enter": function(e) {
// accept enter key as a click
e.preventDefault();
e.stopPropagation();
document.getElementById("SearchPanel").addEventListener("keydown", (event) => {
switch (event.key) {
case "Enter": {
event.preventDefault();
event.stopPropagation();
const elem = e.event.srcElement;
if (elem.className.contains("searchInputField")) {
document.getElementById("startSearchButton").click();
return;
}
switch (elem.id) {
switch (event.target.id) {
case "manageSearchPlugins":
manageSearchPlugins();
break;
case "searchPattern":
document.getElementById("startSearchButton").click();
break;
}
break;
}
}
}).activate();
});
// restore search tabs
const searchJobs = JSON.parse(LocalPreferences.get("search_jobs", "[]"));