deepie-merge 1.0.0 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,7 +1,7 @@
1
1
  # deepie-merge
2
2
  [![](https://img.shields.io/npm/v/deepie-merge.svg?style=flat)](https://www.npmjs.org/package/deepie-merge) [![](https://img.shields.io/npm/dm/deepie-merge.svg)](https://www.npmjs.org/package/deepie-merge) [![](https://packagephobia.com/badge?p=deepie-merge)](https://packagephobia.com/result?p=deepie-merge)
3
3
 
4
- > Yet another deep merge
4
+ > Yay, another deep merge
5
5
 
6
6
  ## Usage
7
7
  ```console
@@ -12,10 +12,23 @@ npm i deepie-merge
12
12
  import {deepMerge} from "deepie-merge";
13
13
 
14
14
  deepMerge({a: [1]}, {a: [2]});
15
- // => {a: [1]}
15
+ // => {a: [2]}
16
16
 
17
17
  deepMerge({a: [1]}, {a: [2]}, {arrayExtend: true});
18
18
  // => {a: [1, 2]}
19
+
20
+ deepMerge({a: [1], b: [1]}, {a: [2], b: [2]}, {arrayExtend: ["a"]});
21
+ // => {a: [1, 2], b: [2]}
19
22
  ```
20
23
 
24
+ ## API
25
+
26
+ ### deepMerge(dst, src, options)
27
+
28
+ - `dst` *any*: Destination value
29
+ - `src` *any*: Source value
30
+ - `options` *object*:
31
+ - `arrayExtend` *boolean* or *string[]*: Whether to extend arrays instead of replacing them. When passed a string array, it will only extend the object keys provided in that array.
32
+ - `maxRecursions` *number*: Amount of nesting levels to recurse into. Default: `10`
33
+
21
34
  © [silverwind](https://github.com/silverwind), distributed under BSD licence
@@ -0,0 +1,9 @@
1
+ type ArrayExtend = boolean | string[];
2
+ type DeepieMergeOpts = {
3
+ /** Either a boolean or a array of property keys to allow extension. */
4
+ arrayExtend: ArrayExtend;
5
+ /** Maximum recursions to perform. Default: 10. */
6
+ maxRecursion?: number;
7
+ };
8
+ export declare function deepMerge(a: any, b: any, { arrayExtend, maxRecursion }?: DeepieMergeOpts): any;
9
+ export {};
package/dist/index.js ADDED
@@ -0,0 +1,40 @@
1
+ const isObject = (obj) => Object.prototype.toString.call(obj) === "[object Object]";
2
+ const uniq = (arr) => Array.from(new Set(arr));
3
+ const extendArrays = (a, b) => uniq([...a, ...b]);
4
+ function getType(obj) {
5
+ if (isObject(obj))
6
+ return "object";
7
+ if (Array.isArray(obj))
8
+ return "array";
9
+ return typeof obj;
10
+ }
11
+ function canExtendArray(key, arrayExtend) {
12
+ return Array.isArray(arrayExtend) ? arrayExtend.includes(key) : arrayExtend;
13
+ }
14
+ function deepMerge(a, b, { arrayExtend = false, maxRecursion = 10 } = { arrayExtend: false, maxRecursion: 10 }) {
15
+ if (Array.isArray(a) && Array.isArray(b))
16
+ return arrayExtend ? extendArrays(a, b) : b;
17
+ if (!isObject(b))
18
+ return b;
19
+ if (maxRecursion === 0)
20
+ return a;
21
+ for (const key of Object.keys(b)) {
22
+ const typeA = getType(a[key]);
23
+ const typeB = getType(b[key]);
24
+ if (typeA !== typeB) {
25
+ a[key] = b[key];
26
+ } else {
27
+ if (typeA === "array" && canExtendArray(key, arrayExtend)) {
28
+ a[key] = extendArrays(a[key], b[key]);
29
+ } else if (typeA === "object") {
30
+ a[key] = deepMerge(a[key], b[key], { arrayExtend, maxRecursion: maxRecursion - 1 });
31
+ } else {
32
+ a[key] = b[key];
33
+ }
34
+ }
35
+ }
36
+ return a;
37
+ }
38
+ export {
39
+ deepMerge
40
+ };
package/package.json CHANGED
@@ -1,25 +1,32 @@
1
1
  {
2
2
  "name": "deepie-merge",
3
- "version": "1.0.0",
4
- "description": "Yet another deep merge",
3
+ "version": "1.2.0",
4
+ "description": "Yay, another deep merge",
5
5
  "author": "silverwind <me@silverwind.io>",
6
6
  "repository": "silverwind/deepie-merge",
7
7
  "license": "BSD-2-Clause",
8
- "exports": "./index.js",
9
8
  "type": "module",
10
9
  "sideEffects": false,
10
+ "exports": "./dist/index.js",
11
+ "types": "./dist/index.d.ts",
12
+ "files": [
13
+ "dist"
14
+ ],
11
15
  "engines": {
12
16
  "node": ">=18"
13
17
  },
14
- "files": [
15
- "index.js"
16
- ],
17
18
  "devDependencies": {
19
+ "@types/node": "20.12.8",
18
20
  "eslint": "8.57.0",
19
- "eslint-config-silverwind": "80.0.5",
20
- "updates": "15.1.2",
21
+ "eslint-config-silverwind": "84.0.0",
22
+ "eslint-config-silverwind-typescript": "3.2.3",
23
+ "typescript": "5.4.5",
24
+ "typescript-config-silverwind": "4.0.1",
25
+ "updates": "16.0.1",
21
26
  "versions": "12.0.1",
22
- "vitest": "1.3.1",
23
- "vitest-config-silverwind": "5.1.1"
27
+ "vite": "5.2.11",
28
+ "vite-plugin-dts": "3.9.0",
29
+ "vitest": "1.5.3",
30
+ "vitest-config-silverwind": "9.0.4"
24
31
  }
25
32
  }
package/index.js DELETED
@@ -1,41 +0,0 @@
1
- const isObject = obj => Object.prototype.toString.call(obj) === "[object Object]";
2
- const uniq = arr => Array.from(new Set(arr));
3
-
4
- function extendArrays(a, b) {
5
- return uniq([...a, ...b]);
6
- }
7
-
8
- function type(obj) {
9
- if (isObject(obj)) return "object";
10
- if (Array.isArray(obj)) return "array";
11
- return typeof obj;
12
- }
13
-
14
- function canExtendArray(key, arrayExtend) {
15
- return Array.isArray(arrayExtend) ? arrayExtend.includes(key) : arrayExtend;
16
- }
17
-
18
- // merge b int a, arrayExtend is either a boolean or a array of property keys to allow extension
19
- export function deepMerge(a, b, {maxRecursion = 10, arrayExtend = false} = {}) {
20
- if (Array.isArray(a) && Array.isArray(b)) return arrayExtend ? extendArrays(a, b) : b;
21
- if (!isObject(b)) return b;
22
- if (maxRecursion === 0) return a;
23
-
24
- for (const key of Object.keys(b)) {
25
- const typeA = type(a[key]);
26
- const typeB = type(b[key]);
27
- if (typeA !== typeB) { // different type, overwrite
28
- a[key] = b[key];
29
- } else { // same type
30
- if (typeA === "array" && canExtendArray(key, arrayExtend)) {
31
- a[key] = extendArrays(a[key], b[key]);
32
- } else if (typeA === "object") {
33
- a[key] = deepMerge(a[key], b[key], {arrayExtend, maxRecursion: maxRecursion - 1});
34
- } else {
35
- a[key] = b[key];
36
- }
37
- }
38
- }
39
-
40
- return a;
41
- }