diff options
author | leo60228 <leo@60228.dev> | 2024-09-11 17:48:20 -0400 |
---|---|---|
committer | (quasar) nebula <qznebula@protonmail.com> | 2025-01-10 18:51:25 -0400 |
commit | 21de3c57d4a5364228fc95ffc3d79dae5ea16586 (patch) | |
tree | c6a808158e6581d1b580e8321968958474041041 | |
parent | 64cf539eca28933449e8c8df4118600a05ea4593 (diff) |
search result keyboard focus
-rw-r--r-- | src/static/js/client/sidebar-search.js | 36 |
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; } |