ayanami
Version:
A better way to react with state
40 lines (39 loc) • 1.75 kB
JavaScript
import { Subject } from 'rxjs';
import { getActionNames } from '../decorators';
import { effectSymbols, reducerSymbols, immerReducerSymbols, defineActionSymbols } from '../symbols';
var getOriginalFunctionNames = function (ayanami) { return ({
effects: getActionNames(effectSymbols, ayanami.constructor),
reducers: getActionNames(reducerSymbols, ayanami.constructor),
defineActions: getActionNames(defineActionSymbols, ayanami.constructor),
immerReducers: getActionNames(immerReducerSymbols, ayanami.constructor),
}); };
var transformDefineActions = function (actionNames) {
var result = {};
actionNames.forEach(function (actionName) {
var actions$ = new Subject();
result[actionName] = {
observable: actions$.asObservable(),
next: function (params) { return actions$.next(params); },
};
});
return result;
};
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
export var getOriginalFunctions = function (ayanami) {
var _a = getOriginalFunctionNames(ayanami), effects = _a.effects, reducers = _a.reducers, immerReducers = _a.immerReducers, defineActions = _a.defineActions;
return {
effects: effects.reduce(function (acc, method) {
acc[method] = ayanami[method].bind(ayanami);
return acc;
}, {}),
reducers: reducers.reduce(function (acc, method) {
acc[method] = ayanami[method].bind(ayanami);
return acc;
}, {}),
immerReducers: immerReducers.reduce(function (acc, method) {
acc[method] = ayanami[method].bind(ayanami);
return acc;
}, {}),
defineActions: transformDefineActions(defineActions),
};
};