2017-12-21 14:32:51 -03:00
|
|
|
import { createSelector } from 'reselect';
|
|
|
|
import { selectCurrentParams } from 'redux/selectors/navigation';
|
2017-04-28 22:14:44 +07:00
|
|
|
|
2017-12-21 14:32:51 -03:00
|
|
|
export const selectState = state => state.costInfo || {};
|
2017-04-28 22:14:44 +07:00
|
|
|
|
2017-12-21 14:32:51 -03:00
|
|
|
export const selectAllCostInfoByUri = createSelector(selectState, state => state.byUri || {});
|
2017-04-28 22:14:44 +07:00
|
|
|
|
2017-12-13 18:36:30 -03:00
|
|
|
export const makeSelectCostInfoForUri = uri =>
|
2017-12-21 14:32:51 -03:00
|
|
|
createSelector(selectAllCostInfoByUri, costInfos => costInfos && costInfos[uri]);
|
2017-05-28 19:16:07 +04:00
|
|
|
|
2017-08-22 17:19:33 -04:00
|
|
|
export const selectCostForCurrentPageUri = createSelector(
|
|
|
|
selectAllCostInfoByUri,
|
|
|
|
selectCurrentParams,
|
2017-12-21 14:32:51 -03:00
|
|
|
(costInfo, params) => (params.uri && costInfo[params.uri] ? costInfo[params.uri].cost : undefined)
|
2017-08-22 17:19:33 -04:00
|
|
|
);
|
|
|
|
|
2017-12-21 14:32:51 -03:00
|
|
|
export const selectFetchingCostInfo = createSelector(selectState, state => state.fetching || {});
|
2017-05-28 19:16:07 +04:00
|
|
|
|
2017-12-13 18:36:30 -03:00
|
|
|
export const makeSelectFetchingCostInfoForUri = uri =>
|
2017-12-21 14:32:51 -03:00
|
|
|
createSelector(selectFetchingCostInfo, fetchingByUri => fetchingByUri && fetchingByUri[uri]);
|