@dangl/angular-ava 0.1.1-beta0093

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/README.md +1 -0
  2. package/esm2022/dangl-angular-ava.mjs +5 -0
  3. package/esm2022/lib/angular-ava.module.mjs +91 -0
  4. package/esm2022/lib/ava-tree/tree/components/ava-tree/ava-tree.component.mjs +412 -0
  5. package/esm2022/lib/ava-tree/tree/components/list-structure/list-structure.component.mjs +41 -0
  6. package/esm2022/lib/ava-tree/tree/components/table-structure/table-structure.component.mjs +110 -0
  7. package/esm2022/lib/ava-tree/tree/components/tree-item/tree-item.component.mjs +102 -0
  8. package/esm2022/lib/ava-tree/tree/components/tree-node/tree-node.component.mjs +53 -0
  9. package/esm2022/lib/ava-tree/tree/components/tree-structure/tree-structure.component.mjs +33 -0
  10. package/esm2022/lib/ava-tree/tree/constants/defaultFilters.mjs +23 -0
  11. package/esm2022/lib/ava-tree/tree/constants/defaultTextWords.mjs +11 -0
  12. package/esm2022/lib/ava-tree/tree/constants/defaults.mjs +4 -0
  13. package/esm2022/lib/ava-tree/tree/constants/index.mjs +5 -0
  14. package/esm2022/lib/ava-tree/tree/directives/save-changing-view.directive.mjs +47 -0
  15. package/esm2022/lib/ava-tree/tree/model/ava-models.mjs +199 -0
  16. package/esm2022/lib/ava-tree/tree/model/context-menu-data.model.mjs +2 -0
  17. package/esm2022/lib/ava-tree/tree/model/function-view-line.model.mjs +2 -0
  18. package/esm2022/lib/ava-tree/tree/model/index.mjs +4 -0
  19. package/esm2022/lib/ava-tree/tree/model/selecting.model.mjs +2 -0
  20. package/esm2022/lib/ava-tree/tree/model/tableColumnType.mjs +2 -0
  21. package/esm2022/lib/ava-tree/tree/model/tree-mode.model.mjs +7 -0
  22. package/esm2022/lib/ava-tree/tree/pipes/element-icon-name.pipe.mjs +27 -0
  23. package/esm2022/lib/ava-tree/tree/pipes/element-item-number.pipe.mjs +23 -0
  24. package/esm2022/lib/ava-tree/tree/pipes/element-text.pipe.mjs +27 -0
  25. package/esm2022/lib/ava-tree/tree/pipes/group-child-elements.pipe.mjs +20 -0
  26. package/esm2022/lib/ava-tree/tree/services/expand-parent-group.service.mjs +32 -0
  27. package/esm2022/lib/ava-tree/tree/services/flat-elements.service.mjs +96 -0
  28. package/esm2022/lib/ava-tree/tree/services/keyboard-operation.service.mjs +116 -0
  29. package/esm2022/lib/ava-tree/tree/services/select-element.service.mjs +41 -0
  30. package/esm2022/lib/ava-tree/tree/services/tree-node-selection.service.mjs +133 -0
  31. package/esm2022/lib/version.mjs +10 -0
  32. package/esm2022/public-api.mjs +8 -0
  33. package/fesm2022/dangl-angular-ava.mjs +1574 -0
  34. package/fesm2022/dangl-angular-ava.mjs.map +1 -0
  35. package/index.d.ts +5 -0
  36. package/lib/angular-ava.module.d.ts +27 -0
  37. package/lib/ava-tree/tree/components/ava-tree/ava-tree.component.d.ts +165 -0
  38. package/lib/ava-tree/tree/components/list-structure/list-structure.component.d.ts +18 -0
  39. package/lib/ava-tree/tree/components/table-structure/table-structure.component.d.ts +34 -0
  40. package/lib/ava-tree/tree/components/tree-item/tree-item.component.d.ts +35 -0
  41. package/lib/ava-tree/tree/components/tree-node/tree-node.component.d.ts +23 -0
  42. package/lib/ava-tree/tree/components/tree-structure/tree-structure.component.d.ts +14 -0
  43. package/lib/ava-tree/tree/constants/defaultFilters.d.ts +2 -0
  44. package/lib/ava-tree/tree/constants/defaultTextWords.d.ts +11 -0
  45. package/lib/ava-tree/tree/constants/defaults.d.ts +3 -0
  46. package/lib/ava-tree/tree/constants/index.d.ts +4 -0
  47. package/lib/ava-tree/tree/directives/save-changing-view.directive.d.ts +13 -0
  48. package/lib/ava-tree/tree/model/ava-models.d.ts +1041 -0
  49. package/lib/ava-tree/tree/model/context-menu-data.model.d.ts +8 -0
  50. package/lib/ava-tree/tree/model/function-view-line.model.d.ts +12 -0
  51. package/lib/ava-tree/tree/model/index.d.ts +7 -0
  52. package/lib/ava-tree/tree/model/selecting.model.d.ts +14 -0
  53. package/lib/ava-tree/tree/model/tableColumnType.d.ts +6 -0
  54. package/lib/ava-tree/tree/model/tree-mode.model.d.ts +5 -0
  55. package/lib/ava-tree/tree/pipes/element-icon-name.pipe.d.ts +8 -0
  56. package/lib/ava-tree/tree/pipes/element-item-number.pipe.d.ts +8 -0
  57. package/lib/ava-tree/tree/pipes/element-text.pipe.d.ts +8 -0
  58. package/lib/ava-tree/tree/pipes/group-child-elements.pipe.d.ts +8 -0
  59. package/lib/ava-tree/tree/services/expand-parent-group.service.d.ts +7 -0
  60. package/lib/ava-tree/tree/services/flat-elements.service.d.ts +28 -0
  61. package/lib/ava-tree/tree/services/keyboard-operation.service.d.ts +35 -0
  62. package/lib/ava-tree/tree/services/select-element.service.d.ts +31 -0
  63. package/lib/ava-tree/tree/services/tree-node-selection.service.d.ts +23 -0
  64. package/lib/version.d.ts +8 -0
  65. package/package.json +31 -0
  66. package/public-api.d.ts +4 -0
package/README.md ADDED
@@ -0,0 +1 @@
1
+ # Dangl.AngularAva
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGFuZ2wtYW5ndWxhci1hdmEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWF2YS9zcmMvZGFuZ2wtYW5ndWxhci1hdmEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -0,0 +1,91 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
+ import { MatButtonModule } from '@angular/material/button';
5
+ import { MatCheckboxModule } from '@angular/material/checkbox';
6
+ import { MatRippleModule } from '@angular/material/core';
7
+ import { MatFormFieldModule } from '@angular/material/form-field';
8
+ import { MatIconModule } from '@angular/material/icon';
9
+ import { MatInputModule } from '@angular/material/input';
10
+ import { MatTableModule } from '@angular/material/table';
11
+ import { MatTooltipModule } from '@angular/material/tooltip';
12
+ import { AvaTreeComponent } from './ava-tree/tree/components/ava-tree/ava-tree.component';
13
+ import { ListStructureComponent } from './ava-tree/tree/components/list-structure/list-structure.component';
14
+ import { TableStructureComponent } from './ava-tree/tree/components/table-structure/table-structure.component';
15
+ import { TreeItemComponent } from './ava-tree/tree/components/tree-item/tree-item.component';
16
+ import { TreeNodeComponent } from './ava-tree/tree/components/tree-node/tree-node.component';
17
+ import { TreeStructureComponent } from './ava-tree/tree/components/tree-structure/tree-structure.component';
18
+ import { SaveChangingViewDirective } from './ava-tree/tree/directives/save-changing-view.directive';
19
+ import { ElementIconNamePipe } from './ava-tree/tree/pipes/element-icon-name.pipe';
20
+ import { ElementItemNumberPipe } from './ava-tree/tree/pipes/element-item-number.pipe';
21
+ import { ElementTextPipe } from './ava-tree/tree/pipes/element-text.pipe';
22
+ import { GroupChildElementsPipe } from './ava-tree/tree/pipes/group-child-elements.pipe';
23
+ import * as i0 from "@angular/core";
24
+ export class AngularAvaModule {
25
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: AngularAvaModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
26
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.2.1", ngImport: i0, type: AngularAvaModule, declarations: [TreeStructureComponent,
27
+ TreeNodeComponent,
28
+ AvaTreeComponent,
29
+ TreeItemComponent,
30
+ ListStructureComponent,
31
+ TableStructureComponent,
32
+ ElementIconNamePipe,
33
+ ElementTextPipe,
34
+ GroupChildElementsPipe,
35
+ ElementItemNumberPipe,
36
+ SaveChangingViewDirective], imports: [CommonModule,
37
+ MatIconModule,
38
+ MatRippleModule,
39
+ MatInputModule,
40
+ MatFormFieldModule,
41
+ ReactiveFormsModule,
42
+ FormsModule,
43
+ MatButtonModule,
44
+ MatCheckboxModule,
45
+ MatTableModule,
46
+ MatTooltipModule], exports: [AvaTreeComponent] }); }
47
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: AngularAvaModule, imports: [CommonModule,
48
+ MatIconModule,
49
+ MatRippleModule,
50
+ MatInputModule,
51
+ MatFormFieldModule,
52
+ ReactiveFormsModule,
53
+ FormsModule,
54
+ MatButtonModule,
55
+ MatCheckboxModule,
56
+ MatTableModule,
57
+ MatTooltipModule] }); }
58
+ }
59
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: AngularAvaModule, decorators: [{
60
+ type: NgModule,
61
+ args: [{
62
+ declarations: [
63
+ TreeStructureComponent,
64
+ TreeNodeComponent,
65
+ AvaTreeComponent,
66
+ TreeItemComponent,
67
+ ListStructureComponent,
68
+ TableStructureComponent,
69
+ ElementIconNamePipe,
70
+ ElementTextPipe,
71
+ GroupChildElementsPipe,
72
+ ElementItemNumberPipe,
73
+ SaveChangingViewDirective
74
+ ],
75
+ imports: [
76
+ CommonModule,
77
+ MatIconModule,
78
+ MatRippleModule,
79
+ MatInputModule,
80
+ MatFormFieldModule,
81
+ ReactiveFormsModule,
82
+ FormsModule,
83
+ MatButtonModule,
84
+ MatCheckboxModule,
85
+ MatTableModule,
86
+ MatTooltipModule
87
+ ],
88
+ exports: [AvaTreeComponent]
89
+ }]
90
+ }] });
91
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1hdmEubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci1hdmEvc3JjL2xpYi9hbmd1bGFyLWF2YS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFN0QsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0RBQXdELENBQUM7QUFDMUYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDNUcsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sc0VBQXNFLENBQUM7QUFDL0csT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMERBQTBELENBQUM7QUFDN0YsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMERBQTBELENBQUM7QUFDN0YsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDNUcsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDcEcsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDbkYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDdkYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGlEQUFpRCxDQUFDOztBQStCekYsTUFBTSxPQUFPLGdCQUFnQjs4R0FBaEIsZ0JBQWdCOytHQUFoQixnQkFBZ0IsaUJBM0J6QixzQkFBc0I7WUFDdEIsaUJBQWlCO1lBQ2pCLGdCQUFnQjtZQUNoQixpQkFBaUI7WUFDakIsc0JBQXNCO1lBQ3RCLHVCQUF1QjtZQUN2QixtQkFBbUI7WUFDbkIsZUFBZTtZQUNmLHNCQUFzQjtZQUN0QixxQkFBcUI7WUFDckIseUJBQXlCLGFBR3pCLFlBQVk7WUFDWixhQUFhO1lBQ2IsZUFBZTtZQUNmLGNBQWM7WUFDZCxrQkFBa0I7WUFDbEIsbUJBQW1CO1lBQ25CLFdBQVc7WUFDWCxlQUFlO1lBQ2YsaUJBQWlCO1lBQ2pCLGNBQWM7WUFDZCxnQkFBZ0IsYUFFUixnQkFBZ0I7K0dBRWYsZ0JBQWdCLFlBZHpCLFlBQVk7WUFDWixhQUFhO1lBQ2IsZUFBZTtZQUNmLGNBQWM7WUFDZCxrQkFBa0I7WUFDbEIsbUJBQW1CO1lBQ25CLFdBQVc7WUFDWCxlQUFlO1lBQ2YsaUJBQWlCO1lBQ2pCLGNBQWM7WUFDZCxnQkFBZ0I7OzJGQUlQLGdCQUFnQjtrQkE3QjVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHNCQUFzQjt3QkFDdEIsaUJBQWlCO3dCQUNqQixnQkFBZ0I7d0JBQ2hCLGlCQUFpQjt3QkFDakIsc0JBQXNCO3dCQUN0Qix1QkFBdUI7d0JBQ3ZCLG1CQUFtQjt3QkFDbkIsZUFBZTt3QkFDZixzQkFBc0I7d0JBQ3RCLHFCQUFxQjt3QkFDckIseUJBQXlCO3FCQUMxQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxrQkFBa0I7d0JBQ2xCLG1CQUFtQjt3QkFDbkIsV0FBVzt3QkFDWCxlQUFlO3dCQUNmLGlCQUFpQjt3QkFDakIsY0FBYzt3QkFDZCxnQkFBZ0I7cUJBQ2pCO29CQUNELE9BQU8sRUFBRSxDQUFDLGdCQUFnQixDQUFDO2lCQUM1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0Q2hlY2tib3hNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jaGVja2JveCc7XG5pbXBvcnQgeyBNYXRSaXBwbGVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQgeyBNYXRUYWJsZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3RhYmxlJztcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcblxuaW1wb3J0IHsgQXZhVHJlZUNvbXBvbmVudCB9IGZyb20gJy4vYXZhLXRyZWUvdHJlZS9jb21wb25lbnRzL2F2YS10cmVlL2F2YS10cmVlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBMaXN0U3RydWN0dXJlQ29tcG9uZW50IH0gZnJvbSAnLi9hdmEtdHJlZS90cmVlL2NvbXBvbmVudHMvbGlzdC1zdHJ1Y3R1cmUvbGlzdC1zdHJ1Y3R1cmUuY29tcG9uZW50JztcbmltcG9ydCB7IFRhYmxlU3RydWN0dXJlQ29tcG9uZW50IH0gZnJvbSAnLi9hdmEtdHJlZS90cmVlL2NvbXBvbmVudHMvdGFibGUtc3RydWN0dXJlL3RhYmxlLXN0cnVjdHVyZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgVHJlZUl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2F2YS10cmVlL3RyZWUvY29tcG9uZW50cy90cmVlLWl0ZW0vdHJlZS1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUcmVlTm9kZUNvbXBvbmVudCB9IGZyb20gJy4vYXZhLXRyZWUvdHJlZS9jb21wb25lbnRzL3RyZWUtbm9kZS90cmVlLW5vZGUuY29tcG9uZW50JztcbmltcG9ydCB7IFRyZWVTdHJ1Y3R1cmVDb21wb25lbnQgfSBmcm9tICcuL2F2YS10cmVlL3RyZWUvY29tcG9uZW50cy90cmVlLXN0cnVjdHVyZS90cmVlLXN0cnVjdHVyZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2F2ZUNoYW5naW5nVmlld0RpcmVjdGl2ZSB9IGZyb20gJy4vYXZhLXRyZWUvdHJlZS9kaXJlY3RpdmVzL3NhdmUtY2hhbmdpbmctdmlldy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRWxlbWVudEljb25OYW1lUGlwZSB9IGZyb20gJy4vYXZhLXRyZWUvdHJlZS9waXBlcy9lbGVtZW50LWljb24tbmFtZS5waXBlJztcbmltcG9ydCB7IEVsZW1lbnRJdGVtTnVtYmVyUGlwZSB9IGZyb20gJy4vYXZhLXRyZWUvdHJlZS9waXBlcy9lbGVtZW50LWl0ZW0tbnVtYmVyLnBpcGUnO1xuaW1wb3J0IHsgRWxlbWVudFRleHRQaXBlIH0gZnJvbSAnLi9hdmEtdHJlZS90cmVlL3BpcGVzL2VsZW1lbnQtdGV4dC5waXBlJztcbmltcG9ydCB7IEdyb3VwQ2hpbGRFbGVtZW50c1BpcGUgfSBmcm9tICcuL2F2YS10cmVlL3RyZWUvcGlwZXMvZ3JvdXAtY2hpbGQtZWxlbWVudHMucGlwZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFRyZWVTdHJ1Y3R1cmVDb21wb25lbnQsXG4gICAgVHJlZU5vZGVDb21wb25lbnQsXG4gICAgQXZhVHJlZUNvbXBvbmVudCxcbiAgICBUcmVlSXRlbUNvbXBvbmVudCxcbiAgICBMaXN0U3RydWN0dXJlQ29tcG9uZW50LFxuICAgIFRhYmxlU3RydWN0dXJlQ29tcG9uZW50LFxuICAgIEVsZW1lbnRJY29uTmFtZVBpcGUsXG4gICAgRWxlbWVudFRleHRQaXBlLFxuICAgIEdyb3VwQ2hpbGRFbGVtZW50c1BpcGUsXG4gICAgRWxlbWVudEl0ZW1OdW1iZXJQaXBlLFxuICAgIFNhdmVDaGFuZ2luZ1ZpZXdEaXJlY3RpdmVcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBNYXRJY29uTW9kdWxlLFxuICAgIE1hdFJpcHBsZU1vZHVsZSxcbiAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICBNYXRGb3JtRmllbGRNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0Q2hlY2tib3hNb2R1bGUsXG4gICAgTWF0VGFibGVNb2R1bGUsXG4gICAgTWF0VG9vbHRpcE1vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbQXZhVHJlZUNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQW5ndWxhckF2YU1vZHVsZSB7fVxuIl19
@@ -0,0 +1,412 @@
1
+ import { Component, EventEmitter, Input, Output, Self, ViewChild } from '@angular/core';
2
+ import { ReplaySubject, Subject, debounceTime, filter, fromEvent, takeUntil } from 'rxjs';
3
+ import { DEFAULT_FILTERS, DEFAULT_TEXT_WORDS } from '../../constants';
4
+ import { ModeViewType } from '../../model';
5
+ import { ExpandParentGroupService } from '../../services/expand-parent-group.service';
6
+ import { FlatElementsService } from '../../services/flat-elements.service';
7
+ import { KeyboardOperationService, KeyboardOperationType } from '../../services/keyboard-operation.service';
8
+ import { SelectElementService } from '../../services/select-element.service';
9
+ import { TreeNodeSelectionService } from '../../services/tree-node-selection.service';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "../../services/flat-elements.service";
12
+ import * as i2 from "../../services/select-element.service";
13
+ import * as i3 from "../../services/tree-node-selection.service";
14
+ import * as i4 from "../../services/expand-parent-group.service";
15
+ import * as i5 from "../../services/keyboard-operation.service";
16
+ import * as i6 from "@angular/common";
17
+ import * as i7 from "@angular/material/icon";
18
+ import * as i8 from "@angular/material/input";
19
+ import * as i9 from "@angular/material/form-field";
20
+ import * as i10 from "@angular/forms";
21
+ import * as i11 from "@angular/material/button";
22
+ import * as i12 from "@angular/material/tooltip";
23
+ import * as i13 from "../tree-structure/tree-structure.component";
24
+ import * as i14 from "../list-structure/list-structure.component";
25
+ import * as i15 from "../table-structure/table-structure.component";
26
+ export class AvaTreeComponent {
27
+ /**
28
+ * You can supply a map of strings to be used for the text in the tree. This allows you to translate
29
+ * the text in the tree to other languages.
30
+ * {
31
+ * textSearch: string,
32
+ * textNothing: string,
33
+ * textNothingFiltered: string,
34
+ * textAll: string,
35
+ * tooltipAllOpen: string,
36
+ * tooltipAllClose: string,
37
+ * tooltipAllAdd:string,
38
+ * tooltipAllRemove: string,
39
+ * }
40
+ */
41
+ set textWords(words) {
42
+ this._textWords = { ...this.textWords, ...words };
43
+ } // allow to translate all texts to other language
44
+ get textWords() {
45
+ return this._textWords;
46
+ }
47
+ /**
48
+ * With this parameter, you can configure which keys will be listenend to to switch the tree elements,
49
+ * and also to disable the functionality of the keys */
50
+ set customKeyboardOperationConfig(config) {
51
+ this.keyboardOperationService.mergeConfigOperation(config);
52
+ }
53
+ constructor(flatElementsService, selectElementService, treeNodeSelectionService, expandParentGroupService, keyboardOperationService, ngZone) {
54
+ this.flatElementsService = flatElementsService;
55
+ this.selectElementService = selectElementService;
56
+ this.treeNodeSelectionService = treeNodeSelectionService;
57
+ this.expandParentGroupService = expandParentGroupService;
58
+ this.keyboardOperationService = keyboardOperationService;
59
+ this.ngZone = ngZone;
60
+ /**
61
+ * This is the main data element for the tree structure. You should supply a ProjectDto with
62
+ * exactly one service specification in it.
63
+ */
64
+ this.project = null;
65
+ /**
66
+ * Optionally, you can supply a map of expansion states for the tree. The keys should be the
67
+ * id properties of the elements in the tree, and the values should be true if the element is
68
+ * expanded, and false if it is collapsed.
69
+ */
70
+ this.expansionState = {};
71
+ /**
72
+ * Optionally, you can supply the id of the node that should be selected in the tree initially.
73
+ */
74
+ this.selectedNodeId = null;
75
+ /**
76
+ * Optional, defaults to 20px. If this is set, then the tree will be indented by the given value each level.
77
+ * This can be any valid CSS value for the padding-left property, such as 20px, 1em, or 5%.
78
+ *
79
+ */
80
+ this.indent = '20px';
81
+ /**
82
+ * Optional, you can supply a color to be used as the background color for the selected line. Defaults to the primary
83
+ * color from the Material theme, which is #00acc1.
84
+ */
85
+ this.selectedColor = null;
86
+ /**
87
+ * You can specify which view type to use for the tree. The default is ModeViewType.Tree, but you can also use
88
+ * ModeViewType.List or ModeViewType.Table.
89
+ */
90
+ this.modeView = ModeViewType.Tree;
91
+ /** Optional, defaults to true. If this is disabled, then the double click event for elements is not raised,
92
+ * and clicking on an elemt sends an immediate result since the component has not to wait and check if a double click event
93
+ * is fired.
94
+ */
95
+ this.allowDblClick = true;
96
+ /**
97
+ * If this is set to true, then the tree will be in selection mode, and the user can select elements
98
+ * by clicking on them. The selected elements will be emitted in the selectedElementsChanged event.
99
+ */
100
+ this.isSelectionMode = false;
101
+ /**
102
+ * You can optionally supply a list of elements that should be selected initially. This is only used if
103
+ * isSelectionMode is true.
104
+ */
105
+ this.initiallySelectedElements = null;
106
+ this._textWords = null;
107
+ /**
108
+ * Defaults to true. If this is enabled, then navigating in the tree with the keyboard only works
109
+ * if the mouse is over the tree area. This limitation is useful if you have multiple trees or other components
110
+ * that might be using keyboard input.
111
+ */
112
+ this.mouseAwareKeyboardControl = true;
113
+ /**
114
+ * You can supply custom filters that are processed when the filter input is changed. Default filters are used
115
+ * that check for short text and item number matches, and you can either add custom filters or replace the default ones.
116
+ */
117
+ this.listFilterFunc = DEFAULT_FILTERS;
118
+ /**
119
+ * Optional. For table views, this allows you to add custom columns to the table.
120
+ * addTableColumns: Array of objects
121
+ * {
122
+ * name: string, // name of column
123
+ * title: string, // showed title of column
124
+ * align?: string, // optional alight: left(default) / center / right
125
+ * numberFormat?: string // optional format of number value, example: '1.2-2'
126
+ * }
127
+ */
128
+ this.addTableColumns = [];
129
+ /**
130
+ * This allows you to supply a list of functions that can be used to change the appearance of elements.
131
+ * They objects contain a predicate function that is evaluated, along with an option to configure the
132
+ * appearance of the element.
133
+ * functionView: Array of objects
134
+ * {
135
+ * name: string, // name of view part: you can add/remove it when it need
136
+ * func: (element: any, result?: any) => boolean, // this filter function calculate condition to change view
137
+ * view: {
138
+ * iconName?: string, // changed name of icon
139
+ * iconColor?: string, // changed color of icon
140
+ * textBold?: string, // changed weight of text
141
+ * textColor?: string // changed color of text
142
+ * }
143
+ * }
144
+ */
145
+ this.functionView = null;
146
+ this.selectClick = new EventEmitter(); // event after element selected by click
147
+ this.selectDblClick = new EventEmitter(); // event after element selected by double click
148
+ this.contextMenuEvent = new EventEmitter(); // event after element call context menu by right button click
149
+ this.selectedElementsChanged = new EventEmitter(); // event after changed selecting in selecting mode
150
+ this.selectedElement = null;
151
+ this.isListenKeyboard = false;
152
+ this.isEmiteSelectedElements = false;
153
+ this.selectingElementsTreeData = [];
154
+ this.flatElements = null;
155
+ this.preselectedElement = null;
156
+ this.filterInput = '';
157
+ this.listModeViewType = ModeViewType;
158
+ this.filter = '';
159
+ this.$filter = new ReplaySubject(1);
160
+ this.filteredElementList = [];
161
+ this.$destroy = new Subject();
162
+ this._textWords = { ...DEFAULT_TEXT_WORDS };
163
+ }
164
+ ngOnInit() {
165
+ this.selectElementService.preselectedElement.pipe(takeUntil(this.$destroy)).subscribe((e) => (this.preselectedElement = e));
166
+ this.selectElementService.selectClickElement.pipe(takeUntil(this.$destroy)).subscribe((e) => {
167
+ this.selectedElement = e;
168
+ this.selectClick.emit(e);
169
+ });
170
+ this.selectElementService.selectDblClickElement.pipe(takeUntil(this.$destroy)).subscribe((e) => this.selectDblClick.emit(e));
171
+ this.selectElementService.selectContextMenuElement.pipe(takeUntil(this.$destroy)).subscribe((e) => this.contextMenuEvent.emit(e));
172
+ this.flatElementsService.flatElementsDto.pipe(takeUntil(this.$destroy)).subscribe((e) => {
173
+ this.flatElements = e;
174
+ this.getFilteredList();
175
+ });
176
+ this.$filter.pipe(takeUntil(this.$destroy), debounceTime(250)).subscribe((filter) => {
177
+ this.filter = filter;
178
+ this.getFilteredList();
179
+ });
180
+ }
181
+ ngAfterViewInit() {
182
+ this.initializeEventListeners();
183
+ }
184
+ ngOnChanges(changes) {
185
+ this.flatElementsService.listFilterFunc = this.listFilterFunc;
186
+ this.flatElementsService.functionView = this.functionView;
187
+ if (changes['project'] && this.project?.serviceSpecifications?.[0]) {
188
+ this.serviceSpecification = this.project.serviceSpecifications[0];
189
+ this.flatElementsService.setElementsDto(this.serviceSpecification);
190
+ if (this.isSelectionMode) {
191
+ this.selectingElementsTreeData = this.treeNodeSelectionService.loadSelectingElements(this.serviceSpecification.elements);
192
+ this.treeNodeSelectionService.treeNodeSelecting.pipe(takeUntil(this.$destroy)).subscribe(() => {
193
+ if (this.isEmiteSelectedElements) {
194
+ setTimeout(() => {
195
+ const selectingTree = this.treeNodeSelectionService.getTreeRoot(this.selectingElementsTreeData);
196
+ this.selectedElementsChanged.emit(selectingTree);
197
+ }, 0);
198
+ }
199
+ });
200
+ }
201
+ }
202
+ if ((changes['selectedNodeId'] && this.project) || changes['project']) {
203
+ this.flatElementsService.getOneElementById(this.selectedNodeId).subscribe((e) => {
204
+ if (e) {
205
+ this.selectElementService.setClickElement(e);
206
+ }
207
+ });
208
+ }
209
+ if (this.isSelectionMode && (changes['initiallySelectedElements'] || changes['project'])) {
210
+ this.formSelectingList();
211
+ }
212
+ }
213
+ ngOnDestroy() {
214
+ this.$destroy.next(true);
215
+ this.$destroy.complete();
216
+ }
217
+ mouseOver() {
218
+ if (!this.isListenKeyboard) {
219
+ this.isListenKeyboard = true;
220
+ this.avaTreeFilterInput?.nativeElement.focus();
221
+ }
222
+ }
223
+ mouseOut() {
224
+ this.isListenKeyboard = false;
225
+ }
226
+ handleGlobalKeyboardEvent(event) {
227
+ this.ngZone.run(() => {
228
+ const keyEvent = event;
229
+ if (!this.mouseAwareKeyboardControl || this.isListenKeyboard) {
230
+ const element = this.preselectedElement || this.selectedElement;
231
+ const { operation, nextElement } = this.keyboardOperationService.handleKeyboardEvent(keyEvent, element) || { nextElement: null };
232
+ switch (operation) {
233
+ case KeyboardOperationType.MoveSelectedPositionUp:
234
+ this.showElement(nextElement, '.select');
235
+ break;
236
+ case KeyboardOperationType.MoveSelectedPositionDown:
237
+ this.showElement(nextElement, '.select');
238
+ break;
239
+ case KeyboardOperationType.MoveChosenPositionDown:
240
+ this.showElement(nextElement, nextElement?.id === this.selectedElement?.id ? '.select' : '.choose');
241
+ break;
242
+ case KeyboardOperationType.MoveChosenPositionUp:
243
+ this.showElement(nextElement, nextElement?.id === this.selectedElement?.id ? '.select' : '.choose');
244
+ break;
245
+ default:
246
+ break;
247
+ }
248
+ }
249
+ });
250
+ }
251
+ showElement(element, nameQuery) {
252
+ if (element) {
253
+ if (this.modeView === ModeViewType.Tree) {
254
+ this.expandParentGroups(element);
255
+ }
256
+ setTimeout(() => this.scrollLine(nameQuery), 0);
257
+ }
258
+ }
259
+ scrollLine(nameQuery) {
260
+ const parentRect = this.avaTreeWrapper?.nativeElement.getBoundingClientRect();
261
+ const showedElement = this.avaTreeWrapper?.nativeElement.querySelector(nameQuery);
262
+ if (!showedElement) {
263
+ return;
264
+ }
265
+ const childRect = showedElement.getBoundingClientRect();
266
+ if (childRect.bottom > parentRect.bottom ||
267
+ childRect.top < parentRect.top ||
268
+ (this.modeView === ModeViewType.Table && childRect.top < parentRect.top + 24)) {
269
+ showedElement?.scrollIntoView();
270
+ this.avaTreeWrapper?.nativeElement.scrollTo({ left: 0 });
271
+ if (this.modeView === ModeViewType.Table) {
272
+ setTimeout(() => this.correctScrollTableLine(showedElement, parentRect), 0);
273
+ }
274
+ }
275
+ }
276
+ correctScrollTableLine(showedElement, parentRect) {
277
+ const childRect = showedElement.getBoundingClientRect();
278
+ if (childRect.top < parentRect.top + 24) {
279
+ this.avaTreeWrapper.nativeElement.scrollTop -= 24;
280
+ }
281
+ }
282
+ expandParentGroups(element) {
283
+ this.expandParentGroupService.expandParentGroups(element, this.flatElements, this.expansionState);
284
+ }
285
+ onFilter(value) {
286
+ this.$filter.next(value);
287
+ }
288
+ changeAllElementsExpansionStatus(isExpanded) {
289
+ if (!isExpanded) {
290
+ Object.keys(this.expansionState).forEach((id) => delete this.expansionState[id]);
291
+ }
292
+ else {
293
+ this.flatElements?.forEach((item) => {
294
+ if (item.elementTypeDiscriminator === 'ServiceSpecificationGroupDto') {
295
+ this.expansionState[item.id] = true;
296
+ }
297
+ });
298
+ }
299
+ }
300
+ formSelectingList() {
301
+ this.isEmiteSelectedElements = false;
302
+ if (!this.initiallySelectedElements) {
303
+ this.isEmiteSelectedElements = true;
304
+ return;
305
+ }
306
+ this.treeNodeSelectionService.getFlatSelectedListId(this.initiallySelectedElements);
307
+ this.treeNodeSelectionService.flatSelectedListId.forEach((id, index) => {
308
+ this.treeNodeSelectionService.changeSelecting(true, id);
309
+ if (index === this.treeNodeSelectionService.flatSelectedListId.length - 1) {
310
+ this.isEmiteSelectedElements = true;
311
+ }
312
+ });
313
+ }
314
+ selectOrDeselectAll(value) {
315
+ this.treeNodeSelectionService.changeAll(value);
316
+ }
317
+ getFilteredList() {
318
+ if (this.flatElements?.length) {
319
+ if (!this.filter) {
320
+ this.filteredElementList = this.flatElements;
321
+ }
322
+ else {
323
+ this.filteredElementList = this.flatElements.filter((item) => this.flatElementsService.checkFilterValue(item, this.filter));
324
+ }
325
+ }
326
+ }
327
+ initializeEventListeners() {
328
+ this.ngZone.runOutsideAngular(() => {
329
+ fromEvent(this.avaMainWrapper.nativeElement, 'mouseleave')
330
+ .pipe(takeUntil(this.$destroy))
331
+ .subscribe(() => {
332
+ this.mouseOut();
333
+ });
334
+ fromEvent(this.avaMainWrapper.nativeElement, 'mouseenter')
335
+ .pipe(takeUntil(this.$destroy))
336
+ .subscribe(() => {
337
+ this.mouseOver();
338
+ });
339
+ if (!this.isSelectionMode) {
340
+ fromEvent(document, 'keydown')
341
+ .pipe(takeUntil(this.$destroy), filter(() => !this.mouseAwareKeyboardControl || this.isListenKeyboard))
342
+ .subscribe((event) => {
343
+ this.handleGlobalKeyboardEvent(event);
344
+ });
345
+ }
346
+ });
347
+ }
348
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: AvaTreeComponent, deps: [{ token: i1.FlatElementsService, self: true }, { token: i2.SelectElementService, self: true }, { token: i3.TreeNodeSelectionService, self: true }, { token: i4.ExpandParentGroupService, self: true }, { token: i5.KeyboardOperationService, self: true }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
349
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: AvaTreeComponent, selector: "ava-tree", inputs: { project: "project", expansionState: "expansionState", selectedNodeId: "selectedNodeId", indent: "indent", selectedColor: "selectedColor", modeView: "modeView", allowDblClick: "allowDblClick", isSelectionMode: "isSelectionMode", initiallySelectedElements: "initiallySelectedElements", textWords: "textWords", mouseAwareKeyboardControl: "mouseAwareKeyboardControl", customKeyboardOperationConfig: "customKeyboardOperationConfig", listFilterFunc: "listFilterFunc", addTableColumns: "addTableColumns", functionView: "functionView" }, outputs: { selectClick: "selectClick", selectDblClick: "selectDblClick", contextMenuEvent: "contextMenuEvent", selectedElementsChanged: "selectedElementsChanged" }, providers: [FlatElementsService, SelectElementService, TreeNodeSelectionService, ExpandParentGroupService, KeyboardOperationService], viewQueries: [{ propertyName: "avaTreeWrapper", first: true, predicate: ["avaTreeWrapper"], descendants: true }, { propertyName: "avaMainWrapper", first: true, predicate: ["avaMainWrapper"], descendants: true }, { propertyName: "avaTreeFilterInput", first: true, predicate: ["avaTreeFilterInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n class=\"main-wrapper\"\n #avaMainWrapper\n>\n <div\n class=\"control\"\n #control\n >\n <mat-form-field class=\"control-filter\">\n <mat-label>{{ textWords?.textSearch }}</mat-label>\n <input\n matInput\n [ngModel]=\"filterInput\"\n (ngModelChange)=\"onFilter($event)\"\n #avaTreeFilterInput\n />\n </mat-form-field>\n <ng-container *ngIf=\"modeView === listModeViewType.Tree\">\n <button\n class=\"control-icon\"\n mat-icon-button\n color=\"primary\"\n (click)=\"changeAllElementsExpansionStatus(true)\"\n [matTooltip]=\"textWords?.tooltipAllOpen || ''\"\n >\n <mat-icon class=\"layer-background\">layers</mat-icon>\n <mat-icon class=\"layer-icon\">add</mat-icon>\n </button>\n <button\n class=\"control-icon\"\n mat-icon-button\n color=\"primary\"\n (click)=\"changeAllElementsExpansionStatus(false)\"\n [matTooltip]=\"textWords?.tooltipAllClose || ''\"\n >\n <mat-icon class=\"layer-background\">layers</mat-icon>\n <mat-icon class=\"layer-icon\">remove</mat-icon>\n </button>\n </ng-container>\n <ng-container *ngIf=\"isSelectionMode\">\n <button\n mat-raised-button\n (click)=\"selectOrDeselectAll(true)\"\n [matTooltip]=\"textWords?.tooltipAllAdd || ''\"\n class=\"control-button\"\n >\n <mat-icon>add</mat-icon>\n <span>{{ textWords?.textAll }}</span>\n </button>\n <button\n mat-raised-button\n (click)=\"selectOrDeselectAll(false)\"\n [matTooltip]=\"textWords?.tooltipAllRemove || ''\"\n class=\"control-button\"\n >\n <mat-icon>remove</mat-icon>\n <span>{{ textWords?.textAll }}</span>\n </button>\n </ng-container>\n </div>\n <div\n [style.height]=\"'calc(100% - ' + control.offsetHeight + 'px)'\"\n class=\"ava-tree-wrapper\"\n #avaTreeWrapper\n >\n <ng-container *ngIf=\"flatElements?.length; else nothing\">\n <ng-container *ngIf=\"filteredElementList?.length; else nothingFiltered\">\n <ava-tree-structure\n *ngIf=\"modeView === listModeViewType.Tree && !avaTreeFilterInput.value\"\n [serviceSpecification]=\"serviceSpecification\"\n [indent]=\"indent\"\n [expansionState]=\"expansionState\"\n [isSelectionMode]=\"isSelectionMode\"\n [selectedColor]=\"selectedColor\"\n [allowDblClick]=\"allowDblClick\"\n >\n </ava-tree-structure>\n <ava-list-structure\n *ngIf=\"modeView === listModeViewType.List || (modeView === listModeViewType.Tree && avaTreeFilterInput.value)\"\n [filteredElementList]=\"filteredElementList\"\n [isSelectionMode]=\"isSelectionMode\"\n [selectedColor]=\"selectedColor\"\n [allowDblClick]=\"allowDblClick\"\n >\n </ava-list-structure>\n <ava-table-structure\n *ngIf=\"modeView === listModeViewType.Table\"\n [filteredElementList]=\"filteredElementList\"\n [isSelectionMode]=\"isSelectionMode\"\n [addTableColumns]=\"addTableColumns\"\n [selectedColor]=\"selectedColor\"\n [allowDblClick]=\"allowDblClick\"\n >\n </ava-table-structure>\n </ng-container>\n </ng-container>\n </div>\n</div>\n<ng-template #nothing>\n {{ textWords?.textNothing }}\n</ng-template>\n<ng-template #nothingFiltered>\n {{ textWords?.textNothingFiltered }}\n</ng-template>\n", styles: [".main-wrapper{max-height:100%;height:100%;overflow-y:auto;overflow-x:hidden}.control{display:flex;align-items:center;gap:5px;padding:4px}.control-filter{flex-grow:1}.control-icon{width:36px;height:36px;padding:0}.control-button{padding:0 5px}.ava-tree-wrapper{overflow-y:auto;overflow-x:hidden}::ng-deep .control .mat-mdc-form-field-subscript-wrapper{display:none}::ng-deep .control .control-filter .mat-mdc-form-field-infix{min-height:auto;padding-top:10px;padding-bottom:2px}::ng-deep .control .control-filter .mat-mdc-floating-label{top:18px}::ng-deep .control .control-filter .mdc-text-field{padding:0 6px}.layer-background{font-size:36px;width:36px;height:36px}.layer-icon{width:36px;height:36px;position:absolute;inset:1px 0 0;color:#fff}\n"], dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i8.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i9.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i9.MatLabel, selector: "mat-label" }, { kind: "directive", type: i10.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i11.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i11.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i12.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i13.TreeStructureComponent, selector: "ava-tree-structure", inputs: ["serviceSpecification", "indent", "expansionState", "isSelectionMode", "selectedColor", "allowDblClick"] }, { kind: "component", type: i14.ListStructureComponent, selector: "ava-list-structure", inputs: ["filteredElementList", "isSelectionMode", "selectedColor", "allowDblClick"] }, { kind: "component", type: i15.TableStructureComponent, selector: "ava-table-structure", inputs: ["filteredElementList", "isSelectionMode", "addTableColumns", "selectedColor", "allowDblClick"] }] }); }
350
+ }
351
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: AvaTreeComponent, decorators: [{
352
+ type: Component,
353
+ args: [{ selector: 'ava-tree', providers: [FlatElementsService, SelectElementService, TreeNodeSelectionService, ExpandParentGroupService, KeyboardOperationService], template: "<div\n class=\"main-wrapper\"\n #avaMainWrapper\n>\n <div\n class=\"control\"\n #control\n >\n <mat-form-field class=\"control-filter\">\n <mat-label>{{ textWords?.textSearch }}</mat-label>\n <input\n matInput\n [ngModel]=\"filterInput\"\n (ngModelChange)=\"onFilter($event)\"\n #avaTreeFilterInput\n />\n </mat-form-field>\n <ng-container *ngIf=\"modeView === listModeViewType.Tree\">\n <button\n class=\"control-icon\"\n mat-icon-button\n color=\"primary\"\n (click)=\"changeAllElementsExpansionStatus(true)\"\n [matTooltip]=\"textWords?.tooltipAllOpen || ''\"\n >\n <mat-icon class=\"layer-background\">layers</mat-icon>\n <mat-icon class=\"layer-icon\">add</mat-icon>\n </button>\n <button\n class=\"control-icon\"\n mat-icon-button\n color=\"primary\"\n (click)=\"changeAllElementsExpansionStatus(false)\"\n [matTooltip]=\"textWords?.tooltipAllClose || ''\"\n >\n <mat-icon class=\"layer-background\">layers</mat-icon>\n <mat-icon class=\"layer-icon\">remove</mat-icon>\n </button>\n </ng-container>\n <ng-container *ngIf=\"isSelectionMode\">\n <button\n mat-raised-button\n (click)=\"selectOrDeselectAll(true)\"\n [matTooltip]=\"textWords?.tooltipAllAdd || ''\"\n class=\"control-button\"\n >\n <mat-icon>add</mat-icon>\n <span>{{ textWords?.textAll }}</span>\n </button>\n <button\n mat-raised-button\n (click)=\"selectOrDeselectAll(false)\"\n [matTooltip]=\"textWords?.tooltipAllRemove || ''\"\n class=\"control-button\"\n >\n <mat-icon>remove</mat-icon>\n <span>{{ textWords?.textAll }}</span>\n </button>\n </ng-container>\n </div>\n <div\n [style.height]=\"'calc(100% - ' + control.offsetHeight + 'px)'\"\n class=\"ava-tree-wrapper\"\n #avaTreeWrapper\n >\n <ng-container *ngIf=\"flatElements?.length; else nothing\">\n <ng-container *ngIf=\"filteredElementList?.length; else nothingFiltered\">\n <ava-tree-structure\n *ngIf=\"modeView === listModeViewType.Tree && !avaTreeFilterInput.value\"\n [serviceSpecification]=\"serviceSpecification\"\n [indent]=\"indent\"\n [expansionState]=\"expansionState\"\n [isSelectionMode]=\"isSelectionMode\"\n [selectedColor]=\"selectedColor\"\n [allowDblClick]=\"allowDblClick\"\n >\n </ava-tree-structure>\n <ava-list-structure\n *ngIf=\"modeView === listModeViewType.List || (modeView === listModeViewType.Tree && avaTreeFilterInput.value)\"\n [filteredElementList]=\"filteredElementList\"\n [isSelectionMode]=\"isSelectionMode\"\n [selectedColor]=\"selectedColor\"\n [allowDblClick]=\"allowDblClick\"\n >\n </ava-list-structure>\n <ava-table-structure\n *ngIf=\"modeView === listModeViewType.Table\"\n [filteredElementList]=\"filteredElementList\"\n [isSelectionMode]=\"isSelectionMode\"\n [addTableColumns]=\"addTableColumns\"\n [selectedColor]=\"selectedColor\"\n [allowDblClick]=\"allowDblClick\"\n >\n </ava-table-structure>\n </ng-container>\n </ng-container>\n </div>\n</div>\n<ng-template #nothing>\n {{ textWords?.textNothing }}\n</ng-template>\n<ng-template #nothingFiltered>\n {{ textWords?.textNothingFiltered }}\n</ng-template>\n", styles: [".main-wrapper{max-height:100%;height:100%;overflow-y:auto;overflow-x:hidden}.control{display:flex;align-items:center;gap:5px;padding:4px}.control-filter{flex-grow:1}.control-icon{width:36px;height:36px;padding:0}.control-button{padding:0 5px}.ava-tree-wrapper{overflow-y:auto;overflow-x:hidden}::ng-deep .control .mat-mdc-form-field-subscript-wrapper{display:none}::ng-deep .control .control-filter .mat-mdc-form-field-infix{min-height:auto;padding-top:10px;padding-bottom:2px}::ng-deep .control .control-filter .mat-mdc-floating-label{top:18px}::ng-deep .control .control-filter .mdc-text-field{padding:0 6px}.layer-background{font-size:36px;width:36px;height:36px}.layer-icon{width:36px;height:36px;position:absolute;inset:1px 0 0;color:#fff}\n"] }]
354
+ }], ctorParameters: () => [{ type: i1.FlatElementsService, decorators: [{
355
+ type: Self
356
+ }] }, { type: i2.SelectElementService, decorators: [{
357
+ type: Self
358
+ }] }, { type: i3.TreeNodeSelectionService, decorators: [{
359
+ type: Self
360
+ }] }, { type: i4.ExpandParentGroupService, decorators: [{
361
+ type: Self
362
+ }] }, { type: i5.KeyboardOperationService, decorators: [{
363
+ type: Self
364
+ }] }, { type: i0.NgZone }], propDecorators: { project: [{
365
+ type: Input
366
+ }], expansionState: [{
367
+ type: Input
368
+ }], selectedNodeId: [{
369
+ type: Input
370
+ }], indent: [{
371
+ type: Input
372
+ }], selectedColor: [{
373
+ type: Input
374
+ }], modeView: [{
375
+ type: Input
376
+ }], allowDblClick: [{
377
+ type: Input
378
+ }], isSelectionMode: [{
379
+ type: Input
380
+ }], initiallySelectedElements: [{
381
+ type: Input
382
+ }], textWords: [{
383
+ type: Input
384
+ }], mouseAwareKeyboardControl: [{
385
+ type: Input
386
+ }], customKeyboardOperationConfig: [{
387
+ type: Input
388
+ }], listFilterFunc: [{
389
+ type: Input
390
+ }], addTableColumns: [{
391
+ type: Input
392
+ }], functionView: [{
393
+ type: Input
394
+ }], selectClick: [{
395
+ type: Output
396
+ }], selectDblClick: [{
397
+ type: Output
398
+ }], contextMenuEvent: [{
399
+ type: Output
400
+ }], selectedElementsChanged: [{
401
+ type: Output
402
+ }], avaTreeWrapper: [{
403
+ type: ViewChild,
404
+ args: ['avaTreeWrapper']
405
+ }], avaMainWrapper: [{
406
+ type: ViewChild,
407
+ args: ['avaMainWrapper']
408
+ }], avaTreeFilterInput: [{
409
+ type: ViewChild,
410
+ args: ['avaTreeFilterInput']
411
+ }] } });
412
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ava-tree.component.js","sourceRoot":"","sources":["../../../../../../../../projects/angular-ava/src/lib/ava-tree/tree/components/ava-tree/ava-tree.component.ts","../../../../../../../../projects/angular-ava/src/lib/ava-tree/tree/components/ava-tree/ava-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  Self,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\n\nimport { ReplaySubject, Subject, debounceTime, filter, fromEvent, takeUntil } from 'rxjs';\n\nimport { DEFAULT_FILTERS, DEFAULT_TEXT_WORDS } from '../../constants';\nimport { ITextWords } from '../../constants/defaultTextWords';\nimport {\n  ContextMenuDataType,\n  IElementDto,\n  IFunctionViewLine,\n  ModeViewType,\n  ProjectDto,\n  SelectedElement,\n  ServiceSpecificationDto,\n  TableColumnType\n} from '../../model';\nimport { SelectingElementsType } from '../../model/selecting.model';\nimport { ExpandParentGroupService } from '../../services/expand-parent-group.service';\nimport { FlatElementsService } from '../../services/flat-elements.service';\nimport { IKeyboardOperationConfig, KeyboardOperationService, KeyboardOperationType } from '../../services/keyboard-operation.service';\nimport { SelectElementService } from '../../services/select-element.service';\nimport { TreeNodeSelectionService } from '../../services/tree-node-selection.service';\n\n@Component({\n  selector: 'ava-tree',\n  templateUrl: './ava-tree.component.html',\n  styleUrls: ['./ava-tree.component.scss'],\n  providers: [FlatElementsService, SelectElementService, TreeNodeSelectionService, ExpandParentGroupService, KeyboardOperationService]\n})\nexport class AvaTreeComponent implements OnInit, OnChanges, OnDestroy, AfterViewInit {\n  /**\n   * This is the main data element for the tree structure. You should supply a ProjectDto with\n   * exactly one service specification in it.\n   */\n  @Input() project: ProjectDto | null = null;\n\n  /**\n   * Optionally, you can supply a map of expansion states for the tree. The keys should be the\n   * id properties of the elements in the tree, and the values should be true if the element is\n   * expanded, and false if it is collapsed.\n   */\n  @Input() expansionState: { [id: string]: boolean } = {};\n\n  /**\n   * Optionally, you can supply the id of the node that should be selected in the tree initially.\n   */\n  @Input() selectedNodeId: string | null = null;\n\n  /**\n   * Optional, defaults to 20px. If this is set, then the tree will be indented by the given value each level.\n   * This can be any valid CSS value for the padding-left property, such as 20px, 1em, or 5%.\n   *\n   */\n  @Input() indent = '20px';\n\n  /**\n   * Optional, you can supply a color to be used as the background color for the selected line. Defaults to the primary\n   * color from the Material theme, which is #00acc1.\n   */\n  @Input() selectedColor: string | null = null;\n\n  /**\n   * You can specify which view type to use for the tree. The default is ModeViewType.Tree, but you can also use\n   * ModeViewType.List or ModeViewType.Table.\n   */\n  @Input() modeView: ModeViewType = ModeViewType.Tree;\n\n  /** Optional, defaults to true. If this is disabled, then the double click event for elements is not raised,\n   * and clicking on an elemt sends an immediate result since the component has not to wait and check if a double click event\n   * is fired.\n   */\n  @Input() allowDblClick = true;\n\n  /**\n   * If this is set to true, then the tree will be in selection mode, and the user can select elements\n   * by clicking on them. The selected elements will be emitted in the selectedElementsChanged event.\n   */\n  @Input() isSelectionMode = false;\n\n  /**\n   * You can optionally supply a list of elements that should be selected initially. This is only used if\n   * isSelectionMode is true.\n   */\n  @Input() initiallySelectedElements: SelectedElement[] | null = null;\n\n  /**\n   * You can supply a map of strings to be used for the text in the tree. This allows you to translate\n   * the text in the tree to other languages.\n   * {\n   *   textSearch: string,\n   *   textNothing: string,\n   *   textNothingFiltered: string,\n   *   textAll: string,\n   *   tooltipAllOpen: string,\n   *   tooltipAllClose: string,\n   *   tooltipAllAdd:string,\n   *   tooltipAllRemove: string,\n   * }\n   */\n  @Input() set textWords(words: ITextWords | null) {\n    this._textWords = { ...this.textWords, ...words };\n  } // allow to translate all texts to other language\n  get textWords() {\n    return this._textWords;\n  }\n  private _textWords: ITextWords | null = null;\n\n  /**\n   * Defaults to true. If this is enabled, then navigating in the tree with the keyboard only works\n   * if the mouse is over the tree area. This limitation is useful if you have multiple trees or other components\n   * that might be using keyboard input.\n   */\n  @Input() mouseAwareKeyboardControl = true;\n\n  /**\n   * With this parameter, you can configure which keys will be listenend to to switch the tree elements,\n   * and also to disable the functionality of the keys */\n  @Input() set customKeyboardOperationConfig(config: IKeyboardOperationConfig) {\n    this.keyboardOperationService.mergeConfigOperation(config);\n  }\n\n  /**\n   * You can supply custom filters that are processed when the filter input is changed. Default filters are used\n   * that check for short text and item number matches, and you can either add custom filters or replace the default ones.\n   */\n  @Input() listFilterFunc = DEFAULT_FILTERS;\n\n  /**\n   * Optional. For table views, this allows you to add custom columns to the table.\n   * addTableColumns: Array of objects\n   * {\n   *   name: string,                                     // name of column\n   *   title: string,                                    // showed title of column\n   *   align?: string,                                   // optional alight: left(default) / center / right\n   *   numberFormat?: string                             // optional format of number value, example: '1.2-2'\n   * }\n   */\n  @Input() addTableColumns: TableColumnType[] = [];\n\n  /**\n   * This allows you to supply a list of functions that can be used to change the appearance of elements.\n   * They objects contain a predicate function that is evaluated, along with an option to configure the\n   * appearance of the element.\n   *   functionView: Array of objects\n   *   {\n   *     name: string,                                   // name of view part: you can add/remove it when it need\n   *     func: (element: any, result?: any) => boolean,  // this filter function calculate condition to change view\n   *     view: {\n   *       iconName?: string,                            // changed name of icon\n   *       iconColor?: string,                           // changed color of icon\n   *       textBold?: string,                            // changed weight of text\n   *       textColor?: string                            // changed color of text\n   *     }\n   *   }\n   */\n  @Input() functionView: IFunctionViewLine[] | null = null;\n\n  @Output() selectClick = new EventEmitter<IElementDto | null>(); // event after element selected by click\n  @Output() selectDblClick = new EventEmitter<IElementDto>(); // event after element selected by double click\n  @Output() contextMenuEvent = new EventEmitter<ContextMenuDataType>(); // event after element call context menu by right button click\n  @Output() selectedElementsChanged = new EventEmitter<SelectedElement[]>(); // event after changed selecting in selecting mode\n  @ViewChild('avaTreeWrapper') avaTreeWrapper!: ElementRef<HTMLDivElement>;\n  @ViewChild('avaMainWrapper') avaMainWrapper!: ElementRef<HTMLDivElement>;\n  @ViewChild('avaTreeFilterInput') avaTreeFilterInput!: ElementRef<HTMLInputElement>;\n  selectedElement: IElementDto | null = null;\n  serviceSpecification!: ServiceSpecificationDto;\n  isListenKeyboard = false;\n  private isEmiteSelectedElements = false;\n  private selectingElementsTreeData: SelectingElementsType[] = [];\n  flatElements: IElementDto[] | null = null;\n  preselectedElement: IElementDto | null = null;\n  filterInput = '';\n  listModeViewType = ModeViewType;\n  private filter = '';\n  private $filter = new ReplaySubject<string>(1);\n  filteredElementList: IElementDto[] = [];\n  private $destroy = new Subject<boolean>();\n\n  constructor(\n    @Self() private flatElementsService: FlatElementsService,\n    @Self() private selectElementService: SelectElementService,\n    @Self() private treeNodeSelectionService: TreeNodeSelectionService,\n    @Self() private expandParentGroupService: ExpandParentGroupService,\n    @Self() private keyboardOperationService: KeyboardOperationService,\n    private ngZone: NgZone\n  ) {\n    this._textWords = { ...DEFAULT_TEXT_WORDS };\n  }\n\n  ngOnInit(): void {\n    this.selectElementService.preselectedElement.pipe(takeUntil(this.$destroy)).subscribe((e) => (this.preselectedElement = e));\n    this.selectElementService.selectClickElement.pipe(takeUntil(this.$destroy)).subscribe((e) => {\n      this.selectedElement = e;\n      this.selectClick.emit(e);\n    });\n    this.selectElementService.selectDblClickElement.pipe(takeUntil(this.$destroy)).subscribe((e) => this.selectDblClick.emit(e));\n    this.selectElementService.selectContextMenuElement.pipe(takeUntil(this.$destroy)).subscribe((e) => this.contextMenuEvent.emit(e));\n    this.flatElementsService.flatElementsDto.pipe(takeUntil(this.$destroy)).subscribe((e) => {\n      this.flatElements = e;\n      this.getFilteredList();\n    });\n\n    this.$filter.pipe(takeUntil(this.$destroy), debounceTime(250)).subscribe((filter) => {\n      this.filter = filter;\n      this.getFilteredList();\n    });\n  }\n\n  ngAfterViewInit(): void {\n    this.initializeEventListeners();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.flatElementsService.listFilterFunc = this.listFilterFunc;\n    this.flatElementsService.functionView = this.functionView;\n\n    if (changes['project'] && this.project?.serviceSpecifications?.[0]) {\n      this.serviceSpecification = this.project.serviceSpecifications[0];\n      this.flatElementsService.setElementsDto(this.serviceSpecification);\n\n      if (this.isSelectionMode) {\n        this.selectingElementsTreeData = this.treeNodeSelectionService.loadSelectingElements(this.serviceSpecification.elements);\n        this.treeNodeSelectionService.treeNodeSelecting.pipe(takeUntil(this.$destroy)).subscribe(() => {\n          if (this.isEmiteSelectedElements) {\n            setTimeout(() => {\n              const selectingTree = this.treeNodeSelectionService.getTreeRoot(this.selectingElementsTreeData);\n              this.selectedElementsChanged.emit(selectingTree);\n            }, 0);\n          }\n        });\n      }\n    }\n\n    if ((changes['selectedNodeId'] && this.project) || changes['project']) {\n      this.flatElementsService.getOneElementById(this.selectedNodeId).subscribe((e) => {\n        if (e) {\n          this.selectElementService.setClickElement(e);\n        }\n      });\n    }\n\n    if (this.isSelectionMode && (changes['initiallySelectedElements'] || changes['project'])) {\n      this.formSelectingList();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.$destroy.next(true);\n    this.$destroy.complete();\n  }\n\n  private mouseOver(): void {\n    if (!this.isListenKeyboard) {\n      this.isListenKeyboard = true;\n      this.avaTreeFilterInput?.nativeElement.focus();\n    }\n  }\n\n  private mouseOut(): void {\n    this.isListenKeyboard = false;\n  }\n\n  private handleGlobalKeyboardEvent(event: Event): void {\n    this.ngZone.run(() => {\n      const keyEvent = event as KeyboardEvent;\n      if (!this.mouseAwareKeyboardControl || this.isListenKeyboard) {\n        const element = this.preselectedElement || this.selectedElement;\n\n        const { operation, nextElement } = this.keyboardOperationService.handleKeyboardEvent(keyEvent, element) || { nextElement: null };\n        switch (operation) {\n          case KeyboardOperationType.MoveSelectedPositionUp:\n            this.showElement(nextElement, '.select');\n            break;\n          case KeyboardOperationType.MoveSelectedPositionDown:\n            this.showElement(nextElement, '.select');\n            break;\n          case KeyboardOperationType.MoveChosenPositionDown:\n            this.showElement(nextElement, nextElement?.id === this.selectedElement?.id ? '.select' : '.choose');\n            break;\n          case KeyboardOperationType.MoveChosenPositionUp:\n            this.showElement(nextElement, nextElement?.id === this.selectedElement?.id ? '.select' : '.choose');\n            break;\n          default:\n            break;\n        }\n      }\n    });\n  }\n\n  private showElement(element: IElementDto | null, nameQuery: string): void {\n    if (element) {\n      if (this.modeView === ModeViewType.Tree) {\n        this.expandParentGroups(element);\n      }\n      setTimeout(() => this.scrollLine(nameQuery), 0);\n    }\n  }\n\n  private scrollLine(nameQuery: string): void {\n    const parentRect = this.avaTreeWrapper?.nativeElement.getBoundingClientRect();\n    const showedElement = this.avaTreeWrapper?.nativeElement.querySelector(nameQuery) as HTMLElement;\n\n    if (!showedElement) {\n      return;\n    }\n\n    const childRect = showedElement.getBoundingClientRect();\n    if (\n      childRect.bottom > parentRect.bottom ||\n      childRect.top < parentRect.top ||\n      (this.modeView === ModeViewType.Table && childRect.top < parentRect.top + 24)\n    ) {\n      showedElement?.scrollIntoView();\n      this.avaTreeWrapper?.nativeElement.scrollTo({ left: 0 });\n      if (this.modeView === ModeViewType.Table) {\n        setTimeout(() => this.correctScrollTableLine(showedElement, parentRect), 0);\n      }\n    }\n  }\n\n  private correctScrollTableLine(showedElement: HTMLElement, parentRect: DOMRect): void {\n    const childRect = showedElement.getBoundingClientRect();\n    if (childRect.top < parentRect.top + 24) {\n      this.avaTreeWrapper.nativeElement.scrollTop -= 24;\n    }\n  }\n\n  expandParentGroups(element: IElementDto): void {\n    this.expandParentGroupService.expandParentGroups(element, this.flatElements, this.expansionState);\n  }\n\n  onFilter(value: string): void {\n    this.$filter.next(value);\n  }\n\n  changeAllElementsExpansionStatus(isExpanded: boolean): void {\n    if (!isExpanded) {\n      Object.keys(this.expansionState).forEach((id: string) => delete this.expansionState[id]);\n    } else {\n      this.flatElements?.forEach((item) => {\n        if (item.elementTypeDiscriminator === 'ServiceSpecificationGroupDto') {\n          this.expansionState[item.id] = true;\n        }\n      });\n    }\n  }\n\n  private formSelectingList(): void {\n    this.isEmiteSelectedElements = false;\n    if (!this.initiallySelectedElements) {\n      this.isEmiteSelectedElements = true;\n      return;\n    }\n\n    this.treeNodeSelectionService.getFlatSelectedListId(this.initiallySelectedElements);\n    this.treeNodeSelectionService.flatSelectedListId.forEach((id, index) => {\n      this.treeNodeSelectionService.changeSelecting(true, id);\n      if (index === this.treeNodeSelectionService.flatSelectedListId.length - 1) {\n        this.isEmiteSelectedElements = true;\n      }\n    });\n  }\n\n  selectOrDeselectAll(value: boolean): void {\n    this.treeNodeSelectionService.changeAll(value);\n  }\n\n  private getFilteredList(): void {\n    if (this.flatElements?.length) {\n      if (!this.filter) {\n        this.filteredElementList = this.flatElements;\n      } else {\n        this.filteredElementList = this.flatElements.filter((item) => this.flatElementsService.checkFilterValue(item, this.filter));\n      }\n    }\n  }\n\n  private initializeEventListeners(): void {\n    this.ngZone.runOutsideAngular(() => {\n      fromEvent(this.avaMainWrapper.nativeElement, 'mouseleave')\n        .pipe(takeUntil(this.$destroy))\n        .subscribe(() => {\n          this.mouseOut();\n        });\n\n      fromEvent(this.avaMainWrapper.nativeElement, 'mouseenter')\n        .pipe(takeUntil(this.$destroy))\n        .subscribe(() => {\n          this.mouseOver();\n        });\n\n      if (!this.isSelectionMode) {\n        fromEvent(document, 'keydown')\n          .pipe(\n            takeUntil(this.$destroy),\n            filter(() => !this.mouseAwareKeyboardControl || this.isListenKeyboard)\n          )\n          .subscribe((event: Event) => {\n            this.handleGlobalKeyboardEvent(event);\n          });\n      }\n    });\n  }\n}\n","<div\n  class=\"main-wrapper\"\n  #avaMainWrapper\n>\n  <div\n    class=\"control\"\n    #control\n  >\n    <mat-form-field class=\"control-filter\">\n      <mat-label>{{ textWords?.textSearch }}</mat-label>\n      <input\n        matInput\n        [ngModel]=\"filterInput\"\n        (ngModelChange)=\"onFilter($event)\"\n        #avaTreeFilterInput\n      />\n    </mat-form-field>\n    <ng-container *ngIf=\"modeView === listModeViewType.Tree\">\n      <button\n        class=\"control-icon\"\n        mat-icon-button\n        color=\"primary\"\n        (click)=\"changeAllElementsExpansionStatus(true)\"\n        [matTooltip]=\"textWords?.tooltipAllOpen || ''\"\n      >\n        <mat-icon class=\"layer-background\">layers</mat-icon>\n        <mat-icon class=\"layer-icon\">add</mat-icon>\n      </button>\n      <button\n        class=\"control-icon\"\n        mat-icon-button\n        color=\"primary\"\n        (click)=\"changeAllElementsExpansionStatus(false)\"\n        [matTooltip]=\"textWords?.tooltipAllClose || ''\"\n      >\n        <mat-icon class=\"layer-background\">layers</mat-icon>\n        <mat-icon class=\"layer-icon\">remove</mat-icon>\n      </button>\n    </ng-container>\n    <ng-container *ngIf=\"isSelectionMode\">\n      <button\n        mat-raised-button\n        (click)=\"selectOrDeselectAll(true)\"\n        [matTooltip]=\"textWords?.tooltipAllAdd || ''\"\n        class=\"control-button\"\n      >\n        <mat-icon>add</mat-icon>\n        <span>{{ textWords?.textAll }}</span>\n      </button>\n      <button\n        mat-raised-button\n        (click)=\"selectOrDeselectAll(false)\"\n        [matTooltip]=\"textWords?.tooltipAllRemove || ''\"\n        class=\"control-button\"\n      >\n        <mat-icon>remove</mat-icon>\n        <span>{{ textWords?.textAll }}</span>\n      </button>\n    </ng-container>\n  </div>\n  <div\n    [style.height]=\"'calc(100% - ' + control.offsetHeight + 'px)'\"\n    class=\"ava-tree-wrapper\"\n    #avaTreeWrapper\n  >\n    <ng-container *ngIf=\"flatElements?.length; else nothing\">\n      <ng-container *ngIf=\"filteredElementList?.length; else nothingFiltered\">\n        <ava-tree-structure\n          *ngIf=\"modeView === listModeViewType.Tree && !avaTreeFilterInput.value\"\n          [serviceSpecification]=\"serviceSpecification\"\n          [indent]=\"indent\"\n          [expansionState]=\"expansionState\"\n          [isSelectionMode]=\"isSelectionMode\"\n          [selectedColor]=\"selectedColor\"\n          [allowDblClick]=\"allowDblClick\"\n        >\n        </ava-tree-structure>\n        <ava-list-structure\n          *ngIf=\"modeView === listModeViewType.List || (modeView === listModeViewType.Tree && avaTreeFilterInput.value)\"\n          [filteredElementList]=\"filteredElementList\"\n          [isSelectionMode]=\"isSelectionMode\"\n          [selectedColor]=\"selectedColor\"\n          [allowDblClick]=\"allowDblClick\"\n        >\n        </ava-list-structure>\n        <ava-table-structure\n          *ngIf=\"modeView === listModeViewType.Table\"\n          [filteredElementList]=\"filteredElementList\"\n          [isSelectionMode]=\"isSelectionMode\"\n          [addTableColumns]=\"addTableColumns\"\n          [selectedColor]=\"selectedColor\"\n          [allowDblClick]=\"allowDblClick\"\n        >\n        </ava-table-structure>\n      </ng-container>\n    </ng-container>\n  </div>\n</div>\n<ng-template #nothing>\n  {{ textWords?.textNothing }}\n</ng-template>\n<ng-template #nothingFiltered>\n  {{ textWords?.textNothingFiltered }}\n</ng-template>\n"]}