2017-04-29 16:50:29 +07:00
|
|
|
import {
|
|
|
|
createSelector,
|
|
|
|
} from 'reselect'
|
2017-04-30 00:02:25 +07:00
|
|
|
import {
|
|
|
|
selectDaemonReady,
|
|
|
|
selectCurrentPage,
|
|
|
|
} from 'selectors/app'
|
2017-04-29 16:50:29 +07:00
|
|
|
|
|
|
|
const _selectState = state => state.availability
|
|
|
|
|
|
|
|
export const selectAvailabilityByUri = createSelector(
|
|
|
|
_selectState,
|
|
|
|
(state) => state.byUri || {}
|
|
|
|
)
|
|
|
|
|
|
|
|
const selectAvailabilityForUri = (state, props) => {
|
|
|
|
return selectAvailabilityByUri(state)[props.uri]
|
|
|
|
}
|
|
|
|
|
2017-05-14 23:50:59 -04:00
|
|
|
export const makeSelectIsAvailableForUri = () => {
|
2017-04-29 16:50:29 +07:00
|
|
|
return createSelector(
|
|
|
|
selectAvailabilityForUri,
|
2017-05-14 23:50:59 -04:00
|
|
|
(availability) => availability === undefined ? undefined : availability > 0
|
2017-04-29 16:50:29 +07:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2017-05-14 23:50:59 -04:00
|
|
|
export const selectFetchingAvailability = createSelector(
|
|
|
|
_selectState,
|
|
|
|
(state) => state.fetching || {}
|
|
|
|
)
|
|
|
|
|
2017-04-29 16:50:29 +07:00
|
|
|
const selectFetchingAvailabilityForUri = (state, props) => {
|
2017-05-14 23:50:59 -04:00
|
|
|
return selectFetchingAvailability(state)[props.uri]
|
2017-04-29 16:50:29 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
export const makeSelectFetchingAvailabilityForUri = () => {
|
|
|
|
return createSelector(
|
|
|
|
selectFetchingAvailabilityForUri,
|
|
|
|
(fetching) => fetching
|
|
|
|
)
|
2017-05-14 23:50:59 -04:00
|
|
|
}
|