2017-06-06 17:19:12 -04:00
|
|
|
import { createSelector } from "reselect";
|
2017-08-30 08:48:32 -04:00
|
|
|
import { selectCurrentParams } from "selectors/navigation";
|
2017-04-28 22:14:44 +07:00
|
|
|
|
2017-06-05 21:21:55 -07:00
|
|
|
export const _selectState = state => state.costInfo || {};
|
2017-04-28 22:14:44 +07:00
|
|
|
|
|
|
|
export const selectAllCostInfoByUri = createSelector(
|
|
|
|
_selectState,
|
2017-06-06 17:19:12 -04:00
|
|
|
state => state.byUri || {}
|
2017-06-05 21:21:55 -07:00
|
|
|
);
|
2017-04-28 22:14:44 +07:00
|
|
|
|
2017-09-07 23:15:05 -04:00
|
|
|
export const makeSelectCostInfoForUri = uri => {
|
|
|
|
return createSelector(
|
|
|
|
selectAllCostInfoByUri,
|
|
|
|
costInfos => costInfos && costInfos[uri]
|
|
|
|
);
|
2017-06-05 21:21:55 -07:00
|
|
|
};
|
2017-05-28 19:16:07 +04:00
|
|
|
|
2017-08-22 17:19:33 -04:00
|
|
|
export const selectCostForCurrentPageUri = createSelector(
|
|
|
|
selectAllCostInfoByUri,
|
|
|
|
selectCurrentParams,
|
|
|
|
(costInfo, params) =>
|
|
|
|
params.uri && costInfo[params.uri] ? costInfo[params.uri].cost : undefined
|
|
|
|
);
|
|
|
|
|
2017-05-28 19:16:07 +04:00
|
|
|
export const selectFetchingCostInfo = createSelector(
|
|
|
|
_selectState,
|
2017-06-06 17:19:12 -04:00
|
|
|
state => state.fetching || {}
|
2017-06-05 21:21:55 -07:00
|
|
|
);
|
2017-05-28 19:16:07 +04:00
|
|
|
|
2017-09-07 23:15:05 -04:00
|
|
|
export const makeSelectFetchingCostInfoForUri = uri => {
|
|
|
|
return createSelector(
|
|
|
|
selectFetchingCostInfo,
|
|
|
|
fetchingByUri => fetchingByUri && fetchingByUri[uri]
|
|
|
|
);
|
2017-06-05 21:21:55 -07:00
|
|
|
};
|