e8d8dfa76b
* Add snack bar notification * Fix and improve code * Better handle paid content on playlists * Fix menu options that show for unauth users
70 lines
2.5 KiB
JavaScript
70 lines
2.5 KiB
JavaScript
import { connect } from 'react-redux';
|
|
import {
|
|
makeSelectFileInfoForUri,
|
|
makeSelectTitleForUri,
|
|
makeSelectStreamingUrlForUri,
|
|
makeSelectClaimIsNsfw,
|
|
makeSelectClaimWasPurchased,
|
|
makeSelectNextUrlForCollectionAndUrl,
|
|
makeSelectPreviousUrlForCollectionAndUrl,
|
|
SETTINGS,
|
|
} from 'lbry-redux';
|
|
import {
|
|
makeSelectIsPlayerFloating,
|
|
selectPrimaryUri,
|
|
selectPlayingUri,
|
|
makeSelectFileRenderModeForUri,
|
|
} from 'redux/selectors/content';
|
|
import { makeSelectClientSetting } from 'redux/selectors/settings';
|
|
import { makeSelectCostInfoForUri } from 'lbryinc';
|
|
import { doPlayUri, doSetPlayingUri } from 'redux/actions/content';
|
|
import { doFetchRecommendedContent } from 'redux/actions/search';
|
|
import { doAnaltyicsPurchaseEvent } from 'redux/actions/app';
|
|
import { withRouter } from 'react-router';
|
|
import FileRenderFloating from './view';
|
|
|
|
const select = (state, props) => {
|
|
const playingUri = selectPlayingUri(state);
|
|
const primaryUri = selectPrimaryUri(state);
|
|
const uri = playingUri && playingUri.uri;
|
|
const collectionId = playingUri && playingUri.collectionId;
|
|
|
|
return {
|
|
uri,
|
|
primaryUri,
|
|
playingUri,
|
|
title: makeSelectTitleForUri(uri)(state),
|
|
fileInfo: makeSelectFileInfoForUri(uri)(state),
|
|
mature: makeSelectClaimIsNsfw(uri)(state),
|
|
isFloating: makeSelectIsPlayerFloating(props.location)(state),
|
|
streamingUrl: makeSelectStreamingUrlForUri(uri)(state),
|
|
floatingPlayerEnabled: makeSelectClientSetting(SETTINGS.FLOATING_PLAYER)(state),
|
|
renderMode: makeSelectFileRenderModeForUri(uri)(state),
|
|
videoTheaterMode: makeSelectClientSetting(SETTINGS.VIDEO_THEATER_MODE)(state),
|
|
costInfo: makeSelectCostInfoForUri(uri)(state),
|
|
claimWasPurchased: makeSelectClaimWasPurchased(uri)(state),
|
|
nextListUri: collectionId && makeSelectNextUrlForCollectionAndUrl(collectionId, uri)(state),
|
|
previousListUri: collectionId && makeSelectPreviousUrlForCollectionAndUrl(collectionId, uri)(state),
|
|
collectionId,
|
|
};
|
|
};
|
|
|
|
const perform = (dispatch) => ({
|
|
closeFloatingPlayer: () => dispatch(doSetPlayingUri({ uri: null })),
|
|
doFetchRecommendedContent: (uri, mature) => dispatch(doFetchRecommendedContent(uri, mature)),
|
|
doPlayUri: (uri, collectionId, hideFailModal) =>
|
|
dispatch(
|
|
doPlayUri(
|
|
uri,
|
|
false,
|
|
false,
|
|
(fileInfo) => {
|
|
dispatch(doAnaltyicsPurchaseEvent(fileInfo));
|
|
},
|
|
hideFailModal
|
|
),
|
|
dispatch(doSetPlayingUri({ uri, collectionId }))
|
|
),
|
|
});
|
|
|
|
export default withRouter(connect(select, perform)(FileRenderFloating));
|