From 6b0d9052d5b6004c4c1e0d4a24672eb0d17221f5 Mon Sep 17 00:00:00 2001 From: ftab Date: Mon, 5 Dec 2022 12:15:29 +0100 Subject: [PATCH] RFE #520 purposal (keep oldValue in diff) --- packages/collection-diff/index.js | 7 ++++--- packages/collection-diff/index.mjs | 7 ++++--- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/packages/collection-diff/index.js b/packages/collection-diff/index.js index 11ad3710b..ffd235647 100644 --- a/packages/collection-diff/index.js +++ b/packages/collection-diff/index.js @@ -114,14 +114,14 @@ function diff(obj1, obj2, pathConverter) { Object(obj1AtKey) !== obj1AtKey || Object(obj2AtKey) !== obj2AtKey ) { - path = pushReplace(path, basePath, key, diffs, pathConverter, obj2); + path = pushReplace(path, basePath, key, diffs, pathConverter, obj2, obj1); } else { if ( !Object.keys(obj1AtKey).length && !Object.keys(obj2AtKey).length && String(obj1AtKey) != String(obj2AtKey) ) { - path = pushReplace(path, basePath, key, diffs, pathConverter, obj2); + path = pushReplace(path, basePath, key, diffs, pathConverter, obj2, obj1); } else { getDiff(obj1[key], obj2[key], basePath.concat(key), diffs); } @@ -138,11 +138,12 @@ function diff(obj1, obj2, pathConverter) { .concat(finalDiffs.add); } -function pushReplace(path, basePath, key, diffs, pathConverter, obj2) { +function pushReplace(path, basePath, key, diffs, pathConverter, obj2, obj1) { path = basePath.concat(key); diffs.replace.push({ op: 'replace', path: pathConverter(path), + oldValue: obj1[key], value: obj2[key], }); return path; diff --git a/packages/collection-diff/index.mjs b/packages/collection-diff/index.mjs index a0c583447..1f51bc045 100644 --- a/packages/collection-diff/index.mjs +++ b/packages/collection-diff/index.mjs @@ -109,14 +109,14 @@ function diff(obj1, obj2, pathConverter) { Object(obj1AtKey) !== obj1AtKey || Object(obj2AtKey) !== obj2AtKey ) { - path = pushReplace(path, basePath, key, diffs, pathConverter, obj2); + path = pushReplace(path, basePath, key, diffs, pathConverter, obj2, obj1); } else { if ( !Object.keys(obj1AtKey).length && !Object.keys(obj2AtKey).length && String(obj1AtKey) != String(obj2AtKey) ) { - path = pushReplace(path, basePath, key, diffs, pathConverter, obj2); + path = pushReplace(path, basePath, key, diffs, pathConverter, obj2, obj1); } else { getDiff(obj1[key], obj2[key], basePath.concat(key), diffs); } @@ -133,11 +133,12 @@ function diff(obj1, obj2, pathConverter) { .concat(finalDiffs.add); } -function pushReplace(path, basePath, key, diffs, pathConverter, obj2) { +function pushReplace(path, basePath, key, diffs, pathConverter, obj2, obj1) { path = basePath.concat(key); diffs.replace.push({ op: 'replace', path: pathConverter(path), + oldValue: obj1[key], value: obj2[key], }); return path;