@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.
- package/dist/angular-tree-component/LICENSE +21 -0
- package/dist/angular-tree-component/README.md +66 -0
- package/dist/angular-tree-component/esm2020/lib/components/tree.component.mjs +196 -0
- package/{fesm2015 → dist/angular-tree-component/fesm2015}/huntsman-cancer-institute-angular-tree-component.mjs +13 -14
- package/dist/angular-tree-component/fesm2015/huntsman-cancer-institute-angular-tree-component.mjs.map +1 -0
- package/{fesm2020 → dist/angular-tree-component/fesm2020}/huntsman-cancer-institute-angular-tree-component.mjs +13 -14
- package/dist/angular-tree-component/fesm2020/huntsman-cancer-institute-angular-tree-component.mjs.map +1 -0
- package/{lib → dist/angular-tree-component/lib}/components/tree.component.d.ts +0 -1
- package/dist/angular-tree-component/package.json +56 -0
- package/package.json +136 -56
- package/esm2020/lib/components/tree.component.mjs +0 -197
- package/fesm2015/huntsman-cancer-institute-angular-tree-component.mjs.map +0 -1
- package/fesm2020/huntsman-cancer-institute-angular-tree-component.mjs.map +0 -1
- /package/{css → dist/angular-tree-component/css}/angular-tree-component.css +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/huntsman-cancer-institute-angular-tree-component.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/angular-tree-component.module.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/loading.component.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-checkbox.component.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-collection.component.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-content.component.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-drop-slot.component.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-expander.component.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-node-wrapper.component.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/components/tree-viewport.component.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/constants/events.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/constants/keys.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/defs/api.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/directives/tree-animate-open.directive.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/directives/tree-drag.directive.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/directives/tree-drop.directive.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/mobx-angular/tree-mobx-autorun.directive.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/models/tree-dragged-element.model.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/models/tree-node.model.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/models/tree-options.model.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/models/tree-virtual-scroll.model.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/lib/models/tree.model.mjs +0 -0
- /package/{esm2020 → dist/angular-tree-component/esm2020}/public-api.mjs +0 -0
- /package/{huntsman-cancer-institute-angular-tree-component.d.ts → dist/angular-tree-component/huntsman-cancer-institute-angular-tree-component.d.ts} +0 -0
- /package/{lib → dist/angular-tree-component/lib}/angular-tree-component.module.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/components/loading.component.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/components/tree-node-checkbox.component.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/components/tree-node-collection.component.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/components/tree-node-content.component.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/components/tree-node-drop-slot.component.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/components/tree-node-expander.component.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/components/tree-node-wrapper.component.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/components/tree-viewport.component.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/constants/events.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/constants/keys.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/defs/api.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/directives/tree-animate-open.directive.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/directives/tree-drag.directive.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/directives/tree-drop.directive.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/mobx-angular/tree-mobx-autorun.directive.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/models/tree-dragged-element.model.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/models/tree-node.model.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/models/tree-options.model.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/models/tree-virtual-scroll.model.d.ts +0 -0
- /package/{lib → dist/angular-tree-component/lib}/models/tree.model.d.ts +0 -0
- /package/{public-api.d.ts → dist/angular-tree-component/public-api.d.ts} +0 -0
- /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
|
+
[](https://badge.fury.io/js/%40circlon%2Fangular-tree-component)
|
|
2
|
+
[](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
|
-
|
|
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
|
-
|
|
2454
|
-
|
|
2455
|
-
|
|
2456
|
-
|
|
2457
|
-
|
|
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)"
|
|
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 {
|