tuain-ng-forms-lib 12.0.19 → 12.0.23
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 +3 -3
- package/bundles/tuain-ng-forms-lib.umd.js +39 -38
- package/bundles/tuain-ng-forms-lib.umd.js.map +1 -1
- package/esm2015/lib/components/elements/field.component.js +2 -2
- package/esm2015/lib/components/elements/layout/element.component.js +9 -8
- package/esm2015/lib/components/elements/tables/table.component.js +31 -31
- package/fesm2015/tuain-ng-forms-lib.js +39 -38
- package/fesm2015/tuain-ng-forms-lib.js.map +1 -1
- package/lib/components/elements/layout/element.component.d.ts +3 -2
- package/lib/components/elements/tables/table.component.d.ts +1 -1
- package/package.json +1 -1
- package/tuain-ng-forms-lib.metadata.json +1 -1
|
@@ -38,7 +38,7 @@ export class FieldComponent {
|
|
|
38
38
|
}
|
|
39
39
|
inputChanged() {
|
|
40
40
|
this.field._fieldValue = this.value;
|
|
41
|
-
this.
|
|
41
|
+
this.onChangeContent();
|
|
42
42
|
}
|
|
43
43
|
inputTyped() {
|
|
44
44
|
this.field._fieldValue = this.value;
|
|
@@ -79,4 +79,4 @@ FieldComponent.propDecorators = {
|
|
|
79
79
|
field: [{ type: Input }],
|
|
80
80
|
currentState: [{ type: Input }]
|
|
81
81
|
};
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHVhaW4tbmctZm9ybXMtbGliL3NyYy9saWIvY29tcG9uZW50cy9lbGVtZW50cy9maWVsZC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHekQsTUFBTSxLQUFLLEdBQUcsRUFBRSxDQUFBO0FBS2hCLE1BQU0sT0FBTyxjQUFjO0lBMEJ6QixRQUFROztRQUNOLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNkLElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBQSxJQUFJLENBQUMsS0FBSywwQ0FBRSxXQUFXLENBQUM7WUFDMUMsaUJBQWlCO1lBQ2pCLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1lBQ3RFLEtBQUssSUFBSSxLQUFLLEdBQUcsQ0FBQyxFQUFFLEtBQUssR0FBRyxPQUFPLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxFQUFFO2dCQUNuRCxNQUFNLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDOUMsTUFBTSxRQUFRLEdBQUcsU0FBUyxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUN0QyxJQUFJLFFBQVEsS0FBSyxLQUFLLEVBQUU7b0JBQ3RCLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztpQkFDcEI7cUJBQU07b0JBQ0wsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLE1BQUEsSUFBSSxDQUFDLEtBQUssMENBQUcsU0FBUyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7aUJBQ3JEO2FBQ0Y7WUFDRCxzQ0FBc0M7WUFDdEMsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUMzQyxNQUFNLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsR0FBRyxLQUFLLENBQUM7Z0JBQ3pDLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUM7Z0JBQ2xFLElBQUksUUFBUSxLQUFLLEtBQUssRUFBRTtvQkFDdEIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO2lCQUNwQjtxQkFBTTtvQkFDTCxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsS0FBSyxDQUFBO2lCQUN2QjtZQUNILENBQUMsQ0FBQyxDQUFDO1NBQ0o7UUFDRCxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDZixDQUFDO0lBRUQsS0FBSyxLQUFLLENBQUM7SUFFWCxLQUFLLEtBQUssQ0FBQztJQUVYLFlBQVk7UUFDVixJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxZQUFZO1FBQ1YsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQztRQUNwQyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELFVBQVU7UUFDUixJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO1FBQ3BDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUM7SUFDdEMsQ0FBQztJQUVELGFBQWE7UUFDWCxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxvQkFBb0IsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFRCxlQUFlO1FBQ2IsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsbUJBQW1CLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBRUQsVUFBVTtRQUNSLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLDBCQUEwQixFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDaEUsQ0FBQztJQUVELHFCQUFxQixDQUFDLEtBQUs7UUFDekIsTUFBTSxDQUFDLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUN6QixPQUFPLENBQUMsQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDNUIsQ0FBQztJQUVELElBQUksT0FBTzs7UUFDVCxPQUFPLE1BQUEsSUFBSSxDQUFDLEtBQUssMENBQUUsU0FBUyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQsSUFBSSxRQUFROztRQUNWLE9BQU8sQ0FBQyxDQUFBLE1BQUEsSUFBSSxDQUFDLEtBQUssMENBQUUsU0FBUyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQSxDQUFDO0lBQ25ELENBQUM7OztZQXZHRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLFdBQVc7Z0JBQ3JCLFFBQVEsRUFBRSwyQkFBMkI7YUFDdEM7OztvQkF3QkUsS0FBSzsyQkFDTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGaWVsZERlc2NyaXB0b3IgfSBmcm9tICcuLi8uLi9jbGFzc2VzL2Zvcm1zL2ZpZWxkJztcblxuY29uc3QgVkFMVUUgPSAnJ1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLWZpZWxkJyxcbiAgdGVtcGxhdGU6IGA8bmctY29udGVudD48L25nLWNvbnRlbnQ+YFxufSlcbmV4cG9ydCBjbGFzcyBGaWVsZENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIGZvcm1Db25maWc6IGFueTtcbiAgLy8gQXRyaWJ1dG9zIG9idGVuaWRvcyBlc3TDoXRpY2FtZW50ZVxuICBjb2RlOiBzdHJpbmc7XG4gIHZhbHVlOiBhbnk7XG4gIGZpZWxkSW5mbzogc3RyaW5nO1xuICBmaWVsZEFsaWdubWVudDogc3RyaW5nO1xuICB0b29sdGlwVGV4dDogc3RyaW5nO1xuXG4gIC8vIEF0cmlidXRvcyBhY3R1YWxpemFkb3MgcG9yIHN1YnNjcmlwY2nDs25cbiAgbWF4TGVuZ3RoOiBhbnk7XG4gIG9uVmFsaWRhdGlvbjogYW55O1xuICBjYXB0dXJlVHlwZTogYW55O1xuICB0aXRsZTogYW55O1xuICB0eXBlOiBhbnk7XG4gIHZpc2libGVMYWJlbDogYW55O1xuICByZXF1aXJlZDogYW55O1xuICBvcHRpb25zOiBhbnk7XG5cbiAgZXJyb3JUeXBlOiBhbnk7XG4gIGVycm9yQ29kZTogYW55O1xuICBlcnJvck1lc3NhZ2U6IGFueTtcblxuICBASW5wdXQoKSBmaWVsZDogRmllbGREZXNjcmlwdG9yO1xuICBASW5wdXQoKSBjdXJyZW50U3RhdGU6IGFueTtcblxuICBuZ09uSW5pdCgpIHtcbiAgICBpZiAodGhpcy5maWVsZCkge1xuICAgICAgdGhpcy5mb3JtQ29uZmlnID0gdGhpcy5maWVsZD8uX2Zvcm1Db25maWc7XG4gICAgICAvLyBJbmljaWFsaXphY2nDs25cbiAgICAgIGNvbnN0IG1hcHBpbmcgPSBPYmplY3QuZW50cmllcyh0aGlzLmZvcm1Db25maWcuY29tcG9uZW50RmllbGRBdHRyTWFwKTtcbiAgICAgIGZvciAobGV0IGluZGV4ID0gMDsgaW5kZXggPCBtYXBwaW5nLmxlbmd0aDsgaW5kZXgrKykge1xuICAgICAgICBjb25zdCBbZmllbGRBdHRyLCBjb21wQXR0cjFdID0gbWFwcGluZ1tpbmRleF07XG4gICAgICAgIGNvbnN0IGNvbXBBdHRyID0gY29tcEF0dHIxLnRvU3RyaW5nKCk7XG4gICAgICAgIGlmIChjb21wQXR0ciA9PT0gVkFMVUUpIHtcbiAgICAgICAgICB0aGlzLnVwZGF0ZVZhbHVlKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgdGhpc1tjb21wQXR0cl0gPSB0aGlzLmZpZWxkPy5bZmllbGRBdHRyLnRvU3RyaW5nKCldO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICAvLyBTdWJzY3JpcGNpw7NuIGEgY2FtYmlvcyBlbiBhdHJpYnV0b3NcbiAgICAgIHRoaXMuZmllbGQuYXR0cmlidXRlQ2hhbmdlLnN1YnNjcmliZShldmVudCA9PiB7XG4gICAgICAgIGNvbnN0IHsgbmFtZTogZmllbGRBdHRyLCB2YWx1ZSB9ID0gZXZlbnQ7XG4gICAgICAgIGNvbnN0IGNvbXBBdHRyID0gdGhpcy5mb3JtQ29uZmlnLmNvbXBvbmVudEZpZWxkQXR0ck1hcFtmaWVsZEF0dHJdO1xuICAgICAgICBpZiAoY29tcEF0dHIgPT09IFZBTFVFKSB7XG4gICAgICAgICAgdGhpcy51cGRhdGVWYWx1ZSgpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHRoaXNbY29tcEF0dHJdID0gdmFsdWVcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfVxuICAgIHRoaXMuc3RhcnQoKTtcbiAgfVxuXG4gIHN0YXJ0KCkgeyB9XG5cbiAgZm9jdXMoKSB7IH1cblxuICB1cGRhdGVPYmplY3QoKSB7XG4gICAgdGhpcy5maWVsZC5fZmllbGRWYWx1ZSA9IHRoaXMudmFsdWU7XG4gIH1cblxuICBpbnB1dENoYW5nZWQoKSB7XG4gICAgdGhpcy5maWVsZC5fZmllbGRWYWx1ZSA9IHRoaXMudmFsdWU7XG4gICAgdGhpcy5vbkNoYW5nZUNvbnRlbnQoKTtcbiAgfVxuXG4gIGlucHV0VHlwZWQoKSB7XG4gICAgdGhpcy5maWVsZC5fZmllbGRWYWx1ZSA9IHRoaXMudmFsdWU7XG4gICAgdGhpcy5vbklucHV0Q2hhbmdlKCk7XG4gIH1cblxuICB1cGRhdGVWYWx1ZSgpIHtcbiAgICB0aGlzLnZhbHVlID0gdGhpcy5maWVsZC5fZmllbGRWYWx1ZTtcbiAgfVxuXG4gIG9uSW5wdXRDaGFuZ2UoKSB7XG4gICAgc2V0VGltZW91dCgoKSA9PiB0aGlzLmZpZWxkLm5vdGlmeUVkaXRpb25QYXJ0aWFsKCksIDUwKTtcbiAgfVxuXG4gIG9uQ2hhbmdlQ29udGVudCgpIHtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHRoaXMuZmllbGQubm90aWZ5RWRpdGlvbkZpbmlzaCgpLCA1MCk7XG4gIH1cblxuICBvblNob3dJbmZvKCkge1xuICAgIHNldFRpbWVvdXQoKCkgPT4gdGhpcy5maWVsZC5ub3RpZnlFZGl0aW9uRGV0YWlsUmVxdWVzdCgpLCA1MCk7XG4gIH1cblxuICBudW1iZXJJbnB1dFZhbGlkYXRpb24oZXZlbnQpIHtcbiAgICBjb25zdCBrID0gZXZlbnQuY2hhckNvZGU7XG4gICAgcmV0dXJuIChrID4gNDcgJiYgayA8IDU4KTtcbiAgfVxuXG4gIGdldCB2aXNpYmxlKCkge1xuICAgIHJldHVybiB0aGlzLmZpZWxkPy52aXNpYmxlT24odGhpcy5jdXJyZW50U3RhdGUpO1xuICB9XG5cbiAgZ2V0IGRpc2FibGVkKCkge1xuICAgIHJldHVybiAhdGhpcy5maWVsZD8uZW5hYmxlZE9uKHRoaXMuY3VycmVudFN0YXRlKTtcbiAgfVxufVxuIl19
|
|
@@ -2,17 +2,17 @@ import { Component, Input } from '@angular/core';
|
|
|
2
2
|
export class ElementComponent {
|
|
3
3
|
ngOnInit() {
|
|
4
4
|
var _a;
|
|
5
|
-
this.formConfig = (_a = this.
|
|
5
|
+
this.formConfig = (_a = this.element) === null || _a === void 0 ? void 0 : _a._formConfig;
|
|
6
6
|
this.start();
|
|
7
7
|
}
|
|
8
8
|
start() { }
|
|
9
9
|
get visible() {
|
|
10
|
-
var _a
|
|
11
|
-
return (_a = this.
|
|
10
|
+
var _a;
|
|
11
|
+
return (_a = this.element) === null || _a === void 0 ? void 0 : _a.visibleOn(this.currentState);
|
|
12
12
|
}
|
|
13
13
|
get disabled() {
|
|
14
|
-
var _a
|
|
15
|
-
return !((_a = this.
|
|
14
|
+
var _a;
|
|
15
|
+
return !((_a = this.element) === null || _a === void 0 ? void 0 : _a.enabledOn(this.currentState));
|
|
16
16
|
}
|
|
17
17
|
}
|
|
18
18
|
ElementComponent.decorators = [
|
|
@@ -22,7 +22,8 @@ ElementComponent.decorators = [
|
|
|
22
22
|
},] }
|
|
23
23
|
];
|
|
24
24
|
ElementComponent.propDecorators = {
|
|
25
|
-
|
|
26
|
-
|
|
25
|
+
element: [{ type: Input }],
|
|
26
|
+
form: [{ type: Input }],
|
|
27
|
+
currentState: [{ type: Input }]
|
|
27
28
|
};
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dWFpbi1uZy1mb3Jtcy1saWIvc3JjL2xpYi9jb21wb25lbnRzL2VsZW1lbnRzL2xheW91dC9lbGVtZW50LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQU16RCxNQUFNLE9BQU8sZ0JBQWdCO0lBTzNCLFFBQVE7O1FBQ04sSUFBSSxDQUFDLFVBQVUsR0FBRyxNQUFBLElBQUksQ0FBQyxPQUFPLDBDQUFFLFdBQVcsQ0FBQztRQUM1QyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDZixDQUFDO0lBRUQsS0FBSyxLQUFLLENBQUM7SUFFWCxJQUFJLE9BQU87O1FBQ1QsT0FBTyxNQUFBLElBQUksQ0FBQyxPQUFPLDBDQUFFLFNBQVMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVELElBQUksUUFBUTs7UUFDVixPQUFPLENBQUMsQ0FBQSxNQUFBLElBQUksQ0FBQyxPQUFPLDBDQUFFLFNBQVMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUEsQ0FBQztJQUNyRCxDQUFDOzs7WUF4QkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxhQUFhO2dCQUN2QixRQUFRLEVBQUUsMkJBQTJCO2FBQ3RDOzs7c0JBSUUsS0FBSzttQkFDTCxLQUFLOzJCQUNMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLWVsZW1lbnQnLFxuICB0ZW1wbGF0ZTogYDxuZy1jb250ZW50PjwvbmctY29udGVudD5gXG59KVxuZXhwb3J0IGNsYXNzIEVsZW1lbnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBmb3JtQ29uZmlnOiBhbnk7XG5cbiAgQElucHV0KCkgZWxlbWVudDogYW55O1xuICBASW5wdXQoKSBmb3JtOiBhbnk7XG4gIEBJbnB1dCgpIGN1cnJlbnRTdGF0ZTogYW55O1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuZm9ybUNvbmZpZyA9IHRoaXMuZWxlbWVudD8uX2Zvcm1Db25maWc7XG4gICAgdGhpcy5zdGFydCgpO1xuICB9XG5cbiAgc3RhcnQoKSB7IH1cblxuICBnZXQgdmlzaWJsZSgpIHtcbiAgICByZXR1cm4gdGhpcy5lbGVtZW50Py52aXNpYmxlT24odGhpcy5jdXJyZW50U3RhdGUpO1xuICB9XG5cbiAgZ2V0IGRpc2FibGVkKCkge1xuICAgIHJldHVybiAhdGhpcy5lbGVtZW50Py5lbmFibGVkT24odGhpcy5jdXJyZW50U3RhdGUpO1xuICB9XG59XG4iXX0=
|
|
@@ -8,23 +8,23 @@ export class LibTableComponent {
|
|
|
8
8
|
}
|
|
9
9
|
ngOnInit() {
|
|
10
10
|
var _a, _b;
|
|
11
|
-
if (this.
|
|
12
|
-
this.formConfig = (_a = this.
|
|
11
|
+
if (this.table) {
|
|
12
|
+
this.formConfig = (_a = this.table) === null || _a === void 0 ? void 0 : _a._formConfig;
|
|
13
13
|
this.tableFieldStyles = this.formConfig.tableFieldStyles;
|
|
14
|
-
this.selectable = this.
|
|
15
|
-
this.hasActions = this.
|
|
16
|
-
this.
|
|
17
|
-
this.inlineActions = this.
|
|
18
|
-
this.globalActions = this.
|
|
19
|
-
this.selectionActions = this.
|
|
14
|
+
this.selectable = this.table.selectable;
|
|
15
|
+
this.hasActions = this.table.hasActions;
|
|
16
|
+
this.table.widget = this;
|
|
17
|
+
this.inlineActions = this.table.getActions(this.formConfig.tableActions.inline);
|
|
18
|
+
this.globalActions = this.table.getActions(this.formConfig.tableActions.global);
|
|
19
|
+
this.selectionActions = this.table.getActions(this.formConfig.tableActions.selection);
|
|
20
20
|
// Inicialización de campos mapeados del objeto
|
|
21
21
|
const mapping = Object.entries(this.formConfig.componentTableAttrMap);
|
|
22
22
|
for (let index = 0; index < mapping.length; index++) {
|
|
23
23
|
const [tableAttr, compAttr] = mapping[index];
|
|
24
|
-
this[compAttr.toString()] = (_b = this.
|
|
24
|
+
this[compAttr.toString()] = (_b = this.table) === null || _b === void 0 ? void 0 : _b[tableAttr.toString()];
|
|
25
25
|
}
|
|
26
26
|
// Subscripción a cambios en atributos
|
|
27
|
-
this.
|
|
27
|
+
this.table.attributeChange.subscribe(event => {
|
|
28
28
|
const { name: tableAttr, value } = event;
|
|
29
29
|
const compAttr = this.formConfig.componentTableAttrMap[tableAttr];
|
|
30
30
|
this.hasOwnProperty(compAttr) && (this[compAttr] = value);
|
|
@@ -34,24 +34,24 @@ export class LibTableComponent {
|
|
|
34
34
|
}
|
|
35
35
|
start() { }
|
|
36
36
|
tableGlobalAction(actionCode) {
|
|
37
|
-
this.
|
|
37
|
+
this.table.notifyGlobalAction(actionCode);
|
|
38
38
|
}
|
|
39
39
|
tableSelectionAction(actionCode) {
|
|
40
|
-
this.
|
|
40
|
+
this.table.notifySelectionAction(actionCode);
|
|
41
41
|
}
|
|
42
42
|
tableActionSelected(actionEvent) {
|
|
43
|
-
this.
|
|
43
|
+
this.table.notifyInlineAction(actionEvent);
|
|
44
44
|
}
|
|
45
45
|
tableColumnSort(columnFieldCode) {
|
|
46
|
-
this.
|
|
46
|
+
this.table.setRequiredOrder(columnFieldCode);
|
|
47
47
|
if (this.clientPaging) {
|
|
48
|
-
return this.
|
|
48
|
+
return this.table.localSortData();
|
|
49
49
|
}
|
|
50
|
-
this.
|
|
50
|
+
this.table.notifyGetDataAction();
|
|
51
51
|
}
|
|
52
52
|
changePage(requestedPage) {
|
|
53
53
|
if (!this.clientPaging) {
|
|
54
|
-
this.
|
|
54
|
+
this.table.notifyGetDataAction(requestedPage);
|
|
55
55
|
}
|
|
56
56
|
}
|
|
57
57
|
get records() {
|
|
@@ -67,45 +67,45 @@ export class LibTableComponent {
|
|
|
67
67
|
const { eventType } = tableFilterEvent;
|
|
68
68
|
let triggerDataUpdate = false;
|
|
69
69
|
if (eventType === TABLE_FILTER_TYPES.simpleFilterChange || eventType === TABLE_FILTER_TYPES.simpleFilterFinish) {
|
|
70
|
-
this.
|
|
70
|
+
this.table.simpleFilterText = tableFilterEvent.simpleFilterString.trim();
|
|
71
71
|
if (this.clientPaging) {
|
|
72
|
-
this.
|
|
73
|
-
this.
|
|
72
|
+
this.table.setAttr('currentPage', 1);
|
|
73
|
+
this.table.updateVisibleRecords();
|
|
74
74
|
}
|
|
75
75
|
else if (eventType === TABLE_FILTER_TYPES.simpleFilterFinish) {
|
|
76
76
|
triggerDataUpdate = true;
|
|
77
77
|
}
|
|
78
78
|
}
|
|
79
79
|
if (eventType === TABLE_FILTER_TYPES.complexFilterAdd) {
|
|
80
|
-
this.
|
|
80
|
+
this.table.addFilterRestriction(tableFilterEvent.complexFilterItem);
|
|
81
81
|
}
|
|
82
82
|
if (eventType === TABLE_FILTER_TYPES.complexFilterRemove) {
|
|
83
|
-
this.
|
|
83
|
+
this.table.removeFilterRestriction(tableFilterEvent.itemName);
|
|
84
84
|
}
|
|
85
85
|
if (triggerDataUpdate) {
|
|
86
86
|
const tableGetDataEvent = {
|
|
87
|
-
tableCode: this.
|
|
87
|
+
tableCode: this.table.tableCode,
|
|
88
88
|
requestedPage: 1,
|
|
89
89
|
};
|
|
90
|
-
this.
|
|
90
|
+
this.table.notifyGetDataAction(tableGetDataEvent);
|
|
91
91
|
}
|
|
92
92
|
}
|
|
93
93
|
tableSelectionToggle(recordId) {
|
|
94
|
-
this.
|
|
94
|
+
this.table.notifyRecordSelection(recordId);
|
|
95
95
|
}
|
|
96
96
|
toggleSelectAll() {
|
|
97
97
|
if (this.allSelected) {
|
|
98
|
-
this.
|
|
98
|
+
this.table.unSelectAll();
|
|
99
99
|
}
|
|
100
100
|
else {
|
|
101
|
-
this.
|
|
101
|
+
this.table.selectAll();
|
|
102
102
|
}
|
|
103
103
|
}
|
|
104
104
|
get availableFilters() {
|
|
105
|
-
return this.
|
|
105
|
+
return this.table.availableFilters;
|
|
106
106
|
}
|
|
107
107
|
get selectedRecords() {
|
|
108
|
-
return this.
|
|
108
|
+
return this.table.selectedRecords;
|
|
109
109
|
}
|
|
110
110
|
}
|
|
111
111
|
LibTableComponent.decorators = [
|
|
@@ -116,10 +116,10 @@ LibTableComponent.decorators = [
|
|
|
116
116
|
},] }
|
|
117
117
|
];
|
|
118
118
|
LibTableComponent.propDecorators = {
|
|
119
|
-
|
|
119
|
+
table: [{ type: Input }],
|
|
120
120
|
tableRecords: [{ type: Input }],
|
|
121
121
|
disabled: [{ type: Input }],
|
|
122
122
|
currentState: [{ type: Input }],
|
|
123
123
|
waiting: [{ type: Input }]
|
|
124
124
|
};
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/tuain-ng-forms-lib/src/lib/components/elements/tables/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, ChangeDetectionStrategy } from '@angular/core';\nimport { TableRecordData } from '../../../classes/forms/table/row-data';\nimport { TableActionEvent } from '../../../classes/forms/table/table';\n\nimport { RecordTable, TableEvent, TableFilterEvent, TABLE_FILTER_TYPES } from '../../../classes/forms/table/table';\n\n@Component({\n  selector: 'lib-table',\n  template: `<ng-content></ng-content>`,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\n\nexport class LibTableComponent implements OnInit {\n  formConfig: any;\n\n  // Atributos sincronizados del objeto\n  code: any;\n  selectionBackend: any;\n  simpleFilter: any;\n  complexFilter: any;\n  allSelected: any;\n  currentPage: any;\n  visibleRecords: any;\n  recordsPerPage: any;\n  clientPaging: any;\n  columns: any;\n  sortable: any;\n  sorting: any;\n  totalRecordsNumber: any;\n  filterConfig: any;\n  filterObject: any;\n\n  tableFieldStyles: any;\n  loaded = false;\n  selectable = false;\n  hasActions = false;\n  inlineActions: any;\n  globalActions: any;\n  selectionActions: any;\n\n  @Input() tableObject: RecordTable;\n  @Input() tableRecords: TableRecordData[];\n  @Input() disabled: boolean;\n  @Input() currentState: string;\n  @Input() waiting: boolean;\n\n  ngOnInit() {\n    if (this.tableObject) {\n      this.formConfig = this.tableObject?._formConfig;\n      this.tableFieldStyles = this.formConfig.tableFieldStyles;\n      this.selectable = this.tableObject.selectable;\n      this.hasActions = this.tableObject.hasActions;\n      this.tableObject.widget = this;\n      this.inlineActions = this.tableObject.getActions(this.formConfig.tableActions.inline);\n      this.globalActions = this.tableObject.getActions(this.formConfig.tableActions.global);\n      this.selectionActions = this.tableObject.getActions(this.formConfig.tableActions.selection);\n      // Inicialización de campos mapeados del objeto\n      const mapping = Object.entries(this.formConfig.componentTableAttrMap);\n      for (let index = 0; index < mapping.length; index++) {\n        const [tableAttr, compAttr] = mapping[index];\n        this[compAttr.toString()] = this.tableObject?.[tableAttr.toString()];\n      }\n      // Subscripción a cambios en atributos\n      this.tableObject.attributeChange.subscribe(event => {\n        const { name: tableAttr, value } = event;\n        const compAttr = this.formConfig.componentTableAttrMap[tableAttr];\n        this.hasOwnProperty(compAttr) && (this[compAttr] = value);\n      });\n    }\n    this.start();\n  }\n\n  start() { }\n\n  tableGlobalAction(actionCode: string) {\n    this.tableObject.notifyGlobalAction(actionCode);\n  }\n\n  tableSelectionAction(actionCode: string) {\n    this.tableObject.notifySelectionAction(actionCode);\n  }\n\n  tableActionSelected(actionEvent: TableActionEvent) {\n    this.tableObject.notifyInlineAction(actionEvent);\n  }\n\n  tableColumnSort(columnFieldCode) {\n    this.tableObject.setRequiredOrder(columnFieldCode);\n    if (this.clientPaging) {\n      return this.tableObject.localSortData();\n    }\n    this.tableObject.notifyGetDataAction();\n  }\n\n  changePage(requestedPage) {\n    if (!this.clientPaging) {\n      this.tableObject.notifyGetDataAction(requestedPage);\n    }\n  }\n\n  get records() {\n    const currentPageRecords = this.visibleRecords;\n    if (this.clientPaging && currentPageRecords && currentPageRecords.length > 0) {\n      this.totalRecordsNumber = currentPageRecords.length;\n      return currentPageRecords.map((record, i) => ({ id: i + 1, ...record }))\n        .slice((this.currentPage - 1) * this.recordsPerPage,\n          (this.currentPage - 1) * this.recordsPerPage + this.recordsPerPage);\n    }\n    return currentPageRecords;\n  }\n\n  applyCurrentFilter(tableFilterEvent: TableFilterEvent) {\n    const { eventType } = tableFilterEvent;\n    let triggerDataUpdate = false;\n    if (eventType === TABLE_FILTER_TYPES.simpleFilterChange || eventType === TABLE_FILTER_TYPES.simpleFilterFinish) {\n      this.tableObject.simpleFilterText = tableFilterEvent.simpleFilterString.trim();\n      if (this.clientPaging) {\n        this.tableObject.setAttr('currentPage', 1);\n        this.tableObject.updateVisibleRecords();\n      } else if (eventType === TABLE_FILTER_TYPES.simpleFilterFinish) {\n        triggerDataUpdate = true;\n      }\n    }\n    if (eventType === TABLE_FILTER_TYPES.complexFilterAdd) {\n      this.tableObject.addFilterRestriction(tableFilterEvent.complexFilterItem);\n    }\n    if (eventType === TABLE_FILTER_TYPES.complexFilterRemove) {\n      this.tableObject.removeFilterRestriction(tableFilterEvent.itemName);\n    }\n    if (triggerDataUpdate) {\n      const tableGetDataEvent = {\n        tableCode: this.tableObject.tableCode,\n        requestedPage: 1,\n      };\n      this.tableObject.notifyGetDataAction(tableGetDataEvent);\n    }\n  }\n\n  tableSelectionToggle(recordId) {\n    this.tableObject.notifyRecordSelection(recordId);\n  }\n\n  toggleSelectAll() {\n    if (this.allSelected) {\n      this.tableObject.unSelectAll();\n    } else {\n      this.tableObject.selectAll();\n    }\n  }\n\n  get availableFilters() {\n    return this.tableObject.availableFilters;\n  }\n\n  get selectedRecords() {\n    return this.tableObject.selectedRecords;\n  }\n}\n"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/tuain-ng-forms-lib/src/lib/components/elements/tables/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, ChangeDetectionStrategy } from '@angular/core';\nimport { TableRecordData } from '../../../classes/forms/table/row-data';\nimport { TableActionEvent } from '../../../classes/forms/table/table';\n\nimport { RecordTable, TableEvent, TableFilterEvent, TABLE_FILTER_TYPES } from '../../../classes/forms/table/table';\n\n@Component({\n  selector: 'lib-table',\n  template: `<ng-content></ng-content>`,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\n\nexport class LibTableComponent implements OnInit {\n  formConfig: any;\n\n  // Atributos sincronizados del objeto\n  code: any;\n  selectionBackend: any;\n  simpleFilter: any;\n  complexFilter: any;\n  allSelected: any;\n  currentPage: any;\n  visibleRecords: any;\n  recordsPerPage: any;\n  clientPaging: any;\n  columns: any;\n  sortable: any;\n  sorting: any;\n  totalRecordsNumber: any;\n  filterConfig: any;\n  filterObject: any;\n\n  tableFieldStyles: any;\n  loaded = false;\n  selectable = false;\n  hasActions = false;\n  inlineActions: any;\n  globalActions: any;\n  selectionActions: any;\n\n  @Input() table: RecordTable;\n  @Input() tableRecords: TableRecordData[];\n  @Input() disabled: boolean;\n  @Input() currentState: string;\n  @Input() waiting: boolean;\n\n  ngOnInit() {\n    if (this.table) {\n      this.formConfig = this.table?._formConfig;\n      this.tableFieldStyles = this.formConfig.tableFieldStyles;\n      this.selectable = this.table.selectable;\n      this.hasActions = this.table.hasActions;\n      this.table.widget = this;\n      this.inlineActions = this.table.getActions(this.formConfig.tableActions.inline);\n      this.globalActions = this.table.getActions(this.formConfig.tableActions.global);\n      this.selectionActions = this.table.getActions(this.formConfig.tableActions.selection);\n      // Inicialización de campos mapeados del objeto\n      const mapping = Object.entries(this.formConfig.componentTableAttrMap);\n      for (let index = 0; index < mapping.length; index++) {\n        const [tableAttr, compAttr] = mapping[index];\n        this[compAttr.toString()] = this.table?.[tableAttr.toString()];\n      }\n      // Subscripción a cambios en atributos\n      this.table.attributeChange.subscribe(event => {\n        const { name: tableAttr, value } = event;\n        const compAttr = this.formConfig.componentTableAttrMap[tableAttr];\n        this.hasOwnProperty(compAttr) && (this[compAttr] = value);\n      });\n    }\n    this.start();\n  }\n\n  start() { }\n\n  tableGlobalAction(actionCode: string) {\n    this.table.notifyGlobalAction(actionCode);\n  }\n\n  tableSelectionAction(actionCode: string) {\n    this.table.notifySelectionAction(actionCode);\n  }\n\n  tableActionSelected(actionEvent: TableActionEvent) {\n    this.table.notifyInlineAction(actionEvent);\n  }\n\n  tableColumnSort(columnFieldCode) {\n    this.table.setRequiredOrder(columnFieldCode);\n    if (this.clientPaging) {\n      return this.table.localSortData();\n    }\n    this.table.notifyGetDataAction();\n  }\n\n  changePage(requestedPage) {\n    if (!this.clientPaging) {\n      this.table.notifyGetDataAction(requestedPage);\n    }\n  }\n\n  get records() {\n    const currentPageRecords = this.visibleRecords;\n    if (this.clientPaging && currentPageRecords && currentPageRecords.length > 0) {\n      this.totalRecordsNumber = currentPageRecords.length;\n      return currentPageRecords.map((record, i) => ({ id: i + 1, ...record }))\n        .slice((this.currentPage - 1) * this.recordsPerPage,\n          (this.currentPage - 1) * this.recordsPerPage + this.recordsPerPage);\n    }\n    return currentPageRecords;\n  }\n\n  applyCurrentFilter(tableFilterEvent: TableFilterEvent) {\n    const { eventType } = tableFilterEvent;\n    let triggerDataUpdate = false;\n    if (eventType === TABLE_FILTER_TYPES.simpleFilterChange || eventType === TABLE_FILTER_TYPES.simpleFilterFinish) {\n      this.table.simpleFilterText = tableFilterEvent.simpleFilterString.trim();\n      if (this.clientPaging) {\n        this.table.setAttr('currentPage', 1);\n        this.table.updateVisibleRecords();\n      } else if (eventType === TABLE_FILTER_TYPES.simpleFilterFinish) {\n        triggerDataUpdate = true;\n      }\n    }\n    if (eventType === TABLE_FILTER_TYPES.complexFilterAdd) {\n      this.table.addFilterRestriction(tableFilterEvent.complexFilterItem);\n    }\n    if (eventType === TABLE_FILTER_TYPES.complexFilterRemove) {\n      this.table.removeFilterRestriction(tableFilterEvent.itemName);\n    }\n    if (triggerDataUpdate) {\n      const tableGetDataEvent = {\n        tableCode: this.table.tableCode,\n        requestedPage: 1,\n      };\n      this.table.notifyGetDataAction(tableGetDataEvent);\n    }\n  }\n\n  tableSelectionToggle(recordId) {\n    this.table.notifyRecordSelection(recordId);\n  }\n\n  toggleSelectAll() {\n    if (this.allSelected) {\n      this.table.unSelectAll();\n    } else {\n      this.table.selectAll();\n    }\n  }\n\n  get availableFilters() {\n    return this.table.availableFilters;\n  }\n\n  get selectedRecords() {\n    return this.table.selectedRecords;\n  }\n}\n"]}
|
|
@@ -98,7 +98,7 @@ class FieldComponent {
|
|
|
98
98
|
}
|
|
99
99
|
inputChanged() {
|
|
100
100
|
this.field._fieldValue = this.value;
|
|
101
|
-
this.
|
|
101
|
+
this.onChangeContent();
|
|
102
102
|
}
|
|
103
103
|
inputTyped() {
|
|
104
104
|
this.field._fieldValue = this.value;
|
|
@@ -143,17 +143,17 @@ FieldComponent.propDecorators = {
|
|
|
143
143
|
class ElementComponent {
|
|
144
144
|
ngOnInit() {
|
|
145
145
|
var _a;
|
|
146
|
-
this.formConfig = (_a = this.
|
|
146
|
+
this.formConfig = (_a = this.element) === null || _a === void 0 ? void 0 : _a._formConfig;
|
|
147
147
|
this.start();
|
|
148
148
|
}
|
|
149
149
|
start() { }
|
|
150
150
|
get visible() {
|
|
151
|
-
var _a
|
|
152
|
-
return (_a = this.
|
|
151
|
+
var _a;
|
|
152
|
+
return (_a = this.element) === null || _a === void 0 ? void 0 : _a.visibleOn(this.currentState);
|
|
153
153
|
}
|
|
154
154
|
get disabled() {
|
|
155
|
-
var _a
|
|
156
|
-
return !((_a = this.
|
|
155
|
+
var _a;
|
|
156
|
+
return !((_a = this.element) === null || _a === void 0 ? void 0 : _a.enabledOn(this.currentState));
|
|
157
157
|
}
|
|
158
158
|
}
|
|
159
159
|
ElementComponent.decorators = [
|
|
@@ -163,8 +163,9 @@ ElementComponent.decorators = [
|
|
|
163
163
|
},] }
|
|
164
164
|
];
|
|
165
165
|
ElementComponent.propDecorators = {
|
|
166
|
-
|
|
167
|
-
|
|
166
|
+
element: [{ type: Input }],
|
|
167
|
+
form: [{ type: Input }],
|
|
168
|
+
currentState: [{ type: Input }]
|
|
168
169
|
};
|
|
169
170
|
|
|
170
171
|
class FormErrorComponent {
|
|
@@ -1050,23 +1051,23 @@ class LibTableComponent {
|
|
|
1050
1051
|
}
|
|
1051
1052
|
ngOnInit() {
|
|
1052
1053
|
var _a, _b;
|
|
1053
|
-
if (this.
|
|
1054
|
-
this.formConfig = (_a = this.
|
|
1054
|
+
if (this.table) {
|
|
1055
|
+
this.formConfig = (_a = this.table) === null || _a === void 0 ? void 0 : _a._formConfig;
|
|
1055
1056
|
this.tableFieldStyles = this.formConfig.tableFieldStyles;
|
|
1056
|
-
this.selectable = this.
|
|
1057
|
-
this.hasActions = this.
|
|
1058
|
-
this.
|
|
1059
|
-
this.inlineActions = this.
|
|
1060
|
-
this.globalActions = this.
|
|
1061
|
-
this.selectionActions = this.
|
|
1057
|
+
this.selectable = this.table.selectable;
|
|
1058
|
+
this.hasActions = this.table.hasActions;
|
|
1059
|
+
this.table.widget = this;
|
|
1060
|
+
this.inlineActions = this.table.getActions(this.formConfig.tableActions.inline);
|
|
1061
|
+
this.globalActions = this.table.getActions(this.formConfig.tableActions.global);
|
|
1062
|
+
this.selectionActions = this.table.getActions(this.formConfig.tableActions.selection);
|
|
1062
1063
|
// Inicialización de campos mapeados del objeto
|
|
1063
1064
|
const mapping = Object.entries(this.formConfig.componentTableAttrMap);
|
|
1064
1065
|
for (let index = 0; index < mapping.length; index++) {
|
|
1065
1066
|
const [tableAttr, compAttr] = mapping[index];
|
|
1066
|
-
this[compAttr.toString()] = (_b = this.
|
|
1067
|
+
this[compAttr.toString()] = (_b = this.table) === null || _b === void 0 ? void 0 : _b[tableAttr.toString()];
|
|
1067
1068
|
}
|
|
1068
1069
|
// Subscripción a cambios en atributos
|
|
1069
|
-
this.
|
|
1070
|
+
this.table.attributeChange.subscribe(event => {
|
|
1070
1071
|
const { name: tableAttr, value } = event;
|
|
1071
1072
|
const compAttr = this.formConfig.componentTableAttrMap[tableAttr];
|
|
1072
1073
|
this.hasOwnProperty(compAttr) && (this[compAttr] = value);
|
|
@@ -1076,24 +1077,24 @@ class LibTableComponent {
|
|
|
1076
1077
|
}
|
|
1077
1078
|
start() { }
|
|
1078
1079
|
tableGlobalAction(actionCode) {
|
|
1079
|
-
this.
|
|
1080
|
+
this.table.notifyGlobalAction(actionCode);
|
|
1080
1081
|
}
|
|
1081
1082
|
tableSelectionAction(actionCode) {
|
|
1082
|
-
this.
|
|
1083
|
+
this.table.notifySelectionAction(actionCode);
|
|
1083
1084
|
}
|
|
1084
1085
|
tableActionSelected(actionEvent) {
|
|
1085
|
-
this.
|
|
1086
|
+
this.table.notifyInlineAction(actionEvent);
|
|
1086
1087
|
}
|
|
1087
1088
|
tableColumnSort(columnFieldCode) {
|
|
1088
|
-
this.
|
|
1089
|
+
this.table.setRequiredOrder(columnFieldCode);
|
|
1089
1090
|
if (this.clientPaging) {
|
|
1090
|
-
return this.
|
|
1091
|
+
return this.table.localSortData();
|
|
1091
1092
|
}
|
|
1092
|
-
this.
|
|
1093
|
+
this.table.notifyGetDataAction();
|
|
1093
1094
|
}
|
|
1094
1095
|
changePage(requestedPage) {
|
|
1095
1096
|
if (!this.clientPaging) {
|
|
1096
|
-
this.
|
|
1097
|
+
this.table.notifyGetDataAction(requestedPage);
|
|
1097
1098
|
}
|
|
1098
1099
|
}
|
|
1099
1100
|
get records() {
|
|
@@ -1109,45 +1110,45 @@ class LibTableComponent {
|
|
|
1109
1110
|
const { eventType } = tableFilterEvent;
|
|
1110
1111
|
let triggerDataUpdate = false;
|
|
1111
1112
|
if (eventType === TABLE_FILTER_TYPES.simpleFilterChange || eventType === TABLE_FILTER_TYPES.simpleFilterFinish) {
|
|
1112
|
-
this.
|
|
1113
|
+
this.table.simpleFilterText = tableFilterEvent.simpleFilterString.trim();
|
|
1113
1114
|
if (this.clientPaging) {
|
|
1114
|
-
this.
|
|
1115
|
-
this.
|
|
1115
|
+
this.table.setAttr('currentPage', 1);
|
|
1116
|
+
this.table.updateVisibleRecords();
|
|
1116
1117
|
}
|
|
1117
1118
|
else if (eventType === TABLE_FILTER_TYPES.simpleFilterFinish) {
|
|
1118
1119
|
triggerDataUpdate = true;
|
|
1119
1120
|
}
|
|
1120
1121
|
}
|
|
1121
1122
|
if (eventType === TABLE_FILTER_TYPES.complexFilterAdd) {
|
|
1122
|
-
this.
|
|
1123
|
+
this.table.addFilterRestriction(tableFilterEvent.complexFilterItem);
|
|
1123
1124
|
}
|
|
1124
1125
|
if (eventType === TABLE_FILTER_TYPES.complexFilterRemove) {
|
|
1125
|
-
this.
|
|
1126
|
+
this.table.removeFilterRestriction(tableFilterEvent.itemName);
|
|
1126
1127
|
}
|
|
1127
1128
|
if (triggerDataUpdate) {
|
|
1128
1129
|
const tableGetDataEvent = {
|
|
1129
|
-
tableCode: this.
|
|
1130
|
+
tableCode: this.table.tableCode,
|
|
1130
1131
|
requestedPage: 1,
|
|
1131
1132
|
};
|
|
1132
|
-
this.
|
|
1133
|
+
this.table.notifyGetDataAction(tableGetDataEvent);
|
|
1133
1134
|
}
|
|
1134
1135
|
}
|
|
1135
1136
|
tableSelectionToggle(recordId) {
|
|
1136
|
-
this.
|
|
1137
|
+
this.table.notifyRecordSelection(recordId);
|
|
1137
1138
|
}
|
|
1138
1139
|
toggleSelectAll() {
|
|
1139
1140
|
if (this.allSelected) {
|
|
1140
|
-
this.
|
|
1141
|
+
this.table.unSelectAll();
|
|
1141
1142
|
}
|
|
1142
1143
|
else {
|
|
1143
|
-
this.
|
|
1144
|
+
this.table.selectAll();
|
|
1144
1145
|
}
|
|
1145
1146
|
}
|
|
1146
1147
|
get availableFilters() {
|
|
1147
|
-
return this.
|
|
1148
|
+
return this.table.availableFilters;
|
|
1148
1149
|
}
|
|
1149
1150
|
get selectedRecords() {
|
|
1150
|
-
return this.
|
|
1151
|
+
return this.table.selectedRecords;
|
|
1151
1152
|
}
|
|
1152
1153
|
}
|
|
1153
1154
|
LibTableComponent.decorators = [
|
|
@@ -1158,7 +1159,7 @@ LibTableComponent.decorators = [
|
|
|
1158
1159
|
},] }
|
|
1159
1160
|
];
|
|
1160
1161
|
LibTableComponent.propDecorators = {
|
|
1161
|
-
|
|
1162
|
+
table: [{ type: Input }],
|
|
1162
1163
|
tableRecords: [{ type: Input }],
|
|
1163
1164
|
disabled: [{ type: Input }],
|
|
1164
1165
|
currentState: [{ type: Input }],
|