import React, {Component, PropTypes} from 'react' import {Menu, SearchBar, ListensToFluxStore} from 'nylas-component-kit' import {FocusedPerspectiveStore} from 'nylas-exports' 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, perspective: PropTypes.object, } _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 ; } if (suggestion.thread) { return suggestion.thread.subject; } if (suggestion.customElement) { return suggestion.customElement } return suggestion.label; } _placeholder = () => { if (this.props.perspective.isInbox()) { return 'Search all email'; } return `Search ${this.props.perspective.name || ""}`; } render() { const {query, isSearching, suggestions} = this.props; return ( 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, { stores: [SearchStore, FocusedPerspectiveStore], getStateFromStores() { return { query: SearchStore.query(), suggestions: SearchStore.suggestions(), isSearching: SearchStore.isSearching(), perspective: FocusedPerspectiveStore.current(), }; }, })