import classNames from 'classnames'; import PropTypes from 'prop-types'; import React from 'react'; import ImmutablePropTypes from 'react-immutable-proptypes'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { FormattedMessage } from 'react-intl'; import { defineMessages, injectIntl } from 'react-intl'; import Hashtag from 'soapbox/components/hashtag'; import ScrollableList from 'soapbox/components/scrollable_list'; import { Tabs } from 'soapbox/components/ui'; import AccountContainer from 'soapbox/containers/account_container'; import StatusContainer from 'soapbox/containers/status_container'; import PlaceholderAccount from 'soapbox/features/placeholder/components/placeholder_account'; import PlaceholderHashtag from 'soapbox/features/placeholder/components/placeholder_hashtag'; import PlaceholderStatus from 'soapbox/features/placeholder/components/placeholder_status'; const messages = defineMessages({ accounts: { id: 'search_results.accounts', defaultMessage: 'People' }, statuses: { id: 'search_results.statuses', defaultMessage: 'Posts' }, hashtags: { id: 'search_results.hashtags', defaultMessage: 'Hashtags' }, }); export default @injectIntl class SearchResults extends ImmutablePureComponent { static propTypes = { value: PropTypes.string, results: ImmutablePropTypes.map.isRequired, submitted: PropTypes.bool, expandSearch: PropTypes.func.isRequired, selectedFilter: PropTypes.string.isRequired, selectFilter: PropTypes.func.isRequired, features: PropTypes.object.isRequired, suggestions: ImmutablePropTypes.list, trendingStatuses: ImmutablePropTypes.list, trends: ImmutablePropTypes.list, intl: PropTypes.object.isRequired, }; handleLoadMore = () => this.props.expandSearch(this.props.selectedFilter); handleSelectFilter = newActiveFilter => this.props.selectFilter(newActiveFilter); componentDidMount() { this.props.fetchTrendingStatuses(); } renderFilterBar() { const { intl, selectedFilter } = this.props; const items = [ { text: intl.formatMessage(messages.accounts), action: () => this.handleSelectFilter('accounts'), name: 'accounts', }, { text: intl.formatMessage(messages.statuses), action: () => this.handleSelectFilter('statuses'), name: 'statuses', }, { text: intl.formatMessage(messages.hashtags), action: () => this.handleSelectFilter('hashtags'), name: 'hashtags', }, ]; return ; } render() { const { value, results, submitted, selectedFilter, suggestions, trendingStatuses, trends } = this.props; let searchResults; let hasMore = false; let loaded; let noResultsMessage; let placeholderComponent = PlaceholderStatus; if (selectedFilter === 'accounts') { hasMore = results.get('accountsHasMore'); loaded = results.get('accountsLoaded'); placeholderComponent = PlaceholderAccount; if (results.get('accounts') && results.get('accounts').size > 0) { searchResults = results.get('accounts').map(accountId => ); } else if (!submitted && suggestions && !suggestions.isEmpty()) { searchResults = suggestions.map(suggestion => ); } else if (loaded) { noResultsMessage = (
); } } if (selectedFilter === 'statuses') { hasMore = results.get('statusesHasMore'); loaded = results.get('statusesLoaded'); if (results.get('statuses') && results.get('statuses').size > 0) { searchResults = results.get('statuses').map(statusId => ); } else if (!submitted && trendingStatuses && !trendingStatuses.isEmpty()) { searchResults = trendingStatuses.map(statusId => ); } else if (loaded) { noResultsMessage = (
); } } if (selectedFilter === 'hashtags') { hasMore = results.get('hashtagsHasMore'); loaded = results.get('hashtagsLoaded'); placeholderComponent = PlaceholderHashtag; if (results.get('hashtags') && results.get('hashtags').size > 0) { searchResults = results.get('hashtags').map(hashtag => ); } else if (!submitted && suggestions && !suggestions.isEmpty()) { searchResults = trends.map(hashtag => ); } else if (loaded) { noResultsMessage = (
); } } return ( <> {this.renderFilterBar()} {noResultsMessage || ( {searchResults} )} ); } }