deepMerge fix
This commit is contained in:
parent
3a039c935f
commit
1a4e732fd5
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@ztimson/utils",
|
||||
"version": "0.12.1",
|
||||
"version": "0.12.2",
|
||||
"description": "Utility library",
|
||||
"author": "Zak Timson",
|
||||
"license": "MIT",
|
||||
|
@ -43,16 +43,16 @@ export function deepCopy<T>(value: T): T {
|
||||
* @return {any} The des
|
||||
*/
|
||||
export function deepMerge<T>(target: any, ...sources: any[]): T {
|
||||
for(const source of sources) {
|
||||
for(const key in source) {
|
||||
if(source[key] && typeof source[key] == 'object' && !Array.isArray(source[key])) {
|
||||
sources.forEach(s => {
|
||||
for(const key in s) {
|
||||
if(s[key] && typeof s[key] == 'object' && !Array.isArray(s[key])) {
|
||||
if(!target[key]) target[key] = {};
|
||||
deepMerge(target[key], source[key]);
|
||||
deepMerge(target[key], s[key]);
|
||||
} else {
|
||||
target[key] = source[key];
|
||||
}
|
||||
target[key] = s[key];
|
||||
}
|
||||
}
|
||||
});
|
||||
return target;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user