import { connect } from 'react-redux'; import { selectClaimForUri, selectIsUriResolving, selectClaimIsMine, makeSelectClaimIsPending, makeSelectReflectingClaimForUri, selectTitleForUri, selectDateForUri, } from 'redux/selectors/claims'; import { makeSelectStreamingUrlForUri } from 'redux/selectors/file_info'; import { makeSelectCollectionIsMine } from 'redux/selectors/collections'; import { doResolveUri } from 'redux/actions/claims'; import { doFileGet } from 'redux/actions/file'; import { selectBanStateForUri } from 'lbryinc'; import { selectIsActiveLivestreamForUri, selectViewersForId } from 'redux/selectors/livestream'; import { selectLanguage, selectShowMatureContent } from 'redux/selectors/settings'; import { makeSelectHasVisitedUri } from 'redux/selectors/content'; import { selectIsSubscribedForUri } from 'redux/selectors/subscriptions'; import { isClaimNsfw, isStreamPlaceholderClaim } from 'util/claim'; import ClaimPreview from './view'; import formatMediaDuration from 'util/formatMediaDuration'; import { doClearContentHistoryUri } from 'redux/actions/content'; const select = (state, props) => { const claim = props.uri && selectClaimForUri(state, props.uri); const media = claim && claim.value && (claim.value.video || claim.value.audio); const mediaDuration = media && media.duration && formatMediaDuration(media.duration, { screenReader: true }); const isLivestream = isStreamPlaceholderClaim(claim); return { claim, mediaDuration, date: props.uri && selectDateForUri(state, props.uri), title: props.uri && selectTitleForUri(state, props.uri), pending: props.uri && makeSelectClaimIsPending(props.uri)(state), reflectingProgress: props.uri && makeSelectReflectingClaimForUri(props.uri)(state), obscureNsfw: selectShowMatureContent(state) === false, claimIsMine: props.uri && selectClaimIsMine(state, claim), isResolvingUri: props.uri && selectIsUriResolving(state, props.uri), isResolvingRepost: props.uri && selectIsUriResolving(state, props.repostUrl), nsfw: claim ? isClaimNsfw(claim) : false, banState: selectBanStateForUri(state, props.uri), hasVisitedUri: props.uri && makeSelectHasVisitedUri(props.uri)(state), isSubscribed: props.uri && selectIsSubscribedForUri(state, props.uri), streamingUrl: props.uri && makeSelectStreamingUrlForUri(props.uri)(state), isLivestream, isLivestreamActive: isLivestream && selectIsActiveLivestreamForUri(state, props.uri), livestreamViewerCount: isLivestream && claim ? selectViewersForId(state, claim.claim_id) : undefined, isCollectionMine: makeSelectCollectionIsMine(props.collectionId)(state), lang: selectLanguage(state), }; }; const perform = (dispatch) => ({ resolveUri: (uri) => dispatch(doResolveUri(uri)), getFile: (uri) => dispatch(doFileGet(uri, false)), doClearContentHistoryUri: (uri) => dispatch(doClearContentHistoryUri(uri)), }); export default connect(select, perform)(ClaimPreview);