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