"use strict"; exports.__esModule = true; exports["default"] = void 0; var _ramda = require("ramda"); var _renameKeysWith = _interopRequireDefault(require("./renameKeysWith")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } var valueOrKey = function valueOrKey(keysMap) { return function (key) { if ((0, _ramda.has)(key, keysMap)) { return keysMap[key]; } return key; }; }; /** * Creates a new object with the own properties of the provided object, but the * keys renamed according to the keysMap object as `{oldKey: newKey}`. * When some key is not found in the keysMap, then it's passed as-is. * * Keep in mind that in the case of keys conflict is behaviour undefined and * the result may vary between various JS engines! * * @func renameKeys * @memberOf RA * @since {@link https://char0n.github.io/ramda-adjunct/1.5.0|v1.5.0} * @category Object * @sig {a: b} -> {a: *} -> {b: *} * @param {!Object} keysMap * @param {!Object} obj * @return {!Object} New object with renamed keys * @see {@link https://github.com/ramda/ramda/wiki/Cookbook#rename-keys-of-an-object|Ramda Cookbook}, {@link RA.renameKeysWith|renameKeysWith} * @example * * const input = { firstName: 'Elisia', age: 22, type: 'human' }; * * RA.renameKeys({ firstName: 'name', type: 'kind', foo: 'bar' })(input); * //=> { name: 'Elisia', age: 22, kind: 'human' } */ var renameKeys = (0, _ramda.curry)(function (keysMap, obj) { return (0, _renameKeysWith["default"])(valueOrKey(keysMap), obj); }); var _default = renameKeys; exports["default"] = _default;