UNPKG

ng2-tree

Version:

angular2 component for visualizing data that can be naturally represented as a tree

121 lines 18.3 kB
import { LoadNextLevelEvent, MenuItemSelectedEvent, NodeCheckedEvent, NodeCollapsedEvent, NodeCreatedEvent, NodeExpandedEvent, NodeIndeterminedEvent, NodeMovedEvent, NodeRemovedEvent, NodeRenamedEvent, NodeSelectedEvent, NodeUncheckedEvent, NodeUnselectedEvent } from './tree.events'; import { Inject, Injectable } from '@angular/core'; import { NodeDraggableService } from './draggable/node-draggable.service'; import { isEmpty } from './utils/fn.utils'; import { Subject } from 'rxjs'; import { filter } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "./draggable/node-draggable.service"; export class TreeService { nodeDraggableService; nodeMoved$ = new Subject(); nodeRemoved$ = new Subject(); nodeRenamed$ = new Subject(); nodeCreated$ = new Subject(); nodeSelected$ = new Subject(); nodeUnselected$ = new Subject(); nodeExpanded$ = new Subject(); nodeCollapsed$ = new Subject(); menuItemSelected$ = new Subject(); loadNextLevel$ = new Subject(); nodeChecked$ = new Subject(); nodeUnchecked$ = new Subject(); nodeIndetermined$ = new Subject(); controllers = new Map(); constructor(nodeDraggableService) { this.nodeDraggableService = nodeDraggableService; this.nodeRemoved$.subscribe((e) => e.node.removeItselfFromParent()); } unselectStream(tree) { return this.nodeSelected$.pipe(filter((e) => tree !== e.node)); } fireNodeRemoved(tree) { this.nodeRemoved$.next(new NodeRemovedEvent(tree, tree.positionInParent)); } fireNodeCreated(tree) { this.nodeCreated$.next(new NodeCreatedEvent(tree)); } fireNodeSelected(tree) { this.nodeSelected$.next(new NodeSelectedEvent(tree)); } fireNodeUnselected(tree) { this.nodeUnselected$.next(new NodeUnselectedEvent(tree)); } fireNodeRenamed(oldValue, tree) { this.nodeRenamed$.next(new NodeRenamedEvent(tree, oldValue, tree.value)); } fireNodeMoved(tree, parent) { this.nodeMoved$.next(new NodeMovedEvent(tree, parent)); } fireMenuItemSelected(tree, selectedItem) { this.menuItemSelected$.next(new MenuItemSelectedEvent(tree, selectedItem)); } fireNodeSwitchFoldingType(tree) { if (tree.isNodeExpanded()) { this.fireNodeExpanded(tree); if (this.shouldFireLoadNextLevel(tree)) { this.fireLoadNextLevel(tree); } } else if (tree.isNodeCollapsed()) { this.fireNodeCollapsed(tree); } } fireNodeExpanded(tree) { this.nodeExpanded$.next(new NodeExpandedEvent(tree)); } fireNodeCollapsed(tree) { this.nodeCollapsed$.next(new NodeCollapsedEvent(tree)); } fireLoadNextLevel(tree) { this.loadNextLevel$.next(new LoadNextLevelEvent(tree)); } fireNodeChecked(tree) { this.nodeChecked$.next(new NodeCheckedEvent(tree)); } fireNodeUnchecked(tree) { this.nodeUnchecked$.next(new NodeUncheckedEvent(tree)); } draggedStream(tree, element) { return this.nodeDraggableService.draggableNodeEvents$.pipe(filter((e) => e.target === element), filter((e) => !e.captured.tree.hasChild(tree))); } setController(id, controller) { this.controllers.set(id, controller); } deleteController(id) { if (this.controllers.has(id)) { this.controllers.delete(id); } } getController(id) { if (this.controllers.has(id)) { return this.controllers.get(id); } return null; } hasController(id) { return this.controllers.has(id); } shouldFireLoadNextLevel(tree) { const shouldLoadNextLevel = tree.node.emitLoadNextLevel && !tree.node.loadChildren && !tree.childrenAreBeingLoaded() && isEmpty(tree.children); if (shouldLoadNextLevel) { tree.loadingChildrenRequested(); } return shouldLoadNextLevel; } fireNodeIndetermined(tree) { this.nodeIndetermined$.next(new NodeIndeterminedEvent(tree)); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TreeService, deps: [{ token: NodeDraggableService }], target: i0.ɵɵFactoryTarget.Injectable }); static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TreeService }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TreeService, decorators: [{ type: Injectable }], ctorParameters: function () { return [{ type: i1.NodeDraggableService, decorators: [{ type: Inject, args: [NodeDraggableService] }] }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.service.js","sourceRoot":"","sources":["../../../src/tree.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  LoadNextLevelEvent,\n  MenuItemSelectedEvent,\n  NodeCheckedEvent,\n  NodeCollapsedEvent,\n  NodeCreatedEvent,\n  NodeExpandedEvent,\n  NodeIndeterminedEvent,\n  NodeMovedEvent,\n  NodeRemovedEvent,\n  NodeRenamedEvent,\n  NodeSelectedEvent,\n  NodeUncheckedEvent,\n  NodeUnselectedEvent\n} from './tree.events';\nimport { RenamableNode } from './tree.types';\nimport { Tree } from './tree';\nimport { TreeController } from './tree-controller';\nimport { ElementRef, Inject, Injectable } from '@angular/core';\nimport { NodeDraggableService } from './draggable/node-draggable.service';\nimport { NodeDraggableEvent } from './draggable/draggable.events';\nimport { isEmpty } from './utils/fn.utils';\nimport { Observable, Subject } from 'rxjs';\nimport { filter } from 'rxjs/operators';\n\n@Injectable()\nexport class TreeService {\n  public nodeMoved$: Subject<NodeMovedEvent> = new Subject<NodeMovedEvent>();\n  public nodeRemoved$: Subject<NodeRemovedEvent> = new Subject<NodeRemovedEvent>();\n  public nodeRenamed$: Subject<NodeRenamedEvent> = new Subject<NodeRenamedEvent>();\n  public nodeCreated$: Subject<NodeCreatedEvent> = new Subject<NodeCreatedEvent>();\n  public nodeSelected$: Subject<NodeSelectedEvent> = new Subject<NodeSelectedEvent>();\n  public nodeUnselected$: Subject<NodeUnselectedEvent> = new Subject<NodeUnselectedEvent>();\n  public nodeExpanded$: Subject<NodeExpandedEvent> = new Subject<NodeExpandedEvent>();\n  public nodeCollapsed$: Subject<NodeCollapsedEvent> = new Subject<NodeCollapsedEvent>();\n  public menuItemSelected$: Subject<MenuItemSelectedEvent> = new Subject<MenuItemSelectedEvent>();\n  public loadNextLevel$: Subject<LoadNextLevelEvent> = new Subject<LoadNextLevelEvent>();\n  public nodeChecked$: Subject<NodeCheckedEvent> = new Subject<NodeCheckedEvent>();\n  public nodeUnchecked$: Subject<NodeUncheckedEvent> = new Subject<NodeUncheckedEvent>();\n  public nodeIndetermined$: Subject<NodeIndeterminedEvent> = new Subject<NodeIndeterminedEvent>();\n\n  private controllers: Map<string | number, TreeController> = new Map();\n\n  public constructor(@Inject(NodeDraggableService) private nodeDraggableService: NodeDraggableService) {\n    this.nodeRemoved$.subscribe((e: NodeRemovedEvent) => e.node.removeItselfFromParent());\n  }\n\n  public unselectStream(tree: Tree): Observable<NodeSelectedEvent> {\n    return this.nodeSelected$.pipe(filter((e: NodeSelectedEvent) => tree !== e.node));\n  }\n\n  public fireNodeRemoved(tree: Tree): void {\n    this.nodeRemoved$.next(new NodeRemovedEvent(tree, tree.positionInParent));\n  }\n\n  public fireNodeCreated(tree: Tree): void {\n    this.nodeCreated$.next(new NodeCreatedEvent(tree));\n  }\n\n  public fireNodeSelected(tree: Tree): void {\n    this.nodeSelected$.next(new NodeSelectedEvent(tree));\n  }\n\n  public fireNodeUnselected(tree: Tree): void {\n    this.nodeUnselected$.next(new NodeUnselectedEvent(tree));\n  }\n\n  public fireNodeRenamed(oldValue: RenamableNode | string, tree: Tree): void {\n    this.nodeRenamed$.next(new NodeRenamedEvent(tree, oldValue, tree.value));\n  }\n\n  public fireNodeMoved(tree: Tree, parent: Tree): void {\n    this.nodeMoved$.next(new NodeMovedEvent(tree, parent));\n  }\n\n  public fireMenuItemSelected(tree: Tree, selectedItem: string): void {\n    this.menuItemSelected$.next(new MenuItemSelectedEvent(tree, selectedItem));\n  }\n\n  public fireNodeSwitchFoldingType(tree: Tree): void {\n    if (tree.isNodeExpanded()) {\n      this.fireNodeExpanded(tree);\n      if (this.shouldFireLoadNextLevel(tree)) {\n        this.fireLoadNextLevel(tree);\n      }\n    } else if (tree.isNodeCollapsed()) {\n      this.fireNodeCollapsed(tree);\n    }\n  }\n\n  private fireNodeExpanded(tree: Tree): void {\n    this.nodeExpanded$.next(new NodeExpandedEvent(tree));\n  }\n\n  private fireNodeCollapsed(tree: Tree): void {\n    this.nodeCollapsed$.next(new NodeCollapsedEvent(tree));\n  }\n\n  private fireLoadNextLevel(tree: Tree): void {\n    this.loadNextLevel$.next(new LoadNextLevelEvent(tree));\n  }\n\n  public fireNodeChecked(tree: Tree): void {\n    this.nodeChecked$.next(new NodeCheckedEvent(tree));\n  }\n\n  public fireNodeUnchecked(tree: Tree): void {\n    this.nodeUnchecked$.next(new NodeUncheckedEvent(tree));\n  }\n\n  public draggedStream(tree: Tree, element: ElementRef): Observable<NodeDraggableEvent> {\n    return this.nodeDraggableService.draggableNodeEvents$.pipe(\n      filter((e: NodeDraggableEvent) => e.target === element),\n      filter((e: NodeDraggableEvent) => !e.captured.tree.hasChild(tree))\n    );\n  }\n\n  public setController(id: string | number, controller: TreeController): void {\n    this.controllers.set(id, controller);\n  }\n\n  public deleteController(id: string | number): void {\n    if (this.controllers.has(id)) {\n      this.controllers.delete(id);\n    }\n  }\n\n  public getController(id: string | number): TreeController {\n    if (this.controllers.has(id)) {\n      return this.controllers.get(id);\n    }\n\n    return null;\n  }\n\n  public hasController(id: string | number): boolean {\n    return this.controllers.has(id);\n  }\n\n  private shouldFireLoadNextLevel(tree: Tree): boolean {\n    const shouldLoadNextLevel =\n      tree.node.emitLoadNextLevel &&\n      !tree.node.loadChildren &&\n      !tree.childrenAreBeingLoaded() &&\n      isEmpty(tree.children);\n\n    if (shouldLoadNextLevel) {\n      tree.loadingChildrenRequested();\n    }\n\n    return shouldLoadNextLevel;\n  }\n\n  public fireNodeIndetermined(tree: Tree): void {\n    this.nodeIndetermined$.next(new NodeIndeterminedEvent(tree));\n  }\n}\n"]}