64cbd4ae8d
* Dont show countdown on Lists * Add Repeat icon * Add Shuffle icon * Add Replay Icon * Add Replay Option to autoplayCountdown * Add Loop Control for Lists * Add Shuffle control for Lists * Improve View List Link and Fetch action * Add Play Button to List page * Add Shuffle Play Option on List Page and Menus * Fix Modal Remove Collection I18n * CSS: Fix Large list titles * Fix List playback on Floating Player * Add Theater Mode to its own class and fix bar text display * Add Play Next VJS component * Add Play Next Button * Add Play Previous VJS Component * Add Play Previous Button * Add Autoplay Next Button * Add separate control for autoplay next in list * Bump redux * Update CHANGELOG.md
109 lines
4.8 KiB
JavaScript
109 lines
4.8 KiB
JavaScript
import { connect } from 'react-redux';
|
|
import {
|
|
doCollectionEdit,
|
|
makeSelectClaimForUri,
|
|
makeSelectFileInfoForUri,
|
|
doPrepareEdit,
|
|
makeSelectCollectionForIdHasClaimUrl,
|
|
makeSelectCollectionIsMine,
|
|
COLLECTIONS_CONSTS,
|
|
makeSelectEditedCollectionForId,
|
|
makeSelectClaimIsMine,
|
|
doFetchItemsInCollection,
|
|
makeSelectUrlsForCollectionId,
|
|
} from 'lbry-redux';
|
|
import { makeSelectChannelIsMuted } from 'redux/selectors/blocked';
|
|
import { doChannelMute, doChannelUnmute } from 'redux/actions/blocked';
|
|
import { doSetActiveChannel, doSetIncognito, doOpenModal } from 'redux/actions/app';
|
|
import {
|
|
doCommentModBlock,
|
|
doCommentModUnBlock,
|
|
doCommentModBlockAsAdmin,
|
|
doCommentModUnBlockAsAdmin,
|
|
} from 'redux/actions/comments';
|
|
import {
|
|
selectHasAdminChannel,
|
|
makeSelectChannelIsBlocked,
|
|
makeSelectChannelIsAdminBlocked,
|
|
} from 'redux/selectors/comments';
|
|
import { doToast } from 'redux/actions/notifications';
|
|
import { doChannelSubscribe, doChannelUnsubscribe } from 'redux/actions/subscriptions';
|
|
import { makeSelectIsSubscribed } from 'redux/selectors/subscriptions';
|
|
import { selectUserVerifiedEmail } from 'redux/selectors/user';
|
|
import { selectListShuffle } from 'redux/selectors/content';
|
|
import { doSetPlayingUri, doToggleShuffleList } from 'redux/actions/content';
|
|
import ClaimPreview from './view';
|
|
import fs from 'fs';
|
|
|
|
const select = (state, props) => {
|
|
const claim = makeSelectClaimForUri(props.uri, false)(state);
|
|
const collectionId = props.collectionId;
|
|
const resolvedList = makeSelectUrlsForCollectionId(collectionId)(state);
|
|
const repostedClaim = claim && claim.reposted_claim;
|
|
const contentClaim = repostedClaim || claim;
|
|
const contentSigningChannel = contentClaim && contentClaim.signing_channel;
|
|
const contentPermanentUri = contentClaim && contentClaim.permanent_url;
|
|
const contentChannelUri = (contentSigningChannel && contentSigningChannel.permanent_url) || contentPermanentUri;
|
|
const shuffleList = selectListShuffle(state);
|
|
const shuffle = shuffleList && shuffleList.collectionId === collectionId && shuffleList.newUrls;
|
|
const playNextUri = shuffle && shuffle[0];
|
|
|
|
return {
|
|
claim,
|
|
repostedClaim,
|
|
contentClaim,
|
|
contentSigningChannel,
|
|
contentChannelUri,
|
|
claimIsMine: makeSelectClaimIsMine(props.uri)(state),
|
|
hasClaimInWatchLater: makeSelectCollectionForIdHasClaimUrl(
|
|
COLLECTIONS_CONSTS.WATCH_LATER_ID,
|
|
contentPermanentUri
|
|
)(state),
|
|
hasClaimInFavorites: makeSelectCollectionForIdHasClaimUrl(
|
|
COLLECTIONS_CONSTS.FAVORITES_ID,
|
|
contentPermanentUri
|
|
)(state),
|
|
channelIsMuted: makeSelectChannelIsMuted(contentChannelUri)(state),
|
|
channelIsBlocked: makeSelectChannelIsBlocked(contentChannelUri)(state),
|
|
fileInfo: makeSelectFileInfoForUri(contentPermanentUri)(state),
|
|
isSubscribed: makeSelectIsSubscribed(contentChannelUri, true)(state),
|
|
channelIsAdminBlocked: makeSelectChannelIsAdminBlocked(props.uri)(state),
|
|
isAdmin: selectHasAdminChannel(state),
|
|
claimInCollection: makeSelectCollectionForIdHasClaimUrl(collectionId, contentPermanentUri)(state),
|
|
isMyCollection: makeSelectCollectionIsMine(collectionId)(state),
|
|
editedCollection: makeSelectEditedCollectionForId(collectionId)(state),
|
|
isAuthenticated: Boolean(selectUserVerifiedEmail(state)),
|
|
resolvedList,
|
|
playNextUri,
|
|
};
|
|
};
|
|
|
|
const perform = (dispatch) => ({
|
|
prepareEdit: (publishData, uri, fileInfo) => {
|
|
if (publishData.signing_channel) {
|
|
dispatch(doSetIncognito(false));
|
|
dispatch(doSetActiveChannel(publishData.signing_channel.claim_id));
|
|
} else {
|
|
dispatch(doSetIncognito(true));
|
|
}
|
|
|
|
dispatch(doPrepareEdit(publishData, uri, fileInfo, fs));
|
|
},
|
|
doToast: (props) => dispatch(doToast(props)),
|
|
openModal: (modal, props) => dispatch(doOpenModal(modal, props)),
|
|
doChannelMute: (channelUri) => dispatch(doChannelMute(channelUri)),
|
|
doChannelUnmute: (channelUri) => dispatch(doChannelUnmute(channelUri)),
|
|
doCommentModBlock: (channelUri) => dispatch(doCommentModBlock(channelUri)),
|
|
doCommentModUnBlock: (channelUri) => dispatch(doCommentModUnBlock(channelUri)),
|
|
doCommentModBlockAsAdmin: (commenterUri, blockerId) => dispatch(doCommentModBlockAsAdmin(commenterUri, blockerId)),
|
|
doCommentModUnBlockAsAdmin: (commenterUri, blockerId) =>
|
|
dispatch(doCommentModUnBlockAsAdmin(commenterUri, blockerId)),
|
|
doChannelSubscribe: (subscription) => dispatch(doChannelSubscribe(subscription)),
|
|
doChannelUnsubscribe: (subscription) => dispatch(doChannelUnsubscribe(subscription)),
|
|
doCollectionEdit: (collection, props) => dispatch(doCollectionEdit(collection, props)),
|
|
fetchCollectionItems: (collectionId) => dispatch(doFetchItemsInCollection({ collectionId })),
|
|
doSetPlayingUri: (uri) => dispatch(doSetPlayingUri({ uri })),
|
|
doToggleShuffleList: (collectionId) => dispatch(doToggleShuffleList(undefined, collectionId, true, true)),
|
|
});
|
|
|
|
export default connect(select, perform)(ClaimPreview);
|