2019-08-02 02:28:14 -04:00
|
|
|
import { connect } from 'react-redux';
|
2020-07-10 17:04:36 -04:00
|
|
|
import { makeSelectClaimForUri, makeSelectFileInfoForUri, makeSelectThumbnailForUri, SETTINGS } from 'lbry-redux';
|
2020-08-07 16:59:20 -04:00
|
|
|
import { doChangeVolume, doChangeMute, doAnalyticsView, doAnalyticsBuffer } from 'redux/actions/app';
|
2019-08-02 02:28:14 -04:00
|
|
|
import { selectVolume, selectMute } from 'redux/selectors/app';
|
2020-05-14 18:18:54 -07:00
|
|
|
import { savePosition, clearPosition } from 'redux/actions/content';
|
2020-04-30 00:49:52 -07:00
|
|
|
import { makeSelectContentPositionForUri } from 'redux/selectors/content';
|
2019-08-02 02:28:14 -04:00
|
|
|
import VideoViewer from './view';
|
2020-02-04 16:14:08 -05:00
|
|
|
import { withRouter } from 'react-router';
|
2020-06-15 16:33:03 -04:00
|
|
|
import { doClaimEligiblePurchaseRewards } from 'redux/actions/rewards';
|
2020-04-13 19:48:11 -04:00
|
|
|
import { makeSelectClientSetting } from 'redux/selectors/settings';
|
2021-01-14 21:16:04 +08:00
|
|
|
import { toggleVideoTheaterMode, doSetClientSetting } from 'redux/actions/settings';
|
2019-08-02 02:28:14 -04:00
|
|
|
|
2020-02-04 16:14:08 -05:00
|
|
|
const select = (state, props) => {
|
|
|
|
const { search } = props.location;
|
|
|
|
const urlParams = new URLSearchParams(search);
|
|
|
|
const autoplay = urlParams.get('autoplay');
|
2020-04-30 00:49:52 -07:00
|
|
|
const position = urlParams.get('t') !== null ? urlParams.get('t') : makeSelectContentPositionForUri(props.uri)(state);
|
2020-03-19 16:25:37 -04:00
|
|
|
|
2020-02-04 16:14:08 -05:00
|
|
|
return {
|
2020-04-13 19:48:11 -04:00
|
|
|
autoplayIfEmbedded: Boolean(autoplay),
|
|
|
|
autoplaySetting: Boolean(makeSelectClientSetting(SETTINGS.AUTOPLAY)(state)),
|
2020-02-04 16:14:08 -05:00
|
|
|
volume: selectVolume(state),
|
|
|
|
muted: selectMute(state),
|
2021-01-14 21:16:04 +08:00
|
|
|
videoPlaybackRate: makeSelectClientSetting(SETTINGS.VIDEO_PLAYBACK_RATE)(state),
|
2020-03-19 16:25:37 -04:00
|
|
|
position: position,
|
2020-02-04 16:14:08 -05:00
|
|
|
hasFileInfo: Boolean(makeSelectFileInfoForUri(props.uri)(state)),
|
|
|
|
thumbnail: makeSelectThumbnailForUri(props.uri)(state),
|
|
|
|
claim: makeSelectClaimForUri(props.uri)(state),
|
|
|
|
};
|
|
|
|
};
|
2019-08-02 02:28:14 -04:00
|
|
|
|
|
|
|
const perform = dispatch => ({
|
|
|
|
changeVolume: volume => dispatch(doChangeVolume(volume)),
|
2019-08-13 01:35:13 -04:00
|
|
|
savePosition: (uri, position) => dispatch(savePosition(uri, position)),
|
2020-05-14 18:18:54 -07:00
|
|
|
clearPosition: uri => dispatch(clearPosition(uri)),
|
2019-08-02 02:28:14 -04:00
|
|
|
changeMute: muted => dispatch(doChangeMute(muted)),
|
2020-04-13 19:48:11 -04:00
|
|
|
doAnalyticsView: (uri, timeToStart) => dispatch(doAnalyticsView(uri, timeToStart)),
|
2020-08-07 16:59:20 -04:00
|
|
|
doAnalyticsBuffer: (uri, bufferData) => dispatch(doAnalyticsBuffer(uri, bufferData)),
|
2020-04-13 19:48:11 -04:00
|
|
|
claimRewards: () => dispatch(doClaimEligiblePurchaseRewards()),
|
2021-01-08 10:21:27 -05:00
|
|
|
toggleVideoTheaterMode: () => dispatch(toggleVideoTheaterMode()),
|
2021-01-14 21:16:04 +08:00
|
|
|
setVideoPlaybackRate: rate => dispatch(doSetClientSetting(SETTINGS.VIDEO_PLAYBACK_RATE, rate)),
|
2019-08-02 02:28:14 -04:00
|
|
|
});
|
|
|
|
|
2020-03-19 16:25:37 -04:00
|
|
|
export default withRouter(connect(select, perform)(VideoViewer));
|