UNPKG

ngm-tree-grid

Version:

A tree grid that supports editable fields like Inputs and Checkboxes.

82 lines 27.5 kB
import { Component, EventEmitter, Input, Output, ViewChildren } from '@angular/core'; import { CellHostDirective } from '../../directive/cell-host.directive'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "../../directive/cell-host.directive"; export class TreeGridItemComponent { /** The level of node */ level = 1; data = []; config = { hasSearch: true, columns: [], searchFn: (obj, txt) => { return Object.values(obj) .filter((x) => (typeof x === 'string' || typeof x === 'number')) .map(x => String(x)) .some((y) => y.includes(txt)); } }; getChildrenFn = (obj) => { return obj['children']; }; expand = new EventEmitter(); collapse = new EventEmitter(); cellInputs; cellPanes; constructor() { } openItem(item) { item['isOpen'] = true; this.expand.emit({ item, level: this.level }); } closeItem(item) { item['isOpen'] = false; this.collapse.emit({ item, level: this.level }); } onExpand(e) { this.expand.emit(e); } onCollapse(e) { this.collapse.emit(e); } ngAfterContentInit() { setTimeout(() => { this.cellPanes.forEach((x, i) => { x.viewContainerRef.clear(); x.viewContainerRef.createEmbeddedView(this.cellInputs.get(i % this.cellInputs.length), { $implicit: this.data[Math.floor(i / this.cellInputs.length)] }); }); }, 10); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TreeGridItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TreeGridItemComponent, selector: "ngm-tree-grid-item", inputs: { level: "level", data: "data", config: "config", getChildrenFn: "getChildrenFn", cellInputs: "cellInputs" }, outputs: { expand: "expand", collapse: "collapse" }, viewQueries: [{ propertyName: "cellPanes", predicate: CellHostDirective, descendants: true }], ngImport: i0, template: "<ng-container>\r\n <div *ngFor=\"let item of data\">\r\n <div class=\"ngm-tree-grid-row\">\r\n <div class=\"ngm-tree-grid-items\">\r\n <div\r\n class=\"ngm-tree-grid-cell\"\r\n *ngFor=\"let column of cellInputs.toArray(); let first = first; let index = index\"\r\n [ngStyle]=\"{\r\n width: config.columns[index].width ? config.columns[index].width + '%' : 100 / (cellInputs.toArray().length) + '%'\r\n }\"\r\n >\r\n <div\r\n class=\"ngm-tree-grid-main\"\r\n *ngIf=\"first\"\r\n [ngStyle]=\"{ 'margin-left': level * 20 + 'px' }\"\r\n >\r\n <div\r\n class=\"ngm-tree-grid-main-icon arrow_up\"\r\n *ngIf=\"\r\n getChildrenFn(item) &&\r\n getChildrenFn(item).length > 0 &&\r\n item.isOpen\r\n \"\r\n (click)=\"closeItem(item)\"\r\n ></div>\r\n <div\r\n *ngIf=\"\r\n getChildrenFn(item) &&\r\n getChildrenFn(item).length > 0 &&\r\n !item.isOpen\r\n \"\r\n (click)=\"openItem(item)\"\r\n class=\"ngm-tree-grid-main-icon arrow_right\"\r\n ></div>\r\n <div\r\n *ngIf=\"!getChildrenFn(item) || getChildrenFn(item).length == 0\"\r\n class=\"ngm-tree-grid-main-icon dash\"\r\n ></div>\r\n <ng-template ngmCellHost></ng-template>\r\n <!-- </span> -->\r\n </div>\r\n <ng-template ngmCellHost *ngIf=\"!first\"></ng-template>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"getChildrenFn(item) && item.isOpen\">\r\n <ngm-tree-grid-item\r\n [data]=\"getChildrenFn(item)\"\r\n [config]=\"config\"\r\n [level]=\"level + 1\"\r\n [getChildrenFn]=\"getChildrenFn\"\r\n (expand)=\"onExpand($event)\"\r\n (collapse)=\"onCollapse($event)\"\r\n [cellInputs]=\"cellInputs\"\r\n ></ngm-tree-grid-item>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [".child{margin-left:20px}.ngm-tree-grid-row{width:100%;display:flex;justify-content:space-between;align-items:center;flex-direction:row}.ngm-tree-grid-row .ngm-tree-grid-items{width:100%;display:flex;justify-content:flex-start;align-items:center;flex-direction:row}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell{min-width:100px;padding:2px;border:1px solid rgba(0,0,0,.1215686275);display:flex;justify-content:flex-start;align-items:center;flex-direction:row;height:40px}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell .ngm-tree-grid-main{display:flex;justify-content:flex-start;align-items:center;flex-direction:row;overflow:hidden}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell .ngm-tree-grid-main .ngm-tree-grid-main-icon{cursor:pointer;width:13px;height:13px}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell .ngm-tree-grid-main .arrow_right{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFwAAABcCAMAAADUMSJqAAAASFBMVEX///9RUVFDQ0PR0dFAQEBJSUmRkZFGRkaOjo7U1NT39/dOTk6bm5vBwcHKysp/f3/l5eVtbW11dXVkZGQ4ODjc3NyhoaHr6+ufeXG1AAABQUlEQVRoge2ZW27DIBREgUATP/JonLb732kt5SNJGf7OyErFLOBoNFwDHkLo6urqamocjqcfE/s75pTT+WJAj59piqtK2RnYJd417Wn6g73Sae/XB3ulJ5R+zPFZrPdliq/0DNJfjbOrOlZwMvdUwUHv10nQKe9DnQtIn0UwXDIf0js1kYcNvN8Ghn6QdLN3Knevd7mq1Mx4J1J79yZjXlVo3qX3iHnfIPc32cUknTo9tPf0xdC194WBa3o+QXSVTJkheJhLDT+/A9wZi3NBnaPY2ACQj8h5IDk3rsaWixxGDd8Iu3FEG30Xo29r3sYZTMZMmKPTedlyXnG1b2gGFTs6vx1r3gi78XuOsHWxAF08ZSVCXWqFcaxE89ZQdYEGln/W6s9aWv6pW0nfwVwUWytubzkfrM8Kwfsg0tXV9T/1CwfjDrXg523+AAAAAElFTkSuQmCC);background-size:cover}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell .ngm-tree-grid-main .arrow_up{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIUAAACFCAMAAABCBMsOAAAAYFBMVEX///9RUVFLS0tOTk5ISEjo6Ojl5eXi4uJbW1vR0dFYWFjv7+9CQkLY2Njb29vs7Oz29vZycnI7OzttbW1oaGiTk5N+fn69vb2MjIzDw8OlpaV4eHhgYGAvLy+dnZ00NDQZisxwAAACwUlEQVR4nO2Z3XqqMBBFJQk/DfSAsVDbevT93/KIxFPBZGaCAW5mXUO+RbaZrbLbMQzDMAzDMAzDMEwUyq+267rjZ72hQ/MtjRJCKKPaZiuJOqmSO6r6s41EnojkFynetpDIikeJXuN9Awk5lrhqmNU1MiGTKVKtHEpeTHfipiFX1UgTl0QfyoonJa2e47BUq+1Grr0S64WSanccVmOd8QXEMWBW2A0ojtVCycA4rIZaeHylCpe4alwW1cgTLA6rsWS1TQsM0lhsNzJBlVgwFFeBARrLVJu7wACNJQ6sr8AAjfjVlqmQOCyxqy0nDCvHbsQNBS4wQCNmtaEF5ideteEFBuxGrFDmxmE14lQbFoesYMkoPxCwAhNF9qNgjderDSswobNdecA0XtwNrMBEcfvP4APReK3aMonEocvbdc0e0Xil2rACE6fMXlliGvMPLFZgQqf/r22wUOZWG1Zg9zgsyEd0ZrVhBSZO6ej6Ejuwc0LBJmZ/RMegoYRXW2qwYVU+34RoBFcbVmBCu/5bjHxS0DiKaRxWAwtFBYSCFZgzjgH0wJKnKF5gXoldE+uklKfQ0zG6G6s2mZMskKexBeYHCUUUFIm3Cl5E++MYwKrNfBIsjuAa04npAjmwsiNYgGX+WGB+kCkq8PcYjQElsDgs4EeUUK81YCEKyk70gKEQZgawF7Q47DJAKIZwVr0NAg0rB4AG4f1W67kbnRMTvKEIyhl5d88LeGI6NTy7Yb4od7cujcA4Bpwaak97BsdWhsYx4Jqi5JXqpzoLj2PgudqkJn/DaE7jm+ftxI1JKFIGPE49egbyxHQwDkVoWq3fNR6eQREKzE/58/Dqtwj9Fn406tprUqq/xxdfXp8vdqVLF76n+fmgE304B+2hk/p736/Uzvvh3tRpHeclfryVGIZhGIZhGIZhGIZhGIZhGIbOP2L7Hmn0yzsaAAAAAElFTkSuQmCC);background-size:cover}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell .ngm-tree-grid-main .dash{background:url(data:image/png;base64,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);background-size:cover}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell:first-child{padding:2px 1px;width:30%}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: TreeGridItemComponent, selector: "ngm-tree-grid-item", inputs: ["level", "data", "config", "getChildrenFn", "cellInputs"], outputs: ["expand", "collapse"] }, { kind: "directive", type: i2.CellHostDirective, selector: "[ngmCellHost]" }] }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TreeGridItemComponent, decorators: [{ type: Component, args: [{ selector: 'ngm-tree-grid-item', template: "<ng-container>\r\n <div *ngFor=\"let item of data\">\r\n <div class=\"ngm-tree-grid-row\">\r\n <div class=\"ngm-tree-grid-items\">\r\n <div\r\n class=\"ngm-tree-grid-cell\"\r\n *ngFor=\"let column of cellInputs.toArray(); let first = first; let index = index\"\r\n [ngStyle]=\"{\r\n width: config.columns[index].width ? config.columns[index].width + '%' : 100 / (cellInputs.toArray().length) + '%'\r\n }\"\r\n >\r\n <div\r\n class=\"ngm-tree-grid-main\"\r\n *ngIf=\"first\"\r\n [ngStyle]=\"{ 'margin-left': level * 20 + 'px' }\"\r\n >\r\n <div\r\n class=\"ngm-tree-grid-main-icon arrow_up\"\r\n *ngIf=\"\r\n getChildrenFn(item) &&\r\n getChildrenFn(item).length > 0 &&\r\n item.isOpen\r\n \"\r\n (click)=\"closeItem(item)\"\r\n ></div>\r\n <div\r\n *ngIf=\"\r\n getChildrenFn(item) &&\r\n getChildrenFn(item).length > 0 &&\r\n !item.isOpen\r\n \"\r\n (click)=\"openItem(item)\"\r\n class=\"ngm-tree-grid-main-icon arrow_right\"\r\n ></div>\r\n <div\r\n *ngIf=\"!getChildrenFn(item) || getChildrenFn(item).length == 0\"\r\n class=\"ngm-tree-grid-main-icon dash\"\r\n ></div>\r\n <ng-template ngmCellHost></ng-template>\r\n <!-- </span> -->\r\n </div>\r\n <ng-template ngmCellHost *ngIf=\"!first\"></ng-template>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"getChildrenFn(item) && item.isOpen\">\r\n <ngm-tree-grid-item\r\n [data]=\"getChildrenFn(item)\"\r\n [config]=\"config\"\r\n [level]=\"level + 1\"\r\n [getChildrenFn]=\"getChildrenFn\"\r\n (expand)=\"onExpand($event)\"\r\n (collapse)=\"onCollapse($event)\"\r\n [cellInputs]=\"cellInputs\"\r\n ></ngm-tree-grid-item>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [".child{margin-left:20px}.ngm-tree-grid-row{width:100%;display:flex;justify-content:space-between;align-items:center;flex-direction:row}.ngm-tree-grid-row .ngm-tree-grid-items{width:100%;display:flex;justify-content:flex-start;align-items:center;flex-direction:row}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell{min-width:100px;padding:2px;border:1px solid rgba(0,0,0,.1215686275);display:flex;justify-content:flex-start;align-items:center;flex-direction:row;height:40px}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell .ngm-tree-grid-main{display:flex;justify-content:flex-start;align-items:center;flex-direction:row;overflow:hidden}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell .ngm-tree-grid-main .ngm-tree-grid-main-icon{cursor:pointer;width:13px;height:13px}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell .ngm-tree-grid-main .arrow_right{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFwAAABcCAMAAADUMSJqAAAASFBMVEX///9RUVFDQ0PR0dFAQEBJSUmRkZFGRkaOjo7U1NT39/dOTk6bm5vBwcHKysp/f3/l5eVtbW11dXVkZGQ4ODjc3NyhoaHr6+ufeXG1AAABQUlEQVRoge2ZW27DIBREgUATP/JonLb732kt5SNJGf7OyErFLOBoNFwDHkLo6urqamocjqcfE/s75pTT+WJAj59piqtK2RnYJd417Wn6g73Sae/XB3ulJ5R+zPFZrPdliq/0DNJfjbOrOlZwMvdUwUHv10nQKe9DnQtIn0UwXDIf0js1kYcNvN8Ghn6QdLN3Knevd7mq1Mx4J1J79yZjXlVo3qX3iHnfIPc32cUknTo9tPf0xdC194WBa3o+QXSVTJkheJhLDT+/A9wZi3NBnaPY2ACQj8h5IDk3rsaWixxGDd8Iu3FEG30Xo29r3sYZTMZMmKPTedlyXnG1b2gGFTs6vx1r3gi78XuOsHWxAF08ZSVCXWqFcaxE89ZQdYEGln/W6s9aWv6pW0nfwVwUWytubzkfrM8Kwfsg0tXV9T/1CwfjDrXg523+AAAAAElFTkSuQmCC);background-size:cover}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell .ngm-tree-grid-main .arrow_up{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIUAAACFCAMAAABCBMsOAAAAYFBMVEX///9RUVFLS0tOTk5ISEjo6Ojl5eXi4uJbW1vR0dFYWFjv7+9CQkLY2Njb29vs7Oz29vZycnI7OzttbW1oaGiTk5N+fn69vb2MjIzDw8OlpaV4eHhgYGAvLy+dnZ00NDQZisxwAAACwUlEQVR4nO2Z3XqqMBBFJQk/DfSAsVDbevT93/KIxFPBZGaCAW5mXUO+RbaZrbLbMQzDMAzDMAzDMEwUyq+267rjZ72hQ/MtjRJCKKPaZiuJOqmSO6r6s41EnojkFynetpDIikeJXuN9Awk5lrhqmNU1MiGTKVKtHEpeTHfipiFX1UgTl0QfyoonJa2e47BUq+1Grr0S64WSanccVmOd8QXEMWBW2A0ojtVCycA4rIZaeHylCpe4alwW1cgTLA6rsWS1TQsM0lhsNzJBlVgwFFeBARrLVJu7wACNJQ6sr8AAjfjVlqmQOCyxqy0nDCvHbsQNBS4wQCNmtaEF5ideteEFBuxGrFDmxmE14lQbFoesYMkoPxCwAhNF9qNgjderDSswobNdecA0XtwNrMBEcfvP4APReK3aMonEocvbdc0e0Xil2rACE6fMXlliGvMPLFZgQqf/r22wUOZWG1Zg9zgsyEd0ZrVhBSZO6ej6Ejuwc0LBJmZ/RMegoYRXW2qwYVU+34RoBFcbVmBCu/5bjHxS0DiKaRxWAwtFBYSCFZgzjgH0wJKnKF5gXoldE+uklKfQ0zG6G6s2mZMskKexBeYHCUUUFIm3Cl5E++MYwKrNfBIsjuAa04npAjmwsiNYgGX+WGB+kCkq8PcYjQElsDgs4EeUUK81YCEKyk70gKEQZgawF7Q47DJAKIZwVr0NAg0rB4AG4f1W67kbnRMTvKEIyhl5d88LeGI6NTy7Yb4od7cujcA4Bpwaak97BsdWhsYx4Jqi5JXqpzoLj2PgudqkJn/DaE7jm+ftxI1JKFIGPE49egbyxHQwDkVoWq3fNR6eQREKzE/58/Dqtwj9Fn406tprUqq/xxdfXp8vdqVLF76n+fmgE304B+2hk/p736/Uzvvh3tRpHeclfryVGIZhGIZhGIZhGIZhGIZhGIbOP2L7Hmn0yzsaAAAAAElFTkSuQmCC);background-size:cover}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell .ngm-tree-grid-main .dash{background:url(data:image/png;base64,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);background-size:cover}.ngm-tree-grid-row .ngm-tree-grid-items .ngm-tree-grid-cell:first-child{padding:2px 1px;width:30%}\n"] }] }], ctorParameters: function () { return []; }, propDecorators: { level: [{ type: Input }], data: [{ type: Input }], config: [{ type: Input }], getChildrenFn: [{ type: Input }], expand: [{ type: Output }], collapse: [{ type: Output }], cellInputs: [{ type: Input }], cellPanes: [{ type: ViewChildren, args: [CellHostDirective] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-grid-item.component.js","sourceRoot":"","sources":["../../../../../../projects/ngm-tree-grid/src/lib/components/tree-grid-item/tree-grid-item.component.ts","../../../../../../projects/ngm-tree-grid/src/lib/components/tree-grid-item/tree-grid-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, EventEmitter, Input, Output, QueryList, ViewChildren } from '@angular/core';\r\nimport { CellHostDirective } from '../../directive/cell-host.directive';\r\nimport { INgmExpansion, INgmTreeGridConfig } from '../../model';\r\n\r\n@Component({\r\n  selector: 'ngm-tree-grid-item',\r\n  templateUrl: './tree-grid-item.component.html',\r\n  styleUrls: ['./tree-grid-item.component.scss']\r\n})\r\nexport class TreeGridItemComponent implements AfterContentInit {\r\n  /** The level of node */\r\n  @Input() level = 1;\r\n  @Input() data: any[] = [];\r\n  @Input()\r\n  config: INgmTreeGridConfig = {\r\n    hasSearch: true,\r\n    columns: [],\r\n    searchFn: (obj: any, txt: string) => {\r\n      return Object.values(obj)\r\n        .filter((x: any) => (typeof x === 'string' || typeof x === 'number'))\r\n        .map(x => String(x))\r\n        .some((y: string) => y.includes(txt))\r\n    }\r\n  }\r\n  @Input() getChildrenFn: (obj: any) => any[] = (obj: any) => {\r\n    return obj['children'];\r\n  };\r\n\r\n  @Output()\r\n  expand = new EventEmitter<INgmExpansion>();\r\n\r\n  @Output()\r\n  collapse = new EventEmitter<INgmExpansion>();\r\n\r\n  @Input() cellInputs: any;\r\n\r\n\r\n  @ViewChildren(CellHostDirective) cellPanes!: QueryList<CellHostDirective>;\r\n\r\n\r\n  constructor() { }\r\n\r\n  openItem(item: any) {\r\n    item['isOpen'] = true;\r\n    this.expand.emit({\r\n      item,\r\n      level: this.level\r\n    })\r\n  }\r\n  closeItem(item: any) {\r\n    item['isOpen'] = false;\r\n    this.collapse.emit({\r\n      item,\r\n      level: this.level\r\n    })\r\n  }\r\n\r\n  onExpand(e: INgmExpansion) {\r\n    this.expand.emit(e)\r\n  }\r\n\r\n  onCollapse(e: INgmExpansion) {\r\n    this.collapse.emit(e)\r\n  }\r\n\r\n  ngAfterContentInit(): void {\r\n    setTimeout(() => {\r\n      this.cellPanes.forEach((x, i) => {\r\n        x.viewContainerRef.clear();\r\n        x.viewContainerRef.createEmbeddedView(this.cellInputs.get(i % this.cellInputs.length)!, {\r\n          $implicit: this.data[Math.floor(i / this.cellInputs.length)]\r\n        })\r\n      });\r\n    }, 10);\r\n  }\r\n\r\n\r\n}\r\n","<ng-container>\r\n  <div *ngFor=\"let item of data\">\r\n    <div class=\"ngm-tree-grid-row\">\r\n      <div class=\"ngm-tree-grid-items\">\r\n        <div\r\n          class=\"ngm-tree-grid-cell\"\r\n          *ngFor=\"let column of cellInputs.toArray(); let first = first; let index = index\"\r\n          [ngStyle]=\"{\r\n            width: config.columns[index].width ? config.columns[index].width + '%' : 100 / (cellInputs.toArray().length) + '%'\r\n          }\"\r\n        >\r\n          <div\r\n            class=\"ngm-tree-grid-main\"\r\n            *ngIf=\"first\"\r\n            [ngStyle]=\"{ 'margin-left': level * 20 + 'px' }\"\r\n          >\r\n            <div\r\n              class=\"ngm-tree-grid-main-icon arrow_up\"\r\n              *ngIf=\"\r\n                getChildrenFn(item) &&\r\n                getChildrenFn(item).length > 0 &&\r\n                item.isOpen\r\n              \"\r\n              (click)=\"closeItem(item)\"\r\n            ></div>\r\n            <div\r\n              *ngIf=\"\r\n                getChildrenFn(item) &&\r\n                getChildrenFn(item).length > 0 &&\r\n                !item.isOpen\r\n              \"\r\n              (click)=\"openItem(item)\"\r\n              class=\"ngm-tree-grid-main-icon arrow_right\"\r\n            ></div>\r\n            <div\r\n              *ngIf=\"!getChildrenFn(item) || getChildrenFn(item).length == 0\"\r\n              class=\"ngm-tree-grid-main-icon dash\"\r\n            ></div>\r\n            <ng-template ngmCellHost></ng-template>\r\n            <!-- </span> -->\r\n          </div>\r\n          <ng-template ngmCellHost *ngIf=\"!first\"></ng-template>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div *ngIf=\"getChildrenFn(item) && item.isOpen\">\r\n      <ngm-tree-grid-item\r\n        [data]=\"getChildrenFn(item)\"\r\n        [config]=\"config\"\r\n        [level]=\"level + 1\"\r\n        [getChildrenFn]=\"getChildrenFn\"\r\n        (expand)=\"onExpand($event)\"\r\n        (collapse)=\"onCollapse($event)\"\r\n        [cellInputs]=\"cellInputs\"\r\n      ></ngm-tree-grid-item>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n"]}