@dangl/angular-ava 0.1.1-fe--1-add-tree-p0053
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/README.md +1 -0
- package/esm2022/dangl-angular-ava.mjs +5 -0
- package/esm2022/lib/angular-ava.module.mjs +88 -0
- package/esm2022/lib/ava-tree/tree/components/ava-tree/ava-tree.component.mjs +356 -0
- package/esm2022/lib/ava-tree/tree/components/list-structure/list-structure.component.mjs +38 -0
- package/esm2022/lib/ava-tree/tree/components/table-structure/table-structure.component.mjs +99 -0
- package/esm2022/lib/ava-tree/tree/components/tree-item/tree-item.component.mjs +89 -0
- package/esm2022/lib/ava-tree/tree/components/tree-node/tree-node.component.mjs +52 -0
- package/esm2022/lib/ava-tree/tree/components/tree-structure/tree-structure.component.mjs +30 -0
- package/esm2022/lib/ava-tree/tree/constants/defaultFilters.mjs +6 -0
- package/esm2022/lib/ava-tree/tree/constants/defaultTextWords.mjs +11 -0
- package/esm2022/lib/ava-tree/tree/constants/index.mjs +4 -0
- package/esm2022/lib/ava-tree/tree/directives/save-changing-view.directive.mjs +43 -0
- package/esm2022/lib/ava-tree/tree/model/ava-models.mjs +199 -0
- package/esm2022/lib/ava-tree/tree/model/context-menu-data.model.mjs +2 -0
- package/esm2022/lib/ava-tree/tree/model/function-view-line.model.mjs +2 -0
- package/esm2022/lib/ava-tree/tree/model/index.mjs +4 -0
- package/esm2022/lib/ava-tree/tree/model/selecting.model.mjs +2 -0
- package/esm2022/lib/ava-tree/tree/model/tableColumnType.mjs +2 -0
- package/esm2022/lib/ava-tree/tree/model/tree-mode.model.mjs +7 -0
- package/esm2022/lib/ava-tree/tree/pipes/element-icon-name.pipe.mjs +27 -0
- package/esm2022/lib/ava-tree/tree/pipes/element-item-number.pipe.mjs +23 -0
- package/esm2022/lib/ava-tree/tree/pipes/element-text.pipe.mjs +27 -0
- package/esm2022/lib/ava-tree/tree/services/expand-parent-group.service.mjs +32 -0
- package/esm2022/lib/ava-tree/tree/services/flat-elements.service.mjs +99 -0
- package/esm2022/lib/ava-tree/tree/services/keyboard-operation.service.mjs +114 -0
- package/esm2022/lib/ava-tree/tree/services/select-element.service.mjs +37 -0
- package/esm2022/lib/ava-tree/tree/services/tree-node-selection.service.mjs +133 -0
- package/esm2022/lib/version.mjs +10 -0
- package/esm2022/public-api.mjs +8 -0
- package/fesm2022/dangl-angular-ava.mjs +1174 -0
- package/fesm2022/dangl-angular-ava.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/angular-ava.module.d.ts +26 -0
- package/lib/ava-tree/tree/components/ava-tree/ava-tree.component.d.ts +77 -0
- package/lib/ava-tree/tree/components/list-structure/list-structure.component.d.ts +16 -0
- package/lib/ava-tree/tree/components/table-structure/table-structure.component.d.ts +34 -0
- package/lib/ava-tree/tree/components/tree-item/tree-item.component.d.ts +34 -0
- package/lib/ava-tree/tree/components/tree-node/tree-node.component.d.ts +22 -0
- package/lib/ava-tree/tree/components/tree-structure/tree-structure.component.d.ts +13 -0
- package/lib/ava-tree/tree/constants/defaultFilters.d.ts +1 -0
- package/lib/ava-tree/tree/constants/defaultTextWords.d.ts +11 -0
- package/lib/ava-tree/tree/constants/index.d.ts +3 -0
- package/lib/ava-tree/tree/directives/save-changing-view.directive.d.ts +12 -0
- package/lib/ava-tree/tree/model/ava-models.d.ts +1041 -0
- package/lib/ava-tree/tree/model/context-menu-data.model.d.ts +8 -0
- package/lib/ava-tree/tree/model/function-view-line.model.d.ts +11 -0
- package/lib/ava-tree/tree/model/index.d.ts +7 -0
- package/lib/ava-tree/tree/model/selecting.model.d.ts +14 -0
- package/lib/ava-tree/tree/model/tableColumnType.d.ts +6 -0
- package/lib/ava-tree/tree/model/tree-mode.model.d.ts +5 -0
- package/lib/ava-tree/tree/pipes/element-icon-name.pipe.d.ts +8 -0
- package/lib/ava-tree/tree/pipes/element-item-number.pipe.d.ts +8 -0
- package/lib/ava-tree/tree/pipes/element-text.pipe.d.ts +8 -0
- package/lib/ava-tree/tree/services/expand-parent-group.service.d.ts +7 -0
- package/lib/ava-tree/tree/services/flat-elements.service.d.ts +28 -0
- package/lib/ava-tree/tree/services/keyboard-operation.service.d.ts +32 -0
- package/lib/ava-tree/tree/services/select-element.service.d.ts +30 -0
- package/lib/ava-tree/tree/services/tree-node-selection.service.d.ts +23 -0
- package/lib/version.d.ts +8 -0
- package/package.json +31 -0
- package/public-api.d.ts +4 -0
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../services/select-element.service";
|
|
5
|
+
import * as i2 from "projects/angular-ava/src/lib/ava-tree/tree/services/tree-node-selection.service";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "@angular/material/icon";
|
|
8
|
+
import * as i5 from "@angular/forms";
|
|
9
|
+
import * as i6 from "@angular/material/checkbox";
|
|
10
|
+
import * as i7 from "@angular/material/table";
|
|
11
|
+
import * as i8 from "../../directives/save-changing-view.directive";
|
|
12
|
+
import * as i9 from "../../pipes/element-icon-name.pipe";
|
|
13
|
+
import * as i10 from "../../pipes/element-text.pipe";
|
|
14
|
+
import * as i11 from "../../pipes/element-item-number.pipe";
|
|
15
|
+
export class TableStructureComponent {
|
|
16
|
+
constructor(selectElementService, treeNodeSelectionService, cdr) {
|
|
17
|
+
this.selectElementService = selectElementService;
|
|
18
|
+
this.treeNodeSelectionService = treeNodeSelectionService;
|
|
19
|
+
this.cdr = cdr;
|
|
20
|
+
this.filteredElementList = [];
|
|
21
|
+
this.isSelectionMode = false;
|
|
22
|
+
this.addTableColumns = [];
|
|
23
|
+
this.selectedColor = null;
|
|
24
|
+
this.displayedColumns = [];
|
|
25
|
+
this.isAllowOneClick = true;
|
|
26
|
+
this.selectedElement = null;
|
|
27
|
+
this.preselectedElement = null;
|
|
28
|
+
this.timerStop = null;
|
|
29
|
+
this.checkedElements = {};
|
|
30
|
+
this.$destroy = new Subject();
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
this.selectElementService.selectClickElement.pipe(takeUntil(this.$destroy)).subscribe((element) => {
|
|
34
|
+
this.selectedElement = element;
|
|
35
|
+
});
|
|
36
|
+
this.selectElementService.preselectedElement.pipe(takeUntil(this.$destroy)).subscribe((element) => {
|
|
37
|
+
this.preselectedElement = element;
|
|
38
|
+
});
|
|
39
|
+
if (this.isSelectionMode) {
|
|
40
|
+
this.displayedColumns = ['icon', 'checkbox', 'itemNumber', 'text', ...this.addTableColumns.map((item) => item.name)];
|
|
41
|
+
this.treeNodeSelectionService.treeNodeSelecting.pipe(takeUntil(this.$destroy)).subscribe((treeNodeSelecting) => {
|
|
42
|
+
this.checkedElements = treeNodeSelecting;
|
|
43
|
+
this.cdr.detectChanges();
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
this.displayedColumns = ['icon', 'itemNumber', 'text', ...this.addTableColumns.map((item) => item.name)];
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
ngOnDestroy() {
|
|
51
|
+
this.timerStop && clearTimeout(this.timerStop);
|
|
52
|
+
this.$destroy.next(true);
|
|
53
|
+
this.$destroy.complete();
|
|
54
|
+
}
|
|
55
|
+
select(row) {
|
|
56
|
+
if (this.isSelectionMode) {
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
if (this.isAllowOneClick) {
|
|
60
|
+
this.isAllowOneClick = false;
|
|
61
|
+
this.timerStop = setTimeout(() => {
|
|
62
|
+
this.selectElementService.setClickElement(this.selectedElement?.id === row.id ? null : row);
|
|
63
|
+
this.isAllowOneClick = true;
|
|
64
|
+
}, 300);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
dblSelect(row) {
|
|
68
|
+
if (this.isSelectionMode) {
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
this.timerStop && clearTimeout(this.timerStop);
|
|
72
|
+
this.selectElementService.setDblClickElement(row);
|
|
73
|
+
this.isAllowOneClick = true;
|
|
74
|
+
}
|
|
75
|
+
openContextMenu(event, row) {
|
|
76
|
+
event.preventDefault();
|
|
77
|
+
this.selectElementService.setContextMenuElement({ position: { x: `${event.x}px`, y: `${event.y}px` }, node: row });
|
|
78
|
+
}
|
|
79
|
+
changeSelecting(element, event) {
|
|
80
|
+
this.treeNodeSelectionService.changeSelecting(event, element.id);
|
|
81
|
+
}
|
|
82
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: TableStructureComponent, deps: [{ token: i1.SelectElementService }, { token: i2.TreeNodeSelectionService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
83
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: TableStructureComponent, selector: "ava-table-structure", inputs: { functionView: "functionView", filteredElementList: "filteredElementList", isSelectionMode: "isSelectionMode", addTableColumns: "addTableColumns", selectedColor: "selectedColor" }, ngImport: i0, template: "<table\r\n mat-table\r\n [dataSource]=\"filteredElementList\"\r\n>\r\n <ng-container matColumnDef=\"icon\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n ></th>\r\n <td\r\n mat-cell\r\n *matCellDef=\"let row\"\r\n class=\"table-cell-small-width\"\r\n >\r\n <mat-icon\r\n class=\"icon-element\"\r\n tdChangingIconView\r\n >\r\n {{ row | elementIconName }}\r\n </mat-icon>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"checkbox\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n ></th>\r\n <td\r\n mat-cell\r\n *matCellDef=\"let element\"\r\n class=\"table-cell-small-width\"\r\n >\r\n <mat-checkbox\r\n class=\"checkbox\"\r\n color=\"primary\"\r\n [indeterminate]=\"checkedElements[element.id].indeterminate\"\r\n [(ngModel)]=\"checkedElements[element.id].checked\"\r\n (ngModelChange)=\"changeSelecting(element, $event)\"\r\n (click)=\"$event.stopPropagation()\"\r\n >\r\n </mat-checkbox>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"itemNumber\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n >\r\n OZ\r\n </th>\r\n <td\r\n mat-cell\r\n *matCellDef=\"let row\"\r\n [style.width.ch]=\"row?.itemNumber?.stringRepresentation.length\"\r\n >\r\n <div\r\n class=\"text-element\"\r\n tdChangingTextView\r\n >\r\n {{ row | elementItemNumber }}\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"text\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n >\r\n Text\r\n </th>\r\n <td\r\n mat-cell\r\n *matCellDef=\"let row\"\r\n class=\"table-text\"\r\n >\r\n <div\r\n class=\"text-element\"\r\n tdChangingTextView\r\n >\r\n {{ row | elementText }}\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngFor=\"let oneColumn of addTableColumns\">\r\n <ng-container matColumnDef=\"{{ oneColumn.name }}\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n >\r\n {{ oneColumn.title }}\r\n </th>\r\n <td\r\n mat-cell\r\n *matCellDef=\"let row\"\r\n >\r\n <div\r\n [style.textAlign]=\"oneColumn.align\"\r\n tdChangingTextView\r\n >\r\n {{ !oneColumn.numberFormat ? row[oneColumn.name] : (row[oneColumn.name] | number: oneColumn.numberFormat) }}\r\n </div>\r\n </td>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <tr\r\n mat-header-row\r\n *matHeaderRowDef=\"displayedColumns; sticky: true\"\r\n class=\"mat-header-row\"\r\n ></tr>\r\n <tr\r\n mat-row\r\n *matRowDef=\"let row; columns: displayedColumns\"\r\n (click)=\"select(row)\"\r\n (dblclick)=\"dblSelect(row)\"\r\n (contextmenu)=\"openContextMenu($event, row)\"\r\n [ngClass]=\"{\r\n choose: !isSelectionMode && row.id === preselectedElement?.id,\r\n select: !isSelectionMode && row.id === selectedElement?.id\r\n }\"\r\n [style.background]=\"!isSelectionMode && row.id === selectedElement?.id ? selectedColor || '' : ''\"\r\n [id]=\"row.id\"\r\n trSaveChangingView\r\n ></tr>\r\n</table>\r\n", styles: ["table{width:100%}table tr.mat-mdc-row,table tr.mat-mdc-header-row{height:24px}table tr input{box-sizing:border-box;padding:0 3px;outline:none;border:none;height:20px;width:calc(100% - 2px)}table tr input:focus{background:#fff!important}table tr .right{text-align:right}table tr td,table tr th{border-right:1px solid #777;border-bottom:1px solid #777;padding:0}table tr td:first-child,table tr th:first-child{border-left:1px solid #777}table tr td.min-width,table tr th.min-width{width:12ch;min-width:12ch}table tr td div,table tr th div{padding:0 3px}table tr th{border-top:1px solid #777;padding:0 3px}.table-text{overflow-x:hidden;position:relative}.table-text div{position:absolute;top:50%;left:0;white-space:nowrap;transform:translateY(-50%)}.select{background:var(--mdc-filled-text-field-caret-color);color:#fff}.select *{color:#fff}.choose div{color:red!important}::ng-deep .checkbox .mdc-form-field .mdc-checkbox{padding:0;flex:0 0 16px;width:16px;height:16px}::ng-deep .checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__native-control{width:100%;height:100%}::ng-deep .checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__native-control:focus~.mdc-checkbox__ripple{opacity:0!important}::ng-deep .checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__background{top:0;left:0;width:100%;height:100%}::ng-deep .checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__background .mdc-checkbox__mixedmark{border-color:#fff!important}::ng-deep .checkbox .mdc-form-field>label{line-height:24px;padding-left:8px;-webkit-user-select:none;user-select:none}.text-element{-webkit-user-select:none;user-select:none}.table-cell-small-width{width:24px;min-width:24px;position:relative;text-align:center}.table-cell-small-width .icon-element{position:absolute;top:0;left:0}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i7.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i7.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i7.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i7.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i7.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i7.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i7.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i7.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i7.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i7.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i8.SaveChangingViewDirective, selector: "[trSaveChangingView]" }, { kind: "pipe", type: i3.DecimalPipe, name: "number" }, { kind: "pipe", type: i9.ElementIconNamePipe, name: "elementIconName" }, { kind: "pipe", type: i10.ElementTextPipe, name: "elementText" }, { kind: "pipe", type: i11.ElementItemNumberPipe, name: "elementItemNumber" }] }); }
|
|
84
|
+
}
|
|
85
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: TableStructureComponent, decorators: [{
|
|
86
|
+
type: Component,
|
|
87
|
+
args: [{ selector: 'ava-table-structure', template: "<table\r\n mat-table\r\n [dataSource]=\"filteredElementList\"\r\n>\r\n <ng-container matColumnDef=\"icon\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n ></th>\r\n <td\r\n mat-cell\r\n *matCellDef=\"let row\"\r\n class=\"table-cell-small-width\"\r\n >\r\n <mat-icon\r\n class=\"icon-element\"\r\n tdChangingIconView\r\n >\r\n {{ row | elementIconName }}\r\n </mat-icon>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"checkbox\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n ></th>\r\n <td\r\n mat-cell\r\n *matCellDef=\"let element\"\r\n class=\"table-cell-small-width\"\r\n >\r\n <mat-checkbox\r\n class=\"checkbox\"\r\n color=\"primary\"\r\n [indeterminate]=\"checkedElements[element.id].indeterminate\"\r\n [(ngModel)]=\"checkedElements[element.id].checked\"\r\n (ngModelChange)=\"changeSelecting(element, $event)\"\r\n (click)=\"$event.stopPropagation()\"\r\n >\r\n </mat-checkbox>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"itemNumber\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n >\r\n OZ\r\n </th>\r\n <td\r\n mat-cell\r\n *matCellDef=\"let row\"\r\n [style.width.ch]=\"row?.itemNumber?.stringRepresentation.length\"\r\n >\r\n <div\r\n class=\"text-element\"\r\n tdChangingTextView\r\n >\r\n {{ row | elementItemNumber }}\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"text\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n >\r\n Text\r\n </th>\r\n <td\r\n mat-cell\r\n *matCellDef=\"let row\"\r\n class=\"table-text\"\r\n >\r\n <div\r\n class=\"text-element\"\r\n tdChangingTextView\r\n >\r\n {{ row | elementText }}\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container *ngFor=\"let oneColumn of addTableColumns\">\r\n <ng-container matColumnDef=\"{{ oneColumn.name }}\">\r\n <th\r\n mat-header-cell\r\n *matHeaderCellDef\r\n >\r\n {{ oneColumn.title }}\r\n </th>\r\n <td\r\n mat-cell\r\n *matCellDef=\"let row\"\r\n >\r\n <div\r\n [style.textAlign]=\"oneColumn.align\"\r\n tdChangingTextView\r\n >\r\n {{ !oneColumn.numberFormat ? row[oneColumn.name] : (row[oneColumn.name] | number: oneColumn.numberFormat) }}\r\n </div>\r\n </td>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <tr\r\n mat-header-row\r\n *matHeaderRowDef=\"displayedColumns; sticky: true\"\r\n class=\"mat-header-row\"\r\n ></tr>\r\n <tr\r\n mat-row\r\n *matRowDef=\"let row; columns: displayedColumns\"\r\n (click)=\"select(row)\"\r\n (dblclick)=\"dblSelect(row)\"\r\n (contextmenu)=\"openContextMenu($event, row)\"\r\n [ngClass]=\"{\r\n choose: !isSelectionMode && row.id === preselectedElement?.id,\r\n select: !isSelectionMode && row.id === selectedElement?.id\r\n }\"\r\n [style.background]=\"!isSelectionMode && row.id === selectedElement?.id ? selectedColor || '' : ''\"\r\n [id]=\"row.id\"\r\n trSaveChangingView\r\n ></tr>\r\n</table>\r\n", styles: ["table{width:100%}table tr.mat-mdc-row,table tr.mat-mdc-header-row{height:24px}table tr input{box-sizing:border-box;padding:0 3px;outline:none;border:none;height:20px;width:calc(100% - 2px)}table tr input:focus{background:#fff!important}table tr .right{text-align:right}table tr td,table tr th{border-right:1px solid #777;border-bottom:1px solid #777;padding:0}table tr td:first-child,table tr th:first-child{border-left:1px solid #777}table tr td.min-width,table tr th.min-width{width:12ch;min-width:12ch}table tr td div,table tr th div{padding:0 3px}table tr th{border-top:1px solid #777;padding:0 3px}.table-text{overflow-x:hidden;position:relative}.table-text div{position:absolute;top:50%;left:0;white-space:nowrap;transform:translateY(-50%)}.select{background:var(--mdc-filled-text-field-caret-color);color:#fff}.select *{color:#fff}.choose div{color:red!important}::ng-deep .checkbox .mdc-form-field .mdc-checkbox{padding:0;flex:0 0 16px;width:16px;height:16px}::ng-deep .checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__native-control{width:100%;height:100%}::ng-deep .checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__native-control:focus~.mdc-checkbox__ripple{opacity:0!important}::ng-deep .checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__background{top:0;left:0;width:100%;height:100%}::ng-deep .checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__background .mdc-checkbox__mixedmark{border-color:#fff!important}::ng-deep .checkbox .mdc-form-field>label{line-height:24px;padding-left:8px;-webkit-user-select:none;user-select:none}.text-element{-webkit-user-select:none;user-select:none}.table-cell-small-width{width:24px;min-width:24px;position:relative;text-align:center}.table-cell-small-width .icon-element{position:absolute;top:0;left:0}\n"] }]
|
|
88
|
+
}], ctorParameters: function () { return [{ type: i1.SelectElementService }, { type: i2.TreeNodeSelectionService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { functionView: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], filteredElementList: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], isSelectionMode: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], addTableColumns: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], selectedColor: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}] } });
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-structure.component.js","sourceRoot":"","sources":["../../../../../../../../projects/angular-ava/src/lib/ava-tree/tree/components/table-structure/table-structure.component.ts","../../../../../../../../projects/angular-ava/src/lib/ava-tree/tree/components/table-structure/table-structure.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input } from '@angular/core';\r\n\r\nimport { Subject, takeUntil } from 'rxjs';\r\n\r\nimport { IElementDto, TableColumnType } from '../../model';\r\nimport { SelectElementService } from '../../services/select-element.service';\r\n\r\nimport { SelectingElementsType } from 'projects/angular-ava/src/lib/ava-tree/tree/model/selecting.model';\r\nimport { TreeNodeSelectionService } from 'projects/angular-ava/src/lib/ava-tree/tree/services/tree-node-selection.service';\r\n\r\n@Component({\r\n  selector: 'ava-table-structure',\r\n  templateUrl: './table-structure.component.html',\r\n  styleUrls: ['./table-structure.component.scss']\r\n})\r\nexport class TableStructureComponent {\r\n  @Input() functionView!: any[];\r\n  @Input() filteredElementList: IElementDto[] = [];\r\n  @Input() isSelectionMode = false;\r\n  @Input() addTableColumns: TableColumnType[] = [];\r\n  @Input() selectedColor: string | null = null;\r\n  displayedColumns: string[] = [];\r\n  private isAllowOneClick = true;\r\n  selectedElement: IElementDto | null = null;\r\n  preselectedElement: IElementDto | null = null;\r\n  private timerStop: ReturnType<typeof setTimeout> | null = null;\r\n  checkedElements: {\r\n    [elementId: string]: SelectingElementsType;\r\n  } = {};\r\n\r\n  private $destroy = new Subject<boolean>();\r\n\r\n  constructor(\r\n    public selectElementService: SelectElementService,\r\n    private treeNodeSelectionService: TreeNodeSelectionService,\r\n    private cdr: ChangeDetectorRef\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.selectElementService.selectClickElement.pipe(takeUntil(this.$destroy)).subscribe((element) => {\r\n      this.selectedElement = element;\r\n    });\r\n    this.selectElementService.preselectedElement.pipe(takeUntil(this.$destroy)).subscribe((element) => {\r\n      this.preselectedElement = element;\r\n    });\r\n\r\n    if (this.isSelectionMode) {\r\n      this.displayedColumns = ['icon', 'checkbox', 'itemNumber', 'text', ...this.addTableColumns.map((item) => item.name)];\r\n      this.treeNodeSelectionService.treeNodeSelecting.pipe(takeUntil(this.$destroy)).subscribe((treeNodeSelecting) => {\r\n        this.checkedElements = treeNodeSelecting;\r\n        this.cdr.detectChanges();\r\n      });\r\n    } else {\r\n      this.displayedColumns = ['icon', 'itemNumber', 'text', ...this.addTableColumns.map((item) => item.name)];\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.timerStop && clearTimeout(this.timerStop);\r\n\r\n    this.$destroy.next(true);\r\n    this.$destroy.complete();\r\n  }\r\n\r\n  select(row: IElementDto): void {\r\n    if (this.isSelectionMode) {\r\n      return;\r\n    }\r\n\r\n    if (this.isAllowOneClick) {\r\n      this.isAllowOneClick = false;\r\n      this.timerStop = setTimeout(() => {\r\n        this.selectElementService.setClickElement(this.selectedElement?.id === row.id ? null : row);\r\n        this.isAllowOneClick = true;\r\n      }, 300);\r\n    }\r\n  }\r\n\r\n  dblSelect(row: IElementDto): void {\r\n    if (this.isSelectionMode) {\r\n      return;\r\n    }\r\n\r\n    this.timerStop && clearTimeout(this.timerStop);\r\n\r\n    this.selectElementService.setDblClickElement(row);\r\n    this.isAllowOneClick = true;\r\n  }\r\n\r\n  openContextMenu(event: MouseEvent, row: IElementDto): void {\r\n    event.preventDefault();\r\n    this.selectElementService.setContextMenuElement({ position: { x: `${event.x}px`, y: `${event.y}px` }, node: row });\r\n  }\r\n\r\n  changeSelecting(element: IElementDto, event: boolean): void {\r\n    this.treeNodeSelectionService.changeSelecting(event, element.id);\r\n  }\r\n}\r\n","<table\r\n  mat-table\r\n  [dataSource]=\"filteredElementList\"\r\n>\r\n  <ng-container matColumnDef=\"icon\">\r\n    <th\r\n      mat-header-cell\r\n      *matHeaderCellDef\r\n    ></th>\r\n    <td\r\n      mat-cell\r\n      *matCellDef=\"let row\"\r\n      class=\"table-cell-small-width\"\r\n    >\r\n      <mat-icon\r\n        class=\"icon-element\"\r\n        tdChangingIconView\r\n      >\r\n        {{ row | elementIconName }}\r\n      </mat-icon>\r\n    </td>\r\n  </ng-container>\r\n\r\n  <ng-container matColumnDef=\"checkbox\">\r\n    <th\r\n      mat-header-cell\r\n      *matHeaderCellDef\r\n    ></th>\r\n    <td\r\n      mat-cell\r\n      *matCellDef=\"let element\"\r\n      class=\"table-cell-small-width\"\r\n    >\r\n      <mat-checkbox\r\n        class=\"checkbox\"\r\n        color=\"primary\"\r\n        [indeterminate]=\"checkedElements[element.id].indeterminate\"\r\n        [(ngModel)]=\"checkedElements[element.id].checked\"\r\n        (ngModelChange)=\"changeSelecting(element, $event)\"\r\n        (click)=\"$event.stopPropagation()\"\r\n      >\r\n      </mat-checkbox>\r\n    </td>\r\n  </ng-container>\r\n\r\n  <ng-container matColumnDef=\"itemNumber\">\r\n    <th\r\n      mat-header-cell\r\n      *matHeaderCellDef\r\n    >\r\n      OZ\r\n    </th>\r\n    <td\r\n      mat-cell\r\n      *matCellDef=\"let row\"\r\n      [style.width.ch]=\"row?.itemNumber?.stringRepresentation.length\"\r\n    >\r\n      <div\r\n        class=\"text-element\"\r\n        tdChangingTextView\r\n      >\r\n        {{ row | elementItemNumber }}\r\n      </div>\r\n    </td>\r\n  </ng-container>\r\n\r\n  <ng-container matColumnDef=\"text\">\r\n    <th\r\n      mat-header-cell\r\n      *matHeaderCellDef\r\n    >\r\n      Text\r\n    </th>\r\n    <td\r\n      mat-cell\r\n      *matCellDef=\"let row\"\r\n      class=\"table-text\"\r\n    >\r\n      <div\r\n        class=\"text-element\"\r\n        tdChangingTextView\r\n      >\r\n        {{ row | elementText }}\r\n      </div>\r\n    </td>\r\n  </ng-container>\r\n\r\n  <ng-container *ngFor=\"let oneColumn of addTableColumns\">\r\n    <ng-container matColumnDef=\"{{ oneColumn.name }}\">\r\n      <th\r\n        mat-header-cell\r\n        *matHeaderCellDef\r\n      >\r\n        {{ oneColumn.title }}\r\n      </th>\r\n      <td\r\n        mat-cell\r\n        *matCellDef=\"let row\"\r\n      >\r\n        <div\r\n          [style.textAlign]=\"oneColumn.align\"\r\n          tdChangingTextView\r\n        >\r\n          {{ !oneColumn.numberFormat ? row[oneColumn.name] : (row[oneColumn.name] | number: oneColumn.numberFormat) }}\r\n        </div>\r\n      </td>\r\n    </ng-container>\r\n  </ng-container>\r\n\r\n  <tr\r\n    mat-header-row\r\n    *matHeaderRowDef=\"displayedColumns; sticky: true\"\r\n    class=\"mat-header-row\"\r\n  ></tr>\r\n  <tr\r\n    mat-row\r\n    *matRowDef=\"let row; columns: displayedColumns\"\r\n    (click)=\"select(row)\"\r\n    (dblclick)=\"dblSelect(row)\"\r\n    (contextmenu)=\"openContextMenu($event, row)\"\r\n    [ngClass]=\"{\r\n      choose: !isSelectionMode && row.id === preselectedElement?.id,\r\n      select: !isSelectionMode && row.id === selectedElement?.id\r\n    }\"\r\n    [style.background]=\"!isSelectionMode && row.id === selectedElement?.id ? selectedColor || '' : ''\"\r\n    [id]=\"row.id\"\r\n    trSaveChangingView\r\n  ></tr>\r\n</table>\r\n"]}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../services/select-element.service";
|
|
5
|
+
import * as i2 from "projects/angular-ava/src/lib/ava-tree/tree/services/tree-node-selection.service";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "@angular/material/icon";
|
|
8
|
+
import * as i5 from "@angular/forms";
|
|
9
|
+
import * as i6 from "@angular/material/checkbox";
|
|
10
|
+
import * as i7 from "../../directives/save-changing-view.directive";
|
|
11
|
+
import * as i8 from "../../pipes/element-icon-name.pipe";
|
|
12
|
+
import * as i9 from "../../pipes/element-text.pipe";
|
|
13
|
+
import * as i10 from "../../pipes/element-item-number.pipe";
|
|
14
|
+
export class TreeItemComponent {
|
|
15
|
+
constructor(selectElementService, treeNodeSelectionService, cdr) {
|
|
16
|
+
this.selectElementService = selectElementService;
|
|
17
|
+
this.treeNodeSelectionService = treeNodeSelectionService;
|
|
18
|
+
this.cdr = cdr;
|
|
19
|
+
this.element = {};
|
|
20
|
+
this.expansionState = {};
|
|
21
|
+
this.isSelectionMode = false;
|
|
22
|
+
this.selectedElement = null;
|
|
23
|
+
this.preselectedElement = null;
|
|
24
|
+
this.isAllowOneClick = true;
|
|
25
|
+
this.timerStop = null;
|
|
26
|
+
this.$destroy = new Subject();
|
|
27
|
+
this.checkedElements = {};
|
|
28
|
+
}
|
|
29
|
+
ngOnInit() {
|
|
30
|
+
this.selectElementService.selectClickElement.pipe(takeUntil(this.$destroy)).subscribe((element) => (this.selectedElement = element));
|
|
31
|
+
this.selectElementService.preselectedElement.pipe(takeUntil(this.$destroy)).subscribe((element) => (this.preselectedElement = element));
|
|
32
|
+
if (this.isSelectionMode) {
|
|
33
|
+
this.treeNodeSelectionService.treeNodeSelecting.pipe(takeUntil(this.$destroy)).subscribe((treeNodeSelecting) => {
|
|
34
|
+
this.checkedElements = treeNodeSelecting;
|
|
35
|
+
this.cdr.detectChanges();
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
ngOnDestroy() {
|
|
40
|
+
this.timerStop && clearTimeout(this.timerStop);
|
|
41
|
+
this.$destroy.next(true);
|
|
42
|
+
this.$destroy.complete();
|
|
43
|
+
}
|
|
44
|
+
expand() {
|
|
45
|
+
if (this.element) {
|
|
46
|
+
this.expansionState[this.element.id] = true;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
select() {
|
|
50
|
+
if (this.isAllowOneClick) {
|
|
51
|
+
this.isAllowOneClick = false;
|
|
52
|
+
this.timerStop = setTimeout(() => {
|
|
53
|
+
this.selectElementService.setClickElement(this.selectedElement?.id === this.element.id ? null : this.element);
|
|
54
|
+
if (this.element.elementTypeDiscriminator === 'ServiceSpecificationGroupDto') {
|
|
55
|
+
this.expand();
|
|
56
|
+
}
|
|
57
|
+
this.isAllowOneClick = true;
|
|
58
|
+
}, 300);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
dblSelect() {
|
|
62
|
+
this.timerStop && clearTimeout(this.timerStop);
|
|
63
|
+
this.selectElementService.setDblClickElement(this.element);
|
|
64
|
+
if (this.element.elementTypeDiscriminator === 'ServiceSpecificationGroupDto') {
|
|
65
|
+
this.expand();
|
|
66
|
+
}
|
|
67
|
+
this.isAllowOneClick = true;
|
|
68
|
+
}
|
|
69
|
+
openContextMenu(event) {
|
|
70
|
+
event.preventDefault();
|
|
71
|
+
this.selectElementService.setContextMenuElement({ position: { x: `${event.x}px`, y: `${event.y}px` }, node: this.element });
|
|
72
|
+
}
|
|
73
|
+
changeSelecting(element, event) {
|
|
74
|
+
this.treeNodeSelectionService.changeSelecting(event, element.id);
|
|
75
|
+
}
|
|
76
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: TreeItemComponent, deps: [{ token: i1.SelectElementService }, { token: i2.TreeNodeSelectionService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: TreeItemComponent, selector: "ava-tree-item", inputs: { element: "element", expansionState: "expansionState", isSelectionMode: "isSelectionMode" }, ngImport: i0, template: "<div\r\n *ngIf=\"element\"\r\n (click)=\"select()\"\r\n (dblclick)=\"dblSelect()\"\r\n (contextmenu)=\"openContextMenu($event)\"\r\n class=\"ava-tree-item\"\r\n [id]=\"element.id\"\r\n trSaveChangingView\r\n>\r\n <mat-icon\r\n class=\"ava-tree-item__icon\"\r\n tdChangingIconView\r\n >{{ element | elementIconName }}</mat-icon\r\n >\r\n <div\r\n *ngIf=\"!isSelectionMode\"\r\n class=\"ava-tree-item__text\"\r\n [class.choose]=\"!isSelectionMode && element.id === preselectedElement?.id\"\r\n tdChangingTextView\r\n >\r\n <ng-container [ngTemplateOutlet]=\"text\"></ng-container>\r\n </div>\r\n <mat-checkbox\r\n *ngIf=\"isSelectionMode\"\r\n class=\"ava-tree-item__checkbox\"\r\n color=\"primary\"\r\n [indeterminate]=\"checkedElements[element.id].indeterminate\"\r\n [(ngModel)]=\"checkedElements[element.id].checked\"\r\n (ngModelChange)=\"changeSelecting(element, $event)\"\r\n (click)=\"$event.stopPropagation()\"\r\n >\r\n <div\r\n class=\"ava-tree-item__text\"\r\n tdChangingTextView\r\n >\r\n <ng-container [ngTemplateOutlet]=\"text\"></ng-container>\r\n </div>\r\n </mat-checkbox>\r\n</div>\r\n\r\n<ng-template #text>\r\n <ng-container\r\n *ngIf=\"\r\n element?.elementTypeDiscriminator === 'ServiceSpecificationGroupDto' || element?.elementTypeDiscriminator === 'PositionDto';\r\n else simpleText\r\n \"\r\n >\r\n {{ element | elementItemNumber }} - {{ element | elementText }}\r\n </ng-container>\r\n</ng-template>\r\n<ng-template #simpleText>\r\n {{ element | elementText }}\r\n</ng-template>\r\n", styles: ["::ng-deep .ava-tree-item__checkbox .mdc-form-field .mdc-checkbox{padding:0;flex:0 0 16px;width:16px;height:16px}::ng-deep .ava-tree-item__checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__native-control{width:100%;height:100%}::ng-deep .ava-tree-item__checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__native-control:focus~.mdc-checkbox__ripple{opacity:0!important}::ng-deep .ava-tree-item__checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__background{top:0;left:0;width:100%;height:100%}::ng-deep .ava-tree-item__checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__background .mdc-checkbox__mixedmark{border-color:#fff!important}::ng-deep .ava-tree-item__checkbox .mdc-form-field>label{line-height:24px;padding-left:8px;-webkit-user-select:none;user-select:none}::ng-deep .ava-tree-item__checkbox .mat-mdc-checkbox-touch-target{width:16px!important;height:16px!important}.ava-tree-item{display:flex;align-items:center}.ava-tree-item__icon,.ava-tree-item__checkbox{flex-shrink:0}.ava-tree-item__text{flex-grow:1;-webkit-user-select:none;user-select:none;white-space:nowrap}.ava-tree-item__text.choose{color:red!important}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i7.SaveChangingViewDirective, selector: "[trSaveChangingView]" }, { kind: "pipe", type: i8.ElementIconNamePipe, name: "elementIconName" }, { kind: "pipe", type: i9.ElementTextPipe, name: "elementText" }, { kind: "pipe", type: i10.ElementItemNumberPipe, name: "elementItemNumber" }] }); }
|
|
78
|
+
}
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: TreeItemComponent, decorators: [{
|
|
80
|
+
type: Component,
|
|
81
|
+
args: [{ selector: 'ava-tree-item', template: "<div\r\n *ngIf=\"element\"\r\n (click)=\"select()\"\r\n (dblclick)=\"dblSelect()\"\r\n (contextmenu)=\"openContextMenu($event)\"\r\n class=\"ava-tree-item\"\r\n [id]=\"element.id\"\r\n trSaveChangingView\r\n>\r\n <mat-icon\r\n class=\"ava-tree-item__icon\"\r\n tdChangingIconView\r\n >{{ element | elementIconName }}</mat-icon\r\n >\r\n <div\r\n *ngIf=\"!isSelectionMode\"\r\n class=\"ava-tree-item__text\"\r\n [class.choose]=\"!isSelectionMode && element.id === preselectedElement?.id\"\r\n tdChangingTextView\r\n >\r\n <ng-container [ngTemplateOutlet]=\"text\"></ng-container>\r\n </div>\r\n <mat-checkbox\r\n *ngIf=\"isSelectionMode\"\r\n class=\"ava-tree-item__checkbox\"\r\n color=\"primary\"\r\n [indeterminate]=\"checkedElements[element.id].indeterminate\"\r\n [(ngModel)]=\"checkedElements[element.id].checked\"\r\n (ngModelChange)=\"changeSelecting(element, $event)\"\r\n (click)=\"$event.stopPropagation()\"\r\n >\r\n <div\r\n class=\"ava-tree-item__text\"\r\n tdChangingTextView\r\n >\r\n <ng-container [ngTemplateOutlet]=\"text\"></ng-container>\r\n </div>\r\n </mat-checkbox>\r\n</div>\r\n\r\n<ng-template #text>\r\n <ng-container\r\n *ngIf=\"\r\n element?.elementTypeDiscriminator === 'ServiceSpecificationGroupDto' || element?.elementTypeDiscriminator === 'PositionDto';\r\n else simpleText\r\n \"\r\n >\r\n {{ element | elementItemNumber }} - {{ element | elementText }}\r\n </ng-container>\r\n</ng-template>\r\n<ng-template #simpleText>\r\n {{ element | elementText }}\r\n</ng-template>\r\n", styles: ["::ng-deep .ava-tree-item__checkbox .mdc-form-field .mdc-checkbox{padding:0;flex:0 0 16px;width:16px;height:16px}::ng-deep .ava-tree-item__checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__native-control{width:100%;height:100%}::ng-deep .ava-tree-item__checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__native-control:focus~.mdc-checkbox__ripple{opacity:0!important}::ng-deep .ava-tree-item__checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__background{top:0;left:0;width:100%;height:100%}::ng-deep .ava-tree-item__checkbox .mdc-form-field .mdc-checkbox .mdc-checkbox__background .mdc-checkbox__mixedmark{border-color:#fff!important}::ng-deep .ava-tree-item__checkbox .mdc-form-field>label{line-height:24px;padding-left:8px;-webkit-user-select:none;user-select:none}::ng-deep .ava-tree-item__checkbox .mat-mdc-checkbox-touch-target{width:16px!important;height:16px!important}.ava-tree-item{display:flex;align-items:center}.ava-tree-item__icon,.ava-tree-item__checkbox{flex-shrink:0}.ava-tree-item__text{flex-grow:1;-webkit-user-select:none;user-select:none;white-space:nowrap}.ava-tree-item__text.choose{color:red!important}\n"] }]
|
|
82
|
+
}], ctorParameters: function () { return [{ type: i1.SelectElementService }, { type: i2.TreeNodeSelectionService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { element: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}], expansionState: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], isSelectionMode: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}] } });
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/angular-ava/src/lib/ava-tree/tree/components/tree-item/tree-item.component.ts","../../../../../../../../projects/angular-ava/src/lib/ava-tree/tree/components/tree-item/tree-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input, OnDestroy, OnInit } from '@angular/core';\r\n\r\nimport { Subject, takeUntil } from 'rxjs';\r\n\r\nimport { IElementDto } from '../../model';\r\nimport { SelectElementService } from '../../services/select-element.service';\r\n\r\nimport { SelectingElementsType } from 'projects/angular-ava/src/lib/ava-tree/tree/model/selecting.model';\r\nimport { TreeNodeSelectionService } from 'projects/angular-ava/src/lib/ava-tree/tree/services/tree-node-selection.service';\r\n\r\n@Component({\r\n  selector: 'ava-tree-item',\r\n  templateUrl: './tree-item.component.html',\r\n  styleUrls: ['./tree-item.component.scss']\r\n})\r\nexport class TreeItemComponent implements OnInit, OnDestroy {\r\n  @Input() element: IElementDto = {} as IElementDto;\r\n  @Input() expansionState: { [id: string]: boolean } = {};\r\n  @Input() isSelectionMode = false;\r\n  selectedElement: IElementDto | null = null;\r\n  preselectedElement: IElementDto | null = null;\r\n  private isAllowOneClick = true;\r\n  private timerStop: ReturnType<typeof setTimeout> | null = null;\r\n  private $destroy = new Subject<boolean>();\r\n\r\n  checkedElements: {\r\n    [elementId: string]: SelectingElementsType;\r\n  } = {};\r\n\r\n  constructor(\r\n    public selectElementService: SelectElementService,\r\n    private treeNodeSelectionService: TreeNodeSelectionService,\r\n    private cdr: ChangeDetectorRef\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.selectElementService.selectClickElement.pipe(takeUntil(this.$destroy)).subscribe((element) => (this.selectedElement = element));\r\n    this.selectElementService.preselectedElement.pipe(takeUntil(this.$destroy)).subscribe((element) => (this.preselectedElement = element));\r\n\r\n    if (this.isSelectionMode) {\r\n      this.treeNodeSelectionService.treeNodeSelecting.pipe(takeUntil(this.$destroy)).subscribe((treeNodeSelecting) => {\r\n        this.checkedElements = treeNodeSelecting;\r\n        this.cdr.detectChanges();\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.timerStop && clearTimeout(this.timerStop);\r\n    this.$destroy.next(true);\r\n    this.$destroy.complete();\r\n  }\r\n\r\n  expand(): void {\r\n    if (this.element) {\r\n      this.expansionState[this.element.id] = true;\r\n    }\r\n  }\r\n\r\n  select(): void {\r\n    if (this.isAllowOneClick) {\r\n      this.isAllowOneClick = false;\r\n      this.timerStop = setTimeout(() => {\r\n        this.selectElementService.setClickElement(this.selectedElement?.id === this.element.id ? null : this.element);\r\n        if (this.element.elementTypeDiscriminator === 'ServiceSpecificationGroupDto') {\r\n          this.expand();\r\n        }\r\n        this.isAllowOneClick = true;\r\n      }, 300);\r\n    }\r\n  }\r\n\r\n  dblSelect(): void {\r\n    this.timerStop && clearTimeout(this.timerStop);\r\n\r\n    this.selectElementService.setDblClickElement(this.element);\r\n    if (this.element.elementTypeDiscriminator === 'ServiceSpecificationGroupDto') {\r\n      this.expand();\r\n    }\r\n    this.isAllowOneClick = true;\r\n  }\r\n\r\n  openContextMenu(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    this.selectElementService.setContextMenuElement({ position: { x: `${event.x}px`, y: `${event.y}px` }, node: this.element });\r\n  }\r\n\r\n  changeSelecting(element: IElementDto, event: boolean): void {\r\n    this.treeNodeSelectionService.changeSelecting(event, element.id);\r\n  }\r\n}\r\n","<div\r\n  *ngIf=\"element\"\r\n  (click)=\"select()\"\r\n  (dblclick)=\"dblSelect()\"\r\n  (contextmenu)=\"openContextMenu($event)\"\r\n  class=\"ava-tree-item\"\r\n  [id]=\"element.id\"\r\n  trSaveChangingView\r\n>\r\n  <mat-icon\r\n    class=\"ava-tree-item__icon\"\r\n    tdChangingIconView\r\n    >{{ element | elementIconName }}</mat-icon\r\n  >\r\n  <div\r\n    *ngIf=\"!isSelectionMode\"\r\n    class=\"ava-tree-item__text\"\r\n    [class.choose]=\"!isSelectionMode && element.id === preselectedElement?.id\"\r\n    tdChangingTextView\r\n  >\r\n    <ng-container [ngTemplateOutlet]=\"text\"></ng-container>\r\n  </div>\r\n  <mat-checkbox\r\n    *ngIf=\"isSelectionMode\"\r\n    class=\"ava-tree-item__checkbox\"\r\n    color=\"primary\"\r\n    [indeterminate]=\"checkedElements[element.id].indeterminate\"\r\n    [(ngModel)]=\"checkedElements[element.id].checked\"\r\n    (ngModelChange)=\"changeSelecting(element, $event)\"\r\n    (click)=\"$event.stopPropagation()\"\r\n  >\r\n    <div\r\n      class=\"ava-tree-item__text\"\r\n      tdChangingTextView\r\n    >\r\n      <ng-container [ngTemplateOutlet]=\"text\"></ng-container>\r\n    </div>\r\n  </mat-checkbox>\r\n</div>\r\n\r\n<ng-template #text>\r\n  <ng-container\r\n    *ngIf=\"\r\n      element?.elementTypeDiscriminator === 'ServiceSpecificationGroupDto' || element?.elementTypeDiscriminator === 'PositionDto';\r\n      else simpleText\r\n    \"\r\n  >\r\n    {{ element | elementItemNumber }} - {{ element | elementText }}\r\n  </ng-container>\r\n</ng-template>\r\n<ng-template #simpleText>\r\n  {{ element | elementText }}\r\n</ng-template>\r\n"]}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../services/select-element.service";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "@angular/material/icon";
|
|
7
|
+
import * as i4 from "@angular/material/core";
|
|
8
|
+
import * as i5 from "../tree-item/tree-item.component";
|
|
9
|
+
export class TreeNodeComponent {
|
|
10
|
+
constructor(selectElementService) {
|
|
11
|
+
this.selectElementService = selectElementService;
|
|
12
|
+
this.elementList = [];
|
|
13
|
+
this.indent = '';
|
|
14
|
+
this.expansionState = {};
|
|
15
|
+
this.isSelectionMode = false;
|
|
16
|
+
this.selectedColor = null;
|
|
17
|
+
this.selectedElement = null;
|
|
18
|
+
this.$destroy = new Subject();
|
|
19
|
+
}
|
|
20
|
+
ngOnInit() {
|
|
21
|
+
this.selectElementService.selectClickElement.pipe(takeUntil(this.$destroy)).subscribe((element) => {
|
|
22
|
+
this.selectedElement = element;
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
ngOnDestroy() {
|
|
26
|
+
this.$destroy.next(true);
|
|
27
|
+
this.$destroy.complete();
|
|
28
|
+
}
|
|
29
|
+
getElements(element) {
|
|
30
|
+
return element.elements;
|
|
31
|
+
}
|
|
32
|
+
expand(element) {
|
|
33
|
+
this.expansionState[element.id] = !this.expansionState[element.id];
|
|
34
|
+
}
|
|
35
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: TreeNodeComponent, deps: [{ token: i1.SelectElementService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
36
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: TreeNodeComponent, selector: "ava-tree-node", inputs: { elementList: "elementList", indent: "indent", expansionState: "expansionState", isSelectionMode: "isSelectionMode", selectedColor: "selectedColor" }, ngImport: i0, template: "<ng-container *ngFor=\"let element of elementList\">\r\n <div\r\n class=\"tree-node-wrapper\"\r\n [class.select]=\"!isSelectionMode && element.id === selectedElement?.id\"\r\n [style.background]=\"!isSelectionMode && element.id === selectedElement?.id ? selectedColor || '' : ''\"\r\n >\r\n <div class=\"tree-node-wrapper__content\">\r\n <mat-icon\r\n *ngIf=\"element.elementTypeDiscriminator === 'ServiceSpecificationGroupDto'; else nullIcon\"\r\n matRipple\r\n (click)=\"expand(element)\"\r\n class=\"tree-node__icon\"\r\n >\r\n {{ expansionState[element.id] ? 'expand_more' : 'chevron_right' }}\r\n </mat-icon>\r\n <ava-tree-item\r\n [element]=\"element\"\r\n [expansionState]=\"expansionState\"\r\n [isSelectionMode]=\"isSelectionMode\"\r\n ></ava-tree-item>\r\n </div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"element.elementTypeDiscriminator === 'ServiceSpecificationGroupDto' && expansionState?.[element.id]\"\r\n [style.paddingLeft]=\"indent\"\r\n >\r\n <ava-tree-node\r\n [elementList]=\"getElements(element)\"\r\n [expansionState]=\"expansionState\"\r\n [isSelectionMode]=\"isSelectionMode\"\r\n [selectedColor]=\"selectedColor\"\r\n [indent]=\"indent\"\r\n ></ava-tree-node>\r\n </div>\r\n</ng-container>\r\n<ng-template #nullIcon>\r\n <mat-icon></mat-icon>\r\n</ng-template>\r\n", styles: [".tree-node-wrapper{display:flex;align-items:center}.tree-node-wrapper__content{flex:1 0 100%;display:flex}.tree-node__icon{flex-shrink:0}.select{background-color:var(--mdc-filled-text-field-caret-color);color:#fff}.select *{color:#fff}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "component", type: TreeNodeComponent, selector: "ava-tree-node", inputs: ["elementList", "indent", "expansionState", "isSelectionMode", "selectedColor"] }, { kind: "component", type: i5.TreeItemComponent, selector: "ava-tree-item", inputs: ["element", "expansionState", "isSelectionMode"] }] }); }
|
|
37
|
+
}
|
|
38
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: TreeNodeComponent, decorators: [{
|
|
39
|
+
type: Component,
|
|
40
|
+
args: [{ selector: 'ava-tree-node', template: "<ng-container *ngFor=\"let element of elementList\">\r\n <div\r\n class=\"tree-node-wrapper\"\r\n [class.select]=\"!isSelectionMode && element.id === selectedElement?.id\"\r\n [style.background]=\"!isSelectionMode && element.id === selectedElement?.id ? selectedColor || '' : ''\"\r\n >\r\n <div class=\"tree-node-wrapper__content\">\r\n <mat-icon\r\n *ngIf=\"element.elementTypeDiscriminator === 'ServiceSpecificationGroupDto'; else nullIcon\"\r\n matRipple\r\n (click)=\"expand(element)\"\r\n class=\"tree-node__icon\"\r\n >\r\n {{ expansionState[element.id] ? 'expand_more' : 'chevron_right' }}\r\n </mat-icon>\r\n <ava-tree-item\r\n [element]=\"element\"\r\n [expansionState]=\"expansionState\"\r\n [isSelectionMode]=\"isSelectionMode\"\r\n ></ava-tree-item>\r\n </div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"element.elementTypeDiscriminator === 'ServiceSpecificationGroupDto' && expansionState?.[element.id]\"\r\n [style.paddingLeft]=\"indent\"\r\n >\r\n <ava-tree-node\r\n [elementList]=\"getElements(element)\"\r\n [expansionState]=\"expansionState\"\r\n [isSelectionMode]=\"isSelectionMode\"\r\n [selectedColor]=\"selectedColor\"\r\n [indent]=\"indent\"\r\n ></ava-tree-node>\r\n </div>\r\n</ng-container>\r\n<ng-template #nullIcon>\r\n <mat-icon></mat-icon>\r\n</ng-template>\r\n", styles: [".tree-node-wrapper{display:flex;align-items:center}.tree-node-wrapper__content{flex:1 0 100%;display:flex}.tree-node__icon{flex-shrink:0}.select{background-color:var(--mdc-filled-text-field-caret-color);color:#fff}.select *{color:#fff}\n"] }]
|
|
41
|
+
}], ctorParameters: function () { return [{ type: i1.SelectElementService }]; }, propDecorators: { elementList: [{
|
|
42
|
+
type: Input
|
|
43
|
+
}], indent: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}], expansionState: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}], isSelectionMode: [{
|
|
48
|
+
type: Input
|
|
49
|
+
}], selectedColor: [{
|
|
50
|
+
type: Input
|
|
51
|
+
}] } });
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1ub2RlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItYXZhL3NyYy9saWIvYXZhLXRyZWUvdHJlZS9jb21wb25lbnRzL3RyZWUtbm9kZS90cmVlLW5vZGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci1hdmEvc3JjL2xpYi9hdmEtdHJlZS90cmVlL2NvbXBvbmVudHMvdHJlZS1ub2RlL3RyZWUtbm9kZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7Ozs7OztBQVUxQyxNQUFNLE9BQU8saUJBQWlCO0lBUzVCLFlBQW1CLG9CQUEwQztRQUExQyx5QkFBb0IsR0FBcEIsb0JBQW9CLENBQXNCO1FBUnBELGdCQUFXLEdBQTBCLEVBQUUsQ0FBQztRQUN4QyxXQUFNLEdBQUcsRUFBRSxDQUFDO1FBQ1osbUJBQWMsR0FBOEIsRUFBRSxDQUFDO1FBQy9DLG9CQUFlLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLGtCQUFhLEdBQWtCLElBQUksQ0FBQztRQUM3QyxvQkFBZSxHQUF1QixJQUFJLENBQUM7UUFDbkMsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFXLENBQUM7SUFFc0IsQ0FBQztJQUVqRSxRQUFRO1FBQ04sSUFBSSxDQUFDLG9CQUFvQixDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDaEcsSUFBSSxDQUFDLGVBQWUsR0FBRyxPQUFPLENBQUM7UUFDakMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3pCLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFxQztRQUMvQyxPQUFPLE9BQU8sQ0FBQyxRQUFRLENBQUM7SUFDMUIsQ0FBQztJQUVELE1BQU0sQ0FBQyxPQUFvQjtRQUN6QixJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3JFLENBQUM7OEdBNUJVLGlCQUFpQjtrR0FBakIsaUJBQWlCLHFOQ1o5QixtNUNBdUNBLGk2QkQzQmEsaUJBQWlCOzsyRkFBakIsaUJBQWlCO2tCQUw3QixTQUFTOytCQUNFLGVBQWU7MkdBS2hCLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0csZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgU3ViamVjdCwgdGFrZVVudGlsIH0gZnJvbSAncnhqcyc7XHJcblxyXG5pbXBvcnQgeyBJRWxlbWVudER0bywgU2VydmljZVNwZWNpZmljYXRpb25Hcm91cER0byB9IGZyb20gJy4uLy4uL21vZGVsJztcclxuaW1wb3J0IHsgU2VsZWN0RWxlbWVudFNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9zZWxlY3QtZWxlbWVudC5zZXJ2aWNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXZhLXRyZWUtbm9kZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3RyZWUtbm9kZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdHJlZS1ub2RlLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFRyZWVOb2RlQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBlbGVtZW50TGlzdD86IElFbGVtZW50RHRvW10gfCBudWxsID0gW107XHJcbiAgQElucHV0KCkgaW5kZW50ID0gJyc7XHJcbiAgQElucHV0KCkgZXhwYW5zaW9uU3RhdGU6IHsgW2lkOiBzdHJpbmddOiBib29sZWFuIH0gPSB7fTtcclxuICBASW5wdXQoKSBpc1NlbGVjdGlvbk1vZGUgPSBmYWxzZTtcclxuICBASW5wdXQoKSBzZWxlY3RlZENvbG9yOiBzdHJpbmcgfCBudWxsID0gbnVsbDtcclxuICBzZWxlY3RlZEVsZW1lbnQ6IElFbGVtZW50RHRvIHwgbnVsbCA9IG51bGw7XHJcbiAgcHJpdmF0ZSAkZGVzdHJveSA9IG5ldyBTdWJqZWN0PGJvb2xlYW4+KCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBzZWxlY3RFbGVtZW50U2VydmljZTogU2VsZWN0RWxlbWVudFNlcnZpY2UpIHt9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5zZWxlY3RFbGVtZW50U2VydmljZS5zZWxlY3RDbGlja0VsZW1lbnQucGlwZSh0YWtlVW50aWwodGhpcy4kZGVzdHJveSkpLnN1YnNjcmliZSgoZWxlbWVudCkgPT4ge1xyXG4gICAgICB0aGlzLnNlbGVjdGVkRWxlbWVudCA9IGVsZW1lbnQ7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgdGhpcy4kZGVzdHJveS5uZXh0KHRydWUpO1xyXG4gICAgdGhpcy4kZGVzdHJveS5jb21wbGV0ZSgpO1xyXG4gIH1cclxuXHJcbiAgZ2V0RWxlbWVudHMoZWxlbWVudDogU2VydmljZVNwZWNpZmljYXRpb25Hcm91cER0byk6IElFbGVtZW50RHRvW10gfCBudWxsIHwgdW5kZWZpbmVkIHtcclxuICAgIHJldHVybiBlbGVtZW50LmVsZW1lbnRzO1xyXG4gIH1cclxuXHJcbiAgZXhwYW5kKGVsZW1lbnQ6IElFbGVtZW50RHRvKTogdm9pZCB7XHJcbiAgICB0aGlzLmV4cGFuc2lvblN0YXRlW2VsZW1lbnQuaWRdID0gIXRoaXMuZXhwYW5zaW9uU3RhdGVbZWxlbWVudC5pZF07XHJcbiAgfVxyXG59XHJcbiIsIjxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGVsZW1lbnQgb2YgZWxlbWVudExpc3RcIj5cclxuICA8ZGl2XHJcbiAgICBjbGFzcz1cInRyZWUtbm9kZS13cmFwcGVyXCJcclxuICAgIFtjbGFzcy5zZWxlY3RdPVwiIWlzU2VsZWN0aW9uTW9kZSAmJiBlbGVtZW50LmlkID09PSBzZWxlY3RlZEVsZW1lbnQ/LmlkXCJcclxuICAgIFtzdHlsZS5iYWNrZ3JvdW5kXT1cIiFpc1NlbGVjdGlvbk1vZGUgJiYgZWxlbWVudC5pZCA9PT0gc2VsZWN0ZWRFbGVtZW50Py5pZCA/IHNlbGVjdGVkQ29sb3IgfHwgJycgOiAnJ1wiXHJcbiAgPlxyXG4gICAgPGRpdiBjbGFzcz1cInRyZWUtbm9kZS13cmFwcGVyX19jb250ZW50XCI+XHJcbiAgICAgIDxtYXQtaWNvblxyXG4gICAgICAgICpuZ0lmPVwiZWxlbWVudC5lbGVtZW50VHlwZURpc2NyaW1pbmF0b3IgPT09ICdTZXJ2aWNlU3BlY2lmaWNhdGlvbkdyb3VwRHRvJzsgZWxzZSBudWxsSWNvblwiXHJcbiAgICAgICAgbWF0UmlwcGxlXHJcbiAgICAgICAgKGNsaWNrKT1cImV4cGFuZChlbGVtZW50KVwiXHJcbiAgICAgICAgY2xhc3M9XCJ0cmVlLW5vZGVfX2ljb25cIlxyXG4gICAgICA+XHJcbiAgICAgICAge3sgZXhwYW5zaW9uU3RhdGVbZWxlbWVudC5pZF0gPyAnZXhwYW5kX21vcmUnIDogJ2NoZXZyb25fcmlnaHQnIH19XHJcbiAgICAgIDwvbWF0LWljb24+XHJcbiAgICAgIDxhdmEtdHJlZS1pdGVtXHJcbiAgICAgICAgW2VsZW1lbnRdPVwiZWxlbWVudFwiXHJcbiAgICAgICAgW2V4cGFuc2lvblN0YXRlXT1cImV4cGFuc2lvblN0YXRlXCJcclxuICAgICAgICBbaXNTZWxlY3Rpb25Nb2RlXT1cImlzU2VsZWN0aW9uTW9kZVwiXHJcbiAgICAgID48L2F2YS10cmVlLWl0ZW0+XHJcbiAgICA8L2Rpdj5cclxuICA8L2Rpdj5cclxuXHJcbiAgPGRpdlxyXG4gICAgKm5nSWY9XCJlbGVtZW50LmVsZW1lbnRUeXBlRGlzY3JpbWluYXRvciA9PT0gJ1NlcnZpY2VTcGVjaWZpY2F0aW9uR3JvdXBEdG8nICYmIGV4cGFuc2lvblN0YXRlPy5bZWxlbWVudC5pZF1cIlxyXG4gICAgW3N0eWxlLnBhZGRpbmdMZWZ0XT1cImluZGVudFwiXHJcbiAgPlxyXG4gICAgPGF2YS10cmVlLW5vZGVcclxuICAgICAgW2VsZW1lbnRMaXN0XT1cImdldEVsZW1lbnRzKGVsZW1lbnQpXCJcclxuICAgICAgW2V4cGFuc2lvblN0YXRlXT1cImV4cGFuc2lvblN0YXRlXCJcclxuICAgICAgW2lzU2VsZWN0aW9uTW9kZV09XCJpc1NlbGVjdGlvbk1vZGVcIlxyXG4gICAgICBbc2VsZWN0ZWRDb2xvcl09XCJzZWxlY3RlZENvbG9yXCJcclxuICAgICAgW2luZGVudF09XCJpbmRlbnRcIlxyXG4gICAgPjwvYXZhLXRyZWUtbm9kZT5cclxuICA8L2Rpdj5cclxuPC9uZy1jb250YWluZXI+XHJcbjxuZy10ZW1wbGF0ZSAjbnVsbEljb24+XHJcbiAgPG1hdC1pY29uPjwvbWF0LWljb24+XHJcbjwvbmctdGVtcGxhdGU+XHJcbiJdfQ==
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../tree-node/tree-node.component";
|
|
5
|
+
export class TreeStructureComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.serviceSpecification = null;
|
|
8
|
+
this.indent = '';
|
|
9
|
+
this.expansionState = {};
|
|
10
|
+
this.isSelectionMode = false;
|
|
11
|
+
this.selectedColor = null;
|
|
12
|
+
}
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: TreeStructureComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
14
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: TreeStructureComponent, selector: "ava-tree-structure", inputs: { serviceSpecification: "serviceSpecification", indent: "indent", expansionState: "expansionState", isSelectionMode: "isSelectionMode", selectedColor: "selectedColor" }, ngImport: i0, template: "<ava-tree-node\r\n *ngIf=\"serviceSpecification?.elements\"\r\n [elementList]=\"serviceSpecification?.elements\"\r\n [indent]=\"indent\"\r\n [expansionState]=\"expansionState\"\r\n [isSelectionMode]=\"isSelectionMode\"\r\n [selectedColor]=\"selectedColor\"\r\n>\r\n</ava-tree-node>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.TreeNodeComponent, selector: "ava-tree-node", inputs: ["elementList", "indent", "expansionState", "isSelectionMode", "selectedColor"] }] }); }
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: TreeStructureComponent, decorators: [{
|
|
17
|
+
type: Component,
|
|
18
|
+
args: [{ selector: 'ava-tree-structure', template: "<ava-tree-node\r\n *ngIf=\"serviceSpecification?.elements\"\r\n [elementList]=\"serviceSpecification?.elements\"\r\n [indent]=\"indent\"\r\n [expansionState]=\"expansionState\"\r\n [isSelectionMode]=\"isSelectionMode\"\r\n [selectedColor]=\"selectedColor\"\r\n>\r\n</ava-tree-node>\r\n" }]
|
|
19
|
+
}], propDecorators: { serviceSpecification: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}], indent: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}], expansionState: [{
|
|
24
|
+
type: Input
|
|
25
|
+
}], isSelectionMode: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}], selectedColor: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}] } });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1zdHJ1Y3R1cmUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci1hdmEvc3JjL2xpYi9hdmEtdHJlZS90cmVlL2NvbXBvbmVudHMvdHJlZS1zdHJ1Y3R1cmUvdHJlZS1zdHJ1Y3R1cmUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci1hdmEvc3JjL2xpYi9hdmEtdHJlZS90cmVlL2NvbXBvbmVudHMvdHJlZS1zdHJ1Y3R1cmUvdHJlZS1zdHJ1Y3R1cmUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFTakQsTUFBTSxPQUFPLHNCQUFzQjtJQUxuQztRQU1XLHlCQUFvQixHQUFtQyxJQUFJLENBQUM7UUFDNUQsV0FBTSxHQUFHLEVBQUUsQ0FBQztRQUNaLG1CQUFjLEdBQThCLEVBQUUsQ0FBQztRQUMvQyxvQkFBZSxHQUFHLEtBQUssQ0FBQztRQUN4QixrQkFBYSxHQUFrQixJQUFJLENBQUM7S0FDOUM7OEdBTlksc0JBQXNCO2tHQUF0QixzQkFBc0IsNE9DVG5DLHFTQVNBOzsyRkRBYSxzQkFBc0I7a0JBTGxDLFNBQVM7K0JBQ0Usb0JBQW9COzhCQUtyQixvQkFBb0I7c0JBQTVCLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0csZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgU2VydmljZVNwZWNpZmljYXRpb25EdG8gfSBmcm9tICcuLi8uLi9tb2RlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2F2YS10cmVlLXN0cnVjdHVyZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3RyZWUtc3RydWN0dXJlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi90cmVlLXN0cnVjdHVyZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUcmVlU3RydWN0dXJlQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBzZXJ2aWNlU3BlY2lmaWNhdGlvbjogU2VydmljZVNwZWNpZmljYXRpb25EdG8gfCBudWxsID0gbnVsbDtcclxuICBASW5wdXQoKSBpbmRlbnQgPSAnJztcclxuICBASW5wdXQoKSBleHBhbnNpb25TdGF0ZTogeyBbaWQ6IHN0cmluZ106IGJvb2xlYW4gfSA9IHt9O1xyXG4gIEBJbnB1dCgpIGlzU2VsZWN0aW9uTW9kZSA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIHNlbGVjdGVkQ29sb3I6IHN0cmluZyB8IG51bGwgPSBudWxsO1xyXG59XHJcbiIsIjxhdmEtdHJlZS1ub2RlXHJcbiAgKm5nSWY9XCJzZXJ2aWNlU3BlY2lmaWNhdGlvbj8uZWxlbWVudHNcIlxyXG4gIFtlbGVtZW50TGlzdF09XCJzZXJ2aWNlU3BlY2lmaWNhdGlvbj8uZWxlbWVudHNcIlxyXG4gIFtpbmRlbnRdPVwiaW5kZW50XCJcclxuICBbZXhwYW5zaW9uU3RhdGVdPVwiZXhwYW5zaW9uU3RhdGVcIlxyXG4gIFtpc1NlbGVjdGlvbk1vZGVdPVwiaXNTZWxlY3Rpb25Nb2RlXCJcclxuICBbc2VsZWN0ZWRDb2xvcl09XCJzZWxlY3RlZENvbG9yXCJcclxuPlxyXG48L2F2YS10cmVlLW5vZGU+XHJcbiJdfQ==
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export const DEFAULT_FILTERS = [
|
|
2
|
+
(element, filter) => element['shortText']?.trim().toLocaleLowerCase().includes(filter),
|
|
3
|
+
(element, filter) => element['label']?.trim().toLocaleLowerCase().includes(filter),
|
|
4
|
+
(element, filter) => element['itemNumber']?.['stringRepresentation']?.includes(filter)
|
|
5
|
+
];
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdEZpbHRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWF2YS9zcmMvbGliL2F2YS10cmVlL3RyZWUvY29uc3RhbnRzL2RlZmF1bHRGaWx0ZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRztJQUM3QixDQUFDLE9BQVksRUFBRSxNQUFjLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUM7SUFDbkcsQ0FBQyxPQUFZLEVBQUUsTUFBYyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDO0lBQy9GLENBQUMsT0FBWSxFQUFFLE1BQWMsRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxFQUFFLENBQUMsc0JBQXNCLENBQUMsRUFBRSxRQUFRLENBQUMsTUFBTSxDQUFDO0NBQ3BHLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgREVGQVVMVF9GSUxURVJTID0gW1xyXG4gIChlbGVtZW50OiBhbnksIGZpbHRlcjogc3RyaW5nKSA9PiBlbGVtZW50WydzaG9ydFRleHQnXT8udHJpbSgpLnRvTG9jYWxlTG93ZXJDYXNlKCkuaW5jbHVkZXMoZmlsdGVyKSxcclxuICAoZWxlbWVudDogYW55LCBmaWx0ZXI6IHN0cmluZykgPT4gZWxlbWVudFsnbGFiZWwnXT8udHJpbSgpLnRvTG9jYWxlTG93ZXJDYXNlKCkuaW5jbHVkZXMoZmlsdGVyKSxcclxuICAoZWxlbWVudDogYW55LCBmaWx0ZXI6IHN0cmluZykgPT4gZWxlbWVudFsnaXRlbU51bWJlciddPy5bJ3N0cmluZ1JlcHJlc2VudGF0aW9uJ10/LmluY2x1ZGVzKGZpbHRlcilcclxuXTtcclxuIl19
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export const DEFAULT_TEXT_WORDS = {
|
|
2
|
+
textSearch: 'Suche',
|
|
3
|
+
textNothing: 'Nothing',
|
|
4
|
+
textNothingFiltered: 'Nothing Filtered',
|
|
5
|
+
textAll: 'Alle',
|
|
6
|
+
tooltipAllOpen: 'Alle aufklappen',
|
|
7
|
+
tooltipAllClose: 'Alle zuklappen',
|
|
8
|
+
tooltipAllAdd: 'Alle hinzufügen',
|
|
9
|
+
tooltipAllRemove: 'Alle entfernen'
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdFRleHRXb3Jkcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItYXZhL3NyYy9saWIvYXZhLXRyZWUvdHJlZS9jb25zdGFudHMvZGVmYXVsdFRleHRXb3Jkcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXQSxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBZTtJQUM1QyxVQUFVLEVBQUUsT0FBTztJQUNuQixXQUFXLEVBQUUsU0FBUztJQUN0QixtQkFBbUIsRUFBRSxrQkFBa0I7SUFDdkMsT0FBTyxFQUFFLE1BQU07SUFDZixjQUFjLEVBQUUsaUJBQWlCO0lBQ2pDLGVBQWUsRUFBRSxnQkFBZ0I7SUFDakMsYUFBYSxFQUFFLGlCQUFpQjtJQUNoQyxnQkFBZ0IsRUFBRSxnQkFBZ0I7Q0FDbkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSVRleHRXb3JkcyB7XHJcbiAgdGV4dFNlYXJjaD86IHN0cmluZztcclxuICB0ZXh0Tm90aGluZz86IHN0cmluZztcclxuICB0ZXh0Tm90aGluZ0ZpbHRlcmVkPzogc3RyaW5nO1xyXG4gIHRleHRBbGw/OiBzdHJpbmc7XHJcbiAgdG9vbHRpcEFsbE9wZW4/OiBzdHJpbmc7XHJcbiAgdG9vbHRpcEFsbENsb3NlPzogc3RyaW5nO1xyXG4gIHRvb2x0aXBBbGxBZGQ/OiBzdHJpbmc7XHJcbiAgdG9vbHRpcEFsbFJlbW92ZT86IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IERFRkFVTFRfVEVYVF9XT1JEUzogSVRleHRXb3JkcyA9IHtcclxuICB0ZXh0U2VhcmNoOiAnU3VjaGUnLFxyXG4gIHRleHROb3RoaW5nOiAnTm90aGluZycsXHJcbiAgdGV4dE5vdGhpbmdGaWx0ZXJlZDogJ05vdGhpbmcgRmlsdGVyZWQnLFxyXG4gIHRleHRBbGw6ICdBbGxlJyxcclxuICB0b29sdGlwQWxsT3BlbjogJ0FsbGUgYXVma2xhcHBlbicsXHJcbiAgdG9vbHRpcEFsbENsb3NlOiAnQWxsZSB6dWtsYXBwZW4nLFxyXG4gIHRvb2x0aXBBbGxBZGQ6ICdBbGxlIGhpbnp1ZsO8Z2VuJyxcclxuICB0b29sdGlwQWxsUmVtb3ZlOiAnQWxsZSBlbnRmZXJuZW4nXHJcbn07XHJcbiJdfQ==
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { DEFAULT_FILTERS } from './defaultFilters';
|
|
2
|
+
import { DEFAULT_TEXT_WORDS } from './defaultTextWords';
|
|
3
|
+
export { DEFAULT_FILTERS, DEFAULT_TEXT_WORDS };
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWF2YS9zcmMvbGliL2F2YS10cmVlL3RyZWUvY29uc3RhbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUV4RCxPQUFPLEVBQUUsZUFBZSxFQUFFLGtCQUFrQixFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBERUZBVUxUX0ZJTFRFUlMgfSBmcm9tICcuL2RlZmF1bHRGaWx0ZXJzJztcclxuaW1wb3J0IHsgREVGQVVMVF9URVhUX1dPUkRTIH0gZnJvbSAnLi9kZWZhdWx0VGV4dFdvcmRzJztcclxuXHJcbmV4cG9ydCB7IERFRkFVTFRfRklMVEVSUywgREVGQVVMVF9URVhUX1dPUkRTIH07XHJcbiJdfQ==
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Directive } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../services/flat-elements.service";
|
|
4
|
+
export class SaveChangingViewDirective {
|
|
5
|
+
constructor(el, renderer, flatElementsService) {
|
|
6
|
+
this.el = el;
|
|
7
|
+
this.renderer = renderer;
|
|
8
|
+
this.flatElementsService = flatElementsService;
|
|
9
|
+
}
|
|
10
|
+
ngOnInit() {
|
|
11
|
+
setTimeout(() => {
|
|
12
|
+
const id = this.el?.nativeElement.id;
|
|
13
|
+
if (id) {
|
|
14
|
+
const view = this.flatElementsService?.getChangedView(id);
|
|
15
|
+
const icon = this.el.nativeElement.querySelector('[tdChangingIconView]');
|
|
16
|
+
if (view?.iconName && icon) {
|
|
17
|
+
icon.textContent = view.iconName;
|
|
18
|
+
}
|
|
19
|
+
if (view?.iconColor && icon) {
|
|
20
|
+
this.renderer?.setStyle(icon, 'color', view.iconColor);
|
|
21
|
+
}
|
|
22
|
+
const textList = this.el.nativeElement.querySelectorAll('[tdChangingTextView]');
|
|
23
|
+
textList?.forEach((text) => {
|
|
24
|
+
if (view?.textBold) {
|
|
25
|
+
this.renderer?.setStyle(text, 'font-weight', view.textBold);
|
|
26
|
+
}
|
|
27
|
+
if (view?.textColor) {
|
|
28
|
+
this.renderer?.setStyle(text, 'color', view.textColor);
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}, 0);
|
|
33
|
+
}
|
|
34
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: SaveChangingViewDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.FlatElementsService }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
35
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.6", type: SaveChangingViewDirective, selector: "[trSaveChangingView]", ngImport: i0 }); }
|
|
36
|
+
}
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: SaveChangingViewDirective, decorators: [{
|
|
38
|
+
type: Directive,
|
|
39
|
+
args: [{
|
|
40
|
+
selector: '[trSaveChangingView]'
|
|
41
|
+
}]
|
|
42
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.FlatElementsService }]; } });
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2F2ZS1jaGFuZ2luZy12aWV3LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItYXZhL3NyYy9saWIvYXZhLXRyZWUvdHJlZS9kaXJlY3RpdmVzL3NhdmUtY2hhbmdpbmctdmlldy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBeUIsTUFBTSxlQUFlLENBQUM7OztBQVFqRSxNQUFNLE9BQU8seUJBQXlCO0lBQ3BDLFlBQ1UsRUFBYyxFQUNkLFFBQW1CLEVBQ25CLG1CQUF3QztRQUZ4QyxPQUFFLEdBQUYsRUFBRSxDQUFZO1FBQ2QsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUNuQix3QkFBbUIsR0FBbkIsbUJBQW1CLENBQXFCO0lBQy9DLENBQUM7SUFFSixRQUFRO1FBQ04sVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNkLE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyxFQUFFLEVBQUUsYUFBYSxDQUFDLEVBQUUsQ0FBQztZQUNyQyxJQUFJLEVBQUUsRUFBRTtnQkFDTixNQUFNLElBQUksR0FBcUIsSUFBSSxDQUFDLG1CQUFtQixFQUFFLGNBQWMsQ0FBQyxFQUFFLENBQUMsQ0FBQztnQkFFNUUsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLHNCQUFzQixDQUFnQixDQUFDO2dCQUN4RixJQUFJLElBQUksRUFBRSxRQUFRLElBQUksSUFBSSxFQUFFO29CQUMxQixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUM7aUJBQ2xDO2dCQUNELElBQUksSUFBSSxFQUFFLFNBQVMsSUFBSSxJQUFJLEVBQUU7b0JBQzNCLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO2lCQUN4RDtnQkFDRCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxzQkFBc0IsQ0FBa0IsQ0FBQztnQkFDakcsUUFBUSxFQUFFLE9BQU8sQ0FBQyxDQUFDLElBQWlCLEVBQUUsRUFBRTtvQkFDdEMsSUFBSSxJQUFJLEVBQUUsUUFBUSxFQUFFO3dCQUNsQixJQUFJLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxJQUFJLEVBQUUsYUFBYSxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztxQkFDN0Q7b0JBQ0QsSUFBSSxJQUFJLEVBQUUsU0FBUyxFQUFFO3dCQUNuQixJQUFJLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztxQkFDeEQ7Z0JBQ0gsQ0FBQyxDQUFDLENBQUM7YUFDSjtRQUNILENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNSLENBQUM7OEdBL0JVLHlCQUF5QjtrR0FBekIseUJBQXlCOzsyRkFBekIseUJBQXlCO2tCQUhyQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7aUJBQ2pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IElWaWV3TGluZSB9IGZyb20gJy4uL21vZGVsJztcclxuaW1wb3J0IHsgRmxhdEVsZW1lbnRzU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2ZsYXQtZWxlbWVudHMuc2VydmljZSc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1t0clNhdmVDaGFuZ2luZ1ZpZXddJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgU2F2ZUNoYW5naW5nVmlld0RpcmVjdGl2ZSB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGVsOiBFbGVtZW50UmVmLFxyXG4gICAgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyLFxyXG4gICAgcHJpdmF0ZSBmbGF0RWxlbWVudHNTZXJ2aWNlOiBGbGF0RWxlbWVudHNTZXJ2aWNlXHJcbiAgKSB7fVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xyXG4gICAgICBjb25zdCBpZCA9IHRoaXMuZWw/Lm5hdGl2ZUVsZW1lbnQuaWQ7XHJcbiAgICAgIGlmIChpZCkge1xyXG4gICAgICAgIGNvbnN0IHZpZXc6IElWaWV3TGluZSB8IG51bGwgPSB0aGlzLmZsYXRFbGVtZW50c1NlcnZpY2U/LmdldENoYW5nZWRWaWV3KGlkKTtcclxuXHJcbiAgICAgICAgY29uc3QgaWNvbiA9IHRoaXMuZWwubmF0aXZlRWxlbWVudC5xdWVyeVNlbGVjdG9yKCdbdGRDaGFuZ2luZ0ljb25WaWV3XScpIGFzIEhUTUxFbGVtZW50O1xyXG4gICAgICAgIGlmICh2aWV3Py5pY29uTmFtZSAmJiBpY29uKSB7XHJcbiAgICAgICAgICBpY29uLnRleHRDb250ZW50ID0gdmlldy5pY29uTmFtZTtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKHZpZXc/Lmljb25Db2xvciAmJiBpY29uKSB7XHJcbiAgICAgICAgICB0aGlzLnJlbmRlcmVyPy5zZXRTdHlsZShpY29uLCAnY29sb3InLCB2aWV3Lmljb25Db2xvcik7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGNvbnN0IHRleHRMaXN0ID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJ1t0ZENoYW5naW5nVGV4dFZpZXddJykgYXMgSFRNTEVsZW1lbnRbXTtcclxuICAgICAgICB0ZXh0TGlzdD8uZm9yRWFjaCgodGV4dDogSFRNTEVsZW1lbnQpID0+IHtcclxuICAgICAgICAgIGlmICh2aWV3Py50ZXh0Qm9sZCkge1xyXG4gICAgICAgICAgICB0aGlzLnJlbmRlcmVyPy5zZXRTdHlsZSh0ZXh0LCAnZm9udC13ZWlnaHQnLCB2aWV3LnRleHRCb2xkKTtcclxuICAgICAgICAgIH1cclxuICAgICAgICAgIGlmICh2aWV3Py50ZXh0Q29sb3IpIHtcclxuICAgICAgICAgICAgdGhpcy5yZW5kZXJlcj8uc2V0U3R5bGUodGV4dCwgJ2NvbG9yJywgdmlldy50ZXh0Q29sb3IpO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgICB9XHJcbiAgICB9LCAwKTtcclxuICB9XHJcbn1cclxuIl19
|