« get me outta code hell

client: dismiss upcoming change event - hsmusic-wiki - HSMusic - static wiki software cataloguing collaborative creation
about summary refs log tree commit diff
path: root/src/static/js/client
diff options
context:
space:
mode:
author(quasar) nebula <qznebula@protonmail.com>2025-01-10 18:25:08 -0400
committer(quasar) nebula <qznebula@protonmail.com>2025-01-10 18:51:26 -0400
commit1eaa19ecac9affb7f6a7c0e6c6363c125ece91cf (patch)
tree8dadb3d971fb58e123c489a7a4848a41478fe68b /src/static/js/client
parentc7d233c4bc1f7bd8f8c3205b6683022c31a43b5f (diff)
client: dismiss upcoming change event
...rather than tracking value changes, which is finnicky and
broke how we detected pressing enter/return to acivate search
(on 'change' event)
Diffstat (limited to 'src/static/js/client')
-rw-r--r--src/static/js/client/sidebar-search.js42
1 files changed, 25 insertions, 17 deletions
diff --git a/src/static/js/client/sidebar-search.js b/src/static/js/client/sidebar-search.js
index 4f0c2d8f..2e34baad 100644
--- a/src/static/js/client/sidebar-search.js
+++ b/src/static/js/client/sidebar-search.js
@@ -77,6 +77,7 @@ export const info = {
     stoppedTypingTimeout: null,
     stoppedScrollingTimeout: null,
     focusFirstResultTimeout: null,
+    dismissChangeEventTimeout: null,
 
     indexDownloadStatuses: Object.create(null),
   },
@@ -106,6 +107,7 @@ export const info = {
     stoppedScrollingDelay: 200,
 
     pressDownToFocusFirstResultLatency: 200,
+    dismissChangeEventAfterFocusingFirstResultLatency: 50,
 
     maxActiveResultsStorage: 100000,
   },
@@ -305,33 +307,24 @@ export function mutatePageContent() {
   info.searchBox.appendChild(info.endSearchLine);
 }
 
-function trackSidebarSearchInputChanged() {
-  const {state} = info;
-
-  const newValue = info.searchInput.value;
-
-  if (newValue === state.currentValue) {
-    return false;
-  } else {
-    state.currentValue = newValue;
-    return !!newValue;
-  }
-}
-
 export function addPageListeners() {
   if (!info.searchInput) return;
 
   info.searchInput.addEventListener('change', _domEvent => {
-    if (trackSidebarSearchInputChanged()) {
-      activateSidebarSearch(info.searchInput.value);
+    const {state} = info;
+
+    if (state.dismissChangeEventTimeout) {
+      state.dismissChangeEventTimeout = null;
+      clearTimeout(state.dismissChangeEventTimeout);
+      return;
     }
+
+    activateSidebarSearch(info.searchInput.value);
   });
 
   info.searchInput.addEventListener('input', _domEvent => {
     const {settings, state} = info;
 
-    trackSidebarSearchInputChanged();
-
     if (!info.searchInput.value) {
       clearSidebarSearch();
       return;
@@ -362,6 +355,10 @@ export function addPageListeners() {
         clearTimeout(state.stoppedTypingTimeout);
         state.stoppedTypingTimeout = null;
 
+        if (state.focusFirstResultTimeout) {
+          clearTimeout(state.focusFirstResultTimeout);
+        }
+
         state.focusFirstResultTimeout =
           setTimeout(() => {
             state.focusFirstResultTimeout = null;
@@ -862,11 +859,22 @@ function hideSidebarSearchResults() {
 }
 
 function focusFirstSidebarSearchResult() {
+  const {settings, state} = info;
+
   const elem = info.results.firstChild;
   if (!elem?.classList.contains('wiki-search-result')) {
     return;
   }
 
+  if (state.dismissChangeEventTimeout) {
+    clearTimeout(state.dismissChangeEventTimeout);
+  }
+
+  state.dismissChangeEventTimeout =
+    setTimeout(() => {
+      state.dismissChangeEventTimeout = null;
+    }, settings.dismissChangeEventAfterFocusingFirstResultLatency);
+
   elem.focus({focusVisible: true});
 }