From 56853321f5ad115589383dbffa589ba3bceafd34 Mon Sep 17 00:00:00 2001 From: robojumper Date: Thu, 2 Feb 2023 19:29:40 +0100 Subject: [PATCH] Work around downshift focus regression --- src/app/search/SearchBar.tsx | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/app/search/SearchBar.tsx b/src/app/search/SearchBar.tsx index 57a3baabf..d4fa8f933 100644 --- a/src/app/search/SearchBar.tsx +++ b/src/app/search/SearchBar.tsx @@ -304,6 +304,12 @@ function SearchBar( ) { const { type, changes } = actionAndChanges; switch (type) { + // FIXME: Do not act on focus because it interacts badly with autofocus + // Downshift will likely switch away from using focus because too + // https://github.com/downshift-js/downshift/issues/1439 + // (Also see onFocus below) + case useCombobox.stateChangeTypes.InputFocus: + return state; case useCombobox.stateChangeTypes.ItemClick: case useCombobox.stateChangeTypes.InputKeyDownEnter: // exit early if non FilterHelper item was selected @@ -316,7 +322,6 @@ function SearchBar( return { ...changes, selectedItem: state.selectedItem, // keep the last selected item (i.e. the edit field stays unchanged) - closeMenu: true, // close the menu }; default: @@ -324,6 +329,8 @@ function SearchBar( } } + // FIXME: Maybe follow suit when Downshift changes opening behavior to + // just use clicks and not focus (see stateReducer above) const onFocus = () => { if (!liveQuery && !isOpen && !autoFocus) { openMenu();