28 lines
1.1 KiB
JavaScript
28 lines
1.1 KiB
JavaScript
|
import * as CS from 'constants/claim_search';
|
||
|
import { connect } from 'react-redux';
|
||
|
import { makeSelectClaimForUri, doResolveUri, SETTINGS } from 'lbry-redux';
|
||
|
import { selectUserVerifiedEmail } from 'redux/selectors/user';
|
||
|
import { selectFollowedTags } from 'redux/selectors/tags';
|
||
|
import { doToggleTagFollowDesktop } from 'redux/actions/tags';
|
||
|
import { makeSelectClientSetting } from 'redux/selectors/settings';
|
||
|
import Tags from './view';
|
||
|
|
||
|
const select = (state, props) => {
|
||
|
const urlParams = new URLSearchParams(props.location.search);
|
||
|
const repostedUriInUrl = urlParams.get(CS.REPOSTED_URI_KEY);
|
||
|
const repostedUri = repostedUriInUrl ? decodeURIComponent(repostedUriInUrl) : undefined;
|
||
|
|
||
|
return {
|
||
|
followedTags: selectFollowedTags(state),
|
||
|
repostedUri: repostedUri,
|
||
|
repostedClaim: repostedUri ? makeSelectClaimForUri(repostedUri)(state) : null,
|
||
|
isAuthenticated: selectUserVerifiedEmail(state),
|
||
|
tileLayout: makeSelectClientSetting(SETTINGS.TILE_LAYOUT)(state),
|
||
|
};
|
||
|
};
|
||
|
|
||
|
export default connect(select, {
|
||
|
doToggleTagFollowDesktop,
|
||
|
doResolveUri,
|
||
|
})(Tags);
|