« get me outta code hell

search result keyboard focus - hsmusic-wiki - HSMusic - static wiki software cataloguing collaborative creation
about summary refs log tree commit diff
path: root/src/static/js/client/sidebar-search.js
diff options
context:
space:
mode:
authorleo60228 <leo@60228.dev>2024-09-11 17:48:20 -0400
committer(quasar) nebula <qznebula@protonmail.com>2025-01-10 18:51:25 -0400
commit21de3c57d4a5364228fc95ffc3d79dae5ea16586 (patch)
treec6a808158e6581d1b580e8321968958474041041 /src/static/js/client/sidebar-search.js
parent64cf539eca28933449e8c8df4118600a05ea4593 (diff)
search result keyboard focus
Diffstat (limited to 'src/static/js/client/sidebar-search.js')
-rw-r--r--src/static/js/client/sidebar-search.js36
1 files changed, 32 insertions, 4 deletions
diff --git a/src/static/js/client/sidebar-search.js b/src/static/js/client/sidebar-search.js
index 9d2cae34..917b9c12 100644
--- a/src/static/js/client/sidebar-search.js
+++ b/src/static/js/client/sidebar-search.js
@@ -329,6 +329,16 @@ export function addPageListeners() {
 
   info.searchInput.addEventListener('drop', handleDroppedIntoSearchInput);
 
+  info.searchInput.addEventListener('keydown', domEvent => {
+    if (domEvent.key === 'ArrowDown' && info.searchInput.value.length === info.searchInput.selectionStart) {
+      const elem = info.results?.firstChild;
+      if (elem && !elem.classList.contains('wiki-search-no-results')) {
+        domEvent.preventDefault();
+        elem.focus();
+      }
+    }
+  });
+
   info.endSearchLink.addEventListener('click', domEvent => {
     domEvent.preventDefault();
     clearSidebarSearch();
@@ -593,7 +603,7 @@ function showSidebarSearchResults(results) {
   }
 
   for (const result of flatResults) {
-    const el = generateSidebarSearchResult(result);
+    const el = generateSidebarSearchResult(result, info);
     if (!el) continue;
 
     info.results.appendChild(el);
@@ -609,7 +619,7 @@ function showSidebarSearchResults(results) {
   restoreSidebarSearchResultsScrollOffset();
 }
 
-function generateSidebarSearchResult(result) {
+function generateSidebarSearchResult(result, info) {
   const preparedSlots = {
     color:
       result.data.color ?? null,
@@ -680,7 +690,7 @@ function generateSidebarSearchResult(result) {
       return null;
   }
 
-  return generateSidebarSearchResultTemplate(preparedSlots);
+  return generateSidebarSearchResultTemplate(preparedSlots, info);
 }
 
 function getSearchResultImageSource(result) {
@@ -693,7 +703,7 @@ function getSearchResultImageSource(result) {
       'rebaseThumb'));
 }
 
-function generateSidebarSearchResultTemplate(slots) {
+function generateSidebarSearchResultTemplate(slots, info) {
   const link = document.createElement('a');
   link.classList.add('wiki-search-result');
 
@@ -775,6 +785,24 @@ function generateSidebarSearchResultTemplate(slots) {
     saveSidebarSearchResultsScrollOffset();
   });
 
+  link.addEventListener('keydown', domEvent => {
+    if (domEvent.key === 'ArrowDown') {
+      const elem = link.nextElementSibling;
+      if (elem) {
+        domEvent.preventDefault();
+        elem.focus();
+      }
+    } else if (domEvent.key === 'ArrowUp') {
+      domEvent.preventDefault();
+      const elem = link.previousElementSibling;
+      if (elem) {
+        elem.focus();
+      } else {
+        info.searchInput.focus();
+      }
+    }
+  });
+
   return link;
 }