@ali-hm/angular-tree-component 12.0.1
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/LICENSE +21 -0
- package/README.md +39 -0
- package/css/angular-tree-component.css +84 -0
- package/esm2020/ali-hm-angular-tree-component.mjs +5 -0
- package/esm2020/lib/angular-tree-component.module.mjs +100 -0
- package/esm2020/lib/components/loading.component.mjs +32 -0
- package/esm2020/lib/components/tree-node-checkbox.component.mjs +34 -0
- package/esm2020/lib/components/tree-node-collection.component.mjs +284 -0
- package/esm2020/lib/components/tree-node-content.component.mjs +32 -0
- package/esm2020/lib/components/tree-node-drop-slot.component.mjs +39 -0
- package/esm2020/lib/components/tree-node-expander.component.mjs +43 -0
- package/esm2020/lib/components/tree-node-wrapper.component.mjs +81 -0
- package/esm2020/lib/components/tree-viewport.component.mjs +66 -0
- package/esm2020/lib/components/tree.component.mjs +186 -0
- package/esm2020/lib/constants/events.mjs +20 -0
- package/esm2020/lib/constants/keys.mjs +10 -0
- package/esm2020/lib/defs/api.mjs +2 -0
- package/esm2020/lib/directives/tree-animate-open.directive.mjs +101 -0
- package/esm2020/lib/directives/tree-drag.directive.mjs +65 -0
- package/esm2020/lib/directives/tree-drop.directive.mjs +127 -0
- package/esm2020/lib/mobx-angular/mobx-proxy.mjs +17 -0
- package/esm2020/lib/mobx-angular/tree-mobx-autorun.directive.mjs +40 -0
- package/esm2020/lib/models/tree-dragged-element.model.mjs +25 -0
- package/esm2020/lib/models/tree-node.model.mjs +390 -0
- package/esm2020/lib/models/tree-options.model.mjs +150 -0
- package/esm2020/lib/models/tree-virtual-scroll.model.mjs +197 -0
- package/esm2020/lib/models/tree.model.mjs +546 -0
- package/esm2020/public-api.mjs +5 -0
- package/fesm2015/ali-hm-angular-tree-component.mjs +2511 -0
- package/fesm2015/ali-hm-angular-tree-component.mjs.map +1 -0
- package/fesm2020/ali-hm-angular-tree-component.mjs +2497 -0
- package/fesm2020/ali-hm-angular-tree-component.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/angular-tree-component.module.d.ts +43 -0
- package/lib/components/loading.component.d.ts +9 -0
- package/lib/components/tree-node-checkbox.component.d.ts +7 -0
- package/lib/components/tree-node-collection.component.d.ts +34 -0
- package/lib/components/tree-node-content.component.d.ts +10 -0
- package/lib/components/tree-node-drop-slot.component.d.ts +10 -0
- package/lib/components/tree-node-expander.component.d.ts +7 -0
- package/lib/components/tree-node-wrapper.component.d.ts +9 -0
- package/lib/components/tree-viewport.component.d.ts +17 -0
- package/lib/components/tree.component.d.ts +47 -0
- package/lib/constants/events.d.ts +19 -0
- package/lib/constants/keys.d.ts +9 -0
- package/lib/defs/api.d.ts +611 -0
- package/lib/directives/tree-animate-open.directive.d.ts +20 -0
- package/lib/directives/tree-drag.directive.d.ts +21 -0
- package/lib/directives/tree-drop.directive.d.ts +33 -0
- package/lib/mobx-angular/mobx-proxy.d.ts +7 -0
- package/lib/mobx-angular/tree-mobx-autorun.directive.d.ts +17 -0
- package/lib/models/tree-dragged-element.model.d.ts +9 -0
- package/lib/models/tree-node.model.d.ts +83 -0
- package/lib/models/tree-options.model.d.ts +77 -0
- package/lib/models/tree-virtual-scroll.model.d.ts +27 -0
- package/lib/models/tree.model.d.ts +91 -0
- package/package.json +66 -0
- package/public-api.d.ts +1 -0
- package/src/lib/angular-tree-component.css +84 -0
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Component, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class TreeNodeContent {
|
|
5
|
+
}
|
|
6
|
+
/** @nocollapse */ TreeNodeContent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeNodeContent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
7
|
+
/** @nocollapse */ TreeNodeContent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TreeNodeContent, selector: "tree-node-content", inputs: { node: "node", index: "index", template: "template" }, ngImport: i0, template: `
|
|
8
|
+
<span *ngIf="!template">{{ node.displayField }}</span>
|
|
9
|
+
<ng-container
|
|
10
|
+
[ngTemplateOutlet]="template"
|
|
11
|
+
[ngTemplateOutletContext]="{ $implicit: node, node: node, index: index }">
|
|
12
|
+
</ng-container>`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeNodeContent, decorators: [{
|
|
14
|
+
type: Component,
|
|
15
|
+
args: [{
|
|
16
|
+
selector: 'tree-node-content',
|
|
17
|
+
encapsulation: ViewEncapsulation.None,
|
|
18
|
+
template: `
|
|
19
|
+
<span *ngIf="!template">{{ node.displayField }}</span>
|
|
20
|
+
<ng-container
|
|
21
|
+
[ngTemplateOutlet]="template"
|
|
22
|
+
[ngTemplateOutletContext]="{ $implicit: node, node: node, index: index }">
|
|
23
|
+
</ng-container>`,
|
|
24
|
+
}]
|
|
25
|
+
}], propDecorators: { node: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}], index: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}], template: [{
|
|
30
|
+
type: Input
|
|
31
|
+
}] } });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1ub2RlLWNvbnRlbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci10cmVlLWNvbXBvbmVudC9zcmMvbGliL2NvbXBvbmVudHMvdHJlZS1ub2RlLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFlLE1BQU0sZUFBZSxDQUFDOzs7QUFhakYsTUFBTSxPQUFPLGVBQWU7OytIQUFmLGVBQWU7bUhBQWYsZUFBZSx5SEFQaEI7Ozs7O2tCQUtNOzJGQUVMLGVBQWU7a0JBVjNCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7b0JBQ3JDLFFBQVEsRUFBRTs7Ozs7a0JBS007aUJBQ2pCOzhCQUVVLElBQUk7c0JBQVosS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uLCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUcmVlTm9kZSB9IGZyb20gJy4uL21vZGVscy90cmVlLW5vZGUubW9kZWwnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd0cmVlLW5vZGUtY29udGVudCcsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICB0ZW1wbGF0ZTogYFxyXG4gIDxzcGFuICpuZ0lmPVwiIXRlbXBsYXRlXCI+e3sgbm9kZS5kaXNwbGF5RmllbGQgfX08L3NwYW4+XHJcbiAgPG5nLWNvbnRhaW5lclxyXG4gICAgW25nVGVtcGxhdGVPdXRsZXRdPVwidGVtcGxhdGVcIlxyXG4gICAgW25nVGVtcGxhdGVPdXRsZXRDb250ZXh0XT1cInsgJGltcGxpY2l0OiBub2RlLCBub2RlOiBub2RlLCBpbmRleDogaW5kZXggfVwiPlxyXG4gIDwvbmctY29udGFpbmVyPmAsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUcmVlTm9kZUNvbnRlbnQge1xyXG4gIEBJbnB1dCgpIG5vZGU6IFRyZWVOb2RlO1xyXG4gIEBJbnB1dCgpIGluZGV4OiBudW1iZXI7XHJcbiAgQElucHV0KCkgdGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Component, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../directives/tree-drop.directive";
|
|
4
|
+
export class TreeNodeDropSlot {
|
|
5
|
+
onDrop($event) {
|
|
6
|
+
this.node.mouseAction('drop', $event.event, {
|
|
7
|
+
from: $event.element,
|
|
8
|
+
to: { parent: this.node, index: this.dropIndex }
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
allowDrop(element, $event) {
|
|
12
|
+
return this.node.options.allowDrop(element, { parent: this.node, index: this.dropIndex }, $event);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
/** @nocollapse */ TreeNodeDropSlot.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeNodeDropSlot, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
16
|
+
/** @nocollapse */ TreeNodeDropSlot.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TreeNodeDropSlot, selector: "TreeNodeDropSlot, tree-node-drop-slot", inputs: { node: "node", dropIndex: "dropIndex" }, ngImport: i0, template: `
|
|
17
|
+
<div
|
|
18
|
+
class="node-drop-slot"
|
|
19
|
+
(treeDrop)="onDrop($event)"
|
|
20
|
+
[treeAllowDrop]="allowDrop.bind(this)"
|
|
21
|
+
[allowDragoverStyling]="true">
|
|
22
|
+
</div>
|
|
23
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.TreeDropDirective, selector: "[treeDrop]", inputs: ["allowDragoverStyling", "treeAllowDrop"], outputs: ["treeDrop", "treeDropDragOver", "treeDropDragLeave", "treeDropDragEnter"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeNodeDropSlot, decorators: [{
|
|
25
|
+
type: Component,
|
|
26
|
+
args: [{ selector: 'TreeNodeDropSlot, tree-node-drop-slot', encapsulation: ViewEncapsulation.None, template: `
|
|
27
|
+
<div
|
|
28
|
+
class="node-drop-slot"
|
|
29
|
+
(treeDrop)="onDrop($event)"
|
|
30
|
+
[treeAllowDrop]="allowDrop.bind(this)"
|
|
31
|
+
[allowDragoverStyling]="true">
|
|
32
|
+
</div>
|
|
33
|
+
` }]
|
|
34
|
+
}], propDecorators: { node: [{
|
|
35
|
+
type: Input
|
|
36
|
+
}], dropIndex: [{
|
|
37
|
+
type: Input
|
|
38
|
+
}] } });
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1ub2RlLWRyb3Atc2xvdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXRyZWUtY29tcG9uZW50L3NyYy9saWIvY29tcG9uZW50cy90cmVlLW5vZGUtZHJvcC1zbG90LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBZ0JwRSxNQUFNLE9BQU8sZ0JBQWdCO0lBSTNCLE1BQU0sQ0FBQyxNQUFNO1FBQ1gsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxLQUFLLEVBQUU7WUFDMUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxPQUFPO1lBQ3BCLEVBQUUsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFO1NBQ2pELENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxTQUFTLENBQUMsT0FBTyxFQUFFLE1BQU07UUFDdkIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUUsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNwRyxDQUFDOztnSUFiVSxnQkFBZ0I7b0hBQWhCLGdCQUFnQiwrSEFUakI7Ozs7Ozs7R0FPVDsyRkFFVSxnQkFBZ0I7a0JBYjVCLFNBQVM7K0JBQ0UsdUNBQXVDLGlCQUNsQyxpQkFBaUIsQ0FBQyxJQUFJLFlBRTNCOzs7Ozs7O0dBT1Q7OEJBR1EsSUFBSTtzQkFBWixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUcmVlTm9kZSB9IGZyb20gJy4uL21vZGVscy90cmVlLW5vZGUubW9kZWwnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdUcmVlTm9kZURyb3BTbG90LCB0cmVlLW5vZGUtZHJvcC1zbG90JyxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gIHN0eWxlczogW10sXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxkaXZcclxuICAgICAgY2xhc3M9XCJub2RlLWRyb3Atc2xvdFwiXHJcbiAgICAgICh0cmVlRHJvcCk9XCJvbkRyb3AoJGV2ZW50KVwiXHJcbiAgICAgIFt0cmVlQWxsb3dEcm9wXT1cImFsbG93RHJvcC5iaW5kKHRoaXMpXCJcclxuICAgICAgW2FsbG93RHJhZ292ZXJTdHlsaW5nXT1cInRydWVcIj5cclxuICAgIDwvZGl2PlxyXG4gIGBcclxufSlcclxuZXhwb3J0IGNsYXNzIFRyZWVOb2RlRHJvcFNsb3Qge1xyXG4gIEBJbnB1dCgpIG5vZGU6IFRyZWVOb2RlO1xyXG4gIEBJbnB1dCgpIGRyb3BJbmRleDogbnVtYmVyO1xyXG5cclxuICBvbkRyb3AoJGV2ZW50KSB7XHJcbiAgICB0aGlzLm5vZGUubW91c2VBY3Rpb24oJ2Ryb3AnLCAkZXZlbnQuZXZlbnQsIHtcclxuICAgICAgZnJvbTogJGV2ZW50LmVsZW1lbnQsXHJcbiAgICAgIHRvOiB7IHBhcmVudDogdGhpcy5ub2RlLCBpbmRleDogdGhpcy5kcm9wSW5kZXggfVxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBhbGxvd0Ryb3AoZWxlbWVudCwgJGV2ZW50KSB7XHJcbiAgICByZXR1cm4gdGhpcy5ub2RlLm9wdGlvbnMuYWxsb3dEcm9wKGVsZW1lbnQsIHsgcGFyZW50OiB0aGlzLm5vZGUsIGluZGV4OiB0aGlzLmRyb3BJbmRleCB9LCAkZXZlbnQpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Component, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../mobx-angular/tree-mobx-autorun.directive";
|
|
5
|
+
export class TreeNodeExpanderComponent {
|
|
6
|
+
}
|
|
7
|
+
/** @nocollapse */ TreeNodeExpanderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeNodeExpanderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
8
|
+
/** @nocollapse */ TreeNodeExpanderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TreeNodeExpanderComponent, selector: "tree-node-expander", inputs: { node: "node" }, ngImport: i0, template: `
|
|
9
|
+
<ng-container *treeMobxAutorun="{ dontDetach: true }">
|
|
10
|
+
<span
|
|
11
|
+
*ngIf="node.hasChildren"
|
|
12
|
+
[class.toggle-children-wrapper-expanded]="node.isExpanded"
|
|
13
|
+
[class.toggle-children-wrapper-collapsed]="node.isCollapsed"
|
|
14
|
+
class="toggle-children-wrapper"
|
|
15
|
+
(click)="node.mouseAction('expanderClick', $event)"
|
|
16
|
+
>
|
|
17
|
+
<span class="toggle-children"></span>
|
|
18
|
+
</span>
|
|
19
|
+
<span *ngIf="!node.hasChildren" class="toggle-children-placeholder">
|
|
20
|
+
</span>
|
|
21
|
+
</ng-container>
|
|
22
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.TreeMobxAutorunDirective, selector: "[treeMobxAutorun]", inputs: ["treeMobxAutorun"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeNodeExpanderComponent, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{ selector: 'tree-node-expander', encapsulation: ViewEncapsulation.None, template: `
|
|
26
|
+
<ng-container *treeMobxAutorun="{ dontDetach: true }">
|
|
27
|
+
<span
|
|
28
|
+
*ngIf="node.hasChildren"
|
|
29
|
+
[class.toggle-children-wrapper-expanded]="node.isExpanded"
|
|
30
|
+
[class.toggle-children-wrapper-collapsed]="node.isCollapsed"
|
|
31
|
+
class="toggle-children-wrapper"
|
|
32
|
+
(click)="node.mouseAction('expanderClick', $event)"
|
|
33
|
+
>
|
|
34
|
+
<span class="toggle-children"></span>
|
|
35
|
+
</span>
|
|
36
|
+
<span *ngIf="!node.hasChildren" class="toggle-children-placeholder">
|
|
37
|
+
</span>
|
|
38
|
+
</ng-container>
|
|
39
|
+
` }]
|
|
40
|
+
}], propDecorators: { node: [{
|
|
41
|
+
type: Input
|
|
42
|
+
}] } });
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1ub2RlLWV4cGFuZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdHJlZS1jb21wb25lbnQvc3JjL2xpYi9jb21wb25lbnRzL3RyZWUtbm9kZS1leHBhbmRlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUF1QnBFLE1BQU0sT0FBTyx5QkFBeUI7O3lJQUF6Qix5QkFBeUI7NkhBQXpCLHlCQUF5QixvRkFoQjFCOzs7Ozs7Ozs7Ozs7OztHQWNUOzJGQUVVLHlCQUF5QjtrQkFwQnJDLFNBQVM7K0JBQ0Usb0JBQW9CLGlCQUNmLGlCQUFpQixDQUFDLElBQUksWUFFM0I7Ozs7Ozs7Ozs7Ozs7O0dBY1Q7OEJBR1EsSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVHJlZU5vZGUgfSBmcm9tICcuLi9tb2RlbHMvdHJlZS1ub2RlLm1vZGVsJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndHJlZS1ub2RlLWV4cGFuZGVyJyxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gIHN0eWxlczogW10sXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxuZy1jb250YWluZXIgKnRyZWVNb2J4QXV0b3J1bj1cInsgZG9udERldGFjaDogdHJ1ZSB9XCI+XHJcbiAgICAgIDxzcGFuXHJcbiAgICAgICAgKm5nSWY9XCJub2RlLmhhc0NoaWxkcmVuXCJcclxuICAgICAgICBbY2xhc3MudG9nZ2xlLWNoaWxkcmVuLXdyYXBwZXItZXhwYW5kZWRdPVwibm9kZS5pc0V4cGFuZGVkXCJcclxuICAgICAgICBbY2xhc3MudG9nZ2xlLWNoaWxkcmVuLXdyYXBwZXItY29sbGFwc2VkXT1cIm5vZGUuaXNDb2xsYXBzZWRcIlxyXG4gICAgICAgIGNsYXNzPVwidG9nZ2xlLWNoaWxkcmVuLXdyYXBwZXJcIlxyXG4gICAgICAgIChjbGljayk9XCJub2RlLm1vdXNlQWN0aW9uKCdleHBhbmRlckNsaWNrJywgJGV2ZW50KVwiXHJcbiAgICAgID5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cInRvZ2dsZS1jaGlsZHJlblwiPjwvc3Bhbj5cclxuICAgICAgPC9zcGFuPlxyXG4gICAgICA8c3BhbiAqbmdJZj1cIiFub2RlLmhhc0NoaWxkcmVuXCIgY2xhc3M9XCJ0b2dnbGUtY2hpbGRyZW4tcGxhY2Vob2xkZXJcIj5cclxuICAgICAgPC9zcGFuPlxyXG4gICAgPC9uZy1jb250YWluZXI+XHJcbiAgYFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVHJlZU5vZGVFeHBhbmRlckNvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgbm9kZTogVHJlZU5vZGU7XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { Component, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "./tree-node-content.component";
|
|
5
|
+
import * as i3 from "../directives/tree-drop.directive";
|
|
6
|
+
import * as i4 from "../directives/tree-drag.directive";
|
|
7
|
+
import * as i5 from "./tree-node-expander.component";
|
|
8
|
+
import * as i6 from "./tree-node-checkbox.component";
|
|
9
|
+
export class TreeNodeWrapperComponent {
|
|
10
|
+
}
|
|
11
|
+
/** @nocollapse */ TreeNodeWrapperComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeNodeWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
+
/** @nocollapse */ TreeNodeWrapperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TreeNodeWrapperComponent, selector: "tree-node-wrapper", inputs: { node: "node", index: "index", templates: "templates" }, ngImport: i0, template: `
|
|
13
|
+
<div *ngIf="!templates.treeNodeWrapperTemplate" class="node-wrapper" [style.padding-left]="node.getNodePadding()">
|
|
14
|
+
<tree-node-checkbox *ngIf="node.options.useCheckbox" [node]="node"></tree-node-checkbox>
|
|
15
|
+
<tree-node-expander [node]="node"></tree-node-expander>
|
|
16
|
+
<div class="node-content-wrapper"
|
|
17
|
+
[class.node-content-wrapper-active]="node.isActive"
|
|
18
|
+
[class.node-content-wrapper-focused]="node.isFocused"
|
|
19
|
+
(click)="node.mouseAction('click', $event)"
|
|
20
|
+
(dblclick)="node.mouseAction('dblClick', $event)"
|
|
21
|
+
(mouseover)="node.mouseAction('mouseOver', $event)"
|
|
22
|
+
(mouseout)="node.mouseAction('mouseOut', $event)"
|
|
23
|
+
(contextmenu)="node.mouseAction('contextMenu', $event)"
|
|
24
|
+
(treeDrop)="node.onDrop($event)"
|
|
25
|
+
(treeDropDragOver)="node.mouseAction('dragOver', $event)"
|
|
26
|
+
(treeDropDragLeave)="node.mouseAction('dragLeave', $event)"
|
|
27
|
+
(treeDropDragEnter)="node.mouseAction('dragEnter', $event)"
|
|
28
|
+
[treeAllowDrop]="node.allowDrop"
|
|
29
|
+
[allowDragoverStyling]="node.allowDragoverStyling()"
|
|
30
|
+
[treeDrag]="node"
|
|
31
|
+
[treeDragEnabled]="node.allowDrag()">
|
|
32
|
+
|
|
33
|
+
<tree-node-content [node]="node" [index]="index" [template]="templates.treeNodeTemplate">
|
|
34
|
+
</tree-node-content>
|
|
35
|
+
</div>
|
|
36
|
+
</div>
|
|
37
|
+
<ng-container
|
|
38
|
+
[ngTemplateOutlet]="templates.treeNodeWrapperTemplate"
|
|
39
|
+
[ngTemplateOutletContext]="{ $implicit: node, node: node, index: index, templates: templates }">
|
|
40
|
+
</ng-container>
|
|
41
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.TreeNodeContent, selector: "tree-node-content", inputs: ["node", "index", "template"] }, { kind: "directive", type: i3.TreeDropDirective, selector: "[treeDrop]", inputs: ["allowDragoverStyling", "treeAllowDrop"], outputs: ["treeDrop", "treeDropDragOver", "treeDropDragLeave", "treeDropDragEnter"] }, { kind: "directive", type: i4.TreeDragDirective, selector: "[treeDrag]", inputs: ["treeDrag", "treeDragEnabled"] }, { kind: "component", type: i5.TreeNodeExpanderComponent, selector: "tree-node-expander", inputs: ["node"] }, { kind: "component", type: i6.TreeNodeCheckboxComponent, selector: "tree-node-checkbox", inputs: ["node"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
42
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeNodeWrapperComponent, decorators: [{
|
|
43
|
+
type: Component,
|
|
44
|
+
args: [{ selector: 'tree-node-wrapper', encapsulation: ViewEncapsulation.None, template: `
|
|
45
|
+
<div *ngIf="!templates.treeNodeWrapperTemplate" class="node-wrapper" [style.padding-left]="node.getNodePadding()">
|
|
46
|
+
<tree-node-checkbox *ngIf="node.options.useCheckbox" [node]="node"></tree-node-checkbox>
|
|
47
|
+
<tree-node-expander [node]="node"></tree-node-expander>
|
|
48
|
+
<div class="node-content-wrapper"
|
|
49
|
+
[class.node-content-wrapper-active]="node.isActive"
|
|
50
|
+
[class.node-content-wrapper-focused]="node.isFocused"
|
|
51
|
+
(click)="node.mouseAction('click', $event)"
|
|
52
|
+
(dblclick)="node.mouseAction('dblClick', $event)"
|
|
53
|
+
(mouseover)="node.mouseAction('mouseOver', $event)"
|
|
54
|
+
(mouseout)="node.mouseAction('mouseOut', $event)"
|
|
55
|
+
(contextmenu)="node.mouseAction('contextMenu', $event)"
|
|
56
|
+
(treeDrop)="node.onDrop($event)"
|
|
57
|
+
(treeDropDragOver)="node.mouseAction('dragOver', $event)"
|
|
58
|
+
(treeDropDragLeave)="node.mouseAction('dragLeave', $event)"
|
|
59
|
+
(treeDropDragEnter)="node.mouseAction('dragEnter', $event)"
|
|
60
|
+
[treeAllowDrop]="node.allowDrop"
|
|
61
|
+
[allowDragoverStyling]="node.allowDragoverStyling()"
|
|
62
|
+
[treeDrag]="node"
|
|
63
|
+
[treeDragEnabled]="node.allowDrag()">
|
|
64
|
+
|
|
65
|
+
<tree-node-content [node]="node" [index]="index" [template]="templates.treeNodeTemplate">
|
|
66
|
+
</tree-node-content>
|
|
67
|
+
</div>
|
|
68
|
+
</div>
|
|
69
|
+
<ng-container
|
|
70
|
+
[ngTemplateOutlet]="templates.treeNodeWrapperTemplate"
|
|
71
|
+
[ngTemplateOutletContext]="{ $implicit: node, node: node, index: index, templates: templates }">
|
|
72
|
+
</ng-container>
|
|
73
|
+
` }]
|
|
74
|
+
}], propDecorators: { node: [{
|
|
75
|
+
type: Input
|
|
76
|
+
}], index: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], templates: [{
|
|
79
|
+
type: Input
|
|
80
|
+
}] } });
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1ub2RlLXdyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci10cmVlLWNvbXBvbmVudC9zcmMvbGliL2NvbXBvbmVudHMvdHJlZS1ub2RlLXdyYXBwZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUcsS0FBSyxFQUFHLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7OztBQXVDdEUsTUFBTSxPQUFPLHdCQUF3Qjs7d0lBQXhCLHdCQUF3Qjs0SEFBeEIsd0JBQXdCLDJIQWhDekI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBNkJUOzJGQUdVLHdCQUF3QjtrQkFwQ3BDLFNBQVM7K0JBQ0UsbUJBQW1CLGlCQUNkLGlCQUFpQixDQUFDLElBQUksWUFFM0I7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBNkJUOzhCQUtRLElBQUk7c0JBQVosS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCAsIElucHV0ICwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVHJlZU5vZGUgfSBmcm9tICcuLi9tb2RlbHMvdHJlZS1ub2RlLm1vZGVsJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndHJlZS1ub2RlLXdyYXBwZXInICxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lICxcclxuICBzdHlsZXM6IFtdICxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgICA8ZGl2ICpuZ0lmPVwiIXRlbXBsYXRlcy50cmVlTm9kZVdyYXBwZXJUZW1wbGF0ZVwiIGNsYXNzPVwibm9kZS13cmFwcGVyXCIgW3N0eWxlLnBhZGRpbmctbGVmdF09XCJub2RlLmdldE5vZGVQYWRkaW5nKClcIj5cclxuICAgICAgICAgIDx0cmVlLW5vZGUtY2hlY2tib3ggKm5nSWY9XCJub2RlLm9wdGlvbnMudXNlQ2hlY2tib3hcIiBbbm9kZV09XCJub2RlXCI+PC90cmVlLW5vZGUtY2hlY2tib3g+XHJcbiAgICAgICAgICA8dHJlZS1ub2RlLWV4cGFuZGVyIFtub2RlXT1cIm5vZGVcIj48L3RyZWUtbm9kZS1leHBhbmRlcj5cclxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJub2RlLWNvbnRlbnQtd3JhcHBlclwiXHJcbiAgICAgICAgICAgICAgIFtjbGFzcy5ub2RlLWNvbnRlbnQtd3JhcHBlci1hY3RpdmVdPVwibm9kZS5pc0FjdGl2ZVwiXHJcbiAgICAgICAgICAgICAgIFtjbGFzcy5ub2RlLWNvbnRlbnQtd3JhcHBlci1mb2N1c2VkXT1cIm5vZGUuaXNGb2N1c2VkXCJcclxuICAgICAgICAgICAgICAgKGNsaWNrKT1cIm5vZGUubW91c2VBY3Rpb24oJ2NsaWNrJywgJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgIChkYmxjbGljayk9XCJub2RlLm1vdXNlQWN0aW9uKCdkYmxDbGljaycsICRldmVudClcIlxyXG4gICAgICAgICAgICAgICAobW91c2VvdmVyKT1cIm5vZGUubW91c2VBY3Rpb24oJ21vdXNlT3ZlcicsICRldmVudClcIlxyXG4gICAgICAgICAgICAgICAobW91c2VvdXQpPVwibm9kZS5tb3VzZUFjdGlvbignbW91c2VPdXQnLCAkZXZlbnQpXCJcclxuICAgICAgICAgICAgICAgKGNvbnRleHRtZW51KT1cIm5vZGUubW91c2VBY3Rpb24oJ2NvbnRleHRNZW51JywgJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgICh0cmVlRHJvcCk9XCJub2RlLm9uRHJvcCgkZXZlbnQpXCJcclxuICAgICAgICAgICAgICAgKHRyZWVEcm9wRHJhZ092ZXIpPVwibm9kZS5tb3VzZUFjdGlvbignZHJhZ092ZXInLCAkZXZlbnQpXCJcclxuICAgICAgICAgICAgICAgKHRyZWVEcm9wRHJhZ0xlYXZlKT1cIm5vZGUubW91c2VBY3Rpb24oJ2RyYWdMZWF2ZScsICRldmVudClcIlxyXG4gICAgICAgICAgICAgICAodHJlZURyb3BEcmFnRW50ZXIpPVwibm9kZS5tb3VzZUFjdGlvbignZHJhZ0VudGVyJywgJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgIFt0cmVlQWxsb3dEcm9wXT1cIm5vZGUuYWxsb3dEcm9wXCJcclxuICAgICAgICAgICAgICAgW2FsbG93RHJhZ292ZXJTdHlsaW5nXT1cIm5vZGUuYWxsb3dEcmFnb3ZlclN0eWxpbmcoKVwiXHJcbiAgICAgICAgICAgICAgIFt0cmVlRHJhZ109XCJub2RlXCJcclxuICAgICAgICAgICAgICAgW3RyZWVEcmFnRW5hYmxlZF09XCJub2RlLmFsbG93RHJhZygpXCI+XHJcblxyXG4gICAgICAgICAgICAgIDx0cmVlLW5vZGUtY29udGVudCBbbm9kZV09XCJub2RlXCIgW2luZGV4XT1cImluZGV4XCIgW3RlbXBsYXRlXT1cInRlbXBsYXRlcy50cmVlTm9kZVRlbXBsYXRlXCI+XHJcbiAgICAgICAgICAgICAgPC90cmVlLW5vZGUtY29udGVudD5cclxuICAgICAgICAgIDwvZGl2PlxyXG4gICAgICA8L2Rpdj5cclxuICAgICAgPG5nLWNvbnRhaW5lclxyXG4gICAgICAgICAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0XT1cInRlbXBsYXRlcy50cmVlTm9kZVdyYXBwZXJUZW1wbGF0ZVwiXHJcbiAgICAgICAgICAgICAgW25nVGVtcGxhdGVPdXRsZXRDb250ZXh0XT1cInsgJGltcGxpY2l0OiBub2RlLCBub2RlOiBub2RlLCBpbmRleDogaW5kZXgsIHRlbXBsYXRlczogdGVtcGxhdGVzIH1cIj5cclxuICAgICAgPC9uZy1jb250YWluZXI+XHJcbiAgYFxyXG59KVxyXG5cclxuZXhwb3J0IGNsYXNzIFRyZWVOb2RlV3JhcHBlckNvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIG5vZGU6IFRyZWVOb2RlO1xyXG4gIEBJbnB1dCgpIGluZGV4OiBudW1iZXI7XHJcbiAgQElucHV0KCkgdGVtcGxhdGVzOiBhbnk7XHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { Component, } from '@angular/core';
|
|
2
|
+
import { TreeVirtualScroll } from '../models/tree-virtual-scroll.model';
|
|
3
|
+
import { TREE_EVENTS } from '../constants/events';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../models/tree-virtual-scroll.model";
|
|
6
|
+
import * as i2 from "../mobx-angular/tree-mobx-autorun.directive";
|
|
7
|
+
export class TreeViewportComponent {
|
|
8
|
+
constructor(elementRef, virtualScroll) {
|
|
9
|
+
this.elementRef = elementRef;
|
|
10
|
+
this.virtualScroll = virtualScroll;
|
|
11
|
+
this.setViewport = this.throttle(() => {
|
|
12
|
+
this.virtualScroll.setViewport(this.elementRef.nativeElement);
|
|
13
|
+
}, 17);
|
|
14
|
+
this.scrollEventHandler = this.setViewport.bind(this);
|
|
15
|
+
}
|
|
16
|
+
ngOnInit() {
|
|
17
|
+
this.virtualScroll.init();
|
|
18
|
+
}
|
|
19
|
+
ngAfterViewInit() {
|
|
20
|
+
setTimeout(() => {
|
|
21
|
+
this.setViewport();
|
|
22
|
+
this.virtualScroll.fireEvent({ eventName: TREE_EVENTS.initialized });
|
|
23
|
+
});
|
|
24
|
+
let el = this.elementRef.nativeElement;
|
|
25
|
+
el.addEventListener('scroll', this.scrollEventHandler);
|
|
26
|
+
}
|
|
27
|
+
ngOnDestroy() {
|
|
28
|
+
this.virtualScroll.clear();
|
|
29
|
+
let el = this.elementRef.nativeElement;
|
|
30
|
+
el.removeEventListener('scroll', this.scrollEventHandler);
|
|
31
|
+
}
|
|
32
|
+
getTotalHeight() {
|
|
33
|
+
return ((this.virtualScroll.isEnabled() &&
|
|
34
|
+
this.virtualScroll.totalHeight + 'px') ||
|
|
35
|
+
'auto');
|
|
36
|
+
}
|
|
37
|
+
throttle(func, timeFrame) {
|
|
38
|
+
let lastTime = 0;
|
|
39
|
+
return function () {
|
|
40
|
+
let now = Date.now();
|
|
41
|
+
if (now - lastTime >= timeFrame) {
|
|
42
|
+
func();
|
|
43
|
+
lastTime = now;
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
/** @nocollapse */ TreeViewportComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeViewportComponent, deps: [{ token: i0.ElementRef }, { token: i1.TreeVirtualScroll }], target: i0.ɵɵFactoryTarget.Component });
|
|
49
|
+
/** @nocollapse */ TreeViewportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TreeViewportComponent, selector: "tree-viewport", providers: [TreeVirtualScroll], ngImport: i0, template: `
|
|
50
|
+
<ng-container *treeMobxAutorun="{ dontDetach: true }">
|
|
51
|
+
<div [style.height]="getTotalHeight()">
|
|
52
|
+
<ng-content></ng-content>
|
|
53
|
+
</div>
|
|
54
|
+
</ng-container>
|
|
55
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i2.TreeMobxAutorunDirective, selector: "[treeMobxAutorun]", inputs: ["treeMobxAutorun"] }] });
|
|
56
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeViewportComponent, decorators: [{
|
|
57
|
+
type: Component,
|
|
58
|
+
args: [{ selector: 'tree-viewport', providers: [TreeVirtualScroll], template: `
|
|
59
|
+
<ng-container *treeMobxAutorun="{ dontDetach: true }">
|
|
60
|
+
<div [style.height]="getTotalHeight()">
|
|
61
|
+
<ng-content></ng-content>
|
|
62
|
+
</div>
|
|
63
|
+
</ng-container>
|
|
64
|
+
` }]
|
|
65
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.TreeVirtualScroll }]; } });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS12aWV3cG9ydC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXRyZWUtY29tcG9uZW50L3NyYy9saWIvY29tcG9uZW50cy90cmVlLXZpZXdwb3J0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxHQUtWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7OztBQWNsRCxNQUFNLE9BQU8scUJBQXFCO0lBT2hDLFlBQ1UsVUFBc0IsRUFDdkIsYUFBZ0M7UUFEL0IsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUN2QixrQkFBYSxHQUFiLGFBQWEsQ0FBbUI7UUFSekMsZ0JBQVcsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUMvQixJQUFJLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ2hFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQVFMLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4RCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUIsQ0FBQztJQUVELGVBQWU7UUFDYixVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ25CLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLEVBQUUsU0FBUyxFQUFFLFdBQVcsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZFLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxFQUFFLEdBQWdCLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDO1FBQ3BELEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzNCLElBQUksRUFBRSxHQUFnQixJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztRQUNwRCxFQUFFLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0lBQzVELENBQUM7SUFFRCxjQUFjO1FBQ1osT0FBTyxDQUNMLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLEVBQUU7WUFDN0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1lBQ3hDLE1BQU0sQ0FDUCxDQUFDO0lBQ0osQ0FBQztJQUVPLFFBQVEsQ0FBQyxJQUFJLEVBQUUsU0FBUztRQUM5QixJQUFJLFFBQVEsR0FBRyxDQUFDLENBQUM7UUFDakIsT0FBTztZQUNMLElBQUksR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNyQixJQUFJLEdBQUcsR0FBRyxRQUFRLElBQUksU0FBUyxFQUFFO2dCQUMvQixJQUFJLEVBQUUsQ0FBQztnQkFDUCxRQUFRLEdBQUcsR0FBRyxDQUFDO2FBQ2hCO1FBQ0gsQ0FBQyxDQUFDO0lBQ0osQ0FBQzs7cUlBbERVLHFCQUFxQjt5SEFBckIscUJBQXFCLHdDQVRyQixDQUFDLGlCQUFpQixDQUFDLDBCQUNwQjs7Ozs7O0dBTVQ7MkZBRVUscUJBQXFCO2tCQVpqQyxTQUFTOytCQUNFLGVBQWUsYUFFZCxDQUFDLGlCQUFpQixDQUFDLFlBQ3BCOzs7Ozs7R0FNVCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIEVsZW1lbnRSZWYsXHJcbiAgQWZ0ZXJWaWV3SW5pdCxcclxuICBPbkluaXQsXHJcbiAgT25EZXN0cm95LFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUcmVlVmlydHVhbFNjcm9sbCB9IGZyb20gJy4uL21vZGVscy90cmVlLXZpcnR1YWwtc2Nyb2xsLm1vZGVsJztcclxuaW1wb3J0IHsgVFJFRV9FVkVOVFMgfSBmcm9tICcuLi9jb25zdGFudHMvZXZlbnRzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndHJlZS12aWV3cG9ydCcsXHJcbiAgc3R5bGVzOiBbXSxcclxuICBwcm92aWRlcnM6IFtUcmVlVmlydHVhbFNjcm9sbF0sXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxuZy1jb250YWluZXIgKnRyZWVNb2J4QXV0b3J1bj1cInsgZG9udERldGFjaDogdHJ1ZSB9XCI+XHJcbiAgICAgIDxkaXYgW3N0eWxlLmhlaWdodF09XCJnZXRUb3RhbEhlaWdodCgpXCI+XHJcbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgICA8L2Rpdj5cclxuICAgIDwvbmctY29udGFpbmVyPlxyXG4gIGBcclxufSlcclxuZXhwb3J0IGNsYXNzIFRyZWVWaWV3cG9ydENvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uSW5pdCwgT25EZXN0cm95IHtcclxuICBzZXRWaWV3cG9ydCA9IHRoaXMudGhyb3R0bGUoKCkgPT4ge1xyXG4gICAgdGhpcy52aXJ0dWFsU2Nyb2xsLnNldFZpZXdwb3J0KHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50KTtcclxuICB9LCAxNyk7XHJcblxyXG4gIHByaXZhdGUgcmVhZG9ubHkgc2Nyb2xsRXZlbnRIYW5kbGVyOiAoJGV2ZW50OiBFdmVudCkgPT4gdm9pZDtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsXHJcbiAgICBwdWJsaWMgdmlydHVhbFNjcm9sbDogVHJlZVZpcnR1YWxTY3JvbGxcclxuICApIHtcclxuICAgIHRoaXMuc2Nyb2xsRXZlbnRIYW5kbGVyID0gdGhpcy5zZXRWaWV3cG9ydC5iaW5kKHRoaXMpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLnZpcnR1YWxTY3JvbGwuaW5pdCgpO1xyXG4gIH1cclxuXHJcbiAgbmdBZnRlclZpZXdJbml0KCkge1xyXG4gICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgIHRoaXMuc2V0Vmlld3BvcnQoKTtcclxuICAgICAgdGhpcy52aXJ0dWFsU2Nyb2xsLmZpcmVFdmVudCh7IGV2ZW50TmFtZTogVFJFRV9FVkVOVFMuaW5pdGlhbGl6ZWQgfSk7XHJcbiAgICB9KTtcclxuICAgIGxldCBlbDogSFRNTEVsZW1lbnQgPSB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudDtcclxuICAgIGVsLmFkZEV2ZW50TGlzdGVuZXIoJ3Njcm9sbCcsIHRoaXMuc2Nyb2xsRXZlbnRIYW5kbGVyKTtcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCkge1xyXG4gICAgdGhpcy52aXJ0dWFsU2Nyb2xsLmNsZWFyKCk7XHJcbiAgICBsZXQgZWw6IEhUTUxFbGVtZW50ID0gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQ7XHJcbiAgICBlbC5yZW1vdmVFdmVudExpc3RlbmVyKCdzY3JvbGwnLCB0aGlzLnNjcm9sbEV2ZW50SGFuZGxlcik7XHJcbiAgfVxyXG5cclxuICBnZXRUb3RhbEhlaWdodCgpIHtcclxuICAgIHJldHVybiAoXHJcbiAgICAgICh0aGlzLnZpcnR1YWxTY3JvbGwuaXNFbmFibGVkKCkgJiZcclxuICAgICAgICB0aGlzLnZpcnR1YWxTY3JvbGwudG90YWxIZWlnaHQgKyAncHgnKSB8fFxyXG4gICAgICAnYXV0bydcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHRocm90dGxlKGZ1bmMsIHRpbWVGcmFtZSkge1xyXG4gICAgbGV0IGxhc3RUaW1lID0gMDtcclxuICAgIHJldHVybiBmdW5jdGlvbiAoKSB7XHJcbiAgICAgIGxldCBub3cgPSBEYXRlLm5vdygpO1xyXG4gICAgICBpZiAobm93IC0gbGFzdFRpbWUgPj0gdGltZUZyYW1lKSB7XHJcbiAgICAgICAgZnVuYygpO1xyXG4gICAgICAgIGxhc3RUaW1lID0gbm93O1xyXG4gICAgICB9XHJcbiAgICB9O1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import { Component, ContentChild, EventEmitter, HostListener, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { TreeModel } from '../models/tree.model';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../models/tree.model";
|
|
5
|
+
import * as i2 from "../models/tree-dragged-element.model";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "./tree-node-drop-slot.component";
|
|
8
|
+
import * as i5 from "./tree-node-collection.component";
|
|
9
|
+
import * as i6 from "./tree-viewport.component";
|
|
10
|
+
export class TreeComponent {
|
|
11
|
+
constructor(treeModel, treeDraggedElement) {
|
|
12
|
+
this.treeModel = treeModel;
|
|
13
|
+
this.treeDraggedElement = treeDraggedElement;
|
|
14
|
+
treeModel.eventNames.forEach((name) => this[name] = new EventEmitter());
|
|
15
|
+
treeModel.subscribeToState((state) => this.stateChange.emit(state));
|
|
16
|
+
}
|
|
17
|
+
// Will be handled in ngOnChanges
|
|
18
|
+
set nodes(nodes) {
|
|
19
|
+
}
|
|
20
|
+
;
|
|
21
|
+
set options(options) {
|
|
22
|
+
}
|
|
23
|
+
;
|
|
24
|
+
set focused(value) {
|
|
25
|
+
this.treeModel.setFocus(value);
|
|
26
|
+
}
|
|
27
|
+
set state(state) {
|
|
28
|
+
this.treeModel.setState(state);
|
|
29
|
+
}
|
|
30
|
+
onKeydown($event) {
|
|
31
|
+
if (!this.treeModel.isFocused)
|
|
32
|
+
return;
|
|
33
|
+
if (['input', 'textarea'].includes(document.activeElement.tagName.toLowerCase()))
|
|
34
|
+
return;
|
|
35
|
+
const focusedNode = this.treeModel.getFocusedNode();
|
|
36
|
+
this.treeModel.performKeyAction(focusedNode, $event);
|
|
37
|
+
}
|
|
38
|
+
onMousedown($event) {
|
|
39
|
+
function isOutsideClick(startElement, nodeName) {
|
|
40
|
+
return !startElement ? true : startElement.localName === nodeName ? false : isOutsideClick(startElement.parentElement, nodeName);
|
|
41
|
+
}
|
|
42
|
+
if (isOutsideClick($event.target, 'tree-root')) {
|
|
43
|
+
this.treeModel.setFocus(false);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
ngOnChanges(changes) {
|
|
47
|
+
if (changes.options || changes.nodes) {
|
|
48
|
+
this.treeModel.setData({
|
|
49
|
+
options: changes.options && changes.options.currentValue,
|
|
50
|
+
nodes: changes.nodes && changes.nodes.currentValue,
|
|
51
|
+
events: this.pick(this, this.treeModel.eventNames)
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
sizeChanged() {
|
|
56
|
+
this.viewportComponent.setViewport();
|
|
57
|
+
}
|
|
58
|
+
pick(object, keys) {
|
|
59
|
+
return keys.reduce((obj, key) => {
|
|
60
|
+
if (object && object.hasOwnProperty(key)) {
|
|
61
|
+
obj[key] = object[key];
|
|
62
|
+
}
|
|
63
|
+
return obj;
|
|
64
|
+
}, {});
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
/** @nocollapse */ TreeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeComponent, deps: [{ token: i1.TreeModel }, { token: i2.TreeDraggedElement }], target: i0.ɵɵFactoryTarget.Component });
|
|
68
|
+
/** @nocollapse */ TreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", 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: { "body: keydown": "onKeydown($event)", "body: mousedown": "onMousedown($event)" } }, 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: `
|
|
69
|
+
<tree-viewport #viewport>
|
|
70
|
+
<div
|
|
71
|
+
class="angular-tree-component"
|
|
72
|
+
[class.node-dragging]="treeDraggedElement.isDragging()"
|
|
73
|
+
[class.angular-tree-component-rtl]="treeModel.options.rtl">
|
|
74
|
+
<tree-node-collection
|
|
75
|
+
*ngIf="treeModel.roots"
|
|
76
|
+
[nodes]="treeModel.roots"
|
|
77
|
+
[treeModel]="treeModel"
|
|
78
|
+
[templates]="{
|
|
79
|
+
loadingTemplate: loadingTemplate,
|
|
80
|
+
treeNodeTemplate: treeNodeTemplate,
|
|
81
|
+
treeNodeWrapperTemplate: treeNodeWrapperTemplate,
|
|
82
|
+
treeNodeFullTemplate: treeNodeFullTemplate
|
|
83
|
+
}">
|
|
84
|
+
</tree-node-collection>
|
|
85
|
+
<tree-node-drop-slot
|
|
86
|
+
class="empty-tree-drop-slot"
|
|
87
|
+
*ngIf="treeModel.isEmptyTree()"
|
|
88
|
+
[dropIndex]="0"
|
|
89
|
+
[node]="treeModel.virtualRoot">
|
|
90
|
+
</tree-node-drop-slot>
|
|
91
|
+
</div>
|
|
92
|
+
</tree-viewport>
|
|
93
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TreeNodeDropSlot, selector: "TreeNodeDropSlot, tree-node-drop-slot", inputs: ["node", "dropIndex"] }, { kind: "component", type: i5.TreeNodeCollectionComponent, selector: "tree-node-collection", inputs: ["nodes", "treeModel", "templates"] }, { kind: "component", type: i6.TreeViewportComponent, selector: "tree-viewport" }] });
|
|
94
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TreeComponent, decorators: [{
|
|
95
|
+
type: Component,
|
|
96
|
+
args: [{ selector: 'Tree, tree-root', providers: [TreeModel], template: `
|
|
97
|
+
<tree-viewport #viewport>
|
|
98
|
+
<div
|
|
99
|
+
class="angular-tree-component"
|
|
100
|
+
[class.node-dragging]="treeDraggedElement.isDragging()"
|
|
101
|
+
[class.angular-tree-component-rtl]="treeModel.options.rtl">
|
|
102
|
+
<tree-node-collection
|
|
103
|
+
*ngIf="treeModel.roots"
|
|
104
|
+
[nodes]="treeModel.roots"
|
|
105
|
+
[treeModel]="treeModel"
|
|
106
|
+
[templates]="{
|
|
107
|
+
loadingTemplate: loadingTemplate,
|
|
108
|
+
treeNodeTemplate: treeNodeTemplate,
|
|
109
|
+
treeNodeWrapperTemplate: treeNodeWrapperTemplate,
|
|
110
|
+
treeNodeFullTemplate: treeNodeFullTemplate
|
|
111
|
+
}">
|
|
112
|
+
</tree-node-collection>
|
|
113
|
+
<tree-node-drop-slot
|
|
114
|
+
class="empty-tree-drop-slot"
|
|
115
|
+
*ngIf="treeModel.isEmptyTree()"
|
|
116
|
+
[dropIndex]="0"
|
|
117
|
+
[node]="treeModel.virtualRoot">
|
|
118
|
+
</tree-node-drop-slot>
|
|
119
|
+
</div>
|
|
120
|
+
</tree-viewport>
|
|
121
|
+
` }]
|
|
122
|
+
}], ctorParameters: function () { return [{ type: i1.TreeModel }, { type: i2.TreeDraggedElement }]; }, propDecorators: { loadingTemplate: [{
|
|
123
|
+
type: ContentChild,
|
|
124
|
+
args: ['loadingTemplate', { static: false }]
|
|
125
|
+
}], treeNodeTemplate: [{
|
|
126
|
+
type: ContentChild,
|
|
127
|
+
args: ['treeNodeTemplate', { static: false }]
|
|
128
|
+
}], treeNodeWrapperTemplate: [{
|
|
129
|
+
type: ContentChild,
|
|
130
|
+
args: ['treeNodeWrapperTemplate', { static: false }]
|
|
131
|
+
}], treeNodeFullTemplate: [{
|
|
132
|
+
type: ContentChild,
|
|
133
|
+
args: ['treeNodeFullTemplate', { static: false }]
|
|
134
|
+
}], viewportComponent: [{
|
|
135
|
+
type: ViewChild,
|
|
136
|
+
args: ['viewport', { static: false }]
|
|
137
|
+
}], nodes: [{
|
|
138
|
+
type: Input
|
|
139
|
+
}], options: [{
|
|
140
|
+
type: Input
|
|
141
|
+
}], focused: [{
|
|
142
|
+
type: Input
|
|
143
|
+
}], state: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], toggleExpanded: [{
|
|
146
|
+
type: Output
|
|
147
|
+
}], activate: [{
|
|
148
|
+
type: Output
|
|
149
|
+
}], deactivate: [{
|
|
150
|
+
type: Output
|
|
151
|
+
}], nodeActivate: [{
|
|
152
|
+
type: Output
|
|
153
|
+
}], nodeDeactivate: [{
|
|
154
|
+
type: Output
|
|
155
|
+
}], select: [{
|
|
156
|
+
type: Output
|
|
157
|
+
}], deselect: [{
|
|
158
|
+
type: Output
|
|
159
|
+
}], focus: [{
|
|
160
|
+
type: Output
|
|
161
|
+
}], blur: [{
|
|
162
|
+
type: Output
|
|
163
|
+
}], updateData: [{
|
|
164
|
+
type: Output
|
|
165
|
+
}], initialized: [{
|
|
166
|
+
type: Output
|
|
167
|
+
}], moveNode: [{
|
|
168
|
+
type: Output
|
|
169
|
+
}], copyNode: [{
|
|
170
|
+
type: Output
|
|
171
|
+
}], loadNodeChildren: [{
|
|
172
|
+
type: Output
|
|
173
|
+
}], changeFilter: [{
|
|
174
|
+
type: Output
|
|
175
|
+
}], event: [{
|
|
176
|
+
type: Output
|
|
177
|
+
}], stateChange: [{
|
|
178
|
+
type: Output
|
|
179
|
+
}], onKeydown: [{
|
|
180
|
+
type: HostListener,
|
|
181
|
+
args: ['body: keydown', ['$event']]
|
|
182
|
+
}], onMousedown: [{
|
|
183
|
+
type: HostListener,
|
|
184
|
+
args: ['body: mousedown', ['$event']]
|
|
185
|
+
}] } });
|
|
186
|
+
//# 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, 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  @HostListener('body: keydown', ['$event'])\r\n  onKeydown($event) {\r\n    if (!this.treeModel.isFocused) return;\r\n    if (['input', 'textarea'].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  @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"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export const TREE_EVENTS = {
|
|
2
|
+
toggleExpanded: 'toggleExpanded',
|
|
3
|
+
activate: 'activate',
|
|
4
|
+
deactivate: 'deactivate',
|
|
5
|
+
nodeActivate: 'nodeActivate',
|
|
6
|
+
nodeDeactivate: 'nodeDeactivate',
|
|
7
|
+
select: 'select',
|
|
8
|
+
deselect: 'deselect',
|
|
9
|
+
focus: 'focus',
|
|
10
|
+
blur: 'blur',
|
|
11
|
+
initialized: 'initialized',
|
|
12
|
+
updateData: 'updateData',
|
|
13
|
+
moveNode: 'moveNode',
|
|
14
|
+
copyNode: 'copyNode',
|
|
15
|
+
event: 'event',
|
|
16
|
+
loadNodeChildren: 'loadNodeChildren',
|
|
17
|
+
changeFilter: 'changeFilter',
|
|
18
|
+
stateChange: 'stateChange'
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci10cmVlLWNvbXBvbmVudC9zcmMvbGliL2NvbnN0YW50cy9ldmVudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHO0lBQ3pCLGNBQWMsRUFBRSxnQkFBZ0I7SUFDaEMsUUFBUSxFQUFFLFVBQVU7SUFDcEIsVUFBVSxFQUFFLFlBQVk7SUFDeEIsWUFBWSxFQUFFLGNBQWM7SUFDNUIsY0FBYyxFQUFFLGdCQUFnQjtJQUNoQyxNQUFNLEVBQUUsUUFBUTtJQUNoQixRQUFRLEVBQUUsVUFBVTtJQUNwQixLQUFLLEVBQUUsT0FBTztJQUNkLElBQUksRUFBRSxNQUFNO0lBQ1osV0FBVyxFQUFFLGFBQWE7SUFDMUIsVUFBVSxFQUFFLFlBQVk7SUFDeEIsUUFBUSxFQUFFLFVBQVU7SUFDcEIsUUFBUSxFQUFFLFVBQVU7SUFDcEIsS0FBSyxFQUFFLE9BQU87SUFDZCxnQkFBZ0IsRUFBRSxrQkFBa0I7SUFDcEMsWUFBWSxFQUFFLGNBQWM7SUFDNUIsV0FBVyxFQUFFLGFBQWE7Q0FDM0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBUUkVFX0VWRU5UUyA9IHtcclxuICB0b2dnbGVFeHBhbmRlZDogJ3RvZ2dsZUV4cGFuZGVkJyxcclxuICBhY3RpdmF0ZTogJ2FjdGl2YXRlJyxcclxuICBkZWFjdGl2YXRlOiAnZGVhY3RpdmF0ZScsXHJcbiAgbm9kZUFjdGl2YXRlOiAnbm9kZUFjdGl2YXRlJyxcclxuICBub2RlRGVhY3RpdmF0ZTogJ25vZGVEZWFjdGl2YXRlJyxcclxuICBzZWxlY3Q6ICdzZWxlY3QnLFxyXG4gIGRlc2VsZWN0OiAnZGVzZWxlY3QnLFxyXG4gIGZvY3VzOiAnZm9jdXMnLFxyXG4gIGJsdXI6ICdibHVyJyxcclxuICBpbml0aWFsaXplZDogJ2luaXRpYWxpemVkJyxcclxuICB1cGRhdGVEYXRhOiAndXBkYXRlRGF0YScsXHJcbiAgbW92ZU5vZGU6ICdtb3ZlTm9kZScsXHJcbiAgY29weU5vZGU6ICdjb3B5Tm9kZScsXHJcbiAgZXZlbnQ6ICdldmVudCcsXHJcbiAgbG9hZE5vZGVDaGlsZHJlbjogJ2xvYWROb2RlQ2hpbGRyZW4nLFxyXG4gIGNoYW5nZUZpbHRlcjogJ2NoYW5nZUZpbHRlcicsXHJcbiAgc3RhdGVDaGFuZ2U6ICdzdGF0ZUNoYW5nZSdcclxufTtcclxuIl19
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export const KEYS = {
|
|
2
|
+
LEFT: 37,
|
|
3
|
+
UP: 38,
|
|
4
|
+
RIGHT: 39,
|
|
5
|
+
DOWN: 40,
|
|
6
|
+
ENTER: 13,
|
|
7
|
+
SPACE: 32,
|
|
8
|
+
CONTEXT_MENU: 32
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdHJlZS1jb21wb25lbnQvc3JjL2xpYi9jb25zdGFudHMva2V5cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxJQUFJLEdBQUc7SUFDbEIsSUFBSSxFQUFFLEVBQUU7SUFDUixFQUFFLEVBQUUsRUFBRTtJQUNOLEtBQUssRUFBRSxFQUFFO0lBQ1QsSUFBSSxFQUFFLEVBQUU7SUFDUixLQUFLLEVBQUUsRUFBRTtJQUNULEtBQUssRUFBRSxFQUFFO0lBQ1QsWUFBWSxFQUFFLEVBQUU7Q0FDakIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBLRVlTID0ge1xyXG4gIExFRlQ6IDM3LFxyXG4gIFVQOiAzOCxcclxuICBSSUdIVDogMzksXHJcbiAgRE9XTjogNDAsXHJcbiAgRU5URVI6IDEzLFxyXG4gIFNQQUNFOiAzMixcclxuICBDT05URVhUX01FTlU6IDMyXHJcbn07XHJcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../../projects/angular-tree-component/src/lib/defs/api.ts"],"names":[],"mappings":"","sourcesContent":["/**\r\n * Welcome to ng2tree\r\n */\r\nexport type IDType = string | number;\r\nexport type IDTypeDictionary = { [id: string]: boolean, [id: number]: boolean };\r\n\r\n/**\r\n * See ITreeNode for documentation\r\n */\r\nexport declare type TreeNode = any;\r\n\r\nexport interface IAllowDropFn {\r\n  (element: any, to: {parent: TreeNode, index: number}, $event?: any): boolean;\r\n}\r\n\r\nexport interface INodeHeightFn {\r\n  (node: TreeNode): number;\r\n}\r\n\r\nexport interface IAllowDragFn {\r\n  (node: TreeNode): boolean;\r\n}\r\n\r\n\r\nexport interface ITreeState {\r\n  expandedNodeIds?: IDTypeDictionary;\r\n  selectedNodeIds?: IDTypeDictionary;\r\n  activeNodeIds?: IDTypeDictionary;\r\n  hiddenNodeIds?: IDTypeDictionary;\r\n  selectedLeafNodeIds?: IDTypeDictionary;\r\n  focusedNodeId?: IDType;\r\n}\r\n\r\nexport interface ITreeOptions {\r\n   /**\r\n    * A string representing the attribute of the node that indicates whether there are child nodes.\r\n\r\n    * **Default value: `hasChildren`.**\r\n\r\n    For example, if your nodes have an `isDirectory` attribute that indicates whether there are children, use:\r\n    ```\r\n      options = { hasChildrenField: 'isDirectory' }\r\n    ```\r\n    */\r\n   hasChildrenField?: string;\r\n   /**\r\n    * A string representing the attribute of the node that contains the array of children.\r\n\r\n    * **Default value: `children`.**\r\n\r\n    For example, if your nodes have a `nodes` attribute, that contains the children, use:\r\n    ```\r\n      options = { childrenField: 'nodes' }\r\n    ```\r\n    */\r\n   childrenField?: string;\r\n   /**\r\n    * A string representing the attribute of the node to display.\r\n\r\n    * **Default value: `name`**\r\n\r\n      For example, if your nodes have a `title` attribute that should be displayed, use:\r\n      ```\r\n        options = { displayField: 'title' }\r\n      ```\r\n    */\r\n   displayField?: string;\r\n   /**\r\n    * A string representing the attribute of the node that contains the unique ID.\r\n      This will be used to construct the `path`, which is an array of IDs that point to the node.\r\n\r\n      * **Default value: `id`.**\r\n\r\n      For example, if your nodes have a `uuid` attribute, that contains the unique key, use:\r\n      ```\r\n        options = { idField: 'uuid' }\r\n      ```\r\n    */\r\n   idField?: string;\r\n   /**\r\n    * A string representing the attribute of the node that contains whether the node starts as expanded.\r\n\r\n      * **Default value: `isExpanded`.**\r\n\r\n      For example, if your nodes have an `expanded` attribute, that contains a boolean value, use:\r\n      ```\r\n        options = { isExpandedField: 'expanded' }\r\n      ```\r\n    */\r\n   isExpandedField?: string;\r\n   /**\r\n    * Function for loading a node's children.\r\n      The function receives a TreeNode, and returns a value or a promise that resolves to the node's children.\r\n\r\n      This function will be called whenever a node is expanded, the `hasChildren` (`options.hasChildrenField`)\r\n      field is true, and the `children` field is empty.\r\n      The result will be loaded into the node's children attribute.\r\n\r\n      Example:\r\n      ```\r\n      * options = {\r\n      *   getChildren: (node:TreeNode) => {\r\n      *     return request('/api/children/' + node.id);\r\n      *   }\r\n      * }\r\n      ```\r\n    */\r\n   getChildren?: (node: TreeNode) => any;\r\n   /**\r\n    * Rewire which trigger causes which action using this attribute, or create custom actions / event bindings.\r\n    * See the [Action Mapping Section](https://angular2-tree.readme.io/docs/action-mapping) for more details.\r\n    */\r\n   actionMapping?: any;\r\n   /**\r\n    * Specify if dragging tree nodes is allowed.\r\n    * This could be a boolean, or a function that receives a TreeNode and returns a boolean\r\n\r\n    * **Default value: false**\r\n\r\n    Example:\r\n    ```\r\n    * options = {\r\n    *  allowDrag: true\r\n    * }\r\n    ```\r\n    */\r\n   allowDrag?: boolean | IAllowDragFn;\r\n   /**\r\n    * Specify whether dropping inside the tree is allowed. Optional types:\r\n    *  - boolean\r\n    *  - (element:any, to:{parent:TreeNode, index:number}):boolean\r\n         A function that receives the dragged element, and the drop location (parent node and index inside the parent),\r\n         and returns true or false.\r\n\r\n    * **Default Value: true**\r\n\r\n    example:\r\n    ```\r\n    * options = {\r\n    *  allowDrop: (element, {parent, index}) => parent.isLeaf\r\n    * }\r\n    ```\r\n   */\r\n   allowDrop?: boolean | IAllowDropFn;\r\n    /**\r\n    Boolean flag to allow adding and removing is-dragging-over and is-dragging-over-disabled classes.\r\n\r\n    If set to false it will not add the above mentioned classes and you should handle the styling yourself with css and in\r\n    the actionMapping -> mouse -> dragEnter, dragLeave\r\n\r\n    * **Default Value: true**\r\n\r\n    example:\r\n    ```\r\n    * options = {\r\n    *   allowDrop: true,\r\n    *   allowDragoverStyling: false\r\n    * }\r\n    ```\r\n    */\r\n   allowDragoverStyling?: boolean;\r\n   /**\r\n   * Specify padding per node (integer).\r\n    Each node will have padding-left value of level * levelPadding, instead of using the default padding for children.\r\n\r\n    This option is good for example for allowing whole row selection, etc.\r\n\r\n    You can alternatively use the tree-node-level-X classes to give padding on a per-level basis.\r\n\r\n    * **Default value: 0**\r\n   */\r\n   levelPadding?: number;\r\n   /**\r\n    * Specify a function that returns a class per node. Useful for styling the nodes individually.\r\n\r\n      Example:\r\n      ```\r\n      * options = {\r\n      *   nodeClass: (node:TreeNode) => {\r\n      *     return 'icon-' + node.data.icon;\r\n      *   }\r\n      * }\r\n      ```\r\n    */\r\n   nodeClass?: (node: TreeNode) => string;\r\n   /**\r\n    Boolean flag to use the virtual scroll option.\r\n\r\n    To use this option, you must supply the height of the container, and the height of each node in the tree.\r\n\r\n    You can also specify height for the dropSlot which is located between nodes.\r\n\r\n    * **Default Value: false**\r\n\r\n    example:\r\n    ```\r\n    * options = {\r\n    *   useVirtualScroll: true,\r\n    *   nodeHeight: (node: TreeNode) => node.myHeight,\r\n    *   dropSlotHeight: 3\r\n    * }\r\n    ```\r\n    */\r\n   useVirtualScroll?: boolean;\r\n   /**\r\n    * For use with `useVirtualScroll` option.\r\n    * Specify a height for nodes in pixels. Could be either:\r\n    * - number\r\n    * - (node: TreeNode) => number\r\n\r\n    * **Default Value: 22**\r\n    */\r\n   nodeHeight?: number | INodeHeightFn;\r\n   /**\r\n    * For use with `useVirtualScroll` option.\r\n    * Specify a height for drop slots (located between nodes) in pixels\r\n\r\n    * **Default Value: 2**\r\n    */\r\n   dropSlotHeight?: number;\r\n   /**\r\n    * Boolean whether or not to animate expand / collapse of nodes.\r\n\r\n    * **Default Value: false**\r\n    */\r\n   animateExpand?: boolean;\r\n   /**\r\n    * Speed of expand animation (described in pixels per 17 ms).\r\n\r\n    * **Default Value: 30**\r\n    */\r\n   animateSpeed?: number;\r\n   /**\r\n    * Increase of expand animation speed (described in multiply per 17 ms).\r\n\r\n    * **Default Value: 1.2**\r\n    */\r\n   animateAcceleration?: number;\r\n   /**\r\n    * Whether to scroll to the node to make it visible when it is activated.\r\n\r\n    * **Default Value: true**\r\n    */\r\n   scrollOnActivate?: boolean;\r\n   /**\r\n    * Function to clone a node.\r\n    * Receives a TreeNode object, and returns a node object (only the data).\r\n    * This callback will be called when copying a node inside the tree,\r\n    * by either calling copyNode, or by dragging and holding the ctrl key\r\n    *\r\n    * For example:\r\n      ```\r\n        options: ITreeOptions = {\r\n          getNodeClone: (node) => ({\r\n            ...node.data,\r\n            id: uuid.v4(),\r\n            name: `copy of ${node.data.name}`\r\n          })\r\n        };\r\n      ```\r\n    *\r\n    * **Default Value: clone the node using Object.assign, and remove 'id' property**\r\n    */\r\n    getNodeClone?: (node: TreeNode) => any;\r\n    /**\r\n     * Makes the tree right-to-left.\r\n     * This include direction, expander style, and change key binding (right key collapse and left key expands instead of vice-versa)\r\n     */\r\n    rtl?: boolean;\r\n    /**\r\n     * Specifies id of root node (virtualRoot)\r\n     */\r\n    rootId?: any;\r\n    /**\r\n     * Whether to display a checkbox next to the node or not\r\n     */\r\n    useCheckbox?: boolean;\r\n    /**\r\n     * Whether to use master checkboxes mechanism if the useCheckbox is set to true\r\n     */\r\n    useTriState?: boolean;\r\n    /**\r\n     * The HTML element that is the scroll container for the tree.\r\n     * The default behaviour is to wrap the tree with a container that has overflow: hidden,\r\n     * and then the scrolling container is the viewport inside the tree component\r\n     */\r\n    scrollContainer?: HTMLElement;\r\n }\r\n\r\nexport interface ITreeNode {\r\n  // properties\r\n  /**\r\n   * Parent node\r\n   */\r\n  parent: ITreeNode;\r\n  /**\r\n   * The value of the node's field that is used for displaying its content.\r\n   * By default 'name', unless stated otherwise in the options\r\n   */\r\n  displayField: string;\r\n  /**\r\n   * The children of the node.\r\n   * By default is determined by 'node.data.children', unless stated otherwise in the options\r\n   */\r\n  children: ITreeNode[];\r\n  /**\r\n   * Pointer to the original data.\r\n   */\r\n  data: any;\r\n  /**\r\n   * Pointer to the ElementRef of the TreeNodeComponent that's displaying this node\r\n   */\r\n  elementRef: any;\r\n  /**\r\n   * Level in the tree (starts from 1).\r\n   */\r\n  level: number;\r\n  /**\r\n   * Path in the tree: Array of IDs.\r\n   */\r\n  path: string[];\r\n  /**\r\n   * index of the node inside its parent's children\r\n   */\r\n  index: number;\r\n  /**\r\n   * A unique key of this node among its siblings.\r\n   * By default it's the 'id' of the original node, unless stated otherwise in options.idField\r\n   */\r\n  id: IDType;\r\n\r\n  // helpers\r\n  isExpanded: boolean;\r\n  isActive: boolean;\r\n  isFocused: boolean;\r\n  isCollapsed: boolean;\r\n  isLeaf: boolean;\r\n  hasChildren: boolean;\r\n  isRoot: boolean;\r\n\r\n  // traversing\r\n  /**\r\n   * @param skipHidden whether to skip hidden nodes\r\n   * @returns next sibling (or null)\r\n   */\r\n  findNextSibling(skipHidden): ITreeNode;\r\n  /**\r\n   * @param skipHidden whether to skip hidden nodes\r\n   * @returns previous sibling (or null)\r\n   */\r\n  findPreviousSibling(skipHidden): ITreeNode;\r\n  /**\r\n   * @param skipHidden whether to skip hidden nodes\r\n   * @returns first child (or null)\r\n   */\r\n  getFirstChild(skipHidden): ITreeNode;\r\n  /**\r\n   * @param skipHidden whether to skip hidden nodes\r\n   * @returns last child (or null)\r\n   */\r\n  getLastChild(skipHidden): ITreeNode;\r\n  /**\r\n   * Finds the visually next node in the tree.\r\n   * @param goInside whether to look for children or just siblings\r\n   * @returns next node.\r\n   */\r\n  findNextNode(goInside: boolean): ITreeNode;\r\n  /**\r\n   * Finds the visually previous node in the tree.\r\n   * @param skipHidden whether to skip hidden nodes\r\n   * @returns previous node.\r\n   */\r\n  findPreviousNode(skipHidden): ITreeNode;\r\n\r\n  /**\r\n   * @returns      true if this node is a descendant of the parameter node\r\n   */\r\n  isDescendantOf(node: ITreeNode): boolean;\r\n\r\n  /**\r\n   * @returns      in case levelPadding option is supplied, returns the current node's padding\r\n   */\r\n  getNodePadding(): string;\r\n\r\n  /**\r\n   * @returns      in case nodeClass option is supplied, returns the current node's class\r\n   */\r\n  getClass(): string;\r\n\r\n  // actions\r\n  /**\r\n   * Expands / Collapses the node\r\n   */\r\n  toggleExpanded();\r\n  /**\r\n   * Expands the node\r\n   */\r\n  expand();\r\n  /**\r\n   * Collapses the node\r\n   */\r\n  collapse();\r\n  /**\r\n   * Expands all ancestors of the node\r\n   */\r\n  ensureVisible();\r\n  /**\r\n   * Activates / Deactivates the node (selects / deselects)\r\n   */\r\n  toggleActivated(multi);\r\n  /**\r\n   * Focus on the node\r\n   */\r\n  focus();\r\n  /**\r\n   * Blur (unfocus) the node\r\n   */\r\n  blur();\r\n  /**\r\n   * Hides the node\r\n   */\r\n  hide();\r\n  /**\r\n   * Makes the node visible\r\n   */\r\n  show();\r\n  /**\r\n   * @param value  if true makes the node hidden, otherwise visible\r\n   */\r\n  setIsHidden(value: boolean);\r\n  /**\r\n   * Scroll the screen to make the node visible\r\n   */\r\n  scrollIntoView();\r\n  /**\r\n   * Fire an event to the renderer of the tree (if it was registered)\r\n   */\r\n  fireEvent(event: any);\r\n  /**\r\n   * Invokes a method for every node under this one - depth first\r\n   * @param fn  a function that receives the node\r\n   */\r\n  doForAll(fn: (node: ITreeNode) => any);\r\n  /**\r\n   * expand all nodes under this one\r\n   */\r\n  expandAll();\r\n  /**\r\n   * collapse all nodes under this one\r\n   */\r\n  collapseAll();\r\n  /**\r\n   * sets the node to active / inactive according to the value.\r\n   * If multi is true (default false) - does a multiselect.\r\n   */\r\n  setIsActive(value: boolean, multi?: boolean);\r\n  /**\r\n   * sets the node to be active and makes sure it's visible by expanding all nodes above it and scrolling it into view.\r\n   * Very similar to calling `activate`, `ensureVisible` and `scrollIntoView` methods.\r\n   * If multi is true (default false) - does a multiselect.\r\n   */\r\n  setActiveAndVisible(multi: boolean);\r\n}\r\n\r\nexport interface ITreeModel {\r\n  // properties\r\n  /**\r\n   * All root nodes\r\n   */\r\n  roots: ITreeNode[];\r\n  /**\r\n   * Current focused node\r\n   */\r\n  focusedNode: ITreeNode;\r\n  /**\r\n   * Options that were passed to the tree component\r\n   */\r\n  options: ITreeOptions;\r\n\r\n  /**\r\n   * Is the tree currently focused\r\n   */\r\n  isFocused: boolean;\r\n  /**\r\n   * @returns Current active nodes\r\n   */\r\n  activeNodes: ITreeNode[];\r\n  /**\r\n   * @returns Current expanded nodes\r\n   */\r\n  expandedNodes: ITreeNode[];\r\n\r\n  // helpers\r\n  /**\r\n   * @returns Current active node. If multiple nodes are active - returns the first one.\r\n   */\r\n  getActiveNode(): ITreeNode;\r\n  /**\r\n   * @returns Current focused node (either hovered or traversed with keys)\r\n   */\r\n  getFocusedNode(): ITreeNode;\r\n  /**\r\n   * Set focus on a node\r\n   * @param value  true or false - whether to set focus or blur.\r\n   */\r\n  setFocusedNode(node: ITreeNode);\r\n  /**\r\n   * @param skipHidden  true or false - whether to skip hidden nodes\r\n   * @returns      first root of the tree\r\n   */\r\n  getFirstRoot(skipHidden?: boolean): ITreeNode;\r\n  /**\r\n   * @param skipHidden  true or false - whether to skip hidden nodes\r\n   * @returns      last root of the tree\r\n   */\r\n  getLastRoot(skipHidden?: boolean): ITreeNode;\r\n  /**\r\n   * @returns      true if the tree is empty\r\n   */\r\n  isEmptyTree(): boolean;\r\n  /**\r\n   * @returns All root nodes that pass the current filter\r\n   */\r\n  getVisibleRoots(): ITreeNode[];\r\n  /**\r\n   * @param     path  array of node IDs to be traversed respectively\r\n   * @param     startNode  optional. Which node to start traversing from\r\n   * @returns   The node, if found - null otherwise\r\n   */\r\n  getNodeByPath(path: any[], startNode?: ITreeNode): ITreeNode;\r\n  /**\r\n   * @param     id  node ID to find\r\n   * @returns   The node, if found - null otherwise\r\n   */\r\n  getNodeById(id: IDType): ITreeNode;\r\n  /**\r\n   * @param     predicate - either an object or a function, used as a test condition on all nodes.\r\n   *            Could be every predicate that's supported by javaScripts Array.prototype.find() method\r\n   * @param     startNode  optional. Which node to start traversing from\r\n   * @returns   First node that matches the predicate, if found - null otherwise\r\n   */\r\n  getNodeBy(predicate: any, startNode?: ITreeNode): ITreeNode;\r\n  /**\r\n   * get tree state\r\n   */\r\n  getState(): ITreeState;\r\n\r\n  // actions\r\n  /**\r\n   * Focuses or blurs the tree\r\n   * @param value  true or false - whether to set focus or blur.\r\n   */\r\n  setFocus(value: boolean);\r\n  /**\r\n   * Focuses on the next node in the tree (same as down arrow)\r\n   */\r\n  focusNextNode();\r\n  /**\r\n   * Focuses on the previous node in the tree (same as up arrow)\r\n   */\r\n  focusPreviousNode();\r\n  /**\r\n   * Focuses on the inner child of the current focused node (same as right arrow on an expanded node)\r\n   */\r\n  focusDrillDown();\r\n  /**\r\n   * Focuses on the parent of the current focused node (same as left arrow on a collapsed node)\r\n   */\r\n  focusDrillUp();\r\n  /**\r\n   * Marks isHidden field in all nodes recursively according to the filter param.\r\n   * If a node is marked visible, all of its ancestors will be marked visible as well.\r\n   * @param filter  either a string or a function.\r\n   *   In case it's a string, it will be searched case insensitively in the node's display attribute\r\n   *   In case it's a function, it will be passed the node, and should return true if the node should be visible, false otherwise\r\n   * @param autoShow  if true, make sure all nodes that passed the filter are visible\r\n   */\r\n  filterNodes(filter, autoShow?: boolean);\r\n  /**\r\n   * Marks all nodes isHidden = false\r\n   */\r\n  clearFilter();\r\n  /**\r\n   * moves a node from one location in the tree to another\r\n   * @param node describes which node needs to be moved\r\n   * @param to describes where to move the node to.\r\n   * @param from describes where to move the node from.\r\n   * Contains a 'parent' node, an 'index', and a 'dropOnNode' - to distinguish between dropping between nodes or on the node\r\n   */\r\n  moveNode(node: ITreeNode, to: {parent: ITreeNode, index: number, dropOnNode: boolean}, from: {parent: ITreeNode, index: number});\r\n  /**\r\n   * Invokes a method for every node of the tree - depth first\r\n   * @param fn  a function that receives the node\r\n   */\r\n  doForAll(fn: (node: ITreeNode) => any);\r\n  /**\r\n   * expand all nodes\r\n   */\r\n  expandAll();\r\n  /**\r\n   * collapse all nodes\r\n   */\r\n  collapseAll();\r\n  /**\r\n   * set tree state\r\n   */\r\n  setState(state: ITreeState);\r\n\r\n  subscribeToState(fn: (state: ITreeState) => any);\r\n}\r\n/**\r\n * This is the interface of the TreeNodeDrag service\r\n */\r\nexport interface ITreeNodeDrag {\r\n  /**\r\n   * Gets the current dragged node. Useful for overriding the drop action.\r\n   * @param node  The parent node of the current dragged node\r\n   * @param index  The index inside parent's children, of the current dragged node\r\n   */\r\n  getDragNode(): { node: TreeNode, index: number };\r\n}\r\n"]}
|