summaryrefslogtreecommitdiffstats
path: root/webapp/components/search_bar.jsx
diff options
context:
space:
mode:
authorAsaad Mahmood <asaadmahmood@users.noreply.github.com>2017-01-09 19:32:27 +0500
committerHarrison Healey <harrisonmhealey@gmail.com>2017-01-09 09:32:27 -0500
commit93a526f7ed5464e18e11137f798d09c0561b16a8 (patch)
tree3ee6b8c139790b99ed9bc5419824dfa981ba14df /webapp/components/search_bar.jsx
parentf6672605e82919798eb23ec45d8e663351af7d97 (diff)
downloadchat-93a526f7ed5464e18e11137f798d09c0561b16a8.tar.gz
chat-93a526f7ed5464e18e11137f798d09c0561b16a8.tar.bz2
chat-93a526f7ed5464e18e11137f798d09c0561b16a8.zip
PLT-5179 - Fixing modal overflow for autocomplete (#5002)
* PLT-5179 - Fixing modal overflow for autocomplete * PLT-5171 - Fixing search bar popover behaviour
Diffstat (limited to 'webapp/components/search_bar.jsx')
-rw-r--r--webapp/components/search_bar.jsx61
1 files changed, 26 insertions, 35 deletions
diff --git a/webapp/components/search_bar.jsx b/webapp/components/search_bar.jsx
index a6fd379ac..a7e9bfcac 100644
--- a/webapp/components/search_bar.jsx
+++ b/webapp/components/search_bar.jsx
@@ -104,7 +104,6 @@ export default class SearchBar extends React.Component {
SearchStore.storeSearchTerm(term);
SearchStore.emitSearchTermChange(false);
this.setState({searchTerm: term});
- this.refs.searchOverlay.hide();
}
handleUserBlur() {
@@ -112,9 +111,8 @@ export default class SearchBar extends React.Component {
}
handleUserFocus() {
- $('.search-bar__container').addClass('focused');
-
this.setState({focused: true});
+ $('.search-bar__container').addClass('focused');
}
performSearch(terms, isMentionSearch) {
@@ -180,6 +178,11 @@ export default class SearchBar extends React.Component {
isSearching = <span className={'fa fa-refresh fa-refresh-animate icon--refresh icon--rotate'}/>;
}
+ let helpClass = 'search-help-popover';
+ if (!this.state.searchTerm && this.state.focused) {
+ helpClass += ' visible';
+ }
+
const recentMentionsTooltip = (
<Tooltip id='recentMentionsTooltip'>
<FormattedMessage
@@ -189,19 +192,6 @@ export default class SearchBar extends React.Component {
</Tooltip>
);
- const searchPopover = (
- <Popover
- id='searchbar-help-popup'
- placement='bottom'
- className='search-help-popover'
- >
- <FormattedHTMLMessage
- id='search_bar.usage'
- defaultMessage='<h4>Search Options</h4><ul><li><span>Use </span><b>"quotation marks"</b><span> to search for phrases</span></li><li><span>Use </span><b>from:</b><span> to find posts from specific users and </span><b>in:</b><span> to find posts in specific channels</span></li></ul>'
- />
- </Popover>
- );
-
const flaggedTooltip = (
<Tooltip id='flaggedTooltip'>
<FormattedMessage
@@ -285,28 +275,29 @@ export default class SearchBar extends React.Component {
autoComplete='off'
>
<span className='fa fa-search sidebar__search-icon'/>
- <OverlayTrigger
- ref='searchOverlay'
- delayShow={Constants.OVERLAY_TIME_DELAY_SMALL}
+ <SuggestionBox
+ ref='search'
+ className='form-control search-bar'
+ placeholder={Utils.localizeMessage('search_bar.search', 'Search')}
+ value={this.state.searchTerm}
+ onFocus={this.handleUserFocus}
+ onBlur={this.handleUserBlur}
+ onChange={this.handleChange}
+ listComponent={SearchSuggestionList}
+ providers={this.suggestionProviders}
+ type='search'
+ />
+ {isSearching}
+ <Popover
+ id='searchbar-help-popup'
placement='bottom'
- overlay={searchPopover}
- trigger='click'
- rootClose={true}
+ className={helpClass}
>
- <SuggestionBox
- ref='search'
- className='form-control search-bar'
- placeholder={Utils.localizeMessage('search_bar.search', 'Search')}
- value={this.state.searchTerm}
- onFocus={this.handleUserFocus}
- onBlur={this.handleUserBlur}
- onChange={this.handleChange}
- listComponent={SearchSuggestionList}
- providers={this.suggestionProviders}
- type='search'
+ <FormattedHTMLMessage
+ id='search_bar.usage'
+ defaultMessage='<h4>Search Options</h4><ul><li><span>Use </span><b>"quotation marks"</b><span> to search for phrases</span></li><li><span>Use </span><b>from:</b><span> to find posts from specific users and </span><b>in:</b><span> to find posts in specific channels</span></li></ul>'
/>
- </OverlayTrigger>
- {isSearching}
+ </Popover>
</form>
{mentionBtn}