From efc710d79649c28164fd17c49d993c06e2c75b21 Mon Sep 17 00:00:00 2001 From: Akinwale Ariwodola Date: Sun, 27 May 2018 21:48:06 +0100 Subject: [PATCH] blur text input and hide suggestions when the soft keyboard is closed --- app/src/component/uriBar/view.js | 24 +++++++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) diff --git a/app/src/component/uriBar/view.js b/app/src/component/uriBar/view.js index ace50902..0fb69d2b 100644 --- a/app/src/component/uriBar/view.js +++ b/app/src/component/uriBar/view.js @@ -8,6 +8,20 @@ import uriBarStyle from '../../styles/uriBar'; class UriBar extends React.PureComponent { static INPUT_TIMEOUT = 500; + textInput = null; + + keyboardDidHideListener = null; + + componentDidMount () { + this.keyboardDidHideListener = Keyboard.addListener('keyboardDidHide', this._keyboardDidHide); + } + + componentWillUnmount() { + if (this.keyboardDidHideListener) { + this.keyboardDidHideListener.remove(); + } + } + constructor(props) { super(props); this.state = { @@ -41,6 +55,13 @@ class UriBar extends React.PureComponent { navigation.navigate({ routeName: 'File', key: 'filePage', params: { uri: normalizeURI(value) }}); } } + + _keyboardDidHide = () => { + if (this.textInput) { + this.textInput.blur(); + } + this.setState({ focused: false }); + } render() { const { navigation, suggestions, updateSearchQuery, value } = this.props; @@ -66,7 +87,8 @@ class UriBar extends React.PureComponent { onPress={() => this.handleItemPress(item)} />} /> )} - { this.textInput = ref }} + style={uriBarStyle.uriText} selectTextOnFocus={true} placeholder={'Search for videos, music, games and more'} underlineColorAndroid={'transparent'}