36 lines
936 B
JavaScript
36 lines
936 B
JavaScript
|
import _curry3 from "./internal/_curry3.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
|
||
|
* @sig String -> a -> {k: v} -> {k: v}
|
||
|
* @param {String} 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) {
|
||
|
var result = {};
|
||
|
|
||
|
for (var p in obj) {
|
||
|
result[p] = obj[p];
|
||
|
}
|
||
|
|
||
|
result[prop] = val;
|
||
|
return result;
|
||
|
});
|
||
|
|
||
|
export default assoc;
|