Added array support to delta calculations
This commit is contained in:
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@ztimson/utils",
|
"name": "@ztimson/utils",
|
||||||
"version": "0.26.25",
|
"version": "0.26.26",
|
||||||
"description": "Utility library",
|
"description": "Utility library",
|
||||||
"author": "Zak Timson",
|
"author": "Zak Timson",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
@ -10,14 +10,15 @@ export function applyDeltas(target: any, deltas: Delta[]): any {
|
|||||||
for(const delta of deltas) {
|
for(const delta of deltas) {
|
||||||
for(const [key, value] of Object.entries(delta)) {
|
for(const [key, value] of Object.entries(delta)) {
|
||||||
if(value === null) {
|
if(value === null) {
|
||||||
delete target[key]; // remove
|
delete target[key]; // Remove
|
||||||
} else if(typeof value === 'object' && !Array.isArray(value)) {
|
} else if(Array.isArray(value)) {
|
||||||
if(typeof target[key] !== 'object' || Array.isArray(target[key])) {
|
target[key] = [...value]; // Array
|
||||||
target[key] = {}; // nested obj
|
} else if(typeof value === 'object') {
|
||||||
}
|
if(typeof target[key] !== 'object' || Array.isArray(target[key]) || !target[key])
|
||||||
applyDeltas(target[key], [value]); // recurse
|
target[key] = {}; // Nested
|
||||||
|
applyDeltas(target[key], [value]); // Recurse
|
||||||
} else {
|
} else {
|
||||||
target[key] = value; // restore
|
target[key] = value; // Primitive
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -37,17 +38,16 @@ export function calcDelta(old: any, target: any): Delta {
|
|||||||
const val1 = old?.[key];
|
const val1 = old?.[key];
|
||||||
const val2 = target?.[key];
|
const val2 = target?.[key];
|
||||||
if(!(key in target)) {
|
if(!(key in target)) {
|
||||||
delta[key] = val1; // removed
|
delta[key] = val1; // Removed
|
||||||
} else if(!(key in old)) {
|
} else if(!(key in old)) {
|
||||||
delta[key] = null; // added
|
delta[key] = null; // Added
|
||||||
} else if(
|
} else if(Array.isArray(val1) || Array.isArray(val2)) {
|
||||||
typeof val1 === 'object' && typeof val2 === 'object' &&
|
if(JSON.stringify(val1) !== JSON.stringify(val2)) delta[key] = val1; // Array
|
||||||
val1 && val2 && !Array.isArray(val1)
|
} else if(typeof val1 === 'object' && typeof val2 === 'object' && val1 && val2) {
|
||||||
) {
|
|
||||||
const nested = calcDelta(val1, val2);
|
const nested = calcDelta(val1, val2);
|
||||||
if(Object.keys(nested).length) delta[key] = nested;
|
if(Object.keys(nested).length) delta[key] = nested; // Nested
|
||||||
} else if(val1 !== val2) {
|
} else if(val1 !== val2) {
|
||||||
delta[key] = val1; // changed
|
delta[key] = val1; // Modified
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return delta;
|
return delta;
|
||||||
|
Reference in New Issue
Block a user