UNPKG

2.58 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6
7var _omit2 = require('lodash/omit');
8
9var _omit3 = _interopRequireDefault(_omit2);
10
11var _isArray2 = require('lodash/isArray');
12
13var _isArray3 = _interopRequireDefault(_isArray2);
14
15var _find3 = require('lodash/find');
16
17var _find4 = _interopRequireDefault(_find3);
18
19var _cloneDeep2 = require('lodash/cloneDeep');
20
21var _cloneDeep3 = _interopRequireDefault(_cloneDeep2);
22
23function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
24
25function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
26
27var pack = function pack() {
28 var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
29 _ref$idField = _ref.idField,
30 idField = _ref$idField === undefined ? 'id' : _ref$idField,
31 _ref$parentField = _ref.parentField,
32 parentField = _ref$parentField === undefined ? 'parent' : _ref$parentField,
33 _ref$childrenField = _ref.childrenField,
34 childrenField = _ref$childrenField === undefined ? 'children' : _ref$childrenField;
35
36 return function (rows) {
37 if (!(0, _isArray3.default)(rows)) {
38 return [];
39 }
40
41 if (!rows.length) {
42 return rows;
43 }
44
45 var ret = [];
46 var previousParents = void 0;
47
48 // Clone deep to guarantee immutability (implementation relies on
49 // references)
50 (0, _cloneDeep3.default)(rows).forEach(function (row) {
51 var rowParent = row[parentField];
52
53 if (typeof rowParent !== 'undefined' && rowParent !== null) {
54 // Check if the parent field matches the accumulated potential parents
55 var foundParent = (0, _find4.default)(previousParents, _defineProperty({}, idField, rowParent));
56
57 if (foundParent) {
58 // Found the matching parent, set up children + push
59 if (!foundParent[childrenField]) {
60 foundParent[childrenField] = [];
61 }
62
63 foundParent[childrenField].push((0, _omit3.default)(row, parentField));
64
65 previousParents.push(last(foundParent[childrenField]));
66 } else {
67 console.warn('tree.pack - Invalid parent id', row, previousParents); // eslint-disable-line no-console
68 }
69 } else {
70 ret.push(row);
71
72 // No parents, flush lookup
73 previousParents = [row];
74 }
75 });
76
77 return ret;
78 };
79};
80
81function last(arr) {
82 return arr[arr.length - 1];
83}
84
85exports.default = pack;
\No newline at end of file