2018-02-07 17:59:55 -06:00
|
|
|
import { FetchCCRatesSucceeded, RatesAction } from 'actions/rates';
|
|
|
|
import { CCResponse } from 'api/rates';
|
2017-09-24 19:06:28 -07:00
|
|
|
import { TypeKeys } from 'actions/rates/constants';
|
2017-09-25 20:41:11 -07:00
|
|
|
|
2017-07-14 01:02:39 +04:00
|
|
|
// SYMBOL -> PRICE TO BUY 1 ETH
|
2017-09-24 19:06:28 -07:00
|
|
|
export interface State {
|
2017-11-14 22:51:09 -07:00
|
|
|
rates: { [symbol: string]: CCResponse['rates'] };
|
2017-09-25 20:41:11 -07:00
|
|
|
ratesError?: string | null;
|
2017-09-24 19:06:28 -07:00
|
|
|
}
|
2017-07-14 01:02:39 +04:00
|
|
|
|
2017-11-14 22:51:09 -07:00
|
|
|
export const INITIAL_STATE: State = {
|
2017-11-18 13:15:02 -07:00
|
|
|
rates: {},
|
|
|
|
ratesError: null
|
2017-11-14 22:51:09 -07:00
|
|
|
};
|
2017-07-14 01:02:39 +04:00
|
|
|
|
2017-12-18 18:29:26 -05:00
|
|
|
function fetchCCRatesSucceeded(state: State, action: FetchCCRatesSucceeded): State {
|
2017-11-14 22:51:09 -07:00
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
rates: {
|
|
|
|
...state.rates,
|
2017-11-18 13:15:02 -07:00
|
|
|
...action.payload
|
2017-11-14 22:51:09 -07:00
|
|
|
}
|
|
|
|
};
|
2017-09-25 20:41:11 -07:00
|
|
|
}
|
|
|
|
|
2017-10-18 22:29:49 -04:00
|
|
|
function fetchCCRatesFailed(state: State): State {
|
2017-09-25 20:41:11 -07:00
|
|
|
// TODO: Make library for error messages
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
ratesError: 'Sorry. We were unable to fetch equivalent rates.'
|
|
|
|
};
|
2017-07-14 01:02:39 +04:00
|
|
|
}
|
|
|
|
|
2017-12-18 18:29:26 -05:00
|
|
|
export function rates(state: State = INITIAL_STATE, action: RatesAction): State {
|
2017-07-14 01:02:39 +04:00
|
|
|
switch (action.type) {
|
2017-09-25 20:41:11 -07:00
|
|
|
case TypeKeys.RATES_FETCH_CC_SUCCEEDED:
|
|
|
|
return fetchCCRatesSucceeded(state, action);
|
|
|
|
case TypeKeys.RATES_FETCH_CC_FAILED:
|
2017-10-18 22:29:49 -04:00
|
|
|
return fetchCCRatesFailed(state);
|
2017-07-14 01:02:39 +04:00
|
|
|
default:
|
|
|
|
return state;
|
|
|
|
}
|
|
|
|
}
|