lbry-desktop/ui/js/selectors/content.js

66 lines
1.5 KiB
JavaScript
Raw Normal View History

2017-04-23 11:56:50 +02:00
import { createSelector } from 'reselect'
import {
selectDaemonReady,
selectCurrentPage,
selectCurrentUri,
2017-04-23 11:56:50 +02:00
} from 'selectors/app'
export const _selectState = state => state.content || {}
2017-05-04 05:44:08 +02:00
export const selectFeaturedUris = createSelector(
2017-04-23 11:56:50 +02:00
_selectState,
(state) => state.featuredUris
2017-04-23 11:56:50 +02:00
)
2017-05-04 05:44:08 +02:00
export const selectFetchingFeaturedUris = createSelector(
2017-04-23 11:56:50 +02:00
_selectState,
(state) => !!state.fetchingFeaturedContent
)
export const selectFetchingFileInfos = createSelector(
_selectState,
(state) => state.fetchingFileInfos || {}
)
export const selectFetchingDownloadedContent = createSelector(
_selectState,
(state) => !!state.fetchingDownloadedContent
)
export const selectDownloadedContent = createSelector(
_selectState,
(state) => state.downloadedContent || {}
)
2017-04-25 07:47:21 +02:00
export const selectDownloadedContentFileInfos = createSelector(
selectDownloadedContent,
(downloadedContent) => downloadedContent.fileInfos || []
)
export const selectFetchingPublishedContent = createSelector(
_selectState,
(state) => !!state.fetchingPublishedContent
)
export const selectPublishedContent = createSelector(
_selectState,
(state) => state.publishedContent || {}
)
2017-05-02 06:48:16 +02:00
export const selectResolvingUris = createSelector(
_selectState,
(state) => state.resolvingUris || []
)
const selectResolvingUri = (state, props) => {
return selectResolvingUris(state).indexOf(props.uri) != -1
}
export const makeSelectResolvingUri = () => {
return createSelector(
selectResolvingUri,
(resolving) => resolving
)
}