Ignore keyevents during text composition (#7205)

KeyboardEvent.key may be physical key name (Escape, Tab, etc.)
even in text composition and it causes hotkeys or suggestion selection.
So we need to check e.which or e.isComposing.

Checking e.which also allows us to avoid Esc key on compositionend in Safari.
pull/456/head
unarist 2018-04-21 01:36:52 +09:00 committed by Eugen Rochko
parent 87e3f0a41d
commit 84214b864c
1 changed files with 6 additions and 0 deletions

View File

@ -84,6 +84,12 @@ export default class AutosuggestTextarea extends ImmutablePureComponent {
return; return;
} }
if (e.which === 229 || e.isComposing) {
// Ignore key events during text composition
// e.key may be a name of the physical key even in this case (e.x. Safari / Chrome on Mac)
return;
}
switch(e.key) { switch(e.key) {
case 'Escape': case 'Escape':
if (suggestions.size === 0 || suggestionsHidden) { if (suggestions.size === 0 || suggestionsHidden) {