lbry-desktop/ui/component/channelContent/index.js

39 lines
1.2 KiB
JavaScript
Raw Normal View History

2019-05-06 22:35:04 -04:00
import { connect } from 'react-redux';
import { doFetchClaimsByChannel } from 'redux/actions/content';
import { PAGE_SIZE } from 'constants/claim';
import {
2019-07-21 20:13:42 -04:00
makeSelectClaimsInChannelForPage,
2019-05-06 22:35:04 -04:00
makeSelectFetchingChannelClaims,
makeSelectClaimIsMine,
makeSelectTotalPagesInChannelSearch,
selectChannelIsBlocked,
makeSelectClaimForUri,
2019-05-06 22:35:04 -04:00
} from 'lbry-redux';
2019-07-21 20:13:42 -04:00
import { withRouter } from 'react-router';
2019-05-06 22:35:04 -04:00
import ChannelPage from './view';
2019-07-21 20:13:42 -04:00
const select = (state, props) => {
const { search } = props.location;
const urlParams = new URLSearchParams(search);
const page = urlParams.get('page') || 0;
return {
pageOfClaimsInChannel: makeSelectClaimsInChannelForPage(props.uri, page)(state),
2019-07-21 20:13:42 -04:00
fetching: makeSelectFetchingChannelClaims(props.uri)(state),
totalPages: makeSelectTotalPagesInChannelSearch(props.uri, PAGE_SIZE)(state),
2019-07-21 20:13:42 -04:00
channelIsMine: makeSelectClaimIsMine(props.uri)(state),
channelIsBlocked: selectChannelIsBlocked(props.uri)(state),
claim: props.uri && makeSelectClaimForUri(props.uri)(state),
2019-07-21 20:13:42 -04:00
};
};
2019-05-06 22:35:04 -04:00
const perform = dispatch => ({
fetchClaims: (uri, page) => dispatch(doFetchClaimsByChannel(uri, page)),
});
2019-07-21 20:13:42 -04:00
export default withRouter(
connect(
select,
perform
)(ChannelPage)
);