722c0b978c
Should support markdown, PDF, and anything in the code viewer. Tested that it's working on web and app.
44 lines
1.6 KiB
JavaScript
44 lines
1.6 KiB
JavaScript
import * as SETTINGS from 'constants/settings';
|
|
import { connect } from 'react-redux';
|
|
import { doPlayUri, doSetPlayingUri } from 'redux/actions/content';
|
|
import {
|
|
makeSelectFileInfoForUri,
|
|
makeSelectThumbnailForUri,
|
|
makeSelectStreamingUrlForUri,
|
|
makeSelectMediaTypeForUri,
|
|
makeSelectContentTypeForUri,
|
|
makeSelectUriIsStreamable,
|
|
} from 'lbry-redux';
|
|
import { makeSelectCostInfoForUri } from 'lbryinc';
|
|
import { makeSelectClientSetting } from 'redux/selectors/settings';
|
|
import { makeSelectIsPlaying, makeSelectShouldObscurePreview, selectPlayingUri } from 'redux/selectors/content';
|
|
import FileViewer from './view';
|
|
|
|
const select = (state, props) => ({
|
|
thumbnail: makeSelectThumbnailForUri(props.uri)(state),
|
|
mediaType: makeSelectMediaTypeForUri(props.uri)(state),
|
|
contentType: makeSelectContentTypeForUri(props.uri)(state),
|
|
fileInfo: makeSelectFileInfoForUri(props.uri)(state),
|
|
obscurePreview: makeSelectShouldObscurePreview(props.uri)(state),
|
|
isPlaying: makeSelectIsPlaying(props.uri)(state),
|
|
playingUri: selectPlayingUri(state),
|
|
streamingUrl: makeSelectStreamingUrlForUri(props.uri)(state),
|
|
isStreamable: makeSelectUriIsStreamable(props.uri)(state),
|
|
autoplay: makeSelectClientSetting(SETTINGS.AUTOPLAY)(state),
|
|
hasCostInfo: Boolean(makeSelectCostInfoForUri(props.uri)(state)),
|
|
costInfo: makeSelectCostInfoForUri(props.uri)(state),
|
|
});
|
|
|
|
const perform = dispatch => ({
|
|
play: uri => {
|
|
dispatch(doSetPlayingUri(uri));
|
|
// @if TARGET='app'
|
|
dispatch(doPlayUri(uri));
|
|
// @endif
|
|
},
|
|
});
|
|
|
|
export default connect(
|
|
select,
|
|
perform
|
|
)(FileViewer);
|