| var _curry2 = |
| /*#__PURE__*/ |
| require("./internal/_curry2"); |
| /** |
| * Creates a new object by recursively evolving a shallow copy of `object`, |
| * according to the `transformation` functions. All non-primitive properties |
| * are copied by reference. |
| * |
| * A `transformation` function will not be invoked if its corresponding key |
| * does not exist in the evolved object. |
| * |
| * @func |
| * @memberOf R |
| * @since v0.9.0 |
| * @category Object |
| * @sig {k: (v -> v)} -> {k: v} -> {k: v} |
| * @param {Object} transformations The object specifying transformation functions to apply |
| * to the object. |
| * @param {Object} object The object to be transformed. |
| * @return {Object} The transformed object. |
| * @example |
| * |
| * const tomato = {firstName: ' Tomato ', data: {elapsed: 100, remaining: 1400}, id:123}; |
| * const transformations = { |
| * firstName: R.trim, |
| * lastName: R.trim, // Will not get invoked. |
| * data: {elapsed: R.add(1), remaining: R.add(-1)} |
| * }; |
| * R.evolve(transformations, tomato); //=> {firstName: 'Tomato', data: {elapsed: 101, remaining: 1399}, id:123} |
| */ |
| |
| |
| var evolve = |
| /*#__PURE__*/ |
| _curry2(function evolve(transformations, object) { |
| var result = object instanceof Array ? [] : {}; |
| var transformation, key, type; |
| |
| for (key in object) { |
| transformation = transformations[key]; |
| type = typeof transformation; |
| result[key] = type === 'function' ? transformation(object[key]) : transformation && type === 'object' ? evolve(transformation, object[key]) : object[key]; |
| } |
| |
| return result; |
| }); |
| |
| module.exports = evolve; |