ng2-tree
Version:
angular2 component for visualizing data that can be naturally represented as a tree
137 lines • 18.6 kB
JavaScript
import { Component, ContentChild, EventEmitter, Inject, Input, Output, TemplateRef, ViewChild } from '@angular/core';
import { TreeService } from './tree.service';
import { Tree } from './tree';
import * as i0 from "@angular/core";
import * as i1 from "./tree-internal.component";
import * as i2 from "./tree.service";
export class TreeComponent {
treeService;
static EMPTY_TREE = new Tree({ value: '' });
/* tslint:disable:no-input-rename */
treeModel;
/* tslint:enable:no-input-rename */
settings;
nodeCreated = new EventEmitter();
nodeRemoved = new EventEmitter();
nodeRenamed = new EventEmitter();
nodeSelected = new EventEmitter();
nodeUnselected = new EventEmitter();
nodeMoved = new EventEmitter();
nodeExpanded = new EventEmitter();
nodeCollapsed = new EventEmitter();
loadNextLevel = new EventEmitter();
nodeChecked = new EventEmitter();
nodeUnchecked = new EventEmitter();
menuItemSelected = new EventEmitter();
tree;
rootComponent;
template;
subscriptions = [];
constructor(treeService) {
this.treeService = treeService;
}
ngOnChanges(changes) {
if (!this.treeModel) {
this.tree = TreeComponent.EMPTY_TREE;
}
else {
this.tree = new Tree(this.treeModel);
}
}
ngOnInit() {
this.subscriptions.push(this.treeService.nodeRemoved$.subscribe((e) => {
this.nodeRemoved.emit(e);
}));
this.subscriptions.push(this.treeService.nodeRenamed$.subscribe((e) => {
this.nodeRenamed.emit(e);
}));
this.subscriptions.push(this.treeService.nodeCreated$.subscribe((e) => {
this.nodeCreated.emit(e);
}));
this.subscriptions.push(this.treeService.nodeSelected$.subscribe((e) => {
this.nodeSelected.emit(e);
}));
this.subscriptions.push(this.treeService.nodeUnselected$.subscribe((e) => {
this.nodeUnselected.emit(e);
}));
this.subscriptions.push(this.treeService.nodeMoved$.subscribe((e) => {
this.nodeMoved.emit(e);
}));
this.subscriptions.push(this.treeService.nodeExpanded$.subscribe((e) => {
this.nodeExpanded.emit(e);
}));
this.subscriptions.push(this.treeService.nodeCollapsed$.subscribe((e) => {
this.nodeCollapsed.emit(e);
}));
this.subscriptions.push(this.treeService.menuItemSelected$.subscribe((e) => {
this.menuItemSelected.emit(e);
}));
this.subscriptions.push(this.treeService.loadNextLevel$.subscribe((e) => {
this.loadNextLevel.emit(e);
}));
this.subscriptions.push(this.treeService.nodeChecked$.subscribe((e) => {
this.nodeChecked.emit(e);
}));
this.subscriptions.push(this.treeService.nodeUnchecked$.subscribe((e) => {
this.nodeUnchecked.emit(e);
}));
}
getController() {
return this.rootComponent.controller;
}
getControllerByNodeId(id) {
return this.treeService.getController(id);
}
ngOnDestroy() {
this.subscriptions.forEach(sub => sub && sub.unsubscribe());
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TreeComponent, deps: [{ token: TreeService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TreeComponent, selector: "tree", inputs: { treeModel: ["tree", "treeModel"], settings: "settings" }, outputs: { nodeCreated: "nodeCreated", nodeRemoved: "nodeRemoved", nodeRenamed: "nodeRenamed", nodeSelected: "nodeSelected", nodeUnselected: "nodeUnselected", nodeMoved: "nodeMoved", nodeExpanded: "nodeExpanded", nodeCollapsed: "nodeCollapsed", loadNextLevel: "loadNextLevel", nodeChecked: "nodeChecked", nodeUnchecked: "nodeUnchecked", menuItemSelected: "menuItemSelected" }, providers: [TreeService], queries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true }], viewQueries: [{ propertyName: "rootComponent", first: true, predicate: ["rootComponent"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<tree-internal #rootComponent [tree]="tree" [settings]="settings" [template]="template"></tree-internal>`, isInline: true, dependencies: [{ kind: "component", type: i1.TreeInternalComponent, selector: "tree-internal", inputs: ["tree", "settings", "template"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TreeComponent, decorators: [{
type: Component,
args: [{
selector: 'tree',
template: `<tree-internal #rootComponent [tree]="tree" [settings]="settings" [template]="template"></tree-internal>`,
providers: [TreeService]
}]
}], ctorParameters: function () { return [{ type: i2.TreeService, decorators: [{
type: Inject,
args: [TreeService]
}] }]; }, propDecorators: { treeModel: [{
type: Input,
args: ['tree']
}], settings: [{
type: Input
}], nodeCreated: [{
type: Output
}], nodeRemoved: [{
type: Output
}], nodeRenamed: [{
type: Output
}], nodeSelected: [{
type: Output
}], nodeUnselected: [{
type: Output
}], nodeMoved: [{
type: Output
}], nodeExpanded: [{
type: Output
}], nodeCollapsed: [{
type: Output
}], loadNextLevel: [{
type: Output
}], nodeChecked: [{
type: Output
}], nodeUnchecked: [{
type: Output
}], menuItemSelected: [{
type: Output
}], rootComponent: [{
type: ViewChild,
args: ['rootComponent', { static: false }]
}], template: [{
type: ContentChild,
args: [TemplateRef, { static: false }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../src/tree.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { TreeService } from './tree.service';\nimport * as TreeTypes from './tree.types';\n\nimport { MenuItemSelectedEvent, NodeCheckedEvent, NodeEvent, NodeUncheckedEvent } from './tree.events';\n\nimport { Tree } from './tree';\nimport { TreeController } from './tree-controller';\nimport { Subscription } from 'rxjs';\n\n@Component({\n  selector: 'tree',\n  template: `<tree-internal #rootComponent [tree]=\"tree\" [settings]=\"settings\" [template]=\"template\"></tree-internal>`,\n  providers: [TreeService]\n})\nexport class TreeComponent implements OnInit, OnChanges, OnDestroy {\n  private static EMPTY_TREE: Tree = new Tree({ value: '' });\n\n  /* tslint:disable:no-input-rename */\n  @Input('tree') public treeModel: TreeTypes.TreeModel;\n  /* tslint:enable:no-input-rename */\n\n  @Input() public settings: TreeTypes.Ng2TreeSettings;\n\n  @Output() public nodeCreated: EventEmitter<any> = new EventEmitter();\n\n  @Output() public nodeRemoved: EventEmitter<any> = new EventEmitter();\n\n  @Output() public nodeRenamed: EventEmitter<any> = new EventEmitter();\n\n  @Output() public nodeSelected: EventEmitter<any> = new EventEmitter();\n\n  @Output() public nodeUnselected: EventEmitter<any> = new EventEmitter();\n\n  @Output() public nodeMoved: EventEmitter<any> = new EventEmitter();\n\n  @Output() public nodeExpanded: EventEmitter<any> = new EventEmitter();\n\n  @Output() public nodeCollapsed: EventEmitter<any> = new EventEmitter();\n\n  @Output() public loadNextLevel: EventEmitter<any> = new EventEmitter();\n\n  @Output() public nodeChecked: EventEmitter<NodeCheckedEvent> = new EventEmitter();\n\n  @Output() public nodeUnchecked: EventEmitter<NodeUncheckedEvent> = new EventEmitter();\n\n  @Output() public menuItemSelected: EventEmitter<any> = new EventEmitter();\n\n  public tree: Tree;\n\n  @ViewChild('rootComponent', { static: false })\n  public rootComponent;\n\n  @ContentChild(TemplateRef, { static: false })\n  public template;\n\n  private subscriptions: Subscription[] = [];\n\n  public constructor(@Inject(TreeService) private treeService: TreeService) {}\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (!this.treeModel) {\n      this.tree = TreeComponent.EMPTY_TREE;\n    } else {\n      this.tree = new Tree(this.treeModel);\n    }\n  }\n\n  public ngOnInit(): void {\n    this.subscriptions.push(\n      this.treeService.nodeRemoved$.subscribe((e: NodeEvent) => {\n        this.nodeRemoved.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.nodeRenamed$.subscribe((e: NodeEvent) => {\n        this.nodeRenamed.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.nodeCreated$.subscribe((e: NodeEvent) => {\n        this.nodeCreated.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.nodeSelected$.subscribe((e: NodeEvent) => {\n        this.nodeSelected.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.nodeUnselected$.subscribe((e: NodeEvent) => {\n        this.nodeUnselected.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.nodeMoved$.subscribe((e: NodeEvent) => {\n        this.nodeMoved.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.nodeExpanded$.subscribe((e: NodeEvent) => {\n        this.nodeExpanded.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.nodeCollapsed$.subscribe((e: NodeEvent) => {\n        this.nodeCollapsed.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.menuItemSelected$.subscribe((e: MenuItemSelectedEvent) => {\n        this.menuItemSelected.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.loadNextLevel$.subscribe((e: NodeEvent) => {\n        this.loadNextLevel.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.nodeChecked$.subscribe((e: NodeCheckedEvent) => {\n        this.nodeChecked.emit(e);\n      })\n    );\n\n    this.subscriptions.push(\n      this.treeService.nodeUnchecked$.subscribe((e: NodeUncheckedEvent) => {\n        this.nodeUnchecked.emit(e);\n      })\n    );\n  }\n\n  public getController(): TreeController {\n    return this.rootComponent.controller;\n  }\n\n  public getControllerByNodeId(id: number | string): TreeController {\n    return this.treeService.getController(id);\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(sub => sub && sub.unsubscribe());\n  }\n}\n"]}