UNPKG

1.82 kBJavaScriptView Raw
1/**
2 * Simple deep merge function. Takes all arguments and returns a deep copy of the objects merged
3 * together in the order provided. If an object creates a circular reference, it will assign the
4 * original reference.
5 */
6export function merge(target) {
7 var args = [];
8 for (var _i = 1; _i < arguments.length; _i++) {
9 args[_i - 1] = arguments[_i];
10 }
11 for (var _a = 0, args_1 = args; _a < args_1.length; _a++) {
12 var arg = args_1[_a];
13 _merge(target || {}, arg);
14 }
15 return target;
16}
17/**
18 * The _merge helper iterates through all props on source and assigns them to target.
19 * When the value is an object, we will create a deep clone of the object. However if
20 * there is a circular reference, the value will not be deep cloned and will persist
21 * the reference.
22 */
23// eslint-disable-next-line @typescript-eslint/no-explicit-any
24function _merge(target, source, circularReferences) {
25 if (circularReferences === void 0) { circularReferences = []; }
26 circularReferences.push(source);
27 for (var name_1 in source) {
28 if (source.hasOwnProperty(name_1)) {
29 if (name_1 !== '__proto__' && name_1 !== 'constructor' && name_1 !== 'prototype') {
30 var value = source[name_1];
31 if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
32 var isCircularReference = circularReferences.indexOf(value) > -1;
33 target[name_1] = (isCircularReference
34 ? value
35 : _merge(target[name_1] || {}, value, circularReferences));
36 }
37 else {
38 target[name_1] = value;
39 }
40 }
41 }
42 }
43 circularReferences.pop();
44 return target;
45}
46//# sourceMappingURL=merge.js.map
\No newline at end of file