merge-value
Advanced tools
Comparing version 0.1.1 to 1.0.0
30
index.js
'use strict'; | ||
var utils = require('./utils'); | ||
var isObject = require('is-extendable'); | ||
var merge = require('mixin-deep'); | ||
var get = require('get-value'); | ||
var set = require('set-value'); | ||
module.exports = function merge(obj, prop, value) { | ||
if (!utils.isObject(obj)) { | ||
throw new TypeError('expected the first argument to be an object.'); | ||
module.exports = function mergeValue(obj, prop, value) { | ||
if (!isObject(obj)) { | ||
throw new TypeError('expected an object'); | ||
} | ||
if (typeof prop === 'undefined' && typeof value === 'undefined') { | ||
return obj; | ||
if (typeof prop !== 'string' || value == null) { | ||
return merge.apply(null, arguments); | ||
} | ||
if (typeof value === 'undefined' && utils.isObject(prop)) { | ||
return utils.merge(obj, prop); | ||
} | ||
if (typeof value === 'string') { | ||
utils.set(obj, prop, value); | ||
set(obj, prop, value); | ||
return obj; | ||
} | ||
var current = utils.get(obj, prop); | ||
var val = utils.merge({}, current, value); | ||
utils.set(obj, prop, val); | ||
var current = get(obj, prop); | ||
if (isObject(value) && isObject(current)) { | ||
value = merge({}, current, value); | ||
} | ||
set(obj, prop, value); | ||
return obj; | ||
}; |
{ | ||
"name": "merge-value", | ||
"description": "Similar to assign-value but deeply merges object values or nested values using object path/dot notation.", | ||
"version": "0.1.1", | ||
"version": "1.0.0", | ||
"homepage": "https://github.com/jonschlinkert/merge-value", | ||
@@ -13,4 +13,3 @@ "author": "Jon Schlinkert (https://github.com/jonschlinkert)", | ||
"files": [ | ||
"index.js", | ||
"utils.js" | ||
"index.js" | ||
], | ||
@@ -25,11 +24,10 @@ "main": "index.js", | ||
"dependencies": { | ||
"get-value": "^1.1.5", | ||
"is-extendable": "^0.1.1", | ||
"lazy-cache": "^0.2.3", | ||
"mixin-deep": "^1.1.3", | ||
"set-value": "^0.2.0" | ||
"get-value": "^2.0.6", | ||
"is-extendable": "^1.0.0", | ||
"mixin-deep": "^1.2.0", | ||
"set-value": "^2.0.0" | ||
}, | ||
"devDependencies": { | ||
"mocha": "*", | ||
"should": "*" | ||
"gulp-format-md": "^1.0.0", | ||
"mocha": "^3.4.2" | ||
}, | ||
@@ -62,4 +60,15 @@ "keywords": [ | ||
] | ||
}, | ||
"toc": false, | ||
"layout": "default", | ||
"tasks": [ | ||
"readme" | ||
], | ||
"plugins": [ | ||
"gulp-format-md" | ||
], | ||
"lint": { | ||
"reflinks": true | ||
} | ||
} | ||
} |
@@ -1,2 +0,2 @@ | ||
# merge-value [![NPM version](https://badge.fury.io/js/merge-value.svg)](http://badge.fury.io/js/merge-value) | ||
# merge-value [![NPM version](https://img.shields.io/npm/v/merge-value.svg?style=flat)](https://www.npmjs.com/package/merge-value) [![NPM monthly downloads](https://img.shields.io/npm/dm/merge-value.svg?style=flat)](https://npmjs.org/package/merge-value) [![NPM total downloads](https://img.shields.io/npm/dt/merge-value.svg?style=flat)](https://npmjs.org/package/merge-value) [![Linux Build Status](https://img.shields.io/travis/jonschlinkert/merge-value.svg?style=flat&label=Travis)](https://travis-ci.org/jonschlinkert/merge-value) | ||
@@ -7,6 +7,6 @@ > Similar to assign-value but deeply merges object values or nested values using object path/dot notation. | ||
Install with [npm](https://www.npmjs.com/) | ||
Install with [npm](https://www.npmjs.com/): | ||
```sh | ||
$ npm i merge-value --save | ||
$ npm install --save merge-value | ||
``` | ||
@@ -21,7 +21,7 @@ | ||
merge(obj, 'foo', {a: 'b'}) | ||
// obj.foo ==> {a: 'b'} | ||
//=> obj.foo ==> {a: 'b'} | ||
var obj = {foo: {a: 'b'}}; | ||
merge(obj, 'foo', {c: 'd'}) | ||
// obj.foo ==> {a: 'b', c: 'd'} | ||
//=> obj.foo ==> {a: 'b', c: 'd'} | ||
@@ -31,3 +31,3 @@ var obj = {}; | ||
merge(obj, 'a.b.c', {three: 'four'}); | ||
// obj.a.b.c ==> {one: 'two', three: 'four'} | ||
//=> obj.a.b.c ==> {one: 'two', three: 'four'} | ||
@@ -39,37 +39,49 @@ var obj = {foo: {bar: {baz: {a: 'b'}}}}; | ||
## Related projects | ||
## About | ||
* [assign-value](https://www.npmjs.com/package/assign-value): Extend a value or deeply nested property of an object using object path notation. | [homepage](https://github.com/jonschlinkert/assign-value) | ||
* [get-value](https://www.npmjs.com/package/get-value): Use property paths (` a.b.c`) to get a nested value from an object. | [homepage](https://github.com/jonschlinkert/get-value) | ||
* [has-value](https://www.npmjs.com/package/has-value): Returns true if a value exists, false if empty. Works with deeply nested values using… [more](https://www.npmjs.com/package/has-value) | [homepage](https://github.com/jonschlinkert/has-value) | ||
* [set-value](https://www.npmjs.com/package/set-value): Create nested values and any intermediaries using dot notation (`'a.b.c'`) paths. | [homepage](https://github.com/jonschlinkert/set-value) | ||
* [union-value](https://www.npmjs.com/package/union-value): Set an array of unique values as the property of an object. Supports setting deeply… [more](https://www.npmjs.com/package/union-value) | [homepage](https://github.com/jonschlinkert/union-value) | ||
* [unset-value](https://www.npmjs.com/package/unset-value): Delete nested properties from an object using dot notation. | [homepage](https://github.com/jonschlinkert/unset-value) | ||
### Related projects | ||
## Running tests | ||
* [assign-value](https://www.npmjs.com/package/assign-value): Assign a value or extend a deeply nested property of an object using object path… [more](https://github.com/jonschlinkert/assign-value) | [homepage](https://github.com/jonschlinkert/assign-value "Assign a value or extend a deeply nested property of an object using object path notation.") | ||
* [get-value](https://www.npmjs.com/package/get-value): Use property paths (`a.b.c`) to get a nested value from an object. | [homepage](https://github.com/jonschlinkert/get-value "Use property paths (`a.b.c`) to get a nested value from an object.") | ||
* [has-value](https://www.npmjs.com/package/has-value): Returns true if a value exists, false if empty. Works with deeply nested values using… [more](https://github.com/jonschlinkert/has-value) | [homepage](https://github.com/jonschlinkert/has-value "Returns true if a value exists, false if empty. Works with deeply nested values using object paths.") | ||
* [set-value](https://www.npmjs.com/package/set-value): Create nested values and any intermediaries using dot notation (`'a.b.c'`) paths. | [homepage](https://github.com/jonschlinkert/set-value "Create nested values and any intermediaries using dot notation (`'a.b.c'`) paths.") | ||
* [union-value](https://www.npmjs.com/package/union-value): Set an array of unique values as the property of an object. Supports setting deeply… [more](https://github.com/jonschlinkert/union-value) | [homepage](https://github.com/jonschlinkert/union-value "Set an array of unique values as the property of an object. Supports setting deeply nested properties using using object-paths/dot notation.") | ||
* [unset-value](https://www.npmjs.com/package/unset-value): Delete nested properties from an object using dot notation. | [homepage](https://github.com/jonschlinkert/unset-value "Delete nested properties from an object using dot notation.") | ||
Install dev dependencies: | ||
### Contributing | ||
Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new). | ||
### Building docs | ||
_(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_ | ||
To generate the readme, run the following command: | ||
```sh | ||
$ npm i -d && npm test | ||
$ npm install -g verbose/verb#dev verb-generate-readme && verb | ||
``` | ||
## Contributing | ||
### Running tests | ||
Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](https://github.com/jonschlinkert/merge-value/issues/new). | ||
Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command: | ||
## Author | ||
```sh | ||
$ npm install && npm test | ||
``` | ||
### Author | ||
**Jon Schlinkert** | ||
+ [github/jonschlinkert](https://github.com/jonschlinkert) | ||
+ [twitter/jonschlinkert](http://twitter.com/jonschlinkert) | ||
* [github/jonschlinkert](https://github.com/jonschlinkert) | ||
* [twitter/jonschlinkert](https://twitter.com/jonschlinkert) | ||
## License | ||
### License | ||
Copyright © 2015 Jon Schlinkert | ||
Released under the MIT license. | ||
Copyright © 2017, [Jon Schlinkert](https://github.com/jonschlinkert). | ||
Released under the [MIT License](LICENSE). | ||
*** | ||
_This file was generated by [verb-cli](https://github.com/assemble/verb-cli) on October 02, 2015._ | ||
_This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.6.0, on July 20, 2017._ |
Sorry, the diff of this file is not supported yet
Dynamic require
Supply chain riskDynamic require can indicate the package is performing dangerous or unsafe dynamic code execution.
Found 1 instance in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
7378
4
0
83
1
4
23
+ Addedassign-symbols@1.0.0(transitive)
+ Addedextend-shallow@2.0.13.0.2(transitive)
+ Addedget-value@2.0.6(transitive)
+ Addedset-value@2.0.1(transitive)
+ Addedsplit-string@3.1.0(transitive)
- Removedlazy-cache@^0.2.3
- Removedarr-flatten@1.1.0(transitive)
- Removedget-value@1.3.1(transitive)
- Removedisobject@1.0.2(transitive)
- Removedlazy-cache@0.2.7(transitive)
- Removednoncharacters@1.1.0(transitive)
- Removedset-value@0.2.0(transitive)
Updatedget-value@^2.0.6
Updatedis-extendable@^1.0.0
Updatedmixin-deep@^1.2.0
Updatedset-value@^2.0.0