aboutsummaryrefslogtreecommitdiff
path: root/src/app
diff options
context:
space:
mode:
Diffstat (limited to 'src/app')
-rw-r--r--src/app/js/navigate.js41
-rw-r--r--src/app/js/settings.js7
2 files changed, 47 insertions, 1 deletions
diff --git a/src/app/js/navigate.js b/src/app/js/navigate.js
index 8cf2584..908a432 100644
--- a/src/app/js/navigate.js
+++ b/src/app/js/navigate.js
@@ -10,6 +10,17 @@ let navigate = {
// according to what is currently the `.active-selection`, if none is
// found, it'll instead be hidden
navigate.selection = (new_selection) => {
+ // if we're not allowed to unselect an element, then make sure that
+ // element is still unselected, and then clear
+ // `navigate.dont_unselect`
+ if (navigate.dont_unselect
+ && navigate.dont_unselect != new_selection) {
+
+ navigate.dont_unselect.classList.add("active-selection");
+ navigate.dont_unselect = false;
+ return;
+ }
+
if (new_selection) {
let selected = document.querySelectorAll(".active-selection");
@@ -505,9 +516,32 @@ navigate.select = () => {
return;
}
+ // correctly open a `<select>`
+ //
+ // they require special handling, as unless the Enter key is
+ // pressed, then the menu won't open, and instead the element is
+ // focused, which isn't great
+ //
+ // so we make the main process send a fake Enter key press
+ if (active.closest("select")) {
+ active = active.closest("select");
+
+ // make sure `<select>` is focused
+ active.focus();
+ active.click();
+
+ // make sure this element doesn't get unselected
+ navigate.dont_unselect = active;
+
+ // send fake Enter key to open selection menu
+ ipcRenderer.send("send-enter-key");
+
+ return;
+ }
+
// click and focus `active`
- active.click();
active.focus();
+ active.click();
}, 150)
}
@@ -854,6 +888,11 @@ events.on("popup-changed", (e) => {
return;
}
+ // ignore if `active_el` is a `<select>`
+ if (active_el.closest("select")) {
+ return;
+ }
+
// add `active_el` to `last_popup_selections` if we opened a popup
if (e.new_state) {
last_popup_selections.push({
diff --git a/src/app/js/settings.js b/src/app/js/settings.js
index b5ef773..56bfc5f 100644
--- a/src/app/js/settings.js
+++ b/src/app/js/settings.js
@@ -264,6 +264,13 @@ settings.popup.load = () => {
}
}
+ let selects = document.querySelectorAll("#options select");
+ for (let el of selects) {
+ el.addEventListener("change", () => {
+ el.blur();
+ })
+ }
+
// create Fuse based on options from `get_search_arr()`
settings_fuse = new Fuse(get_search_arr(), {
keys: ["text"],