UNPKG

20.2 kBJavaScriptView Raw
1var __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};
7var __metadata = (this && this.__metadata) || function (k, v) {
8 if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9};
10import { Component, ContentChild, EventEmitter, HostListener, Input, Output, TemplateRef, ViewChild } from '@angular/core';
11import { TreeModel } from '../models/tree.model';
12import { TreeDraggedElement } from '../models/tree-dragged-element.model';
13import { TreeOptions } from '../models/tree-options.model';
14import { TreeViewportComponent } from './tree-viewport.component';
15import includes from 'lodash/includes';
16import pick from 'lodash/pick';
17var 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}());
214export { TreeComponent };
215//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../lib/components/tree.component.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACtI,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAElE,OAAO,QAAQ,MAAM,iBAAiB,CAAC;AACvC,OAAO,IAAI,MAAM,aAAa,CAAC;AAiC/B;IA2CE,uBACS,SAAoB,EACpB,kBAAsC;QAF/C,iBAMC;QALQ,cAAS,GAAT,SAAS,CAAW;QACpB,uBAAkB,GAAlB,kBAAkB,CAAoB;QAE7C,SAAS,CAAC,UAAU,CAAC,OAAO,CAAC,UAAC,IAAI,IAAK,OAAA,KAAI,CAAC,IAAI,CAAC,GAAG,IAAI,YAAY,EAAE,EAA/B,CAA+B,CAAC,CAAC;QACxE,SAAS,CAAC,gBAAgB,CAAC,UAAC,KAAK,IAAK,OAAA,KAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,EAA5B,CAA4B,CAAC,CAAC;IACtE,CAAC;IAtCQ,sBAAI,gCAAK;QADlB,iCAAiC;aACxB,UAAU,KAAY;QAC/B,CAAC;;;OAAA;IAAA,CAAC;IAEO,sBAAI,kCAAO;aAAX,UAAY,OAAoB;QACzC,CAAC;;;OAAA;IAAA,CAAC;IAEO,sBAAI,kCAAO;aAAX,UAAY,KAAc;YACjC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;;;OAAA;IAEQ,sBAAI,gCAAK;aAAT,UAAU,KAAK;YACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;;;OAAA;IA6BD,iCAAS,GAAT,UAAU,MAAM;QACd,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS;YAAE,OAAO;QACtC,IAAI,QAAQ,CAAC,CAAC,OAAO,EAAE,UAAU,CAAC,EAChC,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;YAAE,OAAO;QAExD,IAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,CAAC;QAEpD,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;IACvD,CAAC;IAGD,mCAAW,GAAX,UAAY,MAAM;QAChB,SAAS,cAAc,CAAC,YAAqB,EAAE,QAAgB;YAC7D,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,cAAc,CAAC,YAAY,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;QACnI,CAAC;QAED,IAAI,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,EAAE;YAC9C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SAChC;IACH,CAAC;IAED,mCAAW,GAAX,UAAY,OAAO;QACjB,IAAI,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,KAAK,EAAE;YACpC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;gBACrB,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,YAAY;gBACxD,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,YAAY;gBAClD,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;aAC9C,CAAC,CAAC;SACJ;IACH,CAAC;IAED,mCAAW,GAAX;QACE,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;IACvC,CAAC;IAjFmD;QAAnD,YAAY,CAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;kCAAkB,WAAW;0DAAM;IACjC;QAApD,YAAY,CAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;kCAAmB,WAAW;2DAAM;IAC5B;QAA3D,YAAY,CAAC,yBAAyB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;kCAA0B,WAAW;kEAAM;IAC7C;QAAxD,YAAY,CAAC,sBAAsB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;kCAAuB,WAAW;+DAAM;IACtD;QAAzC,SAAS,CAAC,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;kCAAoB,qBAAqB;4DAAC;IAG1E;QAAR,KAAK,EAAE;;;8CACP;IAEQ;QAAR,KAAK,EAAE;kCAAsB,WAAW;yCAAX,WAAW;gDACxC;IAEQ;QAAR,KAAK,EAAE;;;gDAEP;IAEQ;QAAR,KAAK,EAAE;;;8CAEP;IAES;QAAT,MAAM,EAAE;;yDAAgB;IACf;QAAT,MAAM,EAAE;;mDAAU;IACT;QAAT,MAAM,EAAE;;qDAAY;IACX;QAAT,MAAM,EAAE;;uDAAc;IACb;QAAT,MAAM,EAAE;;yDAAgB;IACf;QAAT,MAAM,EAAE;;iDAAQ;IACP;QAAT,MAAM,EAAE;;mDAAU;IACT;QAAT,MAAM,EAAE;;gDAAO;IACN;QAAT,MAAM,EAAE;;+CAAM;IACL;QAAT,MAAM,EAAE;;qDAAY;IACX;QAAT,MAAM,EAAE;;sDAAa;IACZ;QAAT,MAAM,EAAE;;mDAAU;IACT;QAAT,MAAM,EAAE;;mDAAU;IACT;QAAT,MAAM,EAAE;;2DAAkB;IACjB;QAAT,MAAM,EAAE;;uDAAc;IACb;QAAT,MAAM,EAAE;;gDAAO;IACN;QAAT,MAAM,EAAE;;sDAAa;IAWtB;QADC,YAAY,CAAC,eAAe,EAAE,CAAC,QAAQ,CAAC,CAAC;;;;kDASzC;IAGD;QADC,YAAY,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,CAAC;;;;oDAS3C;IAvEU,aAAa;QA/BzB,SAAS,CAAC;YACT,QAAQ,EAAE,iBAAiB;YAC3B,SAAS,EAAE,CAAC,SAAS,CAAC;YACtB,MAAM,EAAE,EAAE;YACV,QAAQ,EAAE,6jCAyBT;SACF,CAAC;yCA6CoB,SAAS;YACA,kBAAkB;OA7CpC,aAAa,CAsFzB;IAAD,oBAAC;CAAA,AAtFD,IAsFC;SAtFY,aAAa","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