diff options
author | rstular <rok@stular.eu> | 2020-05-14 02:39:45 +0200 |
---|---|---|
committer | rstular <rok@stular.eu> | 2020-05-14 02:39:45 +0200 |
commit | c3b6d083be07da2831bff06496137200547fc947 (patch) | |
tree | 576605f06170b146b5652496cc41dc6b0c051020 /js/lib | |
parent | Minor styling fix (diff) | |
download | beziapp-c3b6d083be07da2831bff06496137200547fc947.tar beziapp-c3b6d083be07da2831bff06496137200547fc947.tar.gz beziapp-c3b6d083be07da2831bff06496137200547fc947.tar.bz2 beziapp-c3b6d083be07da2831bff06496137200547fc947.tar.lz beziapp-c3b6d083be07da2831bff06496137200547fc947.tar.xz beziapp-c3b6d083be07da2831bff06496137200547fc947.tar.zst beziapp-c3b6d083be07da2831bff06496137200547fc947.zip |
Diffstat (limited to 'js/lib')
-rw-r--r-- | js/lib/mergedeep.js | 25 |
1 files changed, 12 insertions, 13 deletions
diff --git a/js/lib/mergedeep.js b/js/lib/mergedeep.js index dfd0dd2..a56aa1d 100644 --- a/js/lib/mergedeep.js +++ b/js/lib/mergedeep.js @@ -5,7 +5,7 @@ * @returns {boolean} */ function isObject(item) { - return (item && typeof item === 'object' && !Array.isArray(item)); + return (item && typeof item === 'object' && !Array.isArray(item)); } /** @@ -14,19 +14,18 @@ function isObject(item) { * @param ...sources */ function mergeDeep(target, ...sources) { - if (!sources.length) return target; - const source = sources.shift(); + if (!sources.length) return target; + const source = sources.shift(); - if (isObject(target) && isObject(source)) { - for (const key in source) { - if (isObject(source[key])) { - if (!target[key]) Object.assign(target, { [key]: {} }); - mergeDeep(target[key], source[key]); - } else { - Object.assign(target, { [key]: source[key] }); - } + if (isObject(target) && isObject(source)) { + for (const key in source) { + if (isObject(source[key])) { + if (!target[key]) Object.assign(target, { [key]: {} }); + mergeDeep(target[key], source[key]); + } else { + Object.assign(target, { [key]: source[key] }); + } + } } - } - return mergeDeep(target, ...sources); } |