1 | var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
2 | var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
3 | if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
4 | else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
5 | return c > 3 && r && Object.defineProperty(target, key, r), r;
|
6 | };
|
7 | var __metadata = (this && this.__metadata) || function (k, v) {
|
8 | if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
9 | };
|
10 | import { Component, ContentChild, EventEmitter, HostListener, Input, Output, TemplateRef, ViewChild } from '@angular/core';
|
11 | import { TreeModel } from '../models/tree.model';
|
12 | import { TreeDraggedElement } from '../models/tree-dragged-element.model';
|
13 | import { TreeOptions } from '../models/tree-options.model';
|
14 | import { TreeViewportComponent } from './tree-viewport.component';
|
15 | import includes from 'lodash/includes';
|
16 | import pick from 'lodash/pick';
|
17 | var TreeComponent = /** @class */ (function () {
|
18 | function TreeComponent(treeModel, treeDraggedElement) {
|
19 | var _this = this;
|
20 | this.treeModel = treeModel;
|
21 | this.treeDraggedElement = treeDraggedElement;
|
22 | treeModel.eventNames.forEach(function (name) { return _this[name] = new EventEmitter(); });
|
23 | treeModel.subscribeToState(function (state) { return _this.stateChange.emit(state); });
|
24 | }
|
25 | Object.defineProperty(TreeComponent.prototype, "nodes", {
|
26 | // Will be handled in ngOnChanges
|
27 | set: function (nodes) {
|
28 | },
|
29 | enumerable: true,
|
30 | configurable: true
|
31 | });
|
32 | ;
|
33 | Object.defineProperty(TreeComponent.prototype, "options", {
|
34 | set: function (options) {
|
35 | },
|
36 | enumerable: true,
|
37 | configurable: true
|
38 | });
|
39 | ;
|
40 | Object.defineProperty(TreeComponent.prototype, "focused", {
|
41 | set: function (value) {
|
42 | this.treeModel.setFocus(value);
|
43 | },
|
44 | enumerable: true,
|
45 | configurable: true
|
46 | });
|
47 | Object.defineProperty(TreeComponent.prototype, "state", {
|
48 | set: function (state) {
|
49 | this.treeModel.setState(state);
|
50 | },
|
51 | enumerable: true,
|
52 | configurable: true
|
53 | });
|
54 | TreeComponent.prototype.onKeydown = function ($event) {
|
55 | if (!this.treeModel.isFocused)
|
56 | return;
|
57 | if (includes(['input', 'textarea'], document.activeElement.tagName.toLowerCase()))
|
58 | return;
|
59 | var focusedNode = this.treeModel.getFocusedNode();
|
60 | this.treeModel.performKeyAction(focusedNode, $event);
|
61 | };
|
62 | TreeComponent.prototype.onMousedown = function ($event) {
|
63 | function isOutsideClick(startElement, nodeName) {
|
64 | return !startElement ? true : startElement.localName === nodeName ? false : isOutsideClick(startElement.parentElement, nodeName);
|
65 | }
|
66 | if (isOutsideClick($event.target, 'tree-root')) {
|
67 | this.treeModel.setFocus(false);
|
68 | }
|
69 | };
|
70 | TreeComponent.prototype.ngOnChanges = function (changes) {
|
71 | if (changes.options || changes.nodes) {
|
72 | this.treeModel.setData({
|
73 | options: changes.options && changes.options.currentValue,
|
74 | nodes: changes.nodes && changes.nodes.currentValue,
|
75 | events: pick(this, this.treeModel.eventNames)
|
76 | });
|
77 | }
|
78 | };
|
79 | TreeComponent.prototype.sizeChanged = function () {
|
80 | this.viewportComponent.setViewport();
|
81 | };
|
82 | __decorate([
|
83 | ContentChild('loadingTemplate', { static: false }),
|
84 | __metadata("design:type", TemplateRef)
|
85 | ], TreeComponent.prototype, "loadingTemplate", void 0);
|
86 | __decorate([
|
87 | ContentChild('treeNodeTemplate', { static: false }),
|
88 | __metadata("design:type", TemplateRef)
|
89 | ], TreeComponent.prototype, "treeNodeTemplate", void 0);
|
90 | __decorate([
|
91 | ContentChild('treeNodeWrapperTemplate', { static: false }),
|
92 | __metadata("design:type", TemplateRef)
|
93 | ], TreeComponent.prototype, "treeNodeWrapperTemplate", void 0);
|
94 | __decorate([
|
95 | ContentChild('treeNodeFullTemplate', { static: false }),
|
96 | __metadata("design:type", TemplateRef)
|
97 | ], TreeComponent.prototype, "treeNodeFullTemplate", void 0);
|
98 | __decorate([
|
99 | ViewChild('viewport', { static: false }),
|
100 | __metadata("design:type", TreeViewportComponent)
|
101 | ], TreeComponent.prototype, "viewportComponent", void 0);
|
102 | __decorate([
|
103 | Input(),
|
104 | __metadata("design:type", Array),
|
105 | __metadata("design:paramtypes", [Array])
|
106 | ], TreeComponent.prototype, "nodes", null);
|
107 | __decorate([
|
108 | Input(),
|
109 | __metadata("design:type", TreeOptions),
|
110 | __metadata("design:paramtypes", [TreeOptions])
|
111 | ], TreeComponent.prototype, "options", null);
|
112 | __decorate([
|
113 | Input(),
|
114 | __metadata("design:type", Boolean),
|
115 | __metadata("design:paramtypes", [Boolean])
|
116 | ], TreeComponent.prototype, "focused", null);
|
117 | __decorate([
|
118 | Input(),
|
119 | __metadata("design:type", Object),
|
120 | __metadata("design:paramtypes", [Object])
|
121 | ], TreeComponent.prototype, "state", null);
|
122 | __decorate([
|
123 | Output(),
|
124 | __metadata("design:type", Object)
|
125 | ], TreeComponent.prototype, "toggleExpanded", void 0);
|
126 | __decorate([
|
127 | Output(),
|
128 | __metadata("design:type", Object)
|
129 | ], TreeComponent.prototype, "activate", void 0);
|
130 | __decorate([
|
131 | Output(),
|
132 | __metadata("design:type", Object)
|
133 | ], TreeComponent.prototype, "deactivate", void 0);
|
134 | __decorate([
|
135 | Output(),
|
136 | __metadata("design:type", Object)
|
137 | ], TreeComponent.prototype, "nodeActivate", void 0);
|
138 | __decorate([
|
139 | Output(),
|
140 | __metadata("design:type", Object)
|
141 | ], TreeComponent.prototype, "nodeDeactivate", void 0);
|
142 | __decorate([
|
143 | Output(),
|
144 | __metadata("design:type", Object)
|
145 | ], TreeComponent.prototype, "select", void 0);
|
146 | __decorate([
|
147 | Output(),
|
148 | __metadata("design:type", Object)
|
149 | ], TreeComponent.prototype, "deselect", void 0);
|
150 | __decorate([
|
151 | Output(),
|
152 | __metadata("design:type", Object)
|
153 | ], TreeComponent.prototype, "focus", void 0);
|
154 | __decorate([
|
155 | Output(),
|
156 | __metadata("design:type", Object)
|
157 | ], TreeComponent.prototype, "blur", void 0);
|
158 | __decorate([
|
159 | Output(),
|
160 | __metadata("design:type", Object)
|
161 | ], TreeComponent.prototype, "updateData", void 0);
|
162 | __decorate([
|
163 | Output(),
|
164 | __metadata("design:type", Object)
|
165 | ], TreeComponent.prototype, "initialized", void 0);
|
166 | __decorate([
|
167 | Output(),
|
168 | __metadata("design:type", Object)
|
169 | ], TreeComponent.prototype, "moveNode", void 0);
|
170 | __decorate([
|
171 | Output(),
|
172 | __metadata("design:type", Object)
|
173 | ], TreeComponent.prototype, "copyNode", void 0);
|
174 | __decorate([
|
175 | Output(),
|
176 | __metadata("design:type", Object)
|
177 | ], TreeComponent.prototype, "loadNodeChildren", void 0);
|
178 | __decorate([
|
179 | Output(),
|
180 | __metadata("design:type", Object)
|
181 | ], TreeComponent.prototype, "changeFilter", void 0);
|
182 | __decorate([
|
183 | Output(),
|
184 | __metadata("design:type", Object)
|
185 | ], TreeComponent.prototype, "event", void 0);
|
186 | __decorate([
|
187 | Output(),
|
188 | __metadata("design:type", Object)
|
189 | ], TreeComponent.prototype, "stateChange", void 0);
|
190 | __decorate([
|
191 | HostListener('body: keydown', ['$event']),
|
192 | __metadata("design:type", Function),
|
193 | __metadata("design:paramtypes", [Object]),
|
194 | __metadata("design:returntype", void 0)
|
195 | ], TreeComponent.prototype, "onKeydown", null);
|
196 | __decorate([
|
197 | HostListener('body: mousedown', ['$event']),
|
198 | __metadata("design:type", Function),
|
199 | __metadata("design:paramtypes", [Object]),
|
200 | __metadata("design:returntype", void 0)
|
201 | ], TreeComponent.prototype, "onMousedown", null);
|
202 | TreeComponent = __decorate([
|
203 | Component({
|
204 | selector: 'Tree, tree-root',
|
205 | providers: [TreeModel],
|
206 | styles: [],
|
207 | template: "\n <tree-viewport #viewport>\n <div\n class=\"angular-tree-component\"\n [class.node-dragging]=\"treeDraggedElement.isDragging()\"\n [class.angular-tree-component-rtl]=\"treeModel.options.rtl\">\n <tree-node-collection\n *ngIf=\"treeModel.roots\"\n [nodes]=\"treeModel.roots\"\n [treeModel]=\"treeModel\"\n [templates]=\"{\n loadingTemplate: loadingTemplate,\n treeNodeTemplate: treeNodeTemplate,\n treeNodeWrapperTemplate: treeNodeWrapperTemplate,\n treeNodeFullTemplate: treeNodeFullTemplate\n }\">\n </tree-node-collection>\n <tree-node-drop-slot\n class=\"empty-tree-drop-slot\"\n *ngIf=\"treeModel.isEmptyTree()\"\n [dropIndex]=\"0\"\n [node]=\"treeModel.virtualRoot\">\n </tree-node-drop-slot>\n </div>\n </tree-viewport>\n "
|
208 | }),
|
209 | __metadata("design:paramtypes", [TreeModel,
|
210 | TreeDraggedElement])
|
211 | ], TreeComponent);
|
212 | return TreeComponent;
|
213 | }());
|
214 | export { TreeComponent };
|
215 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../lib/components/tree.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, EventEmitter, HostListener, Input, OnChanges, Output, TemplateRef, ViewChild } from '@angular/core';\nimport { TreeModel } from '../models/tree.model';\nimport { TreeDraggedElement } from '../models/tree-dragged-element.model';\nimport { TreeOptions } from '../models/tree-options.model';\nimport { TreeViewportComponent } from './tree-viewport.component';\n\nimport includes from 'lodash/includes';\nimport pick from 'lodash/pick';\n\n@Component({\n  selector: 'Tree, tree-root',\n  providers: [TreeModel],\n  styles: [],\n  template: `\n      <tree-viewport #viewport>\n          <div\n                  class=\"angular-tree-component\"\n                  [class.node-dragging]=\"treeDraggedElement.isDragging()\"\n                  [class.angular-tree-component-rtl]=\"treeModel.options.rtl\">\n              <tree-node-collection\n                      *ngIf=\"treeModel.roots\"\n                      [nodes]=\"treeModel.roots\"\n                      [treeModel]=\"treeModel\"\n                      [templates]=\"{\n            loadingTemplate: loadingTemplate,\n            treeNodeTemplate: treeNodeTemplate,\n            treeNodeWrapperTemplate: treeNodeWrapperTemplate,\n            treeNodeFullTemplate: treeNodeFullTemplate\n          }\">\n              </tree-node-collection>\n              <tree-node-drop-slot\n                      class=\"empty-tree-drop-slot\"\n                      *ngIf=\"treeModel.isEmptyTree()\"\n                      [dropIndex]=\"0\"\n                      [node]=\"treeModel.virtualRoot\">\n              </tree-node-drop-slot>\n          </div>\n      </tree-viewport>\n  `\n})\nexport class TreeComponent implements OnChanges {\n  _nodes: any[];\n  _options: TreeOptions;\n\n  @ContentChild('loadingTemplate', { static: false }) loadingTemplate: TemplateRef<any>;\n  @ContentChild('treeNodeTemplate', { static: false }) treeNodeTemplate: TemplateRef<any>;\n  @ContentChild('treeNodeWrapperTemplate', { static: false }) treeNodeWrapperTemplate: TemplateRef<any>;\n  @ContentChild('treeNodeFullTemplate', { static: false }) treeNodeFullTemplate: TemplateRef<any>;\n  @ViewChild('viewport', { static: false }) viewportComponent: TreeViewportComponent;\n\n  // Will be handled in ngOnChanges\n  @Input() set nodes(nodes: any[]) {\n  };\n\n  @Input() set options(options: TreeOptions) {\n  };\n\n  @Input() set focused(value: boolean) {\n    this.treeModel.setFocus(value);\n  }\n\n  @Input() set state(state) {\n    this.treeModel.setState(state);\n  }\n\n  @Output() toggleExpanded;\n  @Output() activate;\n  @Output() deactivate;\n  @Output() nodeActivate;\n  @Output() nodeDeactivate;\n  @Output() select;\n  @Output() deselect;\n  @Output() focus;\n  @Output() blur;\n  @Output() updateData;\n  @Output() initialized;\n  @Output() moveNode;\n  @Output() copyNode;\n  @Output() loadNodeChildren;\n  @Output() changeFilter;\n  @Output() event;\n  @Output() stateChange;\n\n  constructor(\n    public treeModel: TreeModel,\n    public treeDraggedElement: TreeDraggedElement) {\n\n    treeModel.eventNames.forEach((name) => this[name] = new EventEmitter());\n    treeModel.subscribeToState((state) => this.stateChange.emit(state));\n  }\n\n  @HostListener('body: keydown', ['$event'])\n  onKeydown($event) {\n    if (!this.treeModel.isFocused) return;\n    if (includes(['input', 'textarea'],\n      document.activeElement.tagName.toLowerCase())) return;\n\n    const focusedNode = this.treeModel.getFocusedNode();\n\n    this.treeModel.performKeyAction(focusedNode, $event);\n  }\n\n  @HostListener('body: mousedown', ['$event'])\n  onMousedown($event) {\n    function isOutsideClick(startElement: Element, nodeName: string) {\n      return !startElement ? true : startElement.localName === nodeName ? false : isOutsideClick(startElement.parentElement, nodeName);\n    }\n\n    if (isOutsideClick($event.target, 'tree-root')) {\n      this.treeModel.setFocus(false);\n    }\n  }\n\n  ngOnChanges(changes) {\n    if (changes.options || changes.nodes) {\n      this.treeModel.setData({\n        options: changes.options && changes.options.currentValue,\n        nodes: changes.nodes && changes.nodes.currentValue,\n        events: pick(this, this.treeModel.eventNames)\n      });\n    }\n  }\n\n  sizeChanged() {\n    this.viewportComponent.setViewport();\n  }\n}\n"]} |
\ | No newline at end of file |