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

64 lines
2.5 KiB
JavaScript
Raw Normal View History

import { connect } from 'react-redux';
import EmbedWrapperPage from './view';
import { selectClaimForUri, selectIsUriResolving, selectGeoRestrictionForUri } from 'redux/selectors/claims';
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';
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';
import { selectIsActiveLivestreamForUri, selectActiveLivestreamInitialized } from 'redux/selectors/livestream';
2022-03-16 15:28:59 +01:00
import { getThumbnailFromClaim, isStreamPlaceholderClaim } from 'util/claim';
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
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),
activeLivestreamInitialized: selectActiveLivestreamInitialized(state),
geoRestriction: selectGeoRestrictionForUri(state, uri),
};
};
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
};
2020-04-14 01:48:11 +02:00
export default connect(select, perform)(EmbedWrapperPage);