54 lines
1.6 KiB
JavaScript
54 lines
1.6 KiB
JavaScript
import { connect } from 'react-redux';
|
|
import { PAGE_SIZE } from 'constants/claim';
|
|
import {
|
|
doResolveUri,
|
|
makeSelectClaimForUri,
|
|
makeSelectIsUriResolving,
|
|
makeSelectTotalPagesForChannel,
|
|
makeSelectTitleForUri,
|
|
normalizeURI,
|
|
makeSelectClaimIsMine,
|
|
makeSelectClaimIsPending,
|
|
} from 'lbry-redux';
|
|
import { makeSelectChannelInSubscriptions } from 'redux/selectors/subscriptions';
|
|
import { selectBlackListedOutpoints } from 'lbryinc';
|
|
import ShowPage from './view';
|
|
|
|
const select = (state, props) => {
|
|
const { pathname, hash } = props.location;
|
|
const urlPath = pathname + hash;
|
|
// Remove the leading "/" added by the browser
|
|
const path = urlPath.slice(1).replace(/:/g, '#');
|
|
|
|
let uri;
|
|
try {
|
|
uri = normalizeURI(path);
|
|
} catch (e) {
|
|
const match = path.match(/[#/:]/);
|
|
|
|
if (path === '$/') {
|
|
props.history.replace(`/`);
|
|
} else if (!path.startsWith('$/') && match && match.index) {
|
|
uri = `lbry://${path.slice(0, match.index)}`;
|
|
props.history.replace(`/${path.slice(0, match.index)}`);
|
|
}
|
|
}
|
|
|
|
return {
|
|
claim: makeSelectClaimForUri(uri)(state),
|
|
isResolvingUri: makeSelectIsUriResolving(uri)(state),
|
|
blackListedOutpoints: selectBlackListedOutpoints(state),
|
|
totalPages: makeSelectTotalPagesForChannel(uri, PAGE_SIZE)(state),
|
|
isSubscribed: makeSelectChannelInSubscriptions(uri)(state),
|
|
uri,
|
|
title: makeSelectTitleForUri(uri)(state),
|
|
claimIsMine: makeSelectClaimIsMine(uri)(state),
|
|
claimIsPending: makeSelectClaimIsPending(uri)(state),
|
|
};
|
|
};
|
|
|
|
const perform = dispatch => ({
|
|
resolveUri: uri => dispatch(doResolveUri(uri)),
|
|
});
|
|
|
|
export default connect(select, perform)(ShowPage);
|