2016-11-13 02:32:16 +08:00
|
|
|
import React, {Component, PropTypes} from 'react'
|
|
|
|
import {Menu, SearchBar, ListensToFluxStore} from 'nylas-component-kit'
|
2017-04-04 07:30:06 +08:00
|
|
|
import {FocusedPerspectiveStore} from 'nylas-exports'
|
2016-11-13 02:32:16 +08:00
|
|
|
import SearchStore from './search-store'
|
|
|
|
import SearchActions from './search-actions'
|
|
|
|
|
|
|
|
|
|
|
|
class ThreadSearchBar extends Component {
|
|
|
|
static displayName = 'ThreadSearchBar';
|
|
|
|
|
|
|
|
static propTypes = {
|
|
|
|
query: PropTypes.string,
|
|
|
|
isSearching: PropTypes.bool,
|
|
|
|
suggestions: PropTypes.array,
|
2017-04-04 07:30:06 +08:00
|
|
|
perspective: PropTypes.object,
|
2016-11-13 02:32:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
_onSelectSuggestion = (suggestion) => {
|
|
|
|
if (suggestion.thread) {
|
|
|
|
SearchActions.querySubmitted(`"${suggestion.thread.subject}"`)
|
|
|
|
} else {
|
|
|
|
SearchActions.querySubmitted(suggestion.value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
_onSearchQueryChanged = (query) => {
|
|
|
|
SearchActions.queryChanged(query);
|
|
|
|
if (query === '') {
|
|
|
|
this._onClearSearchQuery();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
_onSubmitSearchQuery = (query) => {
|
|
|
|
SearchActions.querySubmitted(query);
|
|
|
|
}
|
|
|
|
|
|
|
|
_onClearSearchQuery = () => {
|
|
|
|
SearchActions.querySubmitted('');
|
|
|
|
}
|
|
|
|
|
|
|
|
_onClearSearchSuggestions = () => {
|
|
|
|
SearchActions.searchBlurred()
|
|
|
|
}
|
|
|
|
|
|
|
|
_renderSuggestion = (suggestion) => {
|
|
|
|
if (suggestion.contact) {
|
|
|
|
return <Menu.NameEmailItem name={suggestion.contact.name} email={suggestion.contact.email} />;
|
|
|
|
}
|
|
|
|
if (suggestion.thread) {
|
|
|
|
return suggestion.thread.subject;
|
|
|
|
}
|
2016-11-18 06:57:24 +08:00
|
|
|
if (suggestion.customElement) {
|
|
|
|
return suggestion.customElement
|
|
|
|
}
|
2016-11-13 02:32:16 +08:00
|
|
|
return suggestion.label;
|
|
|
|
}
|
|
|
|
|
2017-04-04 07:30:06 +08:00
|
|
|
_placeholder = () => {
|
|
|
|
if (this.props.perspective.isInbox()) {
|
|
|
|
return 'Search all email';
|
|
|
|
}
|
|
|
|
return `Search ${this.props.perspective.name}`;
|
|
|
|
}
|
|
|
|
|
2016-11-13 02:32:16 +08:00
|
|
|
render() {
|
|
|
|
const {query, isSearching, suggestions} = this.props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<SearchBar
|
|
|
|
className="thread-search-bar"
|
2017-04-04 07:30:06 +08:00
|
|
|
placeholder={this._placeholder()}
|
2016-11-13 02:32:16 +08:00
|
|
|
query={query}
|
|
|
|
suggestions={suggestions}
|
|
|
|
isSearching={isSearching}
|
|
|
|
suggestionKey={(suggestion) => suggestion.label || (suggestion.contact || {}).id || (suggestion.thread || {}).id}
|
|
|
|
suggestionRenderer={this._renderSuggestion}
|
|
|
|
onSelectSuggestion={this._onSelectSuggestion}
|
|
|
|
onSubmitSearchQuery={this._onSubmitSearchQuery}
|
|
|
|
onSearchQueryChanged={this._onSearchQueryChanged}
|
|
|
|
onClearSearchQuery={this._onClearSearchQuery}
|
|
|
|
onClearSearchSuggestions={this._onClearSearchSuggestions}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ListensToFluxStore(ThreadSearchBar, {
|
2017-04-04 07:30:06 +08:00
|
|
|
stores: [SearchStore, FocusedPerspectiveStore],
|
2016-11-13 02:32:16 +08:00
|
|
|
getStateFromStores() {
|
|
|
|
return {
|
|
|
|
query: SearchStore.query(),
|
|
|
|
suggestions: SearchStore.suggestions(),
|
|
|
|
isSearching: SearchStore.isSearching(),
|
2017-04-04 07:30:06 +08:00
|
|
|
perspective: FocusedPerspectiveStore.current(),
|
2016-11-13 02:32:16 +08:00
|
|
|
};
|
|
|
|
},
|
|
|
|
})
|