2017-09-27 02:33:08 +08:00
|
|
|
import React, { Component } from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import { Menu, SearchBar, ListensToFluxStore } from 'nylas-component-kit';
|
|
|
|
import { FocusedPerspectiveStore } from 'nylas-exports';
|
|
|
|
import SearchStore from './search-store';
|
|
|
|
import SearchActions from './search-actions';
|
2016-11-13 02:32:16 +08:00
|
|
|
|
|
|
|
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,
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-11-13 02:32:16 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
_onSelectSuggestion = suggestion => {
|
2016-11-13 02:32:16 +08:00
|
|
|
if (suggestion.thread) {
|
2017-09-27 02:33:08 +08:00
|
|
|
SearchActions.querySubmitted(`"${suggestion.thread.subject}"`);
|
2016-11-13 02:32:16 +08:00
|
|
|
} else {
|
|
|
|
SearchActions.querySubmitted(suggestion.value);
|
|
|
|
}
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-11-13 02:32:16 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
_onSearchQueryChanged = query => {
|
2016-11-13 02:32:16 +08:00
|
|
|
SearchActions.queryChanged(query);
|
|
|
|
if (query === '') {
|
|
|
|
this._onClearSearchQuery();
|
|
|
|
}
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-11-13 02:32:16 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
_onSubmitSearchQuery = query => {
|
2016-11-13 02:32:16 +08:00
|
|
|
SearchActions.querySubmitted(query);
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-11-13 02:32:16 +08:00
|
|
|
|
|
|
|
_onClearSearchQuery = () => {
|
|
|
|
SearchActions.querySubmitted('');
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-11-13 02:32:16 +08:00
|
|
|
|
|
|
|
_onClearSearchSuggestions = () => {
|
2017-09-27 02:33:08 +08:00
|
|
|
SearchActions.searchBlurred();
|
|
|
|
};
|
2016-11-13 02:32:16 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
_renderSuggestion = suggestion => {
|
2016-11-13 02:32:16 +08:00
|
|
|
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) {
|
2017-09-27 02:33:08 +08:00
|
|
|
return suggestion.customElement;
|
2016-11-18 06:57:24 +08:00
|
|
|
}
|
2016-11-13 02:32:16 +08:00
|
|
|
return suggestion.label;
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-11-13 02:32:16 +08:00
|
|
|
|
2017-04-04 07:30:06 +08:00
|
|
|
_placeholder = () => {
|
|
|
|
if (this.props.perspective.isInbox()) {
|
|
|
|
return 'Search all email';
|
|
|
|
}
|
2017-09-27 02:33:08 +08:00
|
|
|
return `Search ${this.props.perspective.name || ''}`;
|
|
|
|
};
|
2017-04-04 07:30:06 +08:00
|
|
|
|
2016-11-13 02:32:16 +08:00
|
|
|
render() {
|
2017-09-27 02:33:08 +08:00
|
|
|
const { query, isSearching, suggestions } = this.props;
|
2016-11-13 02:32:16 +08:00
|
|
|
|
|
|
|
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}
|
2017-09-27 02:33:08 +08:00
|
|
|
suggestionKey={suggestion =>
|
|
|
|
suggestion.label || (suggestion.contact || {}).id || (suggestion.thread || {}).id}
|
2016-11-13 02:32:16 +08:00
|
|
|
suggestionRenderer={this._renderSuggestion}
|
|
|
|
onSelectSuggestion={this._onSelectSuggestion}
|
|
|
|
onSubmitSearchQuery={this._onSubmitSearchQuery}
|
|
|
|
onSearchQueryChanged={this._onSearchQueryChanged}
|
|
|
|
onClearSearchQuery={this._onClearSearchQuery}
|
|
|
|
onClearSearchSuggestions={this._onClearSearchSuggestions}
|
|
|
|
/>
|
2017-09-27 02:33:08 +08:00
|
|
|
);
|
2016-11-13 02:32:16 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
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
|
|
|
};
|
|
|
|
},
|
2017-09-27 02:33:08 +08:00
|
|
|
});
|