@asi-ngtools/lib
Version:
This project is a little components library, simple to use, which will help you to simplify your project.
220 lines (219 loc) • 16.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Injectable } from '@angular/core';
import * as nh from '../../native-helper';
var AsiTreeViewService = /** @class */ (function () {
function AsiTreeViewService() {
}
/**
* Function used to open a particular node
* @param {?} nodes
* @param {?} nodeFinder
* @return {?}
*/
AsiTreeViewService.prototype.openNode = /**
* Function used to open a particular node
* @param {?} nodes
* @param {?} nodeFinder
* @return {?}
*/
function (nodes, nodeFinder) {
var _this = this;
nh.forEach(nodes, function (node) {
if (_this.mustOpenNode(node, nodeFinder)) {
node.openNode();
}
});
};
/**
* @param {?} node
* @param {?} nodeFinder
* @return {?}
*/
AsiTreeViewService.prototype.mustOpenNode = /**
* @param {?} node
* @param {?} nodeFinder
* @return {?}
*/
function (node, nodeFinder) {
if (node != null) {
if (nodeFinder(node.data)) {
node.openNode();
node.tagFound(true);
return true;
}
else if (node.childNodes) {
/** @type {?} */
var childNodes = node.childNodes.toArray();
/** @type {?} */
var openNode = false;
try {
for (var childNodes_1 = tslib_1.__values(childNodes), childNodes_1_1 = childNodes_1.next(); !childNodes_1_1.done; childNodes_1_1 = childNodes_1.next()) {
var childNode = childNodes_1_1.value;
if (this.mustOpenNode(childNode, nodeFinder)) {
childNode.openNode();
openNode = true;
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (childNodes_1_1 && !childNodes_1_1.done && (_a = childNodes_1.return)) _a.call(childNodes_1);
}
finally { if (e_1) throw e_1.error; }
}
return openNode;
}
}
return false;
var e_1, _a;
};
/**
* @param {?} nodes
* @return {?}
*/
AsiTreeViewService.prototype.closeAll = /**
* @param {?} nodes
* @return {?}
*/
function (nodes) {
var _this = this;
nh.forEach(nodes, function (node) {
_this.closeNode(node);
});
};
/**
* @param {?} node
* @return {?}
*/
AsiTreeViewService.prototype.closeNode = /**
* @param {?} node
* @return {?}
*/
function (node) {
if (node) {
node.closeNode();
if (node.childNodes) {
node.childNodes.forEach(function (childNode) {
childNode.closeNode();
});
}
}
};
/**
* @param {?} nodes
* @return {?}
*/
AsiTreeViewService.prototype.openAll = /**
* @param {?} nodes
* @return {?}
*/
function (nodes) {
var _this = this;
nh.forEach(nodes, function (node) {
_this.openANode(node);
});
};
/**
* @param {?} node
* @return {?}
*/
AsiTreeViewService.prototype.openANode = /**
* @param {?} node
* @return {?}
*/
function (node) {
if (node) {
node.openNode();
if (node.childNodes) {
node.childNodes.forEach(function (childNode) {
childNode.openNode();
});
}
}
};
/**
* Function used to filter the tree-view
* @param {?} nodes
* @param {?} nodeName
* @param {?} nodeFinder function used to know if the node must be keep
* @param {?=} keepLeaves true if you want to keep the possible leafs of a matching node
* @param {?=} isLeaf
* @return {?}
*/
AsiTreeViewService.prototype.filterNodes = /**
* Function used to filter the tree-view
* @param {?} nodes
* @param {?} nodeName
* @param {?} nodeFinder function used to know if the node must be keep
* @param {?=} keepLeaves true if you want to keep the possible leafs of a matching node
* @param {?=} isLeaf
* @return {?}
*/
function (nodes, nodeName, nodeFinder, keepLeaves, isLeaf) {
var _this = this;
nh.remove(nodes, function (nodeData) {
return _this.shouldRemoveData(nodeData, nodeName, nodeFinder, keepLeaves, isLeaf);
});
return nodes;
};
/**
* @param {?} nodeData
* @param {?} nodeName
* @param {?} nodeFinder
* @param {?=} keepLeaves
* @param {?=} isLeaf
* @return {?}
*/
AsiTreeViewService.prototype.shouldRemoveData = /**
* @param {?} nodeData
* @param {?} nodeName
* @param {?} nodeFinder
* @param {?=} keepLeaves
* @param {?=} isLeaf
* @return {?}
*/
function (nodeData, nodeName, nodeFinder, keepLeaves, isLeaf) {
var _this = this;
/** @type {?} */
var childNodes = /** @type {?} */ (nh.get(nodeData, nodeName));
/** @type {?} */
var matchingLeaf = false;
if (childNodes) {
// Delete not matching children
if (keepLeaves) {
nh.remove(childNodes, function (child) {
/** @type {?} */
var leaf = (isLeaf && isLeaf(child)) || (!isLeaf && nh.isEmpty(nh.get(child, nodeName)));
if (!leaf) {
/** @type {?} */
var removeNode = _this.shouldRemoveData(child, nodeName, nodeFinder, keepLeaves, isLeaf);
matchingLeaf = matchingLeaf || !removeNode;
return removeNode;
}
else {
matchingLeaf = matchingLeaf || nodeFinder(child);
return false;
}
});
}
else {
matchingLeaf = true;
nh.remove(childNodes, function (child) {
return _this.shouldRemoveData(child, nodeName, nodeFinder, keepLeaves, isLeaf);
});
}
}
return (nh.isEmpty(childNodes) || !matchingLeaf) && !nodeFinder(nodeData);
};
AsiTreeViewService.decorators = [
{ type: Injectable }
];
return AsiTreeViewService;
}());
export { AsiTreeViewService };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-tree-view.service.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-tree-view/asi-tree-view.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { AsiTreeViewNodeComponent } from './node/asi-tree-view-node.component';\r\nimport * as nh from '../../native-helper';\r\n\r\n@Injectable()\r\nexport class AsiTreeViewService {\r\n\r\n  /**\r\n   * Function used to open a particular node\r\n   * @param nodeFinder\r\n   */\r\n  public openNode(nodes: Array<AsiTreeViewNodeComponent>, nodeFinder: Function) {\r\n    nh.forEach(nodes, (node: AsiTreeViewNodeComponent) => {\r\n      if (this.mustOpenNode(node, nodeFinder)) {\r\n        node.openNode();\r\n      }\r\n    });\r\n  }\r\n\r\n  private mustOpenNode(node: AsiTreeViewNodeComponent, nodeFinder: Function) {\r\n    if (node != null) {\r\n      if (nodeFinder(node.data)) {\r\n        node.openNode();\r\n        node.tagFound(true);\r\n        return true;\r\n      } else if (node.childNodes) {\r\n        let childNodes = node.childNodes.toArray();\r\n        let openNode = false;\r\n        for (let childNode of childNodes) {\r\n          if (this.mustOpenNode(childNode, nodeFinder)) {\r\n            childNode.openNode();\r\n            openNode = true;\r\n          }\r\n        }\r\n        return openNode;\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public closeAll(nodes: Array<AsiTreeViewNodeComponent>) {\r\n    nh.forEach(nodes, (node: AsiTreeViewNodeComponent) => {\r\n      this.closeNode(node);\r\n    });\r\n  }\r\n\r\n  private closeNode(node: AsiTreeViewNodeComponent) {\r\n    if (node) {\r\n      node.closeNode();\r\n      if (node.childNodes) {\r\n        node.childNodes.forEach(childNode => {\r\n          childNode.closeNode();\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  public openAll(nodes: Array<AsiTreeViewNodeComponent>) {\r\n    nh.forEach(nodes, (node: AsiTreeViewNodeComponent) => {\r\n      this.openANode(node);\r\n    });\r\n  }\r\n\r\n  private openANode(node: AsiTreeViewNodeComponent) {\r\n    if (node) {\r\n      node.openNode();\r\n      if (node.childNodes) {\r\n        node.childNodes.forEach(childNode => {\r\n          childNode.openNode();\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Function used to filter the tree-view\r\n   * @param nodeFinder function used to know if the node must be keep\r\n   * @param keepLeaves true if you want to keep the possible leafs of a matching node\r\n   */\r\n  public filterNodes(nodes: Array<any>, nodeName: string, nodeFinder: Function, keepLeaves?: boolean, isLeaf?: Function): Array<any> {\r\n    nh.remove(nodes, (nodeData) => {\r\n      return this.shouldRemoveData(nodeData, nodeName, nodeFinder, keepLeaves, isLeaf);\r\n    });\r\n    return nodes;\r\n  }\r\n\r\n  private shouldRemoveData(nodeData: any, nodeName: string, nodeFinder: Function, keepLeaves?: boolean, isLeaf?: Function) {\r\n    let childNodes: Array<any> = <Array<any>>nh.get(nodeData, nodeName);\r\n    let matchingLeaf = false;\r\n    if (childNodes) {\r\n      // Delete not matching children\r\n      if (keepLeaves) {\r\n        nh.remove(childNodes, (child) => {\r\n          let leaf = (isLeaf && isLeaf(child)) || (!isLeaf && nh.isEmpty(nh.get(child, nodeName)));\r\n          if (!leaf) {\r\n            let removeNode = this.shouldRemoveData(child, nodeName, nodeFinder, keepLeaves, isLeaf);\r\n            matchingLeaf = matchingLeaf || !removeNode;\r\n            return removeNode;\r\n          } else {\r\n            matchingLeaf = matchingLeaf || nodeFinder(child);\r\n            return false;\r\n          }\r\n        });\r\n      } else {\r\n        matchingLeaf = true;\r\n        nh.remove(childNodes, (child) => {\r\n          return this.shouldRemoveData(child, nodeName, nodeFinder, keepLeaves, isLeaf);\r\n        });\r\n      }\r\n    }\r\n    return (nh.isEmpty(childNodes) || !matchingLeaf) && !nodeFinder(nodeData);\r\n  }\r\n}\r\n"]}