UNPKG

@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
/** * @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"]}