import React from 'react'; import PropTypes from 'prop-types'; import { FormattedMessage } from 'react-intl'; import ImmutablePropTypes from 'react-immutable-proptypes'; import AccountContainer from '../../../containers/account_container'; import StatusContainer from '../../../containers/status_container'; import ImmutablePureComponent from 'react-immutable-pure-component'; import Hashtag from '../../../components/hashtag'; import FilterBar from '../../search/components/filter_bar'; import ScrollableList from 'soapbox/components/scrollable_list'; 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'; export default 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, }; handleLoadMore = () => this.props.expandSearch(this.props.selectedFilter); handleSelectFilter = newActiveFilter => this.props.selectFilter(newActiveFilter); render() { const { value, results, submitted, selectedFilter, suggestions } = 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' && results.get('statuses')) { hasMore = results.get('statusesHasMore'); loaded = results.get('statusesLoaded'); if (results.get('statuses').size > 0) { searchResults = results.get('statuses').map(statusId => ); } else { noResultsMessage = (
); } } if (selectedFilter === 'hashtags' && results.get('hashtags')) { hasMore = results.get('hashtagsHasMore'); loaded = results.get('hashtagsLoaded'); placeholderComponent = PlaceholderHashtag; if (results.get('hashtags').size > 0) { searchResults = results.get('hashtags').map(hashtag => ); } else { noResultsMessage = (
); } } return ( <> {noResultsMessage || ( {searchResults} )} ); } }