2020-01-27 13:52:25 -05:00
|
|
|
import * as SETTINGS from 'constants/settings';
|
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import { makeSelectClaimForUri } from 'lbry-redux';
|
2020-04-16 17:43:09 -04:00
|
|
|
import { withRouter } from 'react-router';
|
2020-04-13 19:48:11 -04:00
|
|
|
import { makeSelectIsPlayerFloating, makeSelectNextUnplayedRecommended } from 'redux/selectors/content';
|
2020-01-27 13:52:25 -05:00
|
|
|
import { makeSelectClientSetting } from 'redux/selectors/settings';
|
2020-01-27 14:32:20 -05:00
|
|
|
import { doSetPlayingUri } from 'redux/actions/content';
|
2020-04-13 19:48:11 -04:00
|
|
|
import AutoplayCountdown from './view';
|
2020-01-27 13:52:25 -05:00
|
|
|
|
2020-04-16 17:43:09 -04:00
|
|
|
/*
|
|
|
|
AutoplayCountdown does not fetch it's own next content to play, it relies on <RecommendedContent> being rendered. This is dumb but I'm just the guy who noticed
|
|
|
|
*/
|
2020-01-27 13:52:25 -05:00
|
|
|
const select = (state, props) => {
|
|
|
|
const nextRecommendedUri = makeSelectNextUnplayedRecommended(props.uri)(state);
|
|
|
|
return {
|
|
|
|
nextRecommendedUri,
|
|
|
|
nextRecommendedClaim: makeSelectClaimForUri(nextRecommendedUri)(state),
|
2020-04-13 19:48:11 -04:00
|
|
|
isFloating: makeSelectIsPlayerFloating(props.location)(state),
|
2020-01-27 13:52:25 -05:00
|
|
|
autoplay: makeSelectClientSetting(SETTINGS.AUTOPLAY)(state),
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-01-27 14:32:20 -05:00
|
|
|
const perform = dispatch => ({
|
|
|
|
setPlayingUri: uri => dispatch(doSetPlayingUri(uri)),
|
|
|
|
});
|
2020-01-27 13:52:25 -05:00
|
|
|
|
2020-04-16 17:43:09 -04:00
|
|
|
export default withRouter(connect(select, perform)(AutoplayCountdown));
|