@huntsman-cancer-institute/angular-tree-component 13.1.1 → 13.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/dist/angular-tree-component/LICENSE +21 -0
  2. package/dist/angular-tree-component/README.md +66 -0
  3. package/dist/angular-tree-component/esm2020/lib/components/tree.component.mjs +196 -0
  4. package/{fesm2015 → dist/angular-tree-component/fesm2015}/huntsman-cancer-institute-angular-tree-component.mjs +13 -14
  5. package/dist/angular-tree-component/fesm2015/huntsman-cancer-institute-angular-tree-component.mjs.map +1 -0
  6. package/{fesm2020 → dist/angular-tree-component/fesm2020}/huntsman-cancer-institute-angular-tree-component.mjs +13 -14
  7. package/dist/angular-tree-component/fesm2020/huntsman-cancer-institute-angular-tree-component.mjs.map +1 -0
  8. package/{lib → dist/angular-tree-component/lib}/components/tree.component.d.ts +0 -1
  9. package/dist/angular-tree-component/package.json +56 -0
  10. package/package.json +136 -56
  11. package/esm2020/lib/components/tree.component.mjs +0 -197
  12. package/fesm2015/huntsman-cancer-institute-angular-tree-component.mjs.map +0 -1
  13. package/fesm2020/huntsman-cancer-institute-angular-tree-component.mjs.map +0 -1
  14. /package/{css → dist/angular-tree-component/css}/angular-tree-component.css +0 -0
  15. /package/{esm2020 → dist/angular-tree-component/esm2020}/huntsman-cancer-institute-angular-tree-component.mjs +0 -0
  16. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/angular-tree-component.module.mjs +0 -0
  17. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/loading.component.mjs +0 -0
  18. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-checkbox.component.mjs +0 -0
  19. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-collection.component.mjs +0 -0
  20. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-content.component.mjs +0 -0
  21. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-drop-slot.component.mjs +0 -0
  22. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-expander.component.mjs +0 -0
  23. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-wrapper.component.mjs +0 -0
  24. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-viewport.component.mjs +0 -0
  25. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/constants/events.mjs +0 -0
  26. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/constants/keys.mjs +0 -0
  27. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/defs/api.mjs +0 -0
  28. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/directives/tree-animate-open.directive.mjs +0 -0
  29. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/directives/tree-drag.directive.mjs +0 -0
  30. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/directives/tree-drop.directive.mjs +0 -0
  31. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/mobx-angular/tree-mobx-autorun.directive.mjs +0 -0
  32. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/models/tree-dragged-element.model.mjs +0 -0
  33. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/models/tree-node.model.mjs +0 -0
  34. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/models/tree-options.model.mjs +0 -0
  35. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/models/tree-virtual-scroll.model.mjs +0 -0
  36. /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/models/tree.model.mjs +0 -0
  37. /package/{esm2020 → dist/angular-tree-component/esm2020}/public-api.mjs +0 -0
  38. /package/{huntsman-cancer-institute-angular-tree-component.d.ts → dist/angular-tree-component/huntsman-cancer-institute-angular-tree-component.d.ts} +0 -0
  39. /package/{lib → dist/angular-tree-component/lib}/angular-tree-component.module.d.ts +0 -0
  40. /package/{lib → dist/angular-tree-component/lib}/components/loading.component.d.ts +0 -0
  41. /package/{lib → dist/angular-tree-component/lib}/components/tree-node-checkbox.component.d.ts +0 -0
  42. /package/{lib → dist/angular-tree-component/lib}/components/tree-node-collection.component.d.ts +0 -0
  43. /package/{lib → dist/angular-tree-component/lib}/components/tree-node-content.component.d.ts +0 -0
  44. /package/{lib → dist/angular-tree-component/lib}/components/tree-node-drop-slot.component.d.ts +0 -0
  45. /package/{lib → dist/angular-tree-component/lib}/components/tree-node-expander.component.d.ts +0 -0
  46. /package/{lib → dist/angular-tree-component/lib}/components/tree-node-wrapper.component.d.ts +0 -0
  47. /package/{lib → dist/angular-tree-component/lib}/components/tree-viewport.component.d.ts +0 -0
  48. /package/{lib → dist/angular-tree-component/lib}/constants/events.d.ts +0 -0
  49. /package/{lib → dist/angular-tree-component/lib}/constants/keys.d.ts +0 -0
  50. /package/{lib → dist/angular-tree-component/lib}/defs/api.d.ts +0 -0
  51. /package/{lib → dist/angular-tree-component/lib}/directives/tree-animate-open.directive.d.ts +0 -0
  52. /package/{lib → dist/angular-tree-component/lib}/directives/tree-drag.directive.d.ts +0 -0
  53. /package/{lib → dist/angular-tree-component/lib}/directives/tree-drop.directive.d.ts +0 -0
  54. /package/{lib → dist/angular-tree-component/lib}/mobx-angular/tree-mobx-autorun.directive.d.ts +0 -0
  55. /package/{lib → dist/angular-tree-component/lib}/models/tree-dragged-element.model.d.ts +0 -0
  56. /package/{lib → dist/angular-tree-component/lib}/models/tree-node.model.d.ts +0 -0
  57. /package/{lib → dist/angular-tree-component/lib}/models/tree-options.model.d.ts +0 -0
  58. /package/{lib → dist/angular-tree-component/lib}/models/tree-virtual-scroll.model.d.ts +0 -0
  59. /package/{lib → dist/angular-tree-component/lib}/models/tree.model.d.ts +0 -0
  60. /package/{public-api.d.ts → dist/angular-tree-component/public-api.d.ts} +0 -0
  61. /package/{src → dist/angular-tree-component/src}/lib/angular-tree-component.css +0 -0
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2020 Circlon Group
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1,66 @@
1
+ [![npm version](https://badge.fury.io/js/%40circlon%2Fangular-tree-component.svg)](https://badge.fury.io/js/%40circlon%2Fangular-tree-component)
2
+ [![Build Status](https://dev.azure.com/pdsgmbh/AngularTree/_apis/build/status/AngularTreeComponent-CI?branchName=master)](https://dev.azure.com/pdsgmbh/AngularTree/_build/latest?definitionId=59&branchName=master)
3
+ <a href="https://angular-tree-component.herokuapp.com/"><img src="https://angular-tree-component.herokuapp.com/badge.svg" alt="slack" ></a>
4
+
5
+ # angular tree component
6
+
7
+ ## Getting started
8
+
9
+ Install `angular-tree-component`:
10
+
11
+ ```npm install @huntsman-cancer-institute/angular-tree-component```
12
+
13
+ Import `TreeModule`:
14
+
15
+ ```
16
+ import { TreeModule } from '@huntsman-cancer-institute/angular-tree-component';
17
+
18
+ @NgModule({
19
+ declarations: [AppComponent],
20
+ imports: [TreeModule],
21
+ bootstrap: [AppComponent]
22
+ })
23
+ export class AppModule {}
24
+ ```
25
+
26
+ Add css to `styles.scss` or include in `angular.json`:
27
+
28
+ ```
29
+ @import '~@huntsman-cancer-institute/angular-tree-component/css/angular-tree-component.css';
30
+ ```
31
+
32
+ ## Docs, Demos & More
33
+ We are redoing the documentation. You can find the new documentation here:
34
+ [https://circlongroup.github.io/angular-tree-component/](https://circlongroup.github.io/angular-tree-component/)
35
+
36
+ The API Reference is still in our old documentation for now:
37
+
38
+ [https://angular2-tree.readme.io/docs/](https://angular2-tree.readme.io/docs/)
39
+
40
+ ## Support
41
+ [Stackoverflow](https://stackoverflow.com/questions/tagged/angular-tree-component)
42
+
43
+ [Slack Community](https://angular-tree-component.herokuapp.com/)
44
+
45
+ ## Angular supported version
46
+
47
+ angular-tree-component supports angular 2 and above, and AoT compilation.
48
+
49
+ ## Contributing
50
+
51
+ Run `npm run build` (`npm run build:win` for windows users) to build. Run `npm start:example-app` and open [localhost:4200](http://localhost:4200) to test your code before submitting a pull request.
52
+
53
+ To run tests locally - make sure port 4200 is available and run:
54
+
55
+ ```
56
+ $ npm run build # build:win for windows; wait until build finished
57
+ $ npm run start:example-app # Wait until webpack finishes and http://localhost:4200 is available
58
+ $ npm run test:dev
59
+ ```
60
+
61
+ Please check the issues / project before starting to work on a feature / bug to make sure it's not already in progress.
62
+
63
+ ## Contributors
64
+
65
+ This project exists thanks to all the people who contribute.
66
+ <a href="https://github.com/CirclonGroup/angular-tree-component/graphs/contributors"><img src="https://opencollective.com/angular-tree-component/contributors.svg?width=890&button=false" /></a>
@@ -0,0 +1,196 @@
1
+ import { Component, ContentChild, EventEmitter, HostListener, HostBinding, Input, Output, TemplateRef, ViewChild } from '@angular/core';
2
+ import { TreeModel } from '../models/tree.model';
3
+ import { TreeDraggedElement } from '../models/tree-dragged-element.model';
4
+ import { TreeViewportComponent } from './tree-viewport.component';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../models/tree.model";
7
+ import * as i2 from "../models/tree-dragged-element.model";
8
+ import * as i3 from "./tree-viewport.component";
9
+ import * as i4 from "./tree-node-collection.component";
10
+ import * as i5 from "./tree-node-drop-slot.component";
11
+ import * as i6 from "@angular/common";
12
+ export class TreeComponent {
13
+ constructor(treeModel, treeDraggedElement) {
14
+ this.treeModel = treeModel;
15
+ this.treeDraggedElement = treeDraggedElement;
16
+ this.tabindex = '0';
17
+ treeModel.eventNames.forEach((name) => this[name] = new EventEmitter());
18
+ treeModel.subscribeToState((state) => this.stateChange.emit(state));
19
+ }
20
+ // Will be handled in ngOnChanges
21
+ set nodes(nodes) {
22
+ }
23
+ ;
24
+ set options(options) {
25
+ }
26
+ ;
27
+ set focused(value) {
28
+ this.treeModel.setFocus(value);
29
+ }
30
+ set state(state) {
31
+ this.treeModel.setState(state);
32
+ }
33
+ onKeydown($event) {
34
+ //if (!this.treeModel.isFocused) return;
35
+ if (['input', 'textarea', 'button'].includes(document.activeElement.tagName.toLowerCase()))
36
+ return;
37
+ const focusedNode = this.treeModel.getFocusedNode();
38
+ this.treeModel.performKeyAction(focusedNode, $event);
39
+ }
40
+ /*
41
+ @HostListener('body: mousedown', ['$event'])
42
+ onMousedown($event) {
43
+ function isOutsideClick(startElement: Element, nodeName: string) {
44
+ return !startElement ? true : startElement.localName === nodeName ? false : isOutsideClick(startElement.parentElement, nodeName);
45
+ }
46
+
47
+ if (isOutsideClick($event.target, 'tree-root')) {
48
+ this.treeModel.setFocus(false);
49
+ }
50
+ }*/
51
+ ngOnChanges(changes) {
52
+ if (changes.options || changes.nodes) {
53
+ this.treeModel.setData({
54
+ options: changes.options && changes.options.currentValue,
55
+ nodes: changes.nodes && changes.nodes.currentValue,
56
+ events: this.pick(this, this.treeModel.eventNames)
57
+ });
58
+ }
59
+ }
60
+ sizeChanged() {
61
+ this.viewportComponent.setViewport();
62
+ }
63
+ pick(object, keys) {
64
+ return keys.reduce((obj, key) => {
65
+ if (object && object.hasOwnProperty(key)) {
66
+ obj[key] = object[key];
67
+ }
68
+ return obj;
69
+ }, {});
70
+ }
71
+ }
72
+ /** @nocollapse */ TreeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: TreeComponent, deps: [{ token: i1.TreeModel }, { token: i2.TreeDraggedElement }], target: i0.ɵɵFactoryTarget.Component });
73
+ /** @nocollapse */ TreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: TreeComponent, selector: "Tree, tree-root", inputs: { nodes: "nodes", options: "options", focused: "focused", state: "state" }, outputs: { toggleExpanded: "toggleExpanded", activate: "activate", deactivate: "deactivate", nodeActivate: "nodeActivate", nodeDeactivate: "nodeDeactivate", select: "select", deselect: "deselect", focus: "focus", blur: "blur", updateData: "updateData", initialized: "initialized", moveNode: "moveNode", copyNode: "copyNode", loadNodeChildren: "loadNodeChildren", changeFilter: "changeFilter", event: "event", stateChange: "stateChange" }, host: { listeners: { "keydown": "onKeydown($event)" }, properties: { "attr.tabindex": "this.tabindex" } }, providers: [TreeModel], queries: [{ propertyName: "loadingTemplate", first: true, predicate: ["loadingTemplate"], descendants: true }, { propertyName: "treeNodeTemplate", first: true, predicate: ["treeNodeTemplate"], descendants: true }, { propertyName: "treeNodeWrapperTemplate", first: true, predicate: ["treeNodeWrapperTemplate"], descendants: true }, { propertyName: "treeNodeFullTemplate", first: true, predicate: ["treeNodeFullTemplate"], descendants: true }], viewQueries: [{ propertyName: "viewportComponent", first: true, predicate: ["viewport"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
74
+ <tree-viewport #viewport>
75
+ <div
76
+ class="angular-tree-component"
77
+ [class.node-dragging]="treeDraggedElement.isDragging()"
78
+ [class.angular-tree-component-rtl]="treeModel.options.rtl">
79
+ <tree-node-collection
80
+ *ngIf="treeModel.roots"
81
+ [nodes]="treeModel.roots"
82
+ [treeModel]="treeModel"
83
+ [templates]="{
84
+ loadingTemplate: loadingTemplate,
85
+ treeNodeTemplate: treeNodeTemplate,
86
+ treeNodeWrapperTemplate: treeNodeWrapperTemplate,
87
+ treeNodeFullTemplate: treeNodeFullTemplate
88
+ }">
89
+ </tree-node-collection>
90
+ <tree-node-drop-slot
91
+ class="empty-tree-drop-slot"
92
+ *ngIf="treeModel.isEmptyTree()"
93
+ [dropIndex]="0"
94
+ [node]="treeModel.virtualRoot">
95
+ </tree-node-drop-slot>
96
+ </div>
97
+ </tree-viewport>
98
+ `, isInline: true, components: [{ type: i3.TreeViewportComponent, selector: "tree-viewport" }, { type: i4.TreeNodeCollectionComponent, selector: "tree-node-collection", inputs: ["nodes", "treeModel", "templates"] }, { type: i5.TreeNodeDropSlotComponent, selector: "TreeNodeDropSlot, tree-node-drop-slot", inputs: ["node", "dropIndex"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
99
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: TreeComponent, decorators: [{
100
+ type: Component,
101
+ args: [{
102
+ selector: 'Tree, tree-root',
103
+ providers: [TreeModel],
104
+ styles: [],
105
+ template: `
106
+ <tree-viewport #viewport>
107
+ <div
108
+ class="angular-tree-component"
109
+ [class.node-dragging]="treeDraggedElement.isDragging()"
110
+ [class.angular-tree-component-rtl]="treeModel.options.rtl">
111
+ <tree-node-collection
112
+ *ngIf="treeModel.roots"
113
+ [nodes]="treeModel.roots"
114
+ [treeModel]="treeModel"
115
+ [templates]="{
116
+ loadingTemplate: loadingTemplate,
117
+ treeNodeTemplate: treeNodeTemplate,
118
+ treeNodeWrapperTemplate: treeNodeWrapperTemplate,
119
+ treeNodeFullTemplate: treeNodeFullTemplate
120
+ }">
121
+ </tree-node-collection>
122
+ <tree-node-drop-slot
123
+ class="empty-tree-drop-slot"
124
+ *ngIf="treeModel.isEmptyTree()"
125
+ [dropIndex]="0"
126
+ [node]="treeModel.virtualRoot">
127
+ </tree-node-drop-slot>
128
+ </div>
129
+ </tree-viewport>
130
+ `
131
+ }]
132
+ }], ctorParameters: function () { return [{ type: i1.TreeModel }, { type: i2.TreeDraggedElement }]; }, propDecorators: { loadingTemplate: [{
133
+ type: ContentChild,
134
+ args: ['loadingTemplate', { static: false }]
135
+ }], treeNodeTemplate: [{
136
+ type: ContentChild,
137
+ args: ['treeNodeTemplate', { static: false }]
138
+ }], treeNodeWrapperTemplate: [{
139
+ type: ContentChild,
140
+ args: ['treeNodeWrapperTemplate', { static: false }]
141
+ }], treeNodeFullTemplate: [{
142
+ type: ContentChild,
143
+ args: ['treeNodeFullTemplate', { static: false }]
144
+ }], viewportComponent: [{
145
+ type: ViewChild,
146
+ args: ['viewport', { static: false }]
147
+ }], nodes: [{
148
+ type: Input
149
+ }], options: [{
150
+ type: Input
151
+ }], focused: [{
152
+ type: Input
153
+ }], state: [{
154
+ type: Input
155
+ }], toggleExpanded: [{
156
+ type: Output
157
+ }], activate: [{
158
+ type: Output
159
+ }], deactivate: [{
160
+ type: Output
161
+ }], nodeActivate: [{
162
+ type: Output
163
+ }], nodeDeactivate: [{
164
+ type: Output
165
+ }], select: [{
166
+ type: Output
167
+ }], deselect: [{
168
+ type: Output
169
+ }], focus: [{
170
+ type: Output
171
+ }], blur: [{
172
+ type: Output
173
+ }], updateData: [{
174
+ type: Output
175
+ }], initialized: [{
176
+ type: Output
177
+ }], moveNode: [{
178
+ type: Output
179
+ }], copyNode: [{
180
+ type: Output
181
+ }], loadNodeChildren: [{
182
+ type: Output
183
+ }], changeFilter: [{
184
+ type: Output
185
+ }], event: [{
186
+ type: Output
187
+ }], stateChange: [{
188
+ type: Output
189
+ }], tabindex: [{
190
+ type: HostBinding,
191
+ args: ['attr.tabindex']
192
+ }], onKeydown: [{
193
+ type: HostListener,
194
+ args: ['keydown', ['$event']]
195
+ }] } });
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../../projects/angular-tree-component/src/lib/components/tree.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, EventEmitter, HostListener, HostBinding, Input, OnChanges, Output, TemplateRef, ViewChild } from '@angular/core';\r\nimport { TreeModel } from '../models/tree.model';\r\nimport { TreeDraggedElement } from '../models/tree-dragged-element.model';\r\nimport { TreeOptions } from '../models/tree-options.model';\r\nimport { ITreeOptions } from '../defs/api';\r\nimport { TreeViewportComponent } from './tree-viewport.component';\r\n\r\n@Component({\r\n  selector: 'Tree, tree-root',\r\n  providers: [TreeModel],\r\n  styles: [],\r\n  template: `\r\n      <tree-viewport #viewport>\r\n          <div\r\n                  class=\"angular-tree-component\"\r\n                  [class.node-dragging]=\"treeDraggedElement.isDragging()\"\r\n                  [class.angular-tree-component-rtl]=\"treeModel.options.rtl\">\r\n              <tree-node-collection\r\n                      *ngIf=\"treeModel.roots\"\r\n                      [nodes]=\"treeModel.roots\"\r\n                      [treeModel]=\"treeModel\"\r\n                      [templates]=\"{\r\n            loadingTemplate: loadingTemplate,\r\n            treeNodeTemplate: treeNodeTemplate,\r\n            treeNodeWrapperTemplate: treeNodeWrapperTemplate,\r\n            treeNodeFullTemplate: treeNodeFullTemplate\r\n          }\">\r\n              </tree-node-collection>\r\n              <tree-node-drop-slot\r\n                      class=\"empty-tree-drop-slot\"\r\n                      *ngIf=\"treeModel.isEmptyTree()\"\r\n                      [dropIndex]=\"0\"\r\n                      [node]=\"treeModel.virtualRoot\">\r\n              </tree-node-drop-slot>\r\n          </div>\r\n      </tree-viewport>\r\n  `\r\n})\r\nexport class TreeComponent implements OnChanges {\r\n  _nodes: any[];\r\n  _options: TreeOptions;\r\n\r\n  @ContentChild('loadingTemplate', { static: false }) loadingTemplate: TemplateRef<any>;\r\n  @ContentChild('treeNodeTemplate', { static: false }) treeNodeTemplate: TemplateRef<any>;\r\n  @ContentChild('treeNodeWrapperTemplate', { static: false }) treeNodeWrapperTemplate: TemplateRef<any>;\r\n  @ContentChild('treeNodeFullTemplate', { static: false }) treeNodeFullTemplate: TemplateRef<any>;\r\n  @ViewChild('viewport', { static: false }) viewportComponent: TreeViewportComponent;\r\n\r\n  // Will be handled in ngOnChanges\r\n  @Input() set nodes(nodes: any[]) {\r\n  };\r\n\r\n  @Input() set options(options: ITreeOptions) {\r\n  };\r\n\r\n  @Input() set focused(value: boolean) {\r\n    this.treeModel.setFocus(value);\r\n  }\r\n\r\n  @Input() set state(state) {\r\n    this.treeModel.setState(state);\r\n  }\r\n\r\n  @Output() toggleExpanded;\r\n  @Output() activate;\r\n  @Output() deactivate;\r\n  @Output() nodeActivate;\r\n  @Output() nodeDeactivate;\r\n  @Output() select;\r\n  @Output() deselect;\r\n  @Output() focus;\r\n  @Output() blur;\r\n  @Output() updateData;\r\n  @Output() initialized;\r\n  @Output() moveNode;\r\n  @Output() copyNode;\r\n  @Output() loadNodeChildren;\r\n  @Output() changeFilter;\r\n  @Output() event;\r\n  @Output() stateChange;\r\n\r\n  constructor(\r\n    public treeModel: TreeModel,\r\n    public treeDraggedElement: TreeDraggedElement) {\r\n\r\n    treeModel.eventNames.forEach((name) => this[name] = new EventEmitter());\r\n    treeModel.subscribeToState((state) => this.stateChange.emit(state));\r\n  }\r\n\r\n  @HostBinding('attr.tabindex') tabindex = '0';\r\n  @HostListener('keydown', ['$event']) //Just listen within component, not to the entire body!\r\n  onKeydown($event) {\r\n    //if (!this.treeModel.isFocused) return;\r\n    if (['input', 'textarea','button'].includes(document.activeElement.tagName.toLowerCase())) return;\r\n\r\n    const focusedNode = this.treeModel.getFocusedNode();\r\n\r\n    this.treeModel.performKeyAction(focusedNode, $event);\r\n  }\r\n\r\n  /*\r\n  @HostListener('body: mousedown', ['$event'])\r\n  onMousedown($event) {\r\n    function isOutsideClick(startElement: Element, nodeName: string) {\r\n      return !startElement ? true : startElement.localName === nodeName ? false : isOutsideClick(startElement.parentElement, nodeName);\r\n    }\r\n\r\n    if (isOutsideClick($event.target, 'tree-root')) {\r\n      this.treeModel.setFocus(false);\r\n    }\r\n  }*/\r\n\r\n  ngOnChanges(changes) {\r\n    if (changes.options || changes.nodes) {\r\n      this.treeModel.setData({\r\n        options: changes.options && changes.options.currentValue,\r\n        nodes: changes.nodes && changes.nodes.currentValue,\r\n        events: this.pick(this, this.treeModel.eventNames)\r\n      });\r\n    }\r\n  }\r\n\r\n  sizeChanged() {\r\n    this.viewportComponent.setViewport();\r\n  }\r\n\r\n  private pick(object, keys) {\r\n    return keys.reduce((obj, key) => {\r\n      if (object && object.hasOwnProperty(key)) {\r\n        obj[key] = object[key];\r\n      }\r\n      return obj;\r\n    }, {});\r\n  }\r\n}\r\n"]}
@@ -2442,21 +2442,23 @@ class TreeComponent {
2442
2442
  this.treeModel.setState(state);
2443
2443
  }
2444
2444
  onKeydown($event) {
2445
- if (!this.treeModel.isFocused)
2446
- return;
2447
- if (['input', 'textarea'].includes(document.activeElement.tagName.toLowerCase()))
2445
+ //if (!this.treeModel.isFocused) return;
2446
+ if (['input', 'textarea', 'button'].includes(document.activeElement.tagName.toLowerCase()))
2448
2447
  return;
2449
2448
  const focusedNode = this.treeModel.getFocusedNode();
2450
2449
  this.treeModel.performKeyAction(focusedNode, $event);
2451
2450
  }
2451
+ /*
2452
+ @HostListener('body: mousedown', ['$event'])
2452
2453
  onMousedown($event) {
2453
- function isOutsideClick(startElement, nodeName) {
2454
- return !startElement ? true : startElement.localName === nodeName ? false : isOutsideClick(startElement.parentElement, nodeName);
2455
- }
2456
- if (isOutsideClick($event.target, 'tree-root')) {
2457
- this.treeModel.setFocus(false);
2458
- }
2459
- }
2454
+ function isOutsideClick(startElement: Element, nodeName: string) {
2455
+ return !startElement ? true : startElement.localName === nodeName ? false : isOutsideClick(startElement.parentElement, nodeName);
2456
+ }
2457
+
2458
+ if (isOutsideClick($event.target, 'tree-root')) {
2459
+ this.treeModel.setFocus(false);
2460
+ }
2461
+ }*/
2460
2462
  ngOnChanges(changes) {
2461
2463
  if (changes.options || changes.nodes) {
2462
2464
  this.treeModel.setData({
@@ -2479,7 +2481,7 @@ class TreeComponent {
2479
2481
  }
2480
2482
  }
2481
2483
  /** @nocollapse */ TreeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: TreeComponent, deps: [{ token: TreeModel }, { token: TreeDraggedElement }], target: i0.ɵɵFactoryTarget.Component });
2482
- /** @nocollapse */ TreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: TreeComponent, selector: "Tree, tree-root", inputs: { nodes: "nodes", options: "options", focused: "focused", state: "state" }, outputs: { toggleExpanded: "toggleExpanded", activate: "activate", deactivate: "deactivate", nodeActivate: "nodeActivate", nodeDeactivate: "nodeDeactivate", select: "select", deselect: "deselect", focus: "focus", blur: "blur", updateData: "updateData", initialized: "initialized", moveNode: "moveNode", copyNode: "copyNode", loadNodeChildren: "loadNodeChildren", changeFilter: "changeFilter", event: "event", stateChange: "stateChange" }, host: { listeners: { "keydown": "onKeydown($event)", "body: mousedown": "onMousedown($event)" }, properties: { "attr.tabindex": "this.tabindex" } }, providers: [TreeModel], queries: [{ propertyName: "loadingTemplate", first: true, predicate: ["loadingTemplate"], descendants: true }, { propertyName: "treeNodeTemplate", first: true, predicate: ["treeNodeTemplate"], descendants: true }, { propertyName: "treeNodeWrapperTemplate", first: true, predicate: ["treeNodeWrapperTemplate"], descendants: true }, { propertyName: "treeNodeFullTemplate", first: true, predicate: ["treeNodeFullTemplate"], descendants: true }], viewQueries: [{ propertyName: "viewportComponent", first: true, predicate: ["viewport"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
2484
+ /** @nocollapse */ TreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: TreeComponent, selector: "Tree, tree-root", inputs: { nodes: "nodes", options: "options", focused: "focused", state: "state" }, outputs: { toggleExpanded: "toggleExpanded", activate: "activate", deactivate: "deactivate", nodeActivate: "nodeActivate", nodeDeactivate: "nodeDeactivate", select: "select", deselect: "deselect", focus: "focus", blur: "blur", updateData: "updateData", initialized: "initialized", moveNode: "moveNode", copyNode: "copyNode", loadNodeChildren: "loadNodeChildren", changeFilter: "changeFilter", event: "event", stateChange: "stateChange" }, host: { listeners: { "keydown": "onKeydown($event)" }, properties: { "attr.tabindex": "this.tabindex" } }, providers: [TreeModel], queries: [{ propertyName: "loadingTemplate", first: true, predicate: ["loadingTemplate"], descendants: true }, { propertyName: "treeNodeTemplate", first: true, predicate: ["treeNodeTemplate"], descendants: true }, { propertyName: "treeNodeWrapperTemplate", first: true, predicate: ["treeNodeWrapperTemplate"], descendants: true }, { propertyName: "treeNodeFullTemplate", first: true, predicate: ["treeNodeFullTemplate"], descendants: true }], viewQueries: [{ propertyName: "viewportComponent", first: true, predicate: ["viewport"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
2483
2485
  <tree-viewport #viewport>
2484
2486
  <div
2485
2487
  class="angular-tree-component"
@@ -2601,9 +2603,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
2601
2603
  }], onKeydown: [{
2602
2604
  type: HostListener,
2603
2605
  args: ['keydown', ['$event']]
2604
- }], onMousedown: [{
2605
- type: HostListener,
2606
- args: ['body: mousedown', ['$event']]
2607
2606
  }] } });
2608
2607
 
2609
2608
  class TreeModule {