2018-03-02 01:28:50 -05:00
|
|
|
import { State } from './transaction';
|
|
|
|
import { Omit } from 'react-redux';
|
|
|
|
import { ResetAction } from 'actions/transaction';
|
|
|
|
|
|
|
|
export const resetHOF = (
|
|
|
|
reducerName: keyof (Omit<State, 'broadcast' | 'network'>),
|
|
|
|
initialState: State[typeof reducerName],
|
|
|
|
returnCb?: (
|
|
|
|
state: State[typeof reducerName],
|
|
|
|
returnedState: State[typeof reducerName]
|
|
|
|
) => State[typeof reducerName]
|
|
|
|
) => (state: State[typeof reducerName], { payload: { exclude, include } }: ResetAction) => {
|
|
|
|
const excludeFields = exclude[reducerName];
|
|
|
|
const includeFields = include[reducerName];
|
|
|
|
|
|
|
|
// sanity check
|
|
|
|
if (includeFields && excludeFields) {
|
|
|
|
throw Error('Cant have include and exclude fields at the same time');
|
|
|
|
}
|
|
|
|
const returnState = { ...initialState };
|
|
|
|
const stateCopy = { ...state };
|
|
|
|
|
|
|
|
if (includeFields) {
|
|
|
|
(includeFields as any[]).forEach(fieldName => {
|
2018-03-07 18:36:05 -05:00
|
|
|
(stateCopy as any)[fieldName] = (returnState as any)[fieldName];
|
2018-03-02 01:28:50 -05:00
|
|
|
});
|
|
|
|
return returnCb ? returnCb(state, returnState) : { ...stateCopy };
|
|
|
|
}
|
|
|
|
|
|
|
|
if (excludeFields) {
|
|
|
|
(excludeFields as any[]).forEach(fieldName => {
|
2018-03-07 18:36:05 -05:00
|
|
|
(returnState as any)[fieldName] = (state as any)[fieldName];
|
2018-03-02 01:28:50 -05:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return returnCb ? returnCb(state, returnState) : returnState;
|
|
|
|
};
|