lbry-desktop/ui/page/search/index.js

50 lines
1.6 KiB
JavaScript
Raw Normal View History

import { connect } from 'react-redux';
import { withRouter } from 'react-router';
2020-07-27 16:04:12 -04:00
import { doSearch } from 'redux/actions/search';
import { SIMPLE_SITE } from 'config';
import {
selectIsSearching,
makeSelectSearchUris,
makeSelectQueryWithOptions,
selectSearchOptions,
2021-03-26 16:33:30 +08:00
makeSelectHasReachedMaxResultsLength,
} from 'redux/selectors/search';
2021-03-31 16:55:26 -04:00
import { selectShowMatureContent } from 'redux/selectors/settings';
import { selectUserVerifiedEmail } from 'redux/selectors/user';
import SearchPage from './view';
2017-05-05 15:01:16 +07:00
const select = (state, props) => {
2021-03-31 16:55:26 -04:00
const showMature = selectShowMatureContent(state);
const urlParams = new URLSearchParams(props.location.search);
let urlQuery = urlParams.get('q') || null;
if (urlQuery) {
urlQuery = urlQuery.replace(/^lbry:\/\//i, '').replace(/\//, ' ');
}
const query = makeSelectQueryWithOptions(
urlQuery,
SIMPLE_SITE
? { nsfw: false, isBackgroundSearch: false }
: showMature === false
? { nsfw: false, isBackgroundSearch: false }
: { isBackgroundSearch: false }
)(state);
const uris = makeSelectSearchUris(query)(state);
2021-03-26 16:33:30 +08:00
const hasReachedMaxResultsLength = makeSelectHasReachedMaxResultsLength(query)(state);
return {
isSearching: selectIsSearching(state),
2021-03-31 16:55:26 -04:00
showNsfw: showMature,
uris: uris,
2020-03-26 17:47:07 -04:00
isAuthenticated: selectUserVerifiedEmail(state),
searchOptions: selectSearchOptions(state),
2021-03-26 16:33:30 +08:00
hasReachedMaxResultsLength: hasReachedMaxResultsLength,
};
};
2017-05-05 15:01:16 +07:00
2021-03-31 16:55:26 -04:00
const perform = (dispatch) => ({
search: (query, options) => dispatch(doSearch(query, options)),
2019-06-11 14:10:58 -04:00
});
2017-05-05 15:01:16 +07:00
export default withRouter(connect(select, perform)(SearchPage));