@seniorsistemas/angular-components 17.27.2 → 17.28.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/bundles/seniorsistemas-angular-components.umd.js +586 -17
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +2 -2
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/accessibility-events/directives/accessibility-event.directive.d.ts +4 -2
- package/components/grid-menu/components/grid-menu-item/grid-menu-item.component.d.ts +7 -0
- package/components/grid-menu/grid-menu.component.d.ts +9 -1
- package/components/grid-menu/types/grid-menu-item.d.ts +6 -1
- package/components/ia-insight/components/ia-insight-sidebar/ia-insight-sidebar.component.d.ts +3 -1
- package/components/ia-insight/ia-insight.component.d.ts +5 -1
- package/components/ia-insight/models/ia-insight-item.d.ts +12 -0
- package/components/index.d.ts +1 -0
- package/components/tree/Models/tree.models.d.ts +28 -0
- package/components/tree/components/tree-node-item/tree-node-item.component.d.ts +35 -0
- package/components/tree/index.d.ts +3 -0
- package/components/tree/tree.component.d.ts +33 -0
- package/components/tree/tree.module.d.ts +2 -0
- package/esm2015/components/accessibility-events/directives/accessibility-event.directive.js +9 -3
- package/esm2015/components/fieldset/fieldset.module.js +2 -3
- package/esm2015/components/grid-menu/components/grid-menu-item/grid-menu-item.component.js +36 -6
- package/esm2015/components/grid-menu/grid-menu.component.js +43 -4
- package/esm2015/components/grid-menu/grid-menu.module.js +3 -2
- package/esm2015/components/grid-menu/types/grid-menu-item.js +1 -1
- package/esm2015/components/ia-insight/components/ia-insight-card/ia-insight-card.component.js +15 -3
- package/esm2015/components/ia-insight/components/ia-insight-sidebar/ia-insight-sidebar.component.js +12 -2
- package/esm2015/components/ia-insight/ia-insight.component.js +17 -3
- package/esm2015/components/ia-insight/models/ia-insight-item.js +1 -1
- package/esm2015/components/index.js +2 -1
- package/esm2015/components/tree/Models/tree.models.js +1 -0
- package/esm2015/components/tree/components/tree-node-item/tree-node-item.component.js +154 -0
- package/esm2015/components/tree/index.js +3 -0
- package/esm2015/components/tree/tree.component.js +254 -0
- package/esm2015/components/tree/tree.module.js +20 -0
- package/esm2015/seniorsistemas-angular-components.js +3 -1
- package/esm5/components/accessibility-events/directives/accessibility-event.directive.js +10 -4
- package/esm5/components/fieldset/fieldset.module.js +2 -3
- package/esm5/components/grid-menu/components/grid-menu-item/grid-menu-item.component.js +38 -6
- package/esm5/components/grid-menu/grid-menu.component.js +43 -4
- package/esm5/components/grid-menu/grid-menu.module.js +3 -2
- package/esm5/components/grid-menu/types/grid-menu-item.js +1 -1
- package/esm5/components/ia-insight/components/ia-insight-card/ia-insight-card.component.js +15 -3
- package/esm5/components/ia-insight/components/ia-insight-sidebar/ia-insight-sidebar.component.js +12 -2
- package/esm5/components/ia-insight/ia-insight.component.js +17 -3
- package/esm5/components/ia-insight/models/ia-insight-item.js +1 -1
- package/esm5/components/index.js +2 -1
- package/esm5/components/tree/Models/tree.models.js +1 -0
- package/esm5/components/tree/components/tree-node-item/tree-node-item.component.js +169 -0
- package/esm5/components/tree/index.js +3 -0
- package/esm5/components/tree/tree.component.js +280 -0
- package/esm5/components/tree/tree.module.js +23 -0
- package/esm5/seniorsistemas-angular-components.js +3 -1
- package/fesm2015/seniorsistemas-angular-components.js +533 -15
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +580 -16
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.d.ts +2 -0
- package/seniorsistemas-angular-components.metadata.json +1 -1
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { animate, query, stagger, style, transition, trigger } from '@angular/animations';
|
|
3
|
+
import { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
4
|
+
import { TranslateService } from '@ngx-translate/core';
|
|
5
|
+
var TreeNodeItemComponent = /** @class */ (function () {
|
|
6
|
+
function TreeNodeItemComponent(cdr, translateService) {
|
|
7
|
+
this.cdr = cdr;
|
|
8
|
+
this.translateService = translateService;
|
|
9
|
+
this.ariaLevel = 0;
|
|
10
|
+
this.showCheckbox = false;
|
|
11
|
+
this.treeNodeItemClicked = new EventEmitter();
|
|
12
|
+
this.treeNodeEdit = new EventEmitter();
|
|
13
|
+
this.nodeExpanded = new EventEmitter();
|
|
14
|
+
this.nodeCollapsed = new EventEmitter();
|
|
15
|
+
}
|
|
16
|
+
Object.defineProperty(TreeNodeItemComponent.prototype, "hasChildren", {
|
|
17
|
+
get: function () {
|
|
18
|
+
return this.treeNodeItem.children && this.treeNodeItem.children.length > 0;
|
|
19
|
+
},
|
|
20
|
+
enumerable: true,
|
|
21
|
+
configurable: true
|
|
22
|
+
});
|
|
23
|
+
Object.defineProperty(TreeNodeItemComponent.prototype, "editable", {
|
|
24
|
+
get: function () {
|
|
25
|
+
var _a;
|
|
26
|
+
return ((_a = this.treeNodeItem) === null || _a === void 0 ? void 0 : _a.editable) || false;
|
|
27
|
+
},
|
|
28
|
+
enumerable: true,
|
|
29
|
+
configurable: true
|
|
30
|
+
});
|
|
31
|
+
Object.defineProperty(TreeNodeItemComponent.prototype, "ariaLabel", {
|
|
32
|
+
get: function () {
|
|
33
|
+
return this.translateService.instant('platform.angular_components.select') + " " + this.treeNodeItem.label;
|
|
34
|
+
},
|
|
35
|
+
enumerable: true,
|
|
36
|
+
configurable: true
|
|
37
|
+
});
|
|
38
|
+
TreeNodeItemComponent.prototype.expandNode = function () {
|
|
39
|
+
if (this.hasChildren && !this.treeNodeItem.isExpanded) {
|
|
40
|
+
this.toggleExpanded(this.treeNodeItem);
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
TreeNodeItemComponent.prototype.collapseNode = function () {
|
|
44
|
+
if (this.hasChildren && this.treeNodeItem.isExpanded) {
|
|
45
|
+
this.toggleExpanded(this.treeNodeItem);
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
TreeNodeItemComponent.prototype.onCheckboxEnter = function (node) {
|
|
49
|
+
var newState = node.checked === true ? false : true;
|
|
50
|
+
node.checked = newState;
|
|
51
|
+
this.treeNodeItemClicked.emit({ item: node, event: new KeyboardEvent('keydown', { key: 'Enter' }) });
|
|
52
|
+
};
|
|
53
|
+
TreeNodeItemComponent.prototype.handleTreeNodeItemClick = function (event, treeNodeItem) {
|
|
54
|
+
var item = treeNodeItem || this.treeNodeItem;
|
|
55
|
+
this.treeNodeItemClicked.emit({ item: item, event: event });
|
|
56
|
+
};
|
|
57
|
+
TreeNodeItemComponent.prototype.handleTreeNodeItemClicked = function (_a) {
|
|
58
|
+
var event = _a.event, item = _a.item;
|
|
59
|
+
if (item.isEditing) {
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
this.handleTreeNodeItemClick(event, item);
|
|
63
|
+
};
|
|
64
|
+
TreeNodeItemComponent.prototype.toggleExpanded = function (treeNodeItem) {
|
|
65
|
+
treeNodeItem.isExpanded = !treeNodeItem.isExpanded;
|
|
66
|
+
if (treeNodeItem.isExpanded) {
|
|
67
|
+
this.nodeExpanded.emit(treeNodeItem);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
this.nodeCollapsed.emit(treeNodeItem);
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
TreeNodeItemComponent.prototype.toggleEditing = function ($event) {
|
|
74
|
+
var _a;
|
|
75
|
+
$event.stopPropagation();
|
|
76
|
+
this.treeNodeItem.isEditing = !this.treeNodeItem.isEditing;
|
|
77
|
+
this.cdr.detectChanges();
|
|
78
|
+
if (this.treeNodeItem.isEditing) {
|
|
79
|
+
this.treeNodeItem.editNewValue = this.treeNodeItem.label;
|
|
80
|
+
var input = (_a = this.input) === null || _a === void 0 ? void 0 : _a.nativeElement;
|
|
81
|
+
input === null || input === void 0 ? void 0 : input.focus();
|
|
82
|
+
}
|
|
83
|
+
};
|
|
84
|
+
TreeNodeItemComponent.prototype.cancelEdit = function ($event) {
|
|
85
|
+
$event.stopPropagation();
|
|
86
|
+
this.treeNodeItem.isEditing = false;
|
|
87
|
+
this.treeNodeItem.editNewValue = '';
|
|
88
|
+
this.treeNodeItem.editPreviousValue = '';
|
|
89
|
+
this.cdr.detectChanges();
|
|
90
|
+
};
|
|
91
|
+
TreeNodeItemComponent.prototype.saveEdit = function ($event) {
|
|
92
|
+
var _this = this;
|
|
93
|
+
$event.stopPropagation();
|
|
94
|
+
this.treeNodeItem.isEditing = false;
|
|
95
|
+
if (!this.treeNodeItem.editNewValue) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
this.treeNodeItem.editPreviousValue = this.treeNodeItem.label;
|
|
99
|
+
this.treeNodeItem.label = this.treeNodeItem.editNewValue;
|
|
100
|
+
var revertAction = function () {
|
|
101
|
+
_this.treeNodeItem.label = _this.treeNodeItem.editPreviousValue;
|
|
102
|
+
_this.treeNodeItem.isEditing = false;
|
|
103
|
+
_this.cdr.detectChanges();
|
|
104
|
+
};
|
|
105
|
+
this.treeNodeEdit.emit({ revertAction: revertAction, item: this.treeNodeItem, newValue: this.treeNodeItem.editNewValue, previousValue: this.treeNodeItem.editPreviousValue });
|
|
106
|
+
};
|
|
107
|
+
TreeNodeItemComponent.prototype.treeNodeEditChildEvent = function (payload) {
|
|
108
|
+
this.treeNodeEdit.emit(payload);
|
|
109
|
+
};
|
|
110
|
+
TreeNodeItemComponent.ctorParameters = function () { return [
|
|
111
|
+
{ type: ChangeDetectorRef },
|
|
112
|
+
{ type: TranslateService }
|
|
113
|
+
]; };
|
|
114
|
+
__decorate([
|
|
115
|
+
Input()
|
|
116
|
+
], TreeNodeItemComponent.prototype, "ariaLevel", void 0);
|
|
117
|
+
__decorate([
|
|
118
|
+
Input()
|
|
119
|
+
], TreeNodeItemComponent.prototype, "showCheckbox", void 0);
|
|
120
|
+
__decorate([
|
|
121
|
+
Input()
|
|
122
|
+
], TreeNodeItemComponent.prototype, "treeNodeItem", void 0);
|
|
123
|
+
__decorate([
|
|
124
|
+
Output()
|
|
125
|
+
], TreeNodeItemComponent.prototype, "treeNodeItemClicked", void 0);
|
|
126
|
+
__decorate([
|
|
127
|
+
Output()
|
|
128
|
+
], TreeNodeItemComponent.prototype, "treeNodeEdit", void 0);
|
|
129
|
+
__decorate([
|
|
130
|
+
Output()
|
|
131
|
+
], TreeNodeItemComponent.prototype, "nodeExpanded", void 0);
|
|
132
|
+
__decorate([
|
|
133
|
+
Output()
|
|
134
|
+
], TreeNodeItemComponent.prototype, "nodeCollapsed", void 0);
|
|
135
|
+
__decorate([
|
|
136
|
+
ViewChild('input', { read: ElementRef })
|
|
137
|
+
], TreeNodeItemComponent.prototype, "input", void 0);
|
|
138
|
+
TreeNodeItemComponent = __decorate([
|
|
139
|
+
Component({
|
|
140
|
+
selector: 's-tree-node-item',
|
|
141
|
+
template: "<div\n *ngIf=\"treeNodeItem\"\n class=\"tree-node-item\"\n role=\"treeitem\"\n [class.tree-node-item-selected]=\"treeNodeItem.checked\"\n [class.selectable]=\"hasChildren\"\n [attr.aria-expanded]=\"hasChildren ? treeNodeItem.isExpanded : null\"\n [attr.aria-selected]=\"treeNodeItem.checked === true\"\n [attr.aria-label]=\"treeNodeItem.label\"\n [attr.aria-level]=\"ariaLevel\"\n tabindex=\"0\"\n (keydown.enter)=\"handleTreeNodeItemClick($event)\"\n (keydown.arrowRight)=\"expandNode()\"\n (keydown.arrowLeft)=\"collapseNode()\"\n>\n <div class=\"arrow\" *ngIf=\"hasChildren || treeNodeItem.leaf === true\" (click)=\"toggleExpanded(treeNodeItem)\">\n <i [class]=\"treeNodeItem.collapsedIcon || 'fas fa-chevron-right'\" *ngIf=\"!treeNodeItem.isExpanded\"></i>\n <i [class]=\"treeNodeItem.expandedIcon || 'fas fa-chevron-down'\" *ngIf=\"treeNodeItem.isExpanded\"></i>\n </div>\n\n <div class=\"tree-node-item-text\" (click)=\"handleTreeNodeItemClick($event)\">\n <span class=\"tree-node-item-text-icon\" *ngIf=\"treeNodeItem.icon || treeNodeItem.isEditing\">\n <i [class]=\"treeNodeItem.icon\" *ngIf=\"treeNodeItem.icon && !treeNodeItem.isEditing\"></i>\n <i class=\"fas fa-edit edit\" *ngIf=\"treeNodeItem.isEditing\" (click)=\"saveEdit($event)\"></i>\n </span>\n\n <span class=\"tree-node-item-text-checkbox\" *ngIf=\"showCheckbox && !treeNodeItem.isEditing\">\n <input\n type=\"checkbox\"\n [checked]=\"treeNodeItem.checked === true\"\n [indeterminate]=\"treeNodeItem.checked === null\"\n [attr.aria-checked]=\"treeNodeItem.checked === null ? 'mixed' : treeNodeItem.checked\"\n [attr.aria-label]=\"ariaLabel\"\n role=\"checkbox\"\n tabindex=\"0\"\n (keydown.enter)=\"onCheckboxEnter(treeNodeItem)\"\n />\n </span>\n\n <span class=\"tree-node-item-text-label\">\n <ng-container *ngIf=\"treeNodeItem.isEditing\">\n <input\n #input\n type=\"text\"\n pInputText\n class=\"tree-node-item-text-input\"\n [(ngModel)]=\"treeNodeItem.editNewValue\"\n (keydown.enter)=\"saveEdit($event)\"\n (keydown.escape)=\"cancelEdit($event)\"\n (click)=\"$event.stopPropagation()\"\n aria-label=\"Editar nome do item\"\n aria-live=\"polite\"\n />\n </ng-container>\n <ng-container *ngIf=\"!treeNodeItem.isEditing\">\n {{ treeNodeItem.label }}\n </ng-container>\n </span>\n\n <span class=\"tree-node-item-text-editable\" *ngIf=\"editable\">\n <i class=\"fas fa-pencil-alt\" (click)=\"toggleEditing($event)\" aria-label=\"Editar item\" tabindex=\"0\"></i>\n </span>\n </div>\n</div>\n\n<div\n *ngIf=\"hasChildren && treeNodeItem.isExpanded\"\n @fadeExpand\n class=\"child\"\n role=\"group\"\n @childrenAnimation\n>\n <s-tree-node-item\n *ngFor=\"let child of treeNodeItem.children\"\n [showCheckbox]=\"showCheckbox\"\n [treeNodeItem]=\"child\"\n [ariaLevel]=\"ariaLevel + 1\"\n (treeNodeItemClicked)=\"handleTreeNodeItemClicked($event)\"\n (treeNodeEdit)=\"treeNodeEditChildEvent($event)\"\n (nodeExpanded)=\"nodeExpanded.emit($event)\"\n (nodeCollapsed)=\"nodeCollapsed.emit($event)\"\n class=\"child-item\"\n >\n </s-tree-node-item>\n</div>\n",
|
|
142
|
+
animations: [
|
|
143
|
+
trigger('fadeExpand', [
|
|
144
|
+
transition(':enter', [
|
|
145
|
+
style({ height: '0px', opacity: 0, overflow: 'hidden' }),
|
|
146
|
+
animate('200ms ease-out', style({ height: '*', opacity: 1 }))
|
|
147
|
+
]),
|
|
148
|
+
transition(':leave', [
|
|
149
|
+
animate('150ms ease-in', style({ height: '0px', opacity: 0 }))
|
|
150
|
+
])
|
|
151
|
+
]),
|
|
152
|
+
trigger('childrenAnimation', [
|
|
153
|
+
transition(':enter', [
|
|
154
|
+
query(':enter', [
|
|
155
|
+
style({ opacity: 0, transform: 'translateY(-10px)' }),
|
|
156
|
+
stagger(60, [
|
|
157
|
+
animate('200ms ease-out', style({ opacity: 1, transform: 'translateY(0)' }))
|
|
158
|
+
])
|
|
159
|
+
], { optional: true })
|
|
160
|
+
])
|
|
161
|
+
])
|
|
162
|
+
],
|
|
163
|
+
styles: [".tree-node-item{width:100%;display:-ms-flexbox;display:flex;cursor:pointer}.tree-node-item .arrow{padding:3px 9px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.tree-node-item-text{-ms-flex:1;flex:1;display:-ms-flexbox;display:flex;padding:3px 0;-ms-flex-align:center;align-items:center}.tree-node-item-text:hover{background:#f1f7f8}.tree-node-item-text-icon{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;padding-right:9px}.tree-node-item-text-icon .edit{color:#428bca}.tree-node-item-text-label{color:#212533;font-family:\"Open Sans\";font-size:14px;font-style:normal;font-weight:400;line-height:150%;display:-ms-flexbox;display:flex;-ms-flex:1;flex:1}.tree-node-item-text-checkbox{padding-right:9px;display:-ms-flexbox;display:flex}.tree-node-item-text-checkbox input[type=checkbox]{accent-color:#428bca;width:14px;height:14px}.tree-node-item-text-editable{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:end;justify-content:flex-end}.tree-node-item-text-editable i{padding:9px}.tree-node-item-text-input{-ms-flex:1;flex:1}.tree-node-item.selectable .tree-node-item-text-label{font-family:\"Open Sans\";font-size:14px;font-style:normal;font-weight:700}.tree-node-item.selectable *{cursor:pointer}.tree-node-item-selected .tree-node-item-text{background:#d5e8ec}.child{overflow:hidden;padding-left:2.2em;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;gap:5px}.child-item:first-child{padding-top:5px}"]
|
|
164
|
+
})
|
|
165
|
+
], TreeNodeItemComponent);
|
|
166
|
+
return TreeNodeItemComponent;
|
|
167
|
+
}());
|
|
168
|
+
export { TreeNodeItemComponent };
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-node-item.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tree/components/tree-node-item/tree-node-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  query,\n  stagger,\n  style,\n  transition,\n  trigger\n} from '@angular/animations';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { InternalTreeNodeItem, TreeNodeEdit } from '../../Models/tree.models';\nimport { TranslateService } from '@ngx-translate/core';\n\n@Component({\n  selector: 's-tree-node-item',\n  templateUrl: './tree-node-item.component.html',\n  styleUrls: ['./tree-node-item.component.scss'],\n  animations: [\n    trigger('fadeExpand', [\n      transition(':enter', [\n        style({ height: '0px', opacity: 0, overflow: 'hidden' }),\n        animate('200ms ease-out', style({ height: '*', opacity: 1 }))\n      ]),\n      transition(':leave', [\n        animate('150ms ease-in', style({ height: '0px', opacity: 0 }))\n      ])\n    ]),\n    trigger('childrenAnimation', [\n      transition(':enter', [\n        query(':enter', [\n          style({ opacity: 0, transform: 'translateY(-10px)' }),\n          stagger(60, [\n            animate('200ms ease-out', style({ opacity: 1, transform: 'translateY(0)' }))\n          ])\n        ], { optional: true })\n      ])\n    ])\n  ],\n})\nexport class TreeNodeItemComponent {\n  @Input() ariaLevel = 0;\n  @Input() showCheckbox = false;\n  @Input() treeNodeItem!: InternalTreeNodeItem;\n  @Output() treeNodeItemClicked = new EventEmitter<{ item: InternalTreeNodeItem, event: Event }>();\n  @Output() treeNodeEdit = new EventEmitter<TreeNodeEdit>();\n  @Output() nodeExpanded = new EventEmitter<InternalTreeNodeItem>();\n  @Output() nodeCollapsed = new EventEmitter<InternalTreeNodeItem>();\n\n  @ViewChild('input', { read: ElementRef }) input!: ElementRef<HTMLInputElement>;\n\n  constructor(private readonly cdr: ChangeDetectorRef, private readonly translateService: TranslateService) { }\n\n  get hasChildren(): boolean {\n    return this.treeNodeItem.children && this.treeNodeItem.children.length > 0;\n  }\n\n  get editable() {\n    return this.treeNodeItem?.editable || false;\n  }\n\n  get ariaLabel() {\n    return `${this.translateService.instant('platform.angular_components.select')} ${this.treeNodeItem.label}`;\n  }\n\n  expandNode() {\n    if (this.hasChildren && !this.treeNodeItem.isExpanded) {\n      this.toggleExpanded(this.treeNodeItem);\n    }\n  }\n\n  collapseNode() {\n    if (this.hasChildren && this.treeNodeItem.isExpanded) {\n      this.toggleExpanded(this.treeNodeItem);\n    }\n  }\n\n  onCheckboxEnter(node: InternalTreeNodeItem) {\n    const newState = node.checked === true ? false : true;\n    node.checked = newState;\n    this.treeNodeItemClicked.emit({ item: node, event: new KeyboardEvent('keydown', { key: 'Enter' }) });\n  }\n\n  handleTreeNodeItemClick(event: Event, treeNodeItem?: InternalTreeNodeItem) {\n    const item = treeNodeItem || this.treeNodeItem;\n    this.treeNodeItemClicked.emit({ item, event });\n  }\n\n  handleTreeNodeItemClicked({ event, item }: { event: Event, item: InternalTreeNodeItem }) {\n    if (item.isEditing) {\n      return;\n    }\n    this.handleTreeNodeItemClick(event, item);\n  }\n\n  toggleExpanded(treeNodeItem: InternalTreeNodeItem) {\n    treeNodeItem.isExpanded = !treeNodeItem.isExpanded;\n    if (treeNodeItem.isExpanded) {\n      this.nodeExpanded.emit(treeNodeItem);\n    } else {\n      this.nodeCollapsed.emit(treeNodeItem);\n    }\n  }\n\n  toggleEditing($event: Event) {\n    $event.stopPropagation();\n    this.treeNodeItem.isEditing = !this.treeNodeItem.isEditing;\n    this.cdr.detectChanges();\n    if (this.treeNodeItem.isEditing) {\n      this.treeNodeItem.editNewValue = this.treeNodeItem.label;\n      const input = this.input?.nativeElement;\n      input?.focus();\n    }\n  }\n\n  cancelEdit($event: Event) {\n    $event.stopPropagation();\n    this.treeNodeItem.isEditing = false;\n    this.treeNodeItem.editNewValue = '';\n    this.treeNodeItem.editPreviousValue = '';\n    this.cdr.detectChanges();\n  }\n\n\n  saveEdit($event: Event) {\n    $event.stopPropagation();\n    this.treeNodeItem.isEditing = false;\n    if (!this.treeNodeItem.editNewValue) {\n      return;\n    }\n\n    this.treeNodeItem.editPreviousValue = this.treeNodeItem.label;\n    this.treeNodeItem.label = this.treeNodeItem.editNewValue;\n\n    const revertAction = () => {\n      this.treeNodeItem.label = this.treeNodeItem.editPreviousValue;\n      this.treeNodeItem.isEditing = false;\n      this.cdr.detectChanges();\n    }\n    this.treeNodeEdit.emit({ revertAction, item: this.treeNodeItem, newValue: this.treeNodeItem.editNewValue, previousValue: this.treeNodeItem.editPreviousValue });\n  }\n\n  treeNodeEditChildEvent(payload: TreeNodeEdit) {\n    this.treeNodeEdit.emit(payload);\n  }\n\n}\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { TreeComponent } from "./tree.component";
|
|
2
|
+
export { TreeModule } from "./tree.module";
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy90cmVlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgVHJlZU5vZGVFZGl0LCBUcmVlTm9kZUl0ZW0gfSBmcm9tIFwiLi9Nb2RlbHMvdHJlZS5tb2RlbHNcIjtcbmV4cG9ydCB7IFRyZWVDb21wb25lbnQgfSBmcm9tIFwiLi90cmVlLmNvbXBvbmVudFwiO1xuZXhwb3J0IHsgVHJlZU1vZHVsZSB9IGZyb20gXCIuL3RyZWUubW9kdWxlXCI7XG5cbiJdfQ==
|
|
@@ -0,0 +1,280 @@
|
|
|
1
|
+
import { __decorate, __read, __spread, __values } from "tslib";
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from "@angular/core";
|
|
3
|
+
var TreeComponent = /** @class */ (function () {
|
|
4
|
+
function TreeComponent() {
|
|
5
|
+
this.treeData = [];
|
|
6
|
+
this._selected = [];
|
|
7
|
+
this.loading = false;
|
|
8
|
+
this.selectionMode = "single";
|
|
9
|
+
this.showCheckbox = false;
|
|
10
|
+
this.allExpanded = false;
|
|
11
|
+
this.selectedChange = new EventEmitter();
|
|
12
|
+
this.treeNodeItemClicked = new EventEmitter();
|
|
13
|
+
this.treeNodeEdit = new EventEmitter();
|
|
14
|
+
this.nodeExpanded = new EventEmitter();
|
|
15
|
+
this.nodeCollapsed = new EventEmitter();
|
|
16
|
+
}
|
|
17
|
+
Object.defineProperty(TreeComponent.prototype, "selected", {
|
|
18
|
+
get: function () {
|
|
19
|
+
return this._selected;
|
|
20
|
+
},
|
|
21
|
+
set: function (value) {
|
|
22
|
+
if (!value) {
|
|
23
|
+
value = [];
|
|
24
|
+
}
|
|
25
|
+
if (!Array.isArray(value)) {
|
|
26
|
+
value = [value];
|
|
27
|
+
}
|
|
28
|
+
this._selected = value;
|
|
29
|
+
},
|
|
30
|
+
enumerable: true,
|
|
31
|
+
configurable: true
|
|
32
|
+
});
|
|
33
|
+
TreeComponent.prototype.ngOnChanges = function (changes) {
|
|
34
|
+
this.onChanges(changes);
|
|
35
|
+
};
|
|
36
|
+
TreeComponent.prototype.onTreeNodeItemClicked = function (_a) {
|
|
37
|
+
var item = _a.item;
|
|
38
|
+
this.treeNodeItemClicked.emit(parseInternalTreeNodeItem(item));
|
|
39
|
+
this.toggleChecked(item);
|
|
40
|
+
};
|
|
41
|
+
TreeComponent.prototype.onTreeNodeEdit = function (payload) {
|
|
42
|
+
var revertAction = payload.revertAction, item = payload.item, newValue = payload.newValue, previousValue = payload.previousValue;
|
|
43
|
+
this.treeNodeEdit.emit({
|
|
44
|
+
revertAction: revertAction,
|
|
45
|
+
item: parseInternalTreeNodeItem(item),
|
|
46
|
+
newValue: newValue,
|
|
47
|
+
previousValue: previousValue,
|
|
48
|
+
});
|
|
49
|
+
};
|
|
50
|
+
TreeComponent.prototype.onNodeExpanded = function (item) {
|
|
51
|
+
this.nodeExpanded.emit(parseInternalTreeNodeItem(item));
|
|
52
|
+
};
|
|
53
|
+
TreeComponent.prototype.onNodeCollapsed = function (item) {
|
|
54
|
+
this.nodeCollapsed.emit(parseInternalTreeNodeItem(item));
|
|
55
|
+
};
|
|
56
|
+
TreeComponent.prototype.toggleChecked = function (treeNodeItem) {
|
|
57
|
+
var elementCheckState = !treeNodeItem.checked;
|
|
58
|
+
if (!this.multiple) {
|
|
59
|
+
flattenTree(this.treeData).forEach(function (x) { return (x.checked = false); });
|
|
60
|
+
this.selected = [treeNodeItem];
|
|
61
|
+
}
|
|
62
|
+
treeNodeItem.checked = elementCheckState;
|
|
63
|
+
if (this.multiple) {
|
|
64
|
+
this.checkTreeDataChildren(treeNodeItem);
|
|
65
|
+
}
|
|
66
|
+
this.setSelected();
|
|
67
|
+
};
|
|
68
|
+
TreeComponent.prototype.checkTreeDataChildren = function (selectedTreeNode) {
|
|
69
|
+
var parentChecked = selectedTreeNode.checked;
|
|
70
|
+
if (selectedTreeNode.children) {
|
|
71
|
+
selectedTreeNode.children.forEach(function (item) {
|
|
72
|
+
var childrens = flattenTree(item.children || []);
|
|
73
|
+
item.checked = parentChecked;
|
|
74
|
+
childrens.forEach(function (child) { return (child.checked = parentChecked); });
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
var getNodeChildrenSummary = function (node) {
|
|
78
|
+
var allChildrenChecked = node.children.every(function (y) { return y.checked === true; });
|
|
79
|
+
var someChildrenChecked = node.children.some(function (y) { return y.checked === true || y.checked === null; });
|
|
80
|
+
var allChildrenUnchecked = node.children.every(function (y) { return y.checked === false || y.checked === undefined; });
|
|
81
|
+
return { allChildrenChecked: allChildrenChecked, someChildrenChecked: someChildrenChecked, allChildrenUnchecked: allChildrenUnchecked };
|
|
82
|
+
};
|
|
83
|
+
var updateCheckedStateRecursively = function (node) {
|
|
84
|
+
var _a;
|
|
85
|
+
if (!((_a = node.children) === null || _a === void 0 ? void 0 : _a.length))
|
|
86
|
+
return;
|
|
87
|
+
node.children.forEach(updateCheckedStateRecursively);
|
|
88
|
+
var _b = getNodeChildrenSummary(node), allChildrenChecked = _b.allChildrenChecked, someChildrenChecked = _b.someChildrenChecked, allChildrenUnchecked = _b.allChildrenUnchecked;
|
|
89
|
+
if (allChildrenChecked) {
|
|
90
|
+
node.checked = true;
|
|
91
|
+
}
|
|
92
|
+
else if (someChildrenChecked) {
|
|
93
|
+
node.checked = null;
|
|
94
|
+
}
|
|
95
|
+
else if (allChildrenUnchecked) {
|
|
96
|
+
node.checked = false;
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
this.treeData.forEach(updateCheckedStateRecursively);
|
|
100
|
+
};
|
|
101
|
+
TreeComponent.prototype.setSelected = function () {
|
|
102
|
+
var selected = this.selectedElements;
|
|
103
|
+
this.selected = __spread(selected);
|
|
104
|
+
this.selectedChange.emit(selected);
|
|
105
|
+
};
|
|
106
|
+
TreeComponent.prototype.onChanges = function (changes) {
|
|
107
|
+
var allExpandedChanges = changes.allExpanded;
|
|
108
|
+
var _checkIsFirstChangeWithValue = function (value) {
|
|
109
|
+
var _a;
|
|
110
|
+
if (!changes[value]) {
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
return (!changes[value].previousValue || changes[value].previousValue.length === 0) && ((_a = changes[value].currentValue) === null || _a === void 0 ? void 0 : _a.length) > 0;
|
|
114
|
+
};
|
|
115
|
+
if (_checkIsFirstChangeWithValue('selected')) {
|
|
116
|
+
this.syncSelectedChanges();
|
|
117
|
+
}
|
|
118
|
+
if (_checkIsFirstChangeWithValue('treeData')) {
|
|
119
|
+
var isAllExpanded = this.allExpanded;
|
|
120
|
+
if (isAllExpanded) {
|
|
121
|
+
this.expandAll();
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
if (allExpandedChanges) {
|
|
125
|
+
if (this.allExpanded) {
|
|
126
|
+
this.expandAll();
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
this.collapseAll();
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
};
|
|
133
|
+
TreeComponent.prototype.syncSelectedChanges = function () {
|
|
134
|
+
var _this = this;
|
|
135
|
+
var treeFlatten = flattenTree(this.treeData);
|
|
136
|
+
this.selected.forEach(function (selectedItem) {
|
|
137
|
+
var item = treeFlatten.find(function (item) { return item.id === selectedItem.id; });
|
|
138
|
+
if (item) {
|
|
139
|
+
item.checked = true;
|
|
140
|
+
}
|
|
141
|
+
if (item.children && _this.multiple) {
|
|
142
|
+
item.children.forEach(function (child) {
|
|
143
|
+
child.checked = true;
|
|
144
|
+
var existChildInSelectedList = _this.selected.some(function (item) { return item.id === child.id; });
|
|
145
|
+
if (!existChildInSelectedList) {
|
|
146
|
+
_this.selected.push(child);
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
var selectedElements = this.selectedElements;
|
|
152
|
+
var selectedElementsNotInSelectedList = selectedElements.filter(function (x) { return !_this.selected.some(function (y) { return y.id === x.id; }); });
|
|
153
|
+
selectedElementsNotInSelectedList.forEach(function (item) {
|
|
154
|
+
_this.checkTreeDataChildren(item);
|
|
155
|
+
});
|
|
156
|
+
this.setSelected();
|
|
157
|
+
};
|
|
158
|
+
TreeComponent.prototype.collapseAll = function () {
|
|
159
|
+
var flatten = flattenTree(this.treeData);
|
|
160
|
+
flatten.forEach(function (item) {
|
|
161
|
+
item.isExpanded = false;
|
|
162
|
+
});
|
|
163
|
+
};
|
|
164
|
+
TreeComponent.prototype.expandAll = function () {
|
|
165
|
+
var flatten = flattenTree(this.treeData);
|
|
166
|
+
flatten.forEach(function (item) {
|
|
167
|
+
item.isExpanded = true;
|
|
168
|
+
});
|
|
169
|
+
};
|
|
170
|
+
Object.defineProperty(TreeComponent.prototype, "selectedElements", {
|
|
171
|
+
get: function () {
|
|
172
|
+
return flattenTree(this.treeData)
|
|
173
|
+
.filter(function (x) { return x.checked; })
|
|
174
|
+
.filter(function (x) { var _a; return x.leaf !== true && !((_a = x.children) === null || _a === void 0 ? void 0 : _a.length); });
|
|
175
|
+
},
|
|
176
|
+
enumerable: true,
|
|
177
|
+
configurable: true
|
|
178
|
+
});
|
|
179
|
+
Object.defineProperty(TreeComponent.prototype, "multiple", {
|
|
180
|
+
get: function () {
|
|
181
|
+
return this.selectionMode === "multiple";
|
|
182
|
+
},
|
|
183
|
+
enumerable: true,
|
|
184
|
+
configurable: true
|
|
185
|
+
});
|
|
186
|
+
__decorate([
|
|
187
|
+
Input()
|
|
188
|
+
], TreeComponent.prototype, "treeData", void 0);
|
|
189
|
+
__decorate([
|
|
190
|
+
Input()
|
|
191
|
+
], TreeComponent.prototype, "selected", null);
|
|
192
|
+
__decorate([
|
|
193
|
+
Input()
|
|
194
|
+
], TreeComponent.prototype, "loading", void 0);
|
|
195
|
+
__decorate([
|
|
196
|
+
Input()
|
|
197
|
+
], TreeComponent.prototype, "selectionMode", void 0);
|
|
198
|
+
__decorate([
|
|
199
|
+
Input()
|
|
200
|
+
], TreeComponent.prototype, "showCheckbox", void 0);
|
|
201
|
+
__decorate([
|
|
202
|
+
Input()
|
|
203
|
+
], TreeComponent.prototype, "allExpanded", void 0);
|
|
204
|
+
__decorate([
|
|
205
|
+
Output()
|
|
206
|
+
], TreeComponent.prototype, "selectedChange", void 0);
|
|
207
|
+
__decorate([
|
|
208
|
+
Output()
|
|
209
|
+
], TreeComponent.prototype, "treeNodeItemClicked", void 0);
|
|
210
|
+
__decorate([
|
|
211
|
+
Output()
|
|
212
|
+
], TreeComponent.prototype, "treeNodeEdit", void 0);
|
|
213
|
+
__decorate([
|
|
214
|
+
Output()
|
|
215
|
+
], TreeComponent.prototype, "nodeExpanded", void 0);
|
|
216
|
+
__decorate([
|
|
217
|
+
Output()
|
|
218
|
+
], TreeComponent.prototype, "nodeCollapsed", void 0);
|
|
219
|
+
TreeComponent = __decorate([
|
|
220
|
+
Component({
|
|
221
|
+
selector: "s-tree",
|
|
222
|
+
template: "<div class=\"tree\" *sLoadingState=\"loading\">\n <s-tree-node-item\n *ngFor=\"let item of treeData\"\n [showCheckbox]=\"showCheckbox\"\n [treeNodeItem]=\"item\"\n (nodeExpanded)=\"onNodeExpanded($event)\"\n (nodeCollapsed)=\"onNodeCollapsed($event)\"\n (treeNodeEdit)=\"onTreeNodeEdit($event)\"\n (treeNodeItemClicked)=\"onTreeNodeItemClicked($event)\">\n </s-tree-node-item>\n</div>\n",
|
|
223
|
+
styles: [".tree{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;gap:5px;border:1px solid #ddd;border-radius:4px;padding:15px;margin:15px}"]
|
|
224
|
+
})
|
|
225
|
+
], TreeComponent);
|
|
226
|
+
return TreeComponent;
|
|
227
|
+
}());
|
|
228
|
+
export { TreeComponent };
|
|
229
|
+
var flattenTree = function (tree) {
|
|
230
|
+
var result = [];
|
|
231
|
+
function traverse(nodes) {
|
|
232
|
+
var e_1, _a;
|
|
233
|
+
try {
|
|
234
|
+
for (var nodes_1 = __values(nodes), nodes_1_1 = nodes_1.next(); !nodes_1_1.done; nodes_1_1 = nodes_1.next()) {
|
|
235
|
+
var node = nodes_1_1.value;
|
|
236
|
+
result.push(node);
|
|
237
|
+
if (node.children && node.children.length) {
|
|
238
|
+
traverse(node.children);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
243
|
+
finally {
|
|
244
|
+
try {
|
|
245
|
+
if (nodes_1_1 && !nodes_1_1.done && (_a = nodes_1.return)) _a.call(nodes_1);
|
|
246
|
+
}
|
|
247
|
+
finally { if (e_1) throw e_1.error; }
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
traverse(tree);
|
|
251
|
+
return result;
|
|
252
|
+
};
|
|
253
|
+
var ɵ0 = flattenTree;
|
|
254
|
+
var parseInternalTreeNodeItem = function (internalTreeNodeItem) {
|
|
255
|
+
var id = internalTreeNodeItem.id, label = internalTreeNodeItem.label, icon = internalTreeNodeItem.icon, checked = internalTreeNodeItem.checked, isExpanded = internalTreeNodeItem.isExpanded, payload = internalTreeNodeItem.payload, editable = internalTreeNodeItem.editable, children = internalTreeNodeItem.children;
|
|
256
|
+
var object = {
|
|
257
|
+
id: id,
|
|
258
|
+
label: label,
|
|
259
|
+
icon: icon,
|
|
260
|
+
checked: checked,
|
|
261
|
+
isExpanded: isExpanded,
|
|
262
|
+
payload: payload,
|
|
263
|
+
editable: editable,
|
|
264
|
+
_children: children === null || children === void 0 ? void 0 : children.map(parseInternalTreeNodeItem),
|
|
265
|
+
get children() {
|
|
266
|
+
return this._children;
|
|
267
|
+
},
|
|
268
|
+
set children(value) {
|
|
269
|
+
this._children = value;
|
|
270
|
+
internalTreeNodeItem.children = value;
|
|
271
|
+
},
|
|
272
|
+
};
|
|
273
|
+
Object.defineProperty(object, "_children", {
|
|
274
|
+
enumerable: false,
|
|
275
|
+
});
|
|
276
|
+
return object;
|
|
277
|
+
};
|
|
278
|
+
var ɵ1 = parseInternalTreeNodeItem;
|
|
279
|
+
export { ɵ0, ɵ1 };
|
|
280
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tree/tree.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from \"@angular/core\";\n\nimport { InternalTreeNodeItem, TreeNodeEdit, TreeNodeItem } from \"./Models/tree.models\";\n\n@Component({\n    selector: \"s-tree\",\n    templateUrl: \"./tree.component.html\",\n    styleUrls: [\"./tree.component.scss\"],\n})\nexport class TreeComponent implements OnChanges {\n    @Input()\n    public treeData: TreeNodeItem[] = [];\n\n    private _selected: TreeNodeItem[] = [];\n    @Input()\n    public get selected(): TreeNodeItem[] {\n        return this._selected;\n    }\n    public set selected(value: TreeNodeItem[]) {\n        if (!value) {\n            value = [];\n        }\n        if (!Array.isArray(value)) {\n            value = [value];\n        }\n        this._selected = value;\n    }\n\n    @Input()\n    public loading = false;\n\n    @Input()\n    public selectionMode: \"single\" | \"multiple\" = \"single\";\n\n    @Input()\n    public showCheckbox = false;\n\n    @Input()\n    public allExpanded = false;\n\n    @Output()\n    public selectedChange: EventEmitter<TreeNodeItem[] | TreeNodeItem> = new EventEmitter();\n\n    @Output()\n    public treeNodeItemClicked: EventEmitter<TreeNodeItem> = new EventEmitter();\n\n    @Output()\n    public treeNodeEdit: EventEmitter<TreeNodeEdit> = new EventEmitter();\n\n    @Output()\n    public nodeExpanded: EventEmitter<TreeNodeItem> = new EventEmitter();\n\n    @Output()\n    public nodeCollapsed: EventEmitter<TreeNodeItem> = new EventEmitter();\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        this.onChanges(changes);\n    }\n\n    public onTreeNodeItemClicked({ item }: { item: InternalTreeNodeItem }) {\n        this.treeNodeItemClicked.emit(parseInternalTreeNodeItem(item));\n        this.toggleChecked(item);\n    }\n\n    public onTreeNodeEdit(payload: TreeNodeEdit) {\n        const { revertAction, item, newValue, previousValue } = payload;\n        this.treeNodeEdit.emit({\n            revertAction,\n            item: parseInternalTreeNodeItem(item),\n            newValue,\n            previousValue,\n        });\n    }\n\n    public onNodeExpanded(item: InternalTreeNodeItem) {\n        this.nodeExpanded.emit(parseInternalTreeNodeItem(item));\n    }\n\n    public onNodeCollapsed(item: InternalTreeNodeItem) {\n        this.nodeCollapsed.emit(parseInternalTreeNodeItem(item));\n    }\n\n    private toggleChecked(treeNodeItem: TreeNodeItem) {\n        const elementCheckState = !treeNodeItem.checked;\n        if (!this.multiple) {\n            flattenTree(this.treeData).forEach((x) => (x.checked = false));\n            this.selected = [treeNodeItem];\n        }\n        treeNodeItem.checked = elementCheckState;\n        if (this.multiple) {\n            this.checkTreeDataChildren(treeNodeItem);\n        }\n        this.setSelected();\n    }\n\n    private checkTreeDataChildren(selectedTreeNode: TreeNodeItem) {\n        const parentChecked = selectedTreeNode.checked;\n        if (selectedTreeNode.children) {\n            selectedTreeNode.children.forEach((item) => {\n                const childrens = flattenTree(item.children || []);\n                item.checked = parentChecked;\n                childrens.forEach((child) => (child.checked = parentChecked));\n            });\n        }\n\n        const getNodeChildrenSummary = (node: TreeNodeItem) => {\n            const allChildrenChecked = node.children.every((y) => y.checked === true);\n            const someChildrenChecked = node.children.some((y) => y.checked === true || y.checked === null);\n            const allChildrenUnchecked = node.children.every((y) => y.checked === false || y.checked === undefined);\n            return { allChildrenChecked, someChildrenChecked, allChildrenUnchecked };\n        };\n        const updateCheckedStateRecursively = (node: TreeNodeItem): void => {\n            if (!node.children?.length) return;\n\n            node.children.forEach(updateCheckedStateRecursively);\n\n            const { allChildrenChecked, someChildrenChecked, allChildrenUnchecked } = getNodeChildrenSummary(node);\n            if (allChildrenChecked) {\n                node.checked = true;\n            } else if (someChildrenChecked) {\n                node.checked = null;\n            } else if (allChildrenUnchecked) {\n                node.checked = false;\n            }\n        };\n        this.treeData.forEach(updateCheckedStateRecursively);\n    }\n\n    private setSelected() {\n        const selected = this.selectedElements;\n        this.selected = [...selected];\n        this.selectedChange.emit(selected);\n    }\n\n    private onChanges(changes: SimpleChanges) {\n        const allExpandedChanges = changes.allExpanded;\n        const _checkIsFirstChangeWithValue = (value: Extract<keyof TreeComponent, 'selected' | 'treeData'>) => {\n            if (!changes[value]) {\n                return;\n            }\n            return (!changes[value].previousValue || changes[value].previousValue.length === 0) && changes[value].currentValue?.length > 0\n        }\n\n        if (_checkIsFirstChangeWithValue('selected')) {\n            this.syncSelectedChanges();\n\n        }\n\n        if (_checkIsFirstChangeWithValue('treeData')) {\n            const isAllExpanded = this.allExpanded;\n            if (isAllExpanded) {\n                this.expandAll();\n            }\n        }\n\n        if (allExpandedChanges) {\n            if (this.allExpanded) {\n                this.expandAll();\n            } else {\n                this.collapseAll();\n            }\n        }\n    }\n\n    private syncSelectedChanges() {\n        const treeFlatten = flattenTree(this.treeData);\n        this.selected.forEach((selectedItem) => {\n            const item = treeFlatten.find((item) => item.id === selectedItem.id);\n            if (item) {\n                item.checked = true;\n            }\n            if (item.children && this.multiple) {\n                item.children.forEach((child) => {\n                    child.checked = true;\n                    const existChildInSelectedList = this.selected.some((item) => item.id === child.id);\n                    if (!existChildInSelectedList) {\n                        this.selected.push(child);\n                    }\n                });\n            }\n        });\n        const selectedElements = this.selectedElements;\n        const selectedElementsNotInSelectedList = selectedElements.filter((x) => !this.selected.some((y) => y.id === x.id));\n        selectedElementsNotInSelectedList.forEach((item) => {\n            this.checkTreeDataChildren(item);\n        });\n        this.setSelected();\n    }\n\n    private collapseAll() {\n        const flatten = flattenTree(this.treeData);\n        flatten.forEach((item) => {\n            item.isExpanded = false;\n        });\n    }\n\n    private expandAll() {\n        const flatten = flattenTree(this.treeData);\n        flatten.forEach((item) => {\n            item.isExpanded = true;\n        });\n    }\n\n    private get selectedElements() {\n        return flattenTree(this.treeData)\n            .filter((x) => x.checked)\n            .filter((x) => x.leaf !== true && !x.children?.length);\n    }\n\n    private get multiple() {\n        return this.selectionMode === \"multiple\";\n    }\n}\n\nconst flattenTree = <T = any>(tree: TreeNodeItem<T>[]): TreeNodeItem<T>[] => {\n    const result: TreeNodeItem<T>[] = [];\n\n    function traverse(nodes: TreeNodeItem<T>[]) {\n        for (const node of nodes) {\n            result.push(node);\n            if (node.children && node.children.length) {\n                traverse(node.children);\n            }\n        }\n    }\n\n    traverse(tree);\n    return result;\n};\n\nconst parseInternalTreeNodeItem = <T = any>(internalTreeNodeItem: InternalTreeNodeItem<T>): TreeNodeItem<T> => {\n    const { id, label, icon, checked, isExpanded, payload, editable, children } = internalTreeNodeItem;\n    const object = {\n        id,\n        label,\n        icon,\n        checked,\n        isExpanded,\n        payload,\n        editable,\n        _children: children?.map(parseInternalTreeNodeItem),\n        get children() {\n            return this._children;\n        },\n        set children(value) {\n            this._children = value;\n            internalTreeNodeItem.children = value;\n        },\n    };\n    Object.defineProperty(object, \"_children\", {\n        enumerable: false,\n    });\n    return object as TreeNodeItem<T>;\n};\n"]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { NgModule } from "@angular/core";
|
|
4
|
+
import { FormsModule } from "@angular/forms";
|
|
5
|
+
import { TranslateModule } from "@ngx-translate/core";
|
|
6
|
+
import { InputTextModule } from "primeng/inputtext";
|
|
7
|
+
import { LoadingStateModule } from "../loading-state";
|
|
8
|
+
import { TreeNodeItemComponent } from "./components/tree-node-item/tree-node-item.component";
|
|
9
|
+
import { TreeComponent } from "./tree.component";
|
|
10
|
+
var TreeModule = /** @class */ (function () {
|
|
11
|
+
function TreeModule() {
|
|
12
|
+
}
|
|
13
|
+
TreeModule = __decorate([
|
|
14
|
+
NgModule({
|
|
15
|
+
declarations: [TreeNodeItemComponent, TreeComponent],
|
|
16
|
+
imports: [CommonModule, FormsModule, InputTextModule, LoadingStateModule, TranslateModule],
|
|
17
|
+
exports: [TreeComponent],
|
|
18
|
+
})
|
|
19
|
+
], TreeModule);
|
|
20
|
+
return TreeModule;
|
|
21
|
+
}());
|
|
22
|
+
export { TreeModule };
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy90cmVlL3RyZWUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFN0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUVwRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUN0RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUM3RixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFPakQ7SUFBQTtJQUF5QixDQUFDO0lBQWIsVUFBVTtRQUx0QixRQUFRLENBQUM7WUFDTixZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxhQUFhLENBQUM7WUFDcEQsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxlQUFlLEVBQUUsa0JBQWtCLEVBQUUsZUFBZSxDQUFDO1lBQzFGLE9BQU8sRUFBRSxDQUFDLGFBQWEsQ0FBQztTQUMzQixDQUFDO09BQ1csVUFBVSxDQUFHO0lBQUQsaUJBQUM7Q0FBQSxBQUExQixJQUEwQjtTQUFiLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tIFwiQG5neC10cmFuc2xhdGUvY29yZVwiO1xuaW1wb3J0IHsgSW5wdXRUZXh0TW9kdWxlIH0gZnJvbSBcInByaW1lbmcvaW5wdXR0ZXh0XCI7XG5cbmltcG9ydCB7IExvYWRpbmdTdGF0ZU1vZHVsZSB9IGZyb20gXCIuLi9sb2FkaW5nLXN0YXRlXCI7XG5pbXBvcnQgeyBUcmVlTm9kZUl0ZW1Db21wb25lbnQgfSBmcm9tIFwiLi9jb21wb25lbnRzL3RyZWUtbm9kZS1pdGVtL3RyZWUtbm9kZS1pdGVtLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgVHJlZUNvbXBvbmVudCB9IGZyb20gXCIuL3RyZWUuY29tcG9uZW50XCI7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbVHJlZU5vZGVJdGVtQ29tcG9uZW50LCBUcmVlQ29tcG9uZW50XSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZSwgSW5wdXRUZXh0TW9kdWxlLCBMb2FkaW5nU3RhdGVNb2R1bGUsIFRyYW5zbGF0ZU1vZHVsZV0sXG4gICAgZXhwb3J0czogW1RyZWVDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBUcmVlTW9kdWxlIHt9XG4iXX0=
|