From 13f8b8fe7679161a272db67ebb06d75c86d6041d Mon Sep 17 00:00:00 2001 From: leo60228 Date: Sat, 14 Sep 2024 17:44:20 -0400 Subject: address review 2 --- src/static/js/client/sidebar-search.js | 30 +++++++++++++++++++++--------- 1 file changed, 21 insertions(+), 9 deletions(-) (limited to 'src') diff --git a/src/static/js/client/sidebar-search.js b/src/static/js/client/sidebar-search.js index ae18c930..f46ce8e8 100644 --- a/src/static/js/client/sidebar-search.js +++ b/src/static/js/client/sidebar-search.js @@ -76,6 +76,8 @@ export const info = { stoppedScrollingTimeout: null, indexDownloadStatuses: Object.create(null), + + currentValue: null, }, session: { @@ -300,22 +302,32 @@ 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; - let prevValue = null; info.searchInput.addEventListener('change', _domEvent => { - if (info.searchInput.value && info.searchInput.value !== prevValue) { + if (trackSidebarSearchInputChanged()) { activateSidebarSearch(info.searchInput.value); } - prevValue = info.searchInput.value; }); info.searchInput.addEventListener('input', _domEvent => { const {settings, state} = info; - if (prevValue === info.searchInput.value) return; - prevValue = info.searchInput.value; + trackSidebarSearchInputChanged(); if (!info.searchInput.value) { clearSidebarSearch(); @@ -608,7 +620,7 @@ function showSidebarSearchResults(results) { } for (const result of flatResults) { - const el = generateSidebarSearchResult(result, info); + const el = generateSidebarSearchResult(result); if (!el) continue; info.results.appendChild(el); @@ -624,7 +636,7 @@ function showSidebarSearchResults(results) { restoreSidebarSearchResultsScrollOffset(); } -function generateSidebarSearchResult(result, info) { +function generateSidebarSearchResult(result) { const preparedSlots = { color: result.data.color ?? null, @@ -695,7 +707,7 @@ function generateSidebarSearchResult(result, info) { return null; } - return generateSidebarSearchResultTemplate(preparedSlots, info); + return generateSidebarSearchResultTemplate(preparedSlots); } function getSearchResultImageSource(result) { @@ -708,7 +720,7 @@ function getSearchResultImageSource(result) { 'rebaseThumb')); } -function generateSidebarSearchResultTemplate(slots, info) { +function generateSidebarSearchResultTemplate(slots) { const link = document.createElement('a'); link.classList.add('wiki-search-result'); -- cgit 1.3.0-6-gf8a5