2018-03-14 16:43:53 -04:00
|
|
|
var forEach = require('min-dash').forEach;
|
2016-04-20 17:31:42 +02:00
|
|
|
|
|
|
|
|
2018-04-02 21:01:53 +02:00
|
|
|
export default function DescriptorTree(tree) {
|
2016-04-20 17:31:42 +02:00
|
|
|
|
2018-03-22 10:22:37 +01:00
|
|
|
var self = this;
|
|
|
|
|
2016-04-20 17:31:42 +02:00
|
|
|
this._tree = {};
|
|
|
|
this._length = 0;
|
|
|
|
|
|
|
|
forEach(tree, function(branch, depth) {
|
|
|
|
if (branch.length) {
|
2018-03-22 10:22:37 +01:00
|
|
|
self._length += 1;
|
2016-04-20 17:31:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
forEach(branch, function(element) {
|
|
|
|
|
|
|
|
element.depth = parseInt(depth, 10);
|
|
|
|
|
2018-03-22 10:22:37 +01:00
|
|
|
self._tree[element.id] = element;
|
|
|
|
});
|
2016-04-20 17:31:42 +02:00
|
|
|
|
2018-03-22 10:22:37 +01:00
|
|
|
});
|
2016-04-20 17:31:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
DescriptorTree.prototype.getLength = function() {
|
|
|
|
return this._length;
|
|
|
|
};
|
|
|
|
|
|
|
|
DescriptorTree.prototype.getElement = function(id) {
|
|
|
|
return this._tree[id];
|
|
|
|
};
|
|
|
|
|
|
|
|
DescriptorTree.prototype.getDepth = function(depth) {
|
|
|
|
var newTree = {};
|
|
|
|
|
|
|
|
forEach(this._tree, function(element) {
|
|
|
|
if (element.depth === depth) {
|
|
|
|
newTree[element.id] = element;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return newTree;
|
|
|
|
};
|
|
|
|
|
|
|
|
DescriptorTree.prototype.getDepthLength = function(depth) {
|
|
|
|
var length = 0;
|
|
|
|
|
|
|
|
forEach(this._tree, function(element) {
|
|
|
|
if (element.depth === depth) {
|
|
|
|
length += 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return length;
|
|
|
|
};
|