tuain-ng-forms-lib 15.1.7 → 15.1.9
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/esm2020/lib/classes/forms/element.mjs +3 -1
- package/esm2020/lib/classes/forms/piece-propagate.mjs +7 -1
- package/esm2020/lib/components/elements/field.component.mjs +7 -5
- package/esm2020/lib/components/elements/layout/section.component.mjs +7 -5
- package/esm2020/lib/components/elements/layout/sub-section.component.mjs +7 -5
- package/esm2020/lib/components/elements/tables/table.component.mjs +7 -5
- package/fesm2015/tuain-ng-forms-lib.mjs +32 -16
- package/fesm2015/tuain-ng-forms-lib.mjs.map +1 -1
- package/fesm2020/tuain-ng-forms-lib.mjs +32 -16
- package/fesm2020/tuain-ng-forms-lib.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -9,10 +9,12 @@ export class FormElement extends FormPiecePropagate {
|
|
|
9
9
|
setAttr(attr, value) {
|
|
10
10
|
const { name: attrName, propagate: name } = attr;
|
|
11
11
|
this[attrName] = value;
|
|
12
|
+
console.log(`Element setAttr name: ${name}`);
|
|
13
|
+
console.log(value);
|
|
12
14
|
name && this.propagateAttribute(name, value);
|
|
13
15
|
}
|
|
14
16
|
isField() { return this.elementType === elementTypes.field; }
|
|
15
17
|
isAction() { return this.elementType === elementTypes.action; }
|
|
16
18
|
isTable() { return this.elementType === elementTypes.table; }
|
|
17
19
|
}
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R1YWluLW5nLWZvcm1zLWxpYi9zcmMvbGliL2NsYXNzZXMvZm9ybXMvZWxlbWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDaEQsTUFBTSxPQUFPLFdBQVksU0FBUSxrQkFBa0I7SUFHakQsWUFBWSxpQkFBc0IsRUFBRSxVQUFlO1FBQ2pELEtBQUssQ0FBQyxpQkFBaUIsRUFBRSxVQUFVLENBQUMsQ0FBQztRQUh2QyxnQkFBVyxHQUFrQixJQUFJLENBQUM7SUFJbEMsQ0FBQztJQUppQyxDQUFDO0lBTW5DLE9BQU8sQ0FBQyxJQUFTLEVBQUUsS0FBVTtRQUMzQixNQUFNLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLEdBQUcsSUFBSSxDQUFDO1FBQ2pELElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxLQUFLLENBQUM7UUFDdkIsT0FBTyxDQUFDLEdBQUcsQ0FBQyx5QkFBeUIsSUFBSSxFQUFFLENBQUMsQ0FBQTtRQUM1QyxPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFBO1FBQ2xCLElBQUksSUFBSSxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFRCxPQUFPLEtBQWMsT0FBTyxJQUFJLENBQUMsV0FBVyxLQUFLLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ3RFLFFBQVEsS0FBYyxPQUFPLElBQUksQ0FBQyxXQUFXLEtBQUssWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7SUFDeEUsT0FBTyxLQUFjLE9BQU8sSUFBSSxDQUFDLFdBQVcsS0FBSyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztDQUN2RSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZvcm1QaWVjZVByb3BhZ2F0ZSB9IGZyb20gJy4vcGllY2UtcHJvcGFnYXRlJztcbmltcG9ydCB7IGVsZW1lbnRUeXBlcyB9IGZyb20gJy4vZm9ybS5jb25zdGFudHMnO1xuZXhwb3J0IGNsYXNzIEZvcm1FbGVtZW50IGV4dGVuZHMgRm9ybVBpZWNlUHJvcGFnYXRlIHtcbiAgZWxlbWVudFR5cGU6IHN0cmluZyB8IG51bGwgPSBudWxsOztcblxuICBjb25zdHJ1Y3RvcihlbGVtZW50RGVmaW5pdGlvbjogYW55LCBmb3JtQ29uZmlnOiBhbnkpIHtcbiAgICBzdXBlcihlbGVtZW50RGVmaW5pdGlvbiwgZm9ybUNvbmZpZyk7XG4gIH1cblxuICBzZXRBdHRyKGF0dHI6IGFueSwgdmFsdWU6IGFueSkge1xuICAgIGNvbnN0IHsgbmFtZTogYXR0ck5hbWUsIHByb3BhZ2F0ZTogbmFtZSB9ID0gYXR0cjtcbiAgICB0aGlzW2F0dHJOYW1lXSA9IHZhbHVlO1xuICAgIGNvbnNvbGUubG9nKGBFbGVtZW50IHNldEF0dHIgbmFtZTogJHtuYW1lfWApXG4gICAgY29uc29sZS5sb2codmFsdWUpXG4gICAgbmFtZSAmJiB0aGlzLnByb3BhZ2F0ZUF0dHJpYnV0ZShuYW1lLCB2YWx1ZSk7XG4gIH1cblxuICBpc0ZpZWxkKCk6IGJvb2xlYW4geyByZXR1cm4gdGhpcy5lbGVtZW50VHlwZSA9PT0gZWxlbWVudFR5cGVzLmZpZWxkOyB9XG4gIGlzQWN0aW9uKCk6IGJvb2xlYW4geyByZXR1cm4gdGhpcy5lbGVtZW50VHlwZSA9PT0gZWxlbWVudFR5cGVzLmFjdGlvbjsgfVxuICBpc1RhYmxlKCk6IGJvb2xlYW4geyByZXR1cm4gdGhpcy5lbGVtZW50VHlwZSA9PT0gZWxlbWVudFR5cGVzLnRhYmxlOyB9XG59XG4iXX0=
|
|
@@ -10,29 +10,35 @@ export class FormPiecePropagate extends FormPiece {
|
|
|
10
10
|
}
|
|
11
11
|
get attributeChange() { return this._attributeChange; }
|
|
12
12
|
propagateAttribute(name, value) {
|
|
13
|
+
console.log(`Propagación ${name} : ${JSON.stringify(value)}`);
|
|
13
14
|
this._attributeChange?.next({ name, value });
|
|
14
15
|
}
|
|
15
16
|
setCustomAttribute(name, value) {
|
|
16
17
|
super.setCustomAttribute(name, value);
|
|
17
18
|
if (this.propagationCustomAttributes?.includes(name)) {
|
|
18
19
|
const fullName = `customAttributes.${name}`;
|
|
20
|
+
console.log('piece setCustomAttribute');
|
|
19
21
|
this.propagateAttribute(fullName, value);
|
|
20
22
|
}
|
|
21
23
|
}
|
|
22
24
|
setVisibility(visible, forced = null) {
|
|
23
25
|
super.setVisibility(visible, forced);
|
|
26
|
+
console.log('piece setVisibility');
|
|
24
27
|
this.propagateAttribute(VISIBLE, this._visible);
|
|
25
28
|
}
|
|
26
29
|
set enabled(enabled) {
|
|
27
30
|
super.enabled = enabled;
|
|
31
|
+
console.log('piece enabled');
|
|
28
32
|
this.propagateAttribute(DISABLED, this._disabled);
|
|
29
33
|
}
|
|
30
34
|
formStateChange(state) {
|
|
31
35
|
super.formStateChange(state);
|
|
32
36
|
if (state) {
|
|
37
|
+
console.log('piece 1 formStateChange');
|
|
33
38
|
this.propagateAttribute(VISIBLE, this._visible);
|
|
39
|
+
console.log('piece 2 formStateChange');
|
|
34
40
|
this.propagateAttribute(DISABLED, this._disabled);
|
|
35
41
|
}
|
|
36
42
|
}
|
|
37
43
|
}
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGllY2UtcHJvcGFnYXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHVhaW4tbmctZm9ybXMtbGliL3NyYy9saWIvY2xhc3Nlcy9mb3Jtcy9waWVjZS1wcm9wYWdhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN2QyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBRXBDLE1BQU0sT0FBTyxHQUFHLFNBQVMsQ0FBQztBQUMxQixNQUFNLFFBQVEsR0FBRyxVQUFVLENBQUM7QUFFNUIsTUFBTSxPQUFPLGtCQUFtQixTQUFRLFNBQVM7SUFJL0MsWUFBWSxlQUFvQixFQUFFLFVBQWU7UUFDL0MsS0FBSyxDQUFDLGVBQWUsRUFBRSxVQUFVLENBQUMsQ0FBQztRQUozQixnQ0FBMkIsR0FBYSxFQUFFLENBQUM7UUFLbkQsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksZUFBZSxDQUFNLElBQUksQ0FBQyxDQUFDO0lBQ3pELENBQUM7SUFFRCxJQUFJLGVBQWUsS0FBSyxPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUM7SUFFdkQsa0JBQWtCLENBQUMsSUFBSSxFQUFFLEtBQUs7UUFDNUIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFlLElBQUksTUFBTSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUM5RCxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVRLGtCQUFrQixDQUFDLElBQVksRUFBRSxLQUFVO1FBQ2xELEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDdEMsSUFBSSxJQUFJLENBQUMsMkJBQTJCLEVBQUUsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ3BELE1BQU0sUUFBUSxHQUFHLG9CQUFvQixJQUFJLEVBQUUsQ0FBQztZQUM1QyxPQUFPLENBQUMsR0FBRyxDQUFDLDBCQUEwQixDQUFDLENBQUE7WUFDdkMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsQ0FBQztTQUMxQztJQUNILENBQUM7SUFFUSxhQUFhLENBQUMsT0FBZ0IsRUFBRSxTQUF5QixJQUFJO1FBQ3BFLEtBQUssQ0FBQyxhQUFhLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3JDLE9BQU8sQ0FBQyxHQUFHLENBQUMscUJBQXFCLENBQUMsQ0FBQTtRQUNsQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQsSUFBYSxPQUFPLENBQUMsT0FBTztRQUMxQixLQUFLLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN4QixPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxDQUFBO1FBQzVCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFUSxlQUFlLENBQUMsS0FBSztRQUM1QixLQUFLLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzdCLElBQUksS0FBSyxFQUFFO1lBQ1QsT0FBTyxDQUFDLEdBQUcsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFBO1lBQ3RDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ2hELE9BQU8sQ0FBQyxHQUFHLENBQUMseUJBQXlCLENBQUMsQ0FBQTtZQUN0QyxJQUFJLENBQUMsa0JBQWtCLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztTQUNuRDtJQUNILENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRm9ybVBpZWNlIH0gZnJvbSAnLi9waWVjZSc7XG5cbmNvbnN0IFZJU0lCTEUgPSAndmlzaWJsZSc7XG5jb25zdCBESVNBQkxFRCA9ICdkaXNhYmxlZCc7XG5cbmV4cG9ydCBjbGFzcyBGb3JtUGllY2VQcm9wYWdhdGUgZXh0ZW5kcyBGb3JtUGllY2Uge1xuICBwcm90ZWN0ZWQgcHJvcGFnYXRpb25DdXN0b21BdHRyaWJ1dGVzOiBzdHJpbmdbXSA9IFtdO1xuICBwcm90ZWN0ZWQgX2F0dHJpYnV0ZUNoYW5nZTogQmVoYXZpb3JTdWJqZWN0PGFueT47XG5cbiAgY29uc3RydWN0b3IocGllY2VEZWZpbml0aW9uOiBhbnksIGZvcm1Db25maWc6IGFueSkge1xuICAgIHN1cGVyKHBpZWNlRGVmaW5pdGlvbiwgZm9ybUNvbmZpZyk7XG4gICAgdGhpcy5fYXR0cmlidXRlQ2hhbmdlID0gbmV3IEJlaGF2aW9yU3ViamVjdDxhbnk+KG51bGwpO1xuICB9XG5cbiAgZ2V0IGF0dHJpYnV0ZUNoYW5nZSgpIHsgcmV0dXJuIHRoaXMuX2F0dHJpYnV0ZUNoYW5nZTsgfVxuXG4gIHByb3BhZ2F0ZUF0dHJpYnV0ZShuYW1lLCB2YWx1ZSkge1xuICAgIGNvbnNvbGUubG9nKGBQcm9wYWdhY2nDs24gJHtuYW1lfSA6ICR7SlNPTi5zdHJpbmdpZnkodmFsdWUpfWApO1xuICAgIHRoaXMuX2F0dHJpYnV0ZUNoYW5nZT8ubmV4dCh7IG5hbWUsIHZhbHVlIH0pO1xuICB9XG5cbiAgb3ZlcnJpZGUgc2V0Q3VzdG9tQXR0cmlidXRlKG5hbWU6IHN0cmluZywgdmFsdWU6IGFueSk6IHZvaWQge1xuICAgIHN1cGVyLnNldEN1c3RvbUF0dHJpYnV0ZShuYW1lLCB2YWx1ZSk7XG4gICAgaWYgKHRoaXMucHJvcGFnYXRpb25DdXN0b21BdHRyaWJ1dGVzPy5pbmNsdWRlcyhuYW1lKSkge1xuICAgICAgY29uc3QgZnVsbE5hbWUgPSBgY3VzdG9tQXR0cmlidXRlcy4ke25hbWV9YDtcbiAgICAgIGNvbnNvbGUubG9nKCdwaWVjZSBzZXRDdXN0b21BdHRyaWJ1dGUnKVxuICAgICAgdGhpcy5wcm9wYWdhdGVBdHRyaWJ1dGUoZnVsbE5hbWUsIHZhbHVlKTtcbiAgICB9IFxuICB9XG5cbiAgb3ZlcnJpZGUgc2V0VmlzaWJpbGl0eSh2aXNpYmxlOiBib29sZWFuLCBmb3JjZWQ6IGJvb2xlYW4gfCBudWxsID0gbnVsbCk6IHZvaWQge1xuICAgIHN1cGVyLnNldFZpc2liaWxpdHkodmlzaWJsZSwgZm9yY2VkKTtcbiAgICBjb25zb2xlLmxvZygncGllY2Ugc2V0VmlzaWJpbGl0eScpXG4gICAgdGhpcy5wcm9wYWdhdGVBdHRyaWJ1dGUoVklTSUJMRSwgdGhpcy5fdmlzaWJsZSk7XG4gIH1cblxuICBvdmVycmlkZSBzZXQgZW5hYmxlZChlbmFibGVkKSB7XG4gICAgc3VwZXIuZW5hYmxlZCA9IGVuYWJsZWQ7XG4gICAgY29uc29sZS5sb2coJ3BpZWNlIGVuYWJsZWQnKVxuICAgIHRoaXMucHJvcGFnYXRlQXR0cmlidXRlKERJU0FCTEVELCB0aGlzLl9kaXNhYmxlZCk7XG4gIH1cblxuICBvdmVycmlkZSBmb3JtU3RhdGVDaGFuZ2Uoc3RhdGUpIHtcbiAgICBzdXBlci5mb3JtU3RhdGVDaGFuZ2Uoc3RhdGUpO1xuICAgIGlmIChzdGF0ZSkge1xuICAgICAgY29uc29sZS5sb2coJ3BpZWNlIDEgZm9ybVN0YXRlQ2hhbmdlJylcbiAgICAgIHRoaXMucHJvcGFnYXRlQXR0cmlidXRlKFZJU0lCTEUsIHRoaXMuX3Zpc2libGUpO1xuICAgICAgY29uc29sZS5sb2coJ3BpZWNlIDIgZm9ybVN0YXRlQ2hhbmdlJylcbiAgICAgIHRoaXMucHJvcGFnYXRlQXR0cmlidXRlKERJU0FCTEVELCB0aGlzLl9kaXNhYmxlZCk7XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -43,11 +43,13 @@ export class FieldComponent extends ElementComponent {
|
|
|
43
43
|
}
|
|
44
44
|
// Subscripción a cambios en atributos
|
|
45
45
|
this.field?.attributeChange.subscribe(event => {
|
|
46
|
+
console.log('FieldComponent attributeChange');
|
|
47
|
+
console.log(event);
|
|
46
48
|
const { name: componentAttr, value = null } = event ?? {};
|
|
47
|
-
if (componentAttr) {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
}
|
|
49
|
+
// if (componentAttr) {
|
|
50
|
+
this.defaultProcessAttributeChange(componentAttr, value);
|
|
51
|
+
this.customProcessAttributeChange(componentAttr, value);
|
|
52
|
+
// }
|
|
51
53
|
});
|
|
52
54
|
if (this.field) {
|
|
53
55
|
this.field.widget = this;
|
|
@@ -96,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImpor
|
|
|
96
98
|
}], propDecorators: { field: [{
|
|
97
99
|
type: Input
|
|
98
100
|
}] } });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.component.js","sourceRoot":"","sources":["../../../../../../projects/tuain-ng-forms-lib/src/lib/components/elements/field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\nimport { FieldDescriptor } from '../../classes/forms/field';\nimport { ElementComponent } from './layout/element.component'\n\nconst VALUE = 'value';\nconst FOCUS = 'focus';\n@Component({\n  selector: 'lib-field',\n  template: `<ng-content></ng-content>`\n})\nexport class FieldComponent extends ElementComponent implements OnInit {\n  // Atributos obtenidos estáticamente\n  code: string = '';\n  value: any;\n  info: string = '';\n  alignment: string = '';\n  tooltip: string = '';\n\n  // Atributos actualizados por subscripción\n  minLength: any;\n  maxLength: any;\n  minValue: any;\n  maxValue: any;\n  onValidation: any;\n  captureType: any;\n  title: any;\n  type: any;\n  visibleLabel: any;\n  required: any;\n  options: any;\n\n  errorType: any;\n  errorCode: any;\n  errorMessage: any;\n\n  @Input() field: FieldDescriptor | null = null;\n\n  ngOnInit() {\n    if (!this.field) { return; }\n    this.formConfig = this.field?._formConfig;\n    const mapping = Object.entries(this.formConfig?.fieldPropagateAttributes);\n    const customAttributesMapping = this.formConfig?.propagationCustomAttributes.fields ?? [];\n\n    for (let index = 0; index < mapping.length; index++) {\n      const fieldAttr = mapping[index]?.[0];\n      const componentAttr = mapping[index]?.[1]?.toString() ?? '';\n      if (componentAttr) {\n        const value = this.field?.[fieldAttr];\n        this.defaultProcessAttributeChange(componentAttr, value);\n        this.customProcessAttributeChange(componentAttr, value);\n      }\n    }\n    // Atributos personalizados\n    for (let index = 0; index < customAttributesMapping.length; index++) {\n      const customAttribute = customAttributesMapping[index];\n      if (customAttribute) {\n        const value = this.field?.getCustomAttribute(customAttribute);\n        const fullName = `customAttributes.${customAttribute}`;\n        if (value) {\n          this.defaultProcessAttributeChange(fullName, value);\n          this.customProcessAttributeChange(fullName, value);\n        }\n      }\n    }\n    // Subscripción a cambios en atributos\n    this.field?.attributeChange.subscribe(event => {\n      console.log('FieldComponent attributeChange');\n      console.log(event);\n      const { name: componentAttr, value = null } = event ?? {};\n      // if (componentAttr) {\n        this.defaultProcessAttributeChange(componentAttr, value);\n        this.customProcessAttributeChange(componentAttr, value);\n      // }\n    });\n    if (this.field) {\n      this.field.widget = this;\n    }\n    this.start();\n  }\n\n  override defaultProcessAttributeChange(attribute: string, value?: any): boolean {\n    if (attribute === VALUE) {\n      this.updateValue();\n    } else if (attribute === FOCUS) {\n      this.focus();\n    } else {\n      return super.defaultProcessAttributeChange(attribute, value);\n    }\n    return true;\n  }\n\n  updateValue() { this.value = this.field?.value; }\n  onInputChange() { setTimeout(() => this.field?.notifyEditionPartial(), 50); }\n  onChangeContent() { setTimeout(() => this.field?.notifyEditionFinish(), 50); }\n  onShowInfo(detail = null) { setTimeout(() => this.field?.notifyEditionDetailRequest(detail), 50); }\n\n  focus() { }\n  updateObject(widgetUpdate = true) { this.field?.setValue(this.value, widgetUpdate); }\n\n  inputChanged() {\n    this.field?.setValue(this.value);\n    this.onChangeContent();\n  }\n\n  inputTyped() {\n    this.updateObject(false);\n    this.onInputChange();\n  }\n\n  numberInputValidation(event) {\n    const k = event.charCode;\n    return (k > 47 && k < 58);\n  }\n}\n"]}
|
|
@@ -13,11 +13,13 @@ export class SectionComponent extends PieceComponent {
|
|
|
13
13
|
}
|
|
14
14
|
// Subscripción a cambios en atributos
|
|
15
15
|
this.section?.attributeChange.subscribe(event => {
|
|
16
|
+
console.log('SectionComponent attributeChange');
|
|
17
|
+
console.log(event);
|
|
16
18
|
const { name: attrName, value = null } = event ?? {};
|
|
17
|
-
if (attrName) {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
}
|
|
19
|
+
// if (attrName) {
|
|
20
|
+
this.defaultProcessAttributeChange(attrName, value);
|
|
21
|
+
this.customProcessAttributeChange(attrName, value);
|
|
22
|
+
// }
|
|
21
23
|
});
|
|
22
24
|
this.start();
|
|
23
25
|
}
|
|
@@ -36,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImpor
|
|
|
36
38
|
}], propDecorators: { section: [{
|
|
37
39
|
type: Input
|
|
38
40
|
}] } });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dWFpbi1uZy1mb3Jtcy1saWIvc3JjL2xpYi9jb21wb25lbnRzL2VsZW1lbnRzL2xheW91dC9zZWN0aW9uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBTW5ELE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxjQUFjO0lBR2xELFFBQVE7UUFDTixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxPQUFPLEVBQUUsV0FBVyxDQUFDO1FBQzVDLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxVQUFVLEVBQUUsMEJBQTBCLENBQUM7UUFDNUQsS0FBSyxJQUFJLEtBQUssR0FBRyxDQUFDLEVBQUUsS0FBSyxHQUFHLE9BQU8sQ0FBQyxNQUFNLEVBQUUsS0FBSyxFQUFFLEVBQUU7WUFDbkQsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQzNDLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUNoRCxJQUFJLENBQUMsNkJBQTZCLENBQUMsUUFBUSxFQUFFLGNBQWMsQ0FBQyxDQUFDO1lBQzdELElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxRQUFRLEVBQUUsY0FBYyxDQUFDLENBQUM7U0FDN0Q7UUFDRCxzQ0FBc0M7UUFDdEMsSUFBSSxDQUFDLE9BQU8sRUFBRSxlQUFlLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQzlDLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0NBQWtDLENBQUMsQ0FBQztZQUNoRCxPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ25CLE1BQU0sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLEtBQUssR0FBRyxJQUFJLEVBQUUsR0FBRyxLQUFLLElBQUksRUFBRSxDQUFDO1lBQ3JELGtCQUFrQjtZQUNoQixJQUFJLENBQUMsNkJBQTZCLENBQUMsUUFBUSxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQ3BELElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFDckQsSUFBSTtRQUNOLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ2YsQ0FBQztJQUVELEtBQUs7UUFDSCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDcEMsQ0FBQzs7NkdBM0JVLGdCQUFnQjtpR0FBaEIsZ0JBQWdCLDBHQUZqQiwyQkFBMkI7MkZBRTFCLGdCQUFnQjtrQkFKNUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsYUFBYTtvQkFDdkIsUUFBUSxFQUFFLDJCQUEyQjtpQkFDdEM7OEJBRVUsT0FBTztzQkFBZixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQaWVjZUNvbXBvbmVudCB9IGZyb20gJy4vcGllY2UuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLXNlY3Rpb24nLFxuICB0ZW1wbGF0ZTogYDxuZy1jb250ZW50PjwvbmctY29udGVudD5gXG59KVxuZXhwb3J0IGNsYXNzIFNlY3Rpb25Db21wb25lbnQgZXh0ZW5kcyBQaWVjZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpIHNlY3Rpb246IGFueTtcblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLmZvcm1Db25maWcgPSB0aGlzLnNlY3Rpb24/Ll9mb3JtQ29uZmlnO1xuICAgIGNvbnN0IG1hcHBpbmcgPSB0aGlzLmZvcm1Db25maWc/LnNlY3Rpb25Qcm9wYWdhdGVBdHRyaWJ1dGVzO1xuICAgIGZvciAobGV0IGluZGV4ID0gMDsgaW5kZXggPCBtYXBwaW5nLmxlbmd0aDsgaW5kZXgrKykge1xuICAgICAgY29uc3QgYXR0ck5hbWUgPSBtYXBwaW5nW2luZGV4XS50b1N0cmluZygpO1xuICAgICAgY29uc3QgYXR0cmlidXRlVmFsdWUgPSB0aGlzLnNlY3Rpb24/LlthdHRyTmFtZV07XG4gICAgICB0aGlzLmRlZmF1bHRQcm9jZXNzQXR0cmlidXRlQ2hhbmdlKGF0dHJOYW1lLCBhdHRyaWJ1dGVWYWx1ZSk7XG4gICAgICB0aGlzLmN1c3RvbVByb2Nlc3NBdHRyaWJ1dGVDaGFuZ2UoYXR0ck5hbWUsIGF0dHJpYnV0ZVZhbHVlKTtcbiAgICB9XG4gICAgLy8gU3Vic2NyaXBjacOzbiBhIGNhbWJpb3MgZW4gYXRyaWJ1dG9zXG4gICAgdGhpcy5zZWN0aW9uPy5hdHRyaWJ1dGVDaGFuZ2Uuc3Vic2NyaWJlKGV2ZW50ID0+IHtcbiAgICAgIGNvbnNvbGUubG9nKCdTZWN0aW9uQ29tcG9uZW50IGF0dHJpYnV0ZUNoYW5nZScpO1xuICAgICAgY29uc29sZS5sb2coZXZlbnQpO1xuICAgICAgY29uc3QgeyBuYW1lOiBhdHRyTmFtZSwgdmFsdWUgPSBudWxsIH0gPSBldmVudCA/PyB7fTtcbiAgICAgIC8vIGlmIChhdHRyTmFtZSkge1xuICAgICAgICB0aGlzLmRlZmF1bHRQcm9jZXNzQXR0cmlidXRlQ2hhbmdlKGF0dHJOYW1lLCB2YWx1ZSk7XG4gICAgICAgIHRoaXMuY3VzdG9tUHJvY2Vzc0F0dHJpYnV0ZUNoYW5nZShhdHRyTmFtZSwgdmFsdWUpO1xuICAgICAgLy8gfVxuICAgIH0pO1xuICAgIHRoaXMuc3RhcnQoKTtcbiAgfVxuXG4gIHN0YXJ0KCkge1xuICAgIHRoaXMuc2V0Rm9ybSh0aGlzLnNlY3Rpb24/Ll9mb3JtKTtcbiAgfVxufVxuIl19
|
|
@@ -13,11 +13,13 @@ export class SubSectionComponent extends PieceComponent {
|
|
|
13
13
|
}
|
|
14
14
|
// Subscripción a cambios en atributos
|
|
15
15
|
this.subSection?.attributeChange.subscribe(event => {
|
|
16
|
+
console.log('SubSectionComponent attributeChange');
|
|
17
|
+
console.log(event);
|
|
16
18
|
const { name: attrName, value = null } = event ?? {};
|
|
17
|
-
if (attrName) {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
}
|
|
19
|
+
// if (attrName) {
|
|
20
|
+
this.defaultProcessAttributeChange(attrName, value);
|
|
21
|
+
this.customProcessAttributeChange(attrName, value);
|
|
22
|
+
// }
|
|
21
23
|
});
|
|
22
24
|
this.start();
|
|
23
25
|
}
|
|
@@ -36,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImpor
|
|
|
36
38
|
}], propDecorators: { subSection: [{
|
|
37
39
|
type: Input
|
|
38
40
|
}] } });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ViLXNlY3Rpb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHVhaW4tbmctZm9ybXMtbGliL3NyYy9saWIvY29tcG9uZW50cy9lbGVtZW50cy9sYXlvdXQvc3ViLXNlY3Rpb24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFNbkQsTUFBTSxPQUFPLG1CQUFvQixTQUFRLGNBQWM7SUFHckQsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxXQUFXLENBQUM7UUFDL0MsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSw2QkFBNkIsQ0FBQztRQUMvRCxLQUFLLElBQUksS0FBSyxHQUFHLENBQUMsRUFBRSxLQUFLLEdBQUcsT0FBTyxDQUFDLE1BQU0sRUFBRSxLQUFLLEVBQUUsRUFBRTtZQUNuRCxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDM0MsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ25ELElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxRQUFRLEVBQUUsY0FBYyxDQUFDLENBQUM7WUFDN0QsSUFBSSxDQUFDLDRCQUE0QixDQUFDLFFBQVEsRUFBRSxjQUFjLENBQUMsQ0FBQztTQUM3RDtRQUNELHNDQUFzQztRQUN0QyxJQUFJLENBQUMsVUFBVSxFQUFFLGVBQWUsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDakQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxxQ0FBcUMsQ0FBQyxDQUFDO1lBQ25ELE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDbkIsTUFBTSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsS0FBSyxHQUFHLElBQUksRUFBRSxHQUFHLEtBQUssSUFBSSxFQUFFLENBQUM7WUFDckQsa0JBQWtCO1lBQ2hCLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFDcEQsSUFBSSxDQUFDLDRCQUE0QixDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsQ0FBQztZQUNyRCxJQUFJO1FBQ04sQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDZixDQUFDO0lBRUQsS0FBSztRQUNILElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN2QyxDQUFDOztnSEEzQlUsbUJBQW1CO29HQUFuQixtQkFBbUIsbUhBRnBCLDJCQUEyQjsyRkFFMUIsbUJBQW1CO2tCQUovQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLFFBQVEsRUFBRSwyQkFBMkI7aUJBQ3RDOzhCQUVVLFVBQVU7c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFBpZWNlQ29tcG9uZW50IH0gZnJvbSAnLi9waWVjZS5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdsaWItc3Vic2VjdGlvbicsXG4gIHRlbXBsYXRlOiBgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PmBcbn0pXG5leHBvcnQgY2xhc3MgU3ViU2VjdGlvbkNvbXBvbmVudCBleHRlbmRzIFBpZWNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgc3ViU2VjdGlvbjogYW55O1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuZm9ybUNvbmZpZyA9IHRoaXMuc3ViU2VjdGlvbj8uX2Zvcm1Db25maWc7XG4gICAgY29uc3QgbWFwcGluZyA9IHRoaXMuZm9ybUNvbmZpZz8uc3ViU2VjdGlvblByb3BhZ2F0ZUF0dHJpYnV0ZXM7XG4gICAgZm9yIChsZXQgaW5kZXggPSAwOyBpbmRleCA8IG1hcHBpbmcubGVuZ3RoOyBpbmRleCsrKSB7XG4gICAgICBjb25zdCBhdHRyTmFtZSA9IG1hcHBpbmdbaW5kZXhdLnRvU3RyaW5nKCk7XG4gICAgICBjb25zdCBhdHRyaWJ1dGVWYWx1ZSA9IHRoaXMuc3ViU2VjdGlvbj8uW2F0dHJOYW1lXTtcbiAgICAgIHRoaXMuZGVmYXVsdFByb2Nlc3NBdHRyaWJ1dGVDaGFuZ2UoYXR0ck5hbWUsIGF0dHJpYnV0ZVZhbHVlKTtcbiAgICAgIHRoaXMuY3VzdG9tUHJvY2Vzc0F0dHJpYnV0ZUNoYW5nZShhdHRyTmFtZSwgYXR0cmlidXRlVmFsdWUpO1xuICAgIH1cbiAgICAvLyBTdWJzY3JpcGNpw7NuIGEgY2FtYmlvcyBlbiBhdHJpYnV0b3NcbiAgICB0aGlzLnN1YlNlY3Rpb24/LmF0dHJpYnV0ZUNoYW5nZS5zdWJzY3JpYmUoZXZlbnQgPT4ge1xuICAgICAgY29uc29sZS5sb2coJ1N1YlNlY3Rpb25Db21wb25lbnQgYXR0cmlidXRlQ2hhbmdlJyk7XG4gICAgICBjb25zb2xlLmxvZyhldmVudCk7XG4gICAgICBjb25zdCB7IG5hbWU6IGF0dHJOYW1lLCB2YWx1ZSA9IG51bGwgfSA9IGV2ZW50ID8/IHt9O1xuICAgICAgLy8gaWYgKGF0dHJOYW1lKSB7XG4gICAgICAgIHRoaXMuZGVmYXVsdFByb2Nlc3NBdHRyaWJ1dGVDaGFuZ2UoYXR0ck5hbWUsIHZhbHVlKTtcbiAgICAgICAgdGhpcy5jdXN0b21Qcm9jZXNzQXR0cmlidXRlQ2hhbmdlKGF0dHJOYW1lLCB2YWx1ZSk7XG4gICAgICAvLyB9XG4gICAgfSk7XG4gICAgdGhpcy5zdGFydCgpO1xuICB9XG5cbiAgc3RhcnQoKSB7XG4gICAgdGhpcy5zZXRGb3JtKHRoaXMuc3ViU2VjdGlvbj8uX2Zvcm0pO1xuICB9XG59XG4iXX0=
|
|
@@ -35,11 +35,13 @@ export class LibTableComponent extends ElementComponent {
|
|
|
35
35
|
}
|
|
36
36
|
// Subscripción a cambios en atributos
|
|
37
37
|
this.table?.attributeChange.subscribe(event => {
|
|
38
|
+
console.log('LibTableComponent attributeChange');
|
|
39
|
+
console.log(event);
|
|
38
40
|
const { name: attrName, value = null } = event ?? {};
|
|
39
|
-
if (attrName) {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
}
|
|
41
|
+
// if (attrName) {
|
|
42
|
+
this.defaultProcessAttributeChange(attrName, value);
|
|
43
|
+
this.customProcessAttributeChange(attrName, value);
|
|
44
|
+
// }
|
|
43
45
|
});
|
|
44
46
|
this.start();
|
|
45
47
|
}
|
|
@@ -89,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImpor
|
|
|
89
91
|
}], waiting: [{
|
|
90
92
|
type: Input
|
|
91
93
|
}] } });
|
|
92
|
-
//# 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, ChangeDetectionStrategy } from '@angular/core';\nimport { TableRecordData } from '../../../classes/forms/table/row-data';\nimport { TableActionEvent } from '../../../classes/forms/table/table';\nimport { RecordTable, TableEvent } from '../../../classes/forms/table/table';\nimport { ElementComponent } from '../layout/element.component';\n\n@Component({\n  selector: 'lib-table',\n  template: `<ng-content></ng-content>`,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\n\nexport class LibTableComponent extends ElementComponent implements OnInit {\n  // Atributos sincronizados del objeto\n  code: any;\n  globalFilterString: string = '';\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 | null = null;\n  @Input() visibleRecords: TableRecordData[] = [];\n  @Input() waiting: boolean = false;\n\n  ngOnInit() {\n    if (!this.table) { return; }\n    this.table.setWidget(this);\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.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?.tablePropagationAttributes);\n    for (let index = 0; index < mapping.length; index++) {\n      const tableAttr = mapping[index]?.[0];\n      const componentAttr = mapping[index]?.[1]?.toString() ?? '';\n      const attributeValue = this.table?.[tableAttr];\n      this.defaultProcessAttributeChange(componentAttr, attributeValue);\n      this.customProcessAttributeChange(componentAttr, attributeValue);\n    }\n    // Subscripción a cambios en atributos\n    this.table?.attributeChange.subscribe(event => {\n      const { name: attrName, value = null } = event ?? {};\n      if (attrName) {\n        this.defaultProcessAttributeChange(attrName, value);\n        this.customProcessAttributeChange(attrName, value);\n      }\n    });\n    this.start();\n  }\n\n  updateTableData() { }\n  tableGlobalAction(actionCode: string) { this.table?.notifyGlobalAction(actionCode); }\n  tableSelectionAction(actionCode: string) { this.table?.notifySelectionAction(actionCode); }\n  tableActionSelected(actionEvent: TableActionEvent) { this.table?.notifyInlineAction(actionEvent); }\n  tableSelectionToggle(recordId: any) { this.table?.notifyRecordSelection(recordId); }\n  toggleSelectAll() { return (this.table?.allSelected) ? this.table?.unSelectAll() : this.table?.selectAll(); }\n  globalFilterCompleted() { this.changePage(1); }\n  changePage(requestedPage: number) { this.table?.changePage(requestedPage); }\n  tableColumnSort(columnName: string, direction = null) { this.table?.sort(columnName, direction ?? 'ascend'); }\n  globalFilterChanged() { this.table?.setGlobalFilterString(this.globalFilterString?.trim() ?? '', false); }\n\n  override defaultProcessAttributeChange(attribute: string, value?: any): boolean {\n    try {\n      if (attribute === 'visibleRecords') {\n        this.updateTableData();\n      }\n      return super.defaultProcessAttributeChange(attribute, value);\n    } catch {\n      return false;\n    }\n  }\n\n  filterHasChanged(column, values) {\n    if (!values || values.length === 0) {\n      this.table?.removeColumnFilter(column.fieldCode);\n    } else {\n      this.table?.addColumnFilter(column.fieldCode, values);\n    }\n  }\n}\n"]}
|
|
94
|
+
//# 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, ChangeDetectionStrategy } from '@angular/core';\nimport { TableRecordData } from '../../../classes/forms/table/row-data';\nimport { TableActionEvent } from '../../../classes/forms/table/table';\nimport { RecordTable, TableEvent } from '../../../classes/forms/table/table';\nimport { ElementComponent } from '../layout/element.component';\n\n@Component({\n  selector: 'lib-table',\n  template: `<ng-content></ng-content>`,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\n\nexport class LibTableComponent extends ElementComponent implements OnInit {\n  // Atributos sincronizados del objeto\n  code: any;\n  globalFilterString: string = '';\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 | null = null;\n  @Input() visibleRecords: TableRecordData[] = [];\n  @Input() waiting: boolean = false;\n\n  ngOnInit() {\n    if (!this.table) { return; }\n    this.table.setWidget(this);\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.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?.tablePropagationAttributes);\n    for (let index = 0; index < mapping.length; index++) {\n      const tableAttr = mapping[index]?.[0];\n      const componentAttr = mapping[index]?.[1]?.toString() ?? '';\n      const attributeValue = this.table?.[tableAttr];\n      this.defaultProcessAttributeChange(componentAttr, attributeValue);\n      this.customProcessAttributeChange(componentAttr, attributeValue);\n    }\n    // Subscripción a cambios en atributos\n    this.table?.attributeChange.subscribe(event => {\n      console.log('LibTableComponent attributeChange');\n      console.log(event);\n      const { name: attrName, value = null } = event ?? {};\n      // if (attrName) {\n        this.defaultProcessAttributeChange(attrName, value);\n        this.customProcessAttributeChange(attrName, value);\n      // }\n    });\n    this.start();\n  }\n\n  updateTableData() { }\n  tableGlobalAction(actionCode: string) { this.table?.notifyGlobalAction(actionCode); }\n  tableSelectionAction(actionCode: string) { this.table?.notifySelectionAction(actionCode); }\n  tableActionSelected(actionEvent: TableActionEvent) { this.table?.notifyInlineAction(actionEvent); }\n  tableSelectionToggle(recordId: any) { this.table?.notifyRecordSelection(recordId); }\n  toggleSelectAll() { return (this.table?.allSelected) ? this.table?.unSelectAll() : this.table?.selectAll(); }\n  globalFilterCompleted() { this.changePage(1); }\n  changePage(requestedPage: number) { this.table?.changePage(requestedPage); }\n  tableColumnSort(columnName: string, direction = null) { this.table?.sort(columnName, direction ?? 'ascend'); }\n  globalFilterChanged() { this.table?.setGlobalFilterString(this.globalFilterString?.trim() ?? '', false); }\n\n  override defaultProcessAttributeChange(attribute: string, value?: any): boolean {\n    try {\n      if (attribute === 'visibleRecords') {\n        this.updateTableData();\n      }\n      return super.defaultProcessAttributeChange(attribute, value);\n    } catch {\n      return false;\n    }\n  }\n\n  filterHasChanged(column, values) {\n    if (!values || values.length === 0) {\n      this.table?.removeColumnFilter(column.fieldCode);\n    } else {\n      this.table?.addColumnFilter(column.fieldCode, values);\n    }\n  }\n}\n"]}
|
|
@@ -162,11 +162,13 @@ class FieldComponent extends ElementComponent {
|
|
|
162
162
|
}
|
|
163
163
|
// Subscripción a cambios en atributos
|
|
164
164
|
(_l = this.field) === null || _l === void 0 ? void 0 : _l.attributeChange.subscribe(event => {
|
|
165
|
+
console.log('FieldComponent attributeChange');
|
|
166
|
+
console.log(event);
|
|
165
167
|
const { name: componentAttr, value = null } = event !== null && event !== void 0 ? event : {};
|
|
166
|
-
if (componentAttr) {
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
}
|
|
168
|
+
// if (componentAttr) {
|
|
169
|
+
this.defaultProcessAttributeChange(componentAttr, value);
|
|
170
|
+
this.customProcessAttributeChange(componentAttr, value);
|
|
171
|
+
// }
|
|
170
172
|
});
|
|
171
173
|
if (this.field) {
|
|
172
174
|
this.field.widget = this;
|
|
@@ -270,11 +272,13 @@ class SectionComponent extends PieceComponent {
|
|
|
270
272
|
}
|
|
271
273
|
// Subscripción a cambios en atributos
|
|
272
274
|
(_d = this.section) === null || _d === void 0 ? void 0 : _d.attributeChange.subscribe(event => {
|
|
275
|
+
console.log('SectionComponent attributeChange');
|
|
276
|
+
console.log(event);
|
|
273
277
|
const { name: attrName, value = null } = event !== null && event !== void 0 ? event : {};
|
|
274
|
-
if (attrName) {
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
}
|
|
278
|
+
// if (attrName) {
|
|
279
|
+
this.defaultProcessAttributeChange(attrName, value);
|
|
280
|
+
this.customProcessAttributeChange(attrName, value);
|
|
281
|
+
// }
|
|
278
282
|
});
|
|
279
283
|
this.start();
|
|
280
284
|
}
|
|
@@ -308,11 +312,13 @@ class SubSectionComponent extends PieceComponent {
|
|
|
308
312
|
}
|
|
309
313
|
// Subscripción a cambios en atributos
|
|
310
314
|
(_d = this.subSection) === null || _d === void 0 ? void 0 : _d.attributeChange.subscribe(event => {
|
|
315
|
+
console.log('SubSectionComponent attributeChange');
|
|
316
|
+
console.log(event);
|
|
311
317
|
const { name: attrName, value = null } = event !== null && event !== void 0 ? event : {};
|
|
312
|
-
if (attrName) {
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
}
|
|
318
|
+
// if (attrName) {
|
|
319
|
+
this.defaultProcessAttributeChange(attrName, value);
|
|
320
|
+
this.customProcessAttributeChange(attrName, value);
|
|
321
|
+
// }
|
|
316
322
|
});
|
|
317
323
|
this.start();
|
|
318
324
|
}
|
|
@@ -462,11 +468,13 @@ class LibTableComponent extends ElementComponent {
|
|
|
462
468
|
}
|
|
463
469
|
// Subscripción a cambios en atributos
|
|
464
470
|
(_s = this.table) === null || _s === void 0 ? void 0 : _s.attributeChange.subscribe(event => {
|
|
471
|
+
console.log('LibTableComponent attributeChange');
|
|
472
|
+
console.log(event);
|
|
465
473
|
const { name: attrName, value = null } = event !== null && event !== void 0 ? event : {};
|
|
466
|
-
if (attrName) {
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
}
|
|
474
|
+
// if (attrName) {
|
|
475
|
+
this.defaultProcessAttributeChange(attrName, value);
|
|
476
|
+
this.customProcessAttributeChange(attrName, value);
|
|
477
|
+
// }
|
|
470
478
|
});
|
|
471
479
|
this.start();
|
|
472
480
|
}
|
|
@@ -680,6 +688,7 @@ class FormPiecePropagate extends FormPiece {
|
|
|
680
688
|
get attributeChange() { return this._attributeChange; }
|
|
681
689
|
propagateAttribute(name, value) {
|
|
682
690
|
var _a;
|
|
691
|
+
console.log(`Propagación ${name} : ${JSON.stringify(value)}`);
|
|
683
692
|
(_a = this._attributeChange) === null || _a === void 0 ? void 0 : _a.next({ name, value });
|
|
684
693
|
}
|
|
685
694
|
setCustomAttribute(name, value) {
|
|
@@ -687,21 +696,26 @@ class FormPiecePropagate extends FormPiece {
|
|
|
687
696
|
super.setCustomAttribute(name, value);
|
|
688
697
|
if ((_a = this.propagationCustomAttributes) === null || _a === void 0 ? void 0 : _a.includes(name)) {
|
|
689
698
|
const fullName = `customAttributes.${name}`;
|
|
699
|
+
console.log('piece setCustomAttribute');
|
|
690
700
|
this.propagateAttribute(fullName, value);
|
|
691
701
|
}
|
|
692
702
|
}
|
|
693
703
|
setVisibility(visible, forced = null) {
|
|
694
704
|
super.setVisibility(visible, forced);
|
|
705
|
+
console.log('piece setVisibility');
|
|
695
706
|
this.propagateAttribute(VISIBLE, this._visible);
|
|
696
707
|
}
|
|
697
708
|
set enabled(enabled) {
|
|
698
709
|
super.enabled = enabled;
|
|
710
|
+
console.log('piece enabled');
|
|
699
711
|
this.propagateAttribute(DISABLED, this._disabled);
|
|
700
712
|
}
|
|
701
713
|
formStateChange(state) {
|
|
702
714
|
super.formStateChange(state);
|
|
703
715
|
if (state) {
|
|
716
|
+
console.log('piece 1 formStateChange');
|
|
704
717
|
this.propagateAttribute(VISIBLE, this._visible);
|
|
718
|
+
console.log('piece 2 formStateChange');
|
|
705
719
|
this.propagateAttribute(DISABLED, this._disabled);
|
|
706
720
|
}
|
|
707
721
|
}
|
|
@@ -716,6 +730,8 @@ class FormElement extends FormPiecePropagate {
|
|
|
716
730
|
setAttr(attr, value) {
|
|
717
731
|
const { name: attrName, propagate: name } = attr;
|
|
718
732
|
this[attrName] = value;
|
|
733
|
+
console.log(`Element setAttr name: ${name}`);
|
|
734
|
+
console.log(value);
|
|
719
735
|
name && this.propagateAttribute(name, value);
|
|
720
736
|
}
|
|
721
737
|
isField() { return this.elementType === elementTypes.field; }
|