2019-12-30 20:54:53 +01:00
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import EmbedWrapperPage from './view';
|
2022-03-16 16:30:02 +01:00
|
|
|
import { selectClaimForUri, selectIsUriResolving, selectGeoRestrictionForUri } from 'redux/selectors/claims';
|
2021-10-17 10:36:14 +02:00
|
|
|
import { makeSelectStreamingUrlForUri } from 'redux/selectors/file_info';
|
|
|
|
import { doResolveUri } from 'redux/actions/claims';
|
|
|
|
import { buildURI } from 'util/lbryURI';
|
2020-05-21 23:11:56 +02:00
|
|
|
import { doPlayUri } from 'redux/actions/content';
|
2022-03-16 15:28:59 +01:00
|
|
|
import { selectShouldObscurePreviewForUri } from 'redux/selectors/content';
|
2021-11-19 03:40:01 +01:00
|
|
|
import { selectCostInfoForUri, doFetchCostInfoForUri, selectBlackListedOutpoints } from 'lbryinc';
|
2022-03-15 17:47:36 +01:00
|
|
|
import { doCommentSocketConnect, doCommentSocketDisconnect } from 'redux/actions/websocket';
|
|
|
|
import { doFetchActiveLivestreams, doFetchChannelLiveStatus } from 'redux/actions/livestream';
|
2022-03-16 16:30:02 +01:00
|
|
|
import { selectIsActiveLivestreamForUri, selectActiveLivestreamInitialized } from 'redux/selectors/livestream';
|
2022-03-16 15:28:59 +01:00
|
|
|
import { getThumbnailFromClaim, isStreamPlaceholderClaim } from 'util/claim';
|
2019-12-30 20:54:53 +01:00
|
|
|
|
|
|
|
const select = (state, props) => {
|
|
|
|
const { match } = props;
|
|
|
|
const { params } = match;
|
|
|
|
const { claimName, claimId } = params;
|
2020-06-12 23:23:16 +02:00
|
|
|
const uri = claimName ? buildURI({ claimName, claimId }) : '';
|
2022-03-15 17:47:36 +01:00
|
|
|
|
|
|
|
const claim = selectClaimForUri(state, uri);
|
2022-03-16 18:35:27 +01:00
|
|
|
const { canonical_url: canonicalUrl, signing_channel: channelClaim, txid, nout } = claim || {};
|
|
|
|
|
|
|
|
const { claim_id: channelClaimId, canonical_url: channelUri, txid: channelTxid, channelNout } = channelClaim || {};
|
|
|
|
const haveClaim = Boolean(claim);
|
|
|
|
const nullClaim = claim === null;
|
2022-03-15 17:47:36 +01:00
|
|
|
|
2019-12-30 20:54:53 +01:00
|
|
|
return {
|
|
|
|
uri,
|
2022-03-16 18:35:27 +01:00
|
|
|
claimId,
|
|
|
|
haveClaim,
|
|
|
|
nullClaim,
|
|
|
|
canonicalUrl,
|
|
|
|
txid,
|
|
|
|
nout,
|
|
|
|
channelUri,
|
|
|
|
channelClaimId,
|
|
|
|
channelTxid,
|
|
|
|
channelNout,
|
|
|
|
costInfo: uri && selectCostInfoForUri(state, uri),
|
|
|
|
streamingUrl: uri && makeSelectStreamingUrlForUri(uri)(state),
|
|
|
|
isResolvingUri: uri && selectIsUriResolving(state, uri),
|
|
|
|
blackListedOutpoints: haveClaim && selectBlackListedOutpoints(state),
|
2022-03-15 17:47:36 +01:00
|
|
|
isCurrentClaimLive: canonicalUrl && selectIsActiveLivestreamForUri(state, canonicalUrl),
|
|
|
|
isLivestreamClaim: isStreamPlaceholderClaim(claim),
|
2022-03-16 15:28:59 +01:00
|
|
|
obscurePreview: selectShouldObscurePreviewForUri(state, uri),
|
|
|
|
claimThumbnail: getThumbnailFromClaim(claim),
|
2022-03-16 16:30:02 +01:00
|
|
|
activeLivestreamInitialized: selectActiveLivestreamInitialized(state),
|
|
|
|
geoRestriction: selectGeoRestrictionForUri(state, uri),
|
2019-12-30 20:54:53 +01:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-03-15 17:47:36 +01:00
|
|
|
const perform = {
|
|
|
|
doResolveUri,
|
|
|
|
doPlayUri,
|
|
|
|
doFetchCostInfoForUri,
|
|
|
|
doFetchChannelLiveStatus,
|
|
|
|
doCommentSocketConnect,
|
|
|
|
doCommentSocketDisconnect,
|
|
|
|
doFetchActiveLivestreams,
|
2020-01-31 20:33:40 +01:00
|
|
|
};
|
2019-12-30 20:54:53 +01:00
|
|
|
|
2020-04-14 01:48:11 +02:00
|
|
|
export default connect(select, perform)(EmbedWrapperPage);
|