deepie-merge 1.3.6 → 1.4.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/dist/index.d.ts CHANGED
@@ -1,13 +1,18 @@
1
+ //#region index.d.ts
1
2
  type ArrayExtend = boolean | Array<string>;
2
- type DeepieMergeOpts = {
3
- /** Either a boolean or a array of property keys to allow extension. Default: false */
4
- arrayExtend?: ArrayExtend;
5
- /** Maximum recursions to perform. Default: 10. */
6
- maxRecursion?: number;
3
+ type DeepieMergeOpts<T = any> = {
4
+ /** Either a boolean or a array of property keys to allow extension. Default: false */arrayExtend?: ArrayExtend; /** Maximum recursions to perform. Default: 10. */
5
+ maxRecursion?: number; /** Return a new value instead of mutating the first argument. Default: false */
6
+ clone?: boolean | ((value: T) => T);
7
7
  };
8
8
  type DeepMergeable = {
9
- [key: string]: any;
9
+ [key: string]: any;
10
10
  } | Array<any>;
11
11
  /** deep-merge b into a */
12
- export declare function deepMerge<T extends DeepMergeable>(a: T, b: any, { arrayExtend, maxRecursion }?: DeepieMergeOpts): T;
13
- export {};
12
+ declare function deepMerge<T extends DeepMergeable>(a: T, b: any, {
13
+ arrayExtend,
14
+ maxRecursion,
15
+ clone
16
+ }?: DeepieMergeOpts<T>): T;
17
+ //#endregion
18
+ export { deepMerge };
package/dist/index.js CHANGED
@@ -1,42 +1,39 @@
1
+ //#region index.ts
1
2
  function isObject(obj) {
2
- return Object.prototype.toString.call(obj) === "[object Object]";
3
+ return Object.prototype.toString.call(obj) === "[object Object]";
3
4
  }
4
5
  function getType(obj) {
5
- if (isObject(obj)) return "object";
6
- if (Array.isArray(obj)) return "array";
7
- return typeof obj;
6
+ if (isObject(obj)) return "object";
7
+ if (Array.isArray(obj)) return "array";
8
+ return typeof obj;
8
9
  }
9
- function deepMerge(a, b, { arrayExtend = false, maxRecursion = 20 } = { arrayExtend: false, maxRecursion: 10 }) {
10
- return merge(a, b, arrayExtend, maxRecursion);
10
+ /** deep-merge b into a */
11
+ function deepMerge(a, b, { arrayExtend = false, maxRecursion = 20, clone = false } = {
12
+ arrayExtend: false,
13
+ maxRecursion: 10
14
+ }) {
15
+ return merge(clone ? typeof clone === "function" ? clone(a) : structuredClone(a) : a, b, arrayExtend, maxRecursion);
11
16
  }
12
17
  function merge(a, b, arrayExtend, maxRecursion) {
13
- if (maxRecursion === 0) return a;
14
- if (Array.isArray(a)) {
15
- if (Array.isArray(b)) {
16
- return arrayExtend ? Array.from(/* @__PURE__ */ new Set([...a, ...b])) : b;
17
- }
18
- return b;
19
- }
20
- if (Array.isArray(b)) return b;
21
- if (isObject(a) && isObject(b)) {
22
- const keys = Object.keys(b);
23
- for (let i = 0, len = keys.length; i < len; i++) {
24
- const key = keys[i];
25
- const typeA = getType(a[key]);
26
- const typeB = getType(b[key]);
27
- if (typeA !== typeB) {
28
- a[key] = b[key];
29
- } else if (typeA === "array" && (Array.isArray(arrayExtend) ? arrayExtend.includes(key) : arrayExtend)) {
30
- a[key] = Array.from(/* @__PURE__ */ new Set([...a[key], ...b[key]]));
31
- } else if (typeA === "object") {
32
- a[key] = merge(a[key], b[key], arrayExtend, maxRecursion - 1);
33
- } else {
34
- a[key] = b[key];
35
- }
36
- }
37
- }
38
- return a;
18
+ if (maxRecursion === 0) return a;
19
+ if (Array.isArray(a)) {
20
+ if (Array.isArray(b)) return arrayExtend ? Array.from(new Set([...a, ...b])) : b;
21
+ return b;
22
+ }
23
+ if (Array.isArray(b)) return b;
24
+ if (isObject(a) && isObject(b)) {
25
+ const keys = Object.keys(b);
26
+ for (let i = 0, len = keys.length; i < len; i++) {
27
+ const key = keys[i];
28
+ const typeA = getType(a[key]);
29
+ if (typeA !== getType(b[key])) a[key] = b[key];
30
+ else if (typeA === "array" && (Array.isArray(arrayExtend) ? arrayExtend.includes(key) : arrayExtend)) a[key] = Array.from(new Set([...a[key], ...b[key]]));
31
+ else if (typeA === "object") a[key] = merge(a[key], b[key], arrayExtend, maxRecursion - 1);
32
+ else a[key] = b[key];
33
+ }
34
+ }
35
+ return a;
39
36
  }
40
- export {
41
- deepMerge
42
- };
37
+
38
+ //#endregion
39
+ export { deepMerge };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "deepie-merge",
3
- "version": "1.3.6",
3
+ "version": "1.4.0",
4
4
  "description": "Yay, another deep merge",
5
5
  "author": "silverwind <me@silverwind.io>",
6
6
  "repository": "silverwind/deepie-merge",
@@ -17,16 +17,19 @@
17
17
  "node": ">=18"
18
18
  },
19
19
  "devDependencies": {
20
- "@types/node": "25.2.0",
21
- "eslint": "9.39.2",
22
- "eslint-config-silverwind": "120.0.0",
20
+ "@types/node": "25.5.0",
21
+ "@typescript/native-preview": "7.0.0-dev.20260330.1",
22
+ "eslint": "10.1.0",
23
+ "eslint-config-silverwind": "130.0.2",
24
+ "jest-extended": "7.0.0",
25
+ "tsdown": "0.21.7",
26
+ "tsdown-config-silverwind": "2.0.5",
23
27
  "typescript": "5.9.3",
24
- "typescript-config-silverwind": "14.0.0",
25
- "updates": "17.1.0",
26
- "versions": "14.1.0",
27
- "vite": "7.3.1",
28
- "vite-config-silverwind": "6.0.9",
29
- "vitest": "4.0.18",
30
- "vitest-config-silverwind": "10.6.1"
28
+ "typescript-config-silverwind": "16.1.0",
29
+ "updates": "17.13.0",
30
+ "updates-config-silverwind": "2.0.1",
31
+ "versions": "14.2.6",
32
+ "vitest": "4.1.2",
33
+ "vitest-config-silverwind": "11.0.2"
31
34
  }
32
- }
35
+ }