UNPKG

@asi-ngtools/lib

Version:

This project is a little components library, simple to use, which will help you to simplify your project.

155 lines (154 loc) 14.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Injectable } from '@angular/core'; import * as nh from '../../native-helper'; export class AsiTreeViewService { /** * Function used to open a particular node * @param {?} nodes * @param {?} nodeFinder * @return {?} */ openNode(nodes, nodeFinder) { nh.forEach(nodes, (node) => { if (this.mustOpenNode(node, nodeFinder)) { node.openNode(); } }); } /** * @param {?} node * @param {?} nodeFinder * @return {?} */ mustOpenNode(node, nodeFinder) { if (node != null) { if (nodeFinder(node.data)) { node.openNode(); node.tagFound(true); return true; } else if (node.childNodes) { /** @type {?} */ let childNodes = node.childNodes.toArray(); /** @type {?} */ let openNode = false; for (let childNode of childNodes) { if (this.mustOpenNode(childNode, nodeFinder)) { childNode.openNode(); openNode = true; } } return openNode; } } return false; } /** * @param {?} nodes * @return {?} */ closeAll(nodes) { nh.forEach(nodes, (node) => { this.closeNode(node); }); } /** * @param {?} node * @return {?} */ closeNode(node) { if (node) { node.closeNode(); if (node.childNodes) { node.childNodes.forEach(childNode => { childNode.closeNode(); }); } } } /** * @param {?} nodes * @return {?} */ openAll(nodes) { nh.forEach(nodes, (node) => { this.openANode(node); }); } /** * @param {?} node * @return {?} */ openANode(node) { if (node) { node.openNode(); if (node.childNodes) { node.childNodes.forEach(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 {?} */ filterNodes(nodes, nodeName, nodeFinder, keepLeaves, isLeaf) { nh.remove(nodes, (nodeData) => { return this.shouldRemoveData(nodeData, nodeName, nodeFinder, keepLeaves, isLeaf); }); return nodes; } /** * @param {?} nodeData * @param {?} nodeName * @param {?} nodeFinder * @param {?=} keepLeaves * @param {?=} isLeaf * @return {?} */ shouldRemoveData(nodeData, nodeName, nodeFinder, keepLeaves, isLeaf) { /** @type {?} */ let childNodes = /** @type {?} */ (nh.get(nodeData, nodeName)); /** @type {?} */ let matchingLeaf = false; if (childNodes) { // Delete not matching children if (keepLeaves) { nh.remove(childNodes, (child) => { /** @type {?} */ let leaf = (isLeaf && isLeaf(child)) || (!isLeaf && nh.isEmpty(nh.get(child, nodeName))); if (!leaf) { /** @type {?} */ let 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, (child) => { return this.shouldRemoveData(child, nodeName, nodeFinder, keepLeaves, isLeaf); }); } } return (nh.isEmpty(childNodes) || !matchingLeaf) && !nodeFinder(nodeData); } } AsiTreeViewService.decorators = [ { type: Injectable } ]; //# 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"]}