37 lines
977 B
JavaScript
37 lines
977 B
JavaScript
|
var _curry3 =
|
||
|
/*#__PURE__*/
|
||
|
require("./internal/_curry3.js");
|
||
|
|
||
|
var assocPath =
|
||
|
/*#__PURE__*/
|
||
|
require("./assocPath.js");
|
||
|
/**
|
||
|
* Makes a shallow clone of an object, setting or overriding the specified
|
||
|
* property with the given value. Note that this copies and flattens prototype
|
||
|
* properties onto the new object as well. All non-primitive properties are
|
||
|
* copied by reference.
|
||
|
*
|
||
|
* @func
|
||
|
* @memberOf R
|
||
|
* @since v0.8.0
|
||
|
* @category Object
|
||
|
* @typedefn Idx = String | Int
|
||
|
* @sig Idx -> a -> {k: v} -> {k: v}
|
||
|
* @param {String|Number} prop The property name to set
|
||
|
* @param {*} val The new value
|
||
|
* @param {Object} obj The object to clone
|
||
|
* @return {Object} A new object equivalent to the original except for the changed property.
|
||
|
* @see R.dissoc, R.pick
|
||
|
* @example
|
||
|
*
|
||
|
* R.assoc('c', 3, {a: 1, b: 2}); //=> {a: 1, b: 2, c: 3}
|
||
|
*/
|
||
|
|
||
|
|
||
|
var assoc =
|
||
|
/*#__PURE__*/
|
||
|
_curry3(function assoc(prop, val, obj) {
|
||
|
return assocPath([prop], val, obj);
|
||
|
});
|
||
|
|
||
|
module.exports = assoc;
|