28 lines
1.1 KiB
JavaScript
28 lines
1.1 KiB
JavaScript
import { connect } from 'react-redux';
|
|
import { getFeatures } from 'soapbox/utils/features';
|
|
import SearchResults from '../components/search_results';
|
|
import { fetchSuggestions, dismissSuggestion } from '../../../actions/suggestions';
|
|
import { expandSearch, setFilter } from '../../../actions/search';
|
|
|
|
const mapStateToProps = state => {
|
|
const instance = state.get('instance');
|
|
|
|
return {
|
|
value: state.getIn(['search', 'submittedValue']),
|
|
results: state.getIn(['search', 'results']),
|
|
suggestions: state.getIn(['suggestions', 'items']),
|
|
trends: state.getIn(['trends', 'items']),
|
|
submitted: state.getIn(['search', 'submitted']),
|
|
selectedFilter: state.getIn(['search', 'filter']),
|
|
features: getFeatures(instance),
|
|
};
|
|
};
|
|
|
|
const mapDispatchToProps = dispatch => ({
|
|
fetchSuggestions: () => dispatch(fetchSuggestions()),
|
|
expandSearch: type => dispatch(expandSearch(type)),
|
|
dismissSuggestion: account => dispatch(dismissSuggestion(account.get('id'))),
|
|
selectFilter: newActiveFilter => dispatch(setFilter(newActiveFilter)),
|
|
});
|
|
|
|
export default connect(mapStateToProps, mapDispatchToProps)(SearchResults);
|