FIX: search escape handler should be on keydown (#25364)

The keydown event fires as soon as the key is pressed down. This is often preferred for actions that need to occur immediately, like stopping a process, closing a modal window, or canceling an ongoing operation. The immediacy of keydown makes it more responsive, as the user doesn't have to fully press and release the key.

Moreover, it allows us to not close chat on escape when the search menu is open.
This commit is contained in:
Joffrey JAFFEUX 2024-01-22 15:19:20 +01:00 committed by GitHub
parent 108aff663e
commit f669a6fa4c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 12 additions and 8 deletions

View File

@ -6,6 +6,7 @@
placeholder={{i18n "search.title"}} placeholder={{i18n "search.title"}}
aria-label={{i18n "search.title"}} aria-label={{i18n "search.title"}}
{{on "keyup" this.onKeyup}} {{on "keyup" this.onKeyup}}
{{on "keydown" this.onKeydown}}
{{on "input" this.updateSearchTerm}} {{on "input" this.updateSearchTerm}}
{{on "focus" @openSearchMenu}} {{on "focus" @openSearchMenu}}
{{did-insert this.focus}} {{did-insert this.focus}}

View File

@ -49,6 +49,15 @@ export default class SearchTerm extends Component {
} }
} }
@action
onKeydown(e) {
if (e.key === "Escape") {
this.args.closeSearchMenu();
e.preventDefault();
e.stopPropagation();
}
}
@action @action
onKeyup(e) { onKeyup(e) {
if ( if (
@ -59,12 +68,6 @@ export default class SearchTerm extends Component {
return; return;
} }
if (e.key === "Escape") {
this.args.closeSearchMenu();
e.preventDefault();
return false;
}
this.args.openSearchMenu(); this.args.openSearchMenu();
this.search.handleArrowUpOrDown(e); this.search.handleArrowUpOrDown(e);

View File

@ -600,7 +600,7 @@ acceptance("Search - Glimmer - Authenticated", function (needs) {
"arrow down sets focus to more results link" "arrow down sets focus to more results link"
); );
await triggerKeyEvent("#search-term", "keyup", "Escape"); await triggerKeyEvent("#search-term", "keydown", "Escape");
assert.strictEqual( assert.strictEqual(
document.activeElement, document.activeElement,
query("#search-button"), query("#search-button"),

View File

@ -43,7 +43,7 @@ module("Integration | Component | search-menu", function (hooks) {
"search result is a list of topics" "search result is a list of topics"
); );
await triggerKeyEvent("#search-term", "keyup", "Escape"); await triggerKeyEvent("#search-term", "keydown", "Escape");
assert.notOk(exists(".menu-panel"), "Menu panel is gone"); assert.notOk(exists(".menu-panel"), "Menu panel is gone");