dmitryfirsanov/frontend-project-lvl2

View on GitHub
src/buildTree.js

Summary

Maintainability
B
4 hrs
Test Coverage
A
100%
import _ from 'lodash';

const buildTree = (data1, data2) => {
  const keys1 = Object.keys(data1);
  const keys2 = Object.keys(data2);

  const uniqueKeys = _.sortBy(_.union(keys1, keys2));

  const result = uniqueKeys.map((key) => {
    if (!_.has(data1, key)) {
      return {
        type: 'added',
        key,
        value: data2[key],
      };
    }

    if (!_.has(data2, key)) {
      return {
        type: 'removed',
        key,
        value: data1[key],
      };
    }

    if (_.isObject(data1[key]) && _.isObject(data2[key])) {
      return {
        type: 'nested',
        key,
        children: buildTree(data1[key], data2[key]),
      };
    }

    if (!_.isEqual(data1[key], data2[key])) {
      return {
        type: 'changed',
        key,
        value1: data1[key],
        value2: data2[key],
      };
    }

    return {
      type: 'unchanged',
      key,
      value: data1[key],
    };
  });
  return result;
};

export default buildTree;