From af518f1236a8ae22b45d2ab05ecb44430398dde2 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Fri, 10 Jan 2025 17:51:48 -0400 Subject: client: activate search when pressing down --- src/static/js/client/sidebar-search.js | 30 +++++++++++++++++++++++++++++- 1 file changed, 29 insertions(+), 1 deletion(-) (limited to 'src/static') diff --git a/src/static/js/client/sidebar-search.js b/src/static/js/client/sidebar-search.js index 5c1b54b8..ef64a259 100644 --- a/src/static/js/client/sidebar-search.js +++ b/src/static/js/client/sidebar-search.js @@ -76,6 +76,7 @@ export const info = { stoppedTypingTimeout: null, stoppedScrollingTimeout: null, + focusFirstResultTimeout: null, indexDownloadStatuses: Object.create(null), }, @@ -104,6 +105,8 @@ export const info = { stoppedTypingDelay: 800, stoppedScrollingDelay: 200, + pressDownToFocusFirstResultLatency: 200, + maxActiveResultsStorage: 100000, }, }; @@ -340,6 +343,7 @@ export function addPageListeners() { state.stoppedTypingTimeout = setTimeout(() => { + state.stoppedTypingTimeout = null; activateSidebarSearch(info.searchInput.value); }, settings.stoppedTypingDelay); }); @@ -347,11 +351,27 @@ export function addPageListeners() { info.searchInput.addEventListener('drop', handleDroppedIntoSearchInput); info.searchInput.addEventListener('keydown', domEvent => { + const {settings, state} = info; + if (domEvent.key === 'ArrowUp' || domEvent.key === 'ArrowDown') { domEvent.preventDefault(); } - if (domEvent.key === 'ArrowDown') { + if (domEvent.key === 'ArrowDown') handleDown: { + if (state.stoppedTypingTimeout) { + clearTimeout(state.stoppedTypingTimeout); + state.stoppedTypingTimeout = null; + + state.focusFirstResultTimeout = + setTimeout(() => { + state.focusFirstResultTimeout = null; + }, settings.pressDownToFocusFirstResultLatency); + + activateSidebarSearch(info.searchInput.value); + + break handleDown; + } + const elem = info.results.firstChild; if (elem?.classList.contains('wiki-search-result')) { elem.focus({focusVisible: true}); @@ -479,6 +499,14 @@ async function activateSidebarSearch(query) { session.resultsScrollOffset = 0; showSidebarSearchResults(results); + + if (state.focusFirstResultTimeout) { + clearTimeout(state.focusFirstResultTimeout); + state.focusFirstResultTimeout = null; + if (!state.stoppedTypingTimeout) { + info.results.firstChild?.focus(); + } + } } function clearSidebarSearch() { -- cgit 1.3.0-6-gf8a5