Compare commits

..

2 Commits

Author SHA1 Message Date
7b2d4ba119 updated xhr error handling
All checks were successful
Build / Build NPM Project (push) Successful in 42s
Build / Tag Version (push) Successful in 4s
2024-06-25 09:58:02 -04:00
1a4e732fd5 deepMerge fix
All checks were successful
Build / Build NPM Project (push) Successful in 22s
Build / Tag Version (push) Successful in 5s
2024-06-18 21:08:18 -04:00
3 changed files with 9 additions and 9 deletions

View File

@ -1,6 +1,6 @@
{
"name": "@ztimson/utils",
"version": "0.12.1",
"version": "0.12.3",
"description": "Utility library",
"author": "Zak Timson",
"license": "MIT",

View File

@ -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;
}

View File

@ -83,8 +83,8 @@ export class XHR {
const payload = await decode();
if(resp.ok) return payload;
const text = resp.statusText || (typeof payload == 'string' ? payload : null);
throw (text ? new Error(text) : payload);
throw Object.assign(new Error(typeof payload == 'string' ? payload : resp.statusText),
typeof payload == 'object' ? payload : {});
});
}
}