bit-ng-library 13.1.11 → 13.1.14
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 +13 -0
- package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general-v2.component.mjs +4 -2
- package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.mjs +38 -3
- package/fesm2015/bit-ng-library.mjs +39 -3
- package/fesm2015/bit-ng-library.mjs.map +1 -1
- package/fesm2020/bit-ng-library.mjs +39 -3
- package/fesm2020/bit-ng-library.mjs.map +1 -1
- package/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general-v2.component.d.ts +2 -1
- package/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general-v2.component.d.ts.map +1 -1
- package/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.d.ts +1 -0
- package/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.d.ts.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -26,6 +26,19 @@ To get more help on the Angular CLI use `ng help` or go check out the [Angular C
|
|
|
26
26
|
|
|
27
27
|
## changelog
|
|
28
28
|
|
|
29
|
+
## [13.1.14] - 2022-08-25
|
|
30
|
+
|
|
31
|
+
Nuevo input transformDataValueTo en BitDropDownGeneralV2Component. Para cambiar el tipo de dato del valor (ID) en listas de dominios. Vienen del servidor como String pero en el form
|
|
32
|
+
control se guardan los valores seleccionados como Number y al no coincidir el dropdown se muestra con opción en blanco.
|
|
33
|
+
|
|
34
|
+
## [13.1.13] - 2022-07-15
|
|
35
|
+
|
|
36
|
+
Fix BitDropdown. No se muestran las opciones si se sobreescribe el atributo atributoLabel.
|
|
37
|
+
|
|
38
|
+
## [13.1.12] - 2022-07-14
|
|
39
|
+
|
|
40
|
+
Fix BitDropdown. Es posible que los atributos label/value de la lista de opciones se sobreescriban y se ha de tener en cuenta al generar la primera opción.
|
|
41
|
+
|
|
29
42
|
## [13.1.11] - 2022-07-14
|
|
30
43
|
|
|
31
44
|
Fixes BitDropdown y BitDropDownMultiple. Valor lectura y bug eliminación de opciones seleccionadas en dropdown múltiple.
|
package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general-v2.component.mjs
CHANGED
|
@@ -56,13 +56,15 @@ export class BitDropDownGeneralV2Component extends BitGeneralV2Component {
|
|
|
56
56
|
}
|
|
57
57
|
}
|
|
58
58
|
BitDropDownGeneralV2Component.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: BitDropDownGeneralV2Component, deps: [{ token: i1.ActivatedRoute }, { token: i2.SessionSharedService }, { token: i2.AyudaService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
59
|
-
BitDropDownGeneralV2Component.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: BitDropDownGeneralV2Component, inputs: { hideLabel: "hideLabel", data: "data", id: "id", excludedValues: "excludedValues", emptyText: "emptyText", includeEmpty: "includeEmpty" }, usesInheritance: true, ngImport: i0 });
|
|
59
|
+
BitDropDownGeneralV2Component.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: BitDropDownGeneralV2Component, inputs: { hideLabel: "hideLabel", data: "data", transformDataValueTo: "transformDataValueTo", id: "id", excludedValues: "excludedValues", emptyText: "emptyText", includeEmpty: "includeEmpty" }, usesInheritance: true, ngImport: i0 });
|
|
60
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: BitDropDownGeneralV2Component, decorators: [{
|
|
61
61
|
type: Directive
|
|
62
62
|
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.SessionSharedService }, { type: i2.AyudaService }, { type: i2.TranslateService }]; }, propDecorators: { hideLabel: [{
|
|
63
63
|
type: Input
|
|
64
64
|
}], data: [{
|
|
65
65
|
type: Input
|
|
66
|
+
}], transformDataValueTo: [{
|
|
67
|
+
type: Input
|
|
66
68
|
}], id: [{
|
|
67
69
|
type: Input
|
|
68
70
|
}], excludedValues: [{
|
|
@@ -72,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
72
74
|
}], includeEmpty: [{
|
|
73
75
|
type: Input
|
|
74
76
|
}] } });
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYml0LWRyb3Bkb3duLWdlbmVyYWwtdjIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYml0LW5nLWxpYnJhcnkvc3JjL2xpYi9zaGFyZWRsaWJyYXJ5L2NvbXBvbmVudHMvZm9ybS9kcm9wZG93bi9iaXQtZHJvcGRvd24tZ2VuZXJhbC12Mi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXRDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDOzs7O0FBR3BFOzs7Ozs7OztJQVFJO0FBRUosTUFBTSxPQUFnQiw2QkFBOEIsU0FBUSxxQkFBcUI7SUFjL0UsWUFDWSxNQUFzQixFQUN0QixhQUFtQyxFQUNuQyxZQUEwQixFQUMxQixnQkFBa0M7UUFFNUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBTFYsV0FBTSxHQUFOLE1BQU0sQ0FBZ0I7UUFDdEIsa0JBQWEsR0FBYixhQUFhLENBQXNCO1FBQ25DLGlCQUFZLEdBQVosWUFBWSxDQUFjO1FBQzFCLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFqQnJDLGNBQVMsR0FBWSxLQUFLLENBQUMsQ0FBQyxzREFBc0Q7UUFLbEYsY0FBUyxHQUFXLDhCQUE4QixDQUFDLENBQUMsc0RBQXNEO1FBQzFHLGlCQUFZLEdBQVksSUFBSSxDQUFDO1FBRXRDLGtCQUFhLEdBQVUsRUFBRSxDQUFDO1FBQzFCLHlCQUFvQixHQUFVLEVBQUUsQ0FBQztRQUVqQyxzQkFBaUIsR0FBVyxFQUFFLENBQUM7SUFTL0IsQ0FBQztJQUVELDZEQUE2RDtJQUM3RCxnQkFBZ0I7UUFDZCxPQUFPLENBQUMsR0FBRyxDQUFDLG1DQUFtQyxHQUFHLElBQUksQ0FBQyxNQUFNLEdBQUcsWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLEdBQUcsR0FBRyxDQUFDLENBQUM7UUFDekcsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3RCLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7WUFDbEUsMkRBQTJEO1lBQzNELElBQUksSUFBSSxDQUFDLGNBQWMsRUFBRTtnQkFDdkIsSUFBSSxDQUFDLG9CQUFvQixHQUFHLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQzthQUNqSDtTQUNGO2FBQU07WUFDTCxJQUFJLENBQUMsb0JBQW9CLEdBQUcsRUFBRSxDQUFDO1NBQ2hDO1FBQ0QsNEVBQTRFO1FBQzVFLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtZQUNyQixPQUFPLENBQUMsR0FBRyxDQUFDLDRDQUE0QyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUN4RSxJQUFJLENBQUMsZ0JBQWdCO2lCQUNsQiwwQkFBMEIsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO2lCQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO2lCQUNiLFNBQVMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxFQUFFO2dCQUN6QixPQUFPLENBQUMsR0FBRyxDQUFDLCtDQUErQyxHQUFHLElBQUksQ0FBQyxNQUFNLEdBQUcsYUFBYSxHQUFHLFdBQVcsQ0FBQyxDQUFDO2dCQUN6RyxJQUFJLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUMsQ0FBQyxDQUFDO2dCQUMxRSxJQUFJLENBQUMsaUJBQWlCLEdBQUcsV0FBVyxDQUFDO2dCQUNyQyxzRUFBc0U7WUFDeEUsQ0FBQyxDQUFDLENBQUM7U0FDTjtJQUNILENBQUM7OzBIQWhEbUIsNkJBQTZCOzhHQUE3Qiw2QkFBNkI7MkZBQTdCLDZCQUE2QjtrQkFEbEQsU0FBUztrTUFFQyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxvQkFBb0I7c0JBQTVCLEtBQUs7Z0JBQ0csRUFBRTtzQkFBVixLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5wdXQsIERpcmVjdGl2ZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEFjdGl2YXRlZFJvdXRlIH0gZnJvbSBcIkBhbmd1bGFyL3JvdXRlclwiO1xyXG5pbXBvcnQgeyB0YWtlIH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XHJcblxyXG5pbXBvcnQgeyBCaXRHZW5lcmFsVjJDb21wb25lbnQgfSBmcm9tIFwiLi4vYml0LWdlbmVyYWwtdjIuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IEF5dWRhU2VydmljZSwgVHJhbnNsYXRlU2VydmljZSwgU2Vzc2lvblNoYXJlZFNlcnZpY2UgfSBmcm9tIFwiLi4vLi4vLi4vc2VydmljZXNcIjtcclxuXHJcbi8qKlxyXG4gKiBDbGFzZSBnZW5lcmFsIGNvbcO6biBhIGFtYm9zIGJpdC1kcm9wZG93biAoRWwgbm9ybWFsIHkgZWwgbcO6bHRpcGxlKS5cclxuICogQWN0dWFsbWVudGUgc29sbyBleHRlbmRpZGEgcG9yIGVsIGRyb3Bkb3duIG5vcm1hbCwgcGVuZGllbnRlIGVsIG3Dumx0aXBsZSBxdWUgYcO6biB1c2EgbGEgaW50ZXJmYXogQ29udHJvbFZhbHVlQWNjZXNzb3IuXHJcbiAqXHJcbiAqIEBpbnB1dCBkYXRhOiBhcnJheSBkZSBvYmpldG9zIGEgbW9zdHJhciBlbiBlbCBzZWxlY3QuIFB1ZWRlIHNlciBudWxsLCBlbiBjdXlvIGNhc28gZG9tYWluIG5vIHB1ZWRlIHNlciBudWxsXHJcbiAqIEBpbnB1dCBkb21haW46IG5vbWJyZSBkZWwgZG9taW5pbyBxdWUgY29udGllbmUgbG9zIGRhdG9zIHkgcXVlIG5vcyByZXNvbHZlcsOhIGxhIHDDoWdpbmEgY3VhbmRvIGNhcmd1ZSBlbCBjb21wb25lbnRlLiBQdWVkZSBzZXIgbnVsbCwgZW4gY3V5byBjYXNvIGRhdGEgbm8gcHVlZGUgc2VyIG51bGxcclxuICogQGlucHV0IGlkOiBpZGVudGlmaWNhZG9yIGRlbCBjb21wb25lbnRlIHNlbGVjdFxyXG4gKiBAaW5wdXQgZmlsdGVyOiB0cnVlIGluZGljYXLDoSBxdWUgcG9kZW1vcyBidXNjYXIgZGVudHJvIGRlbCBzZWxlY3QsIGZhbHNlIHF1ZSBuby5cclxuICoqL1xyXG5ARGlyZWN0aXZlKClcclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJpdERyb3BEb3duR2VuZXJhbFYyQ29tcG9uZW50IGV4dGVuZHMgQml0R2VuZXJhbFYyQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBoaWRlTGFiZWw6IGJvb2xlYW4gPSBmYWxzZTsgLy8gZm9yemFyIG5vIHJlc2VydmFyIGVzcGFjaW8gcGFyYSBlbCBub21icmUgZGVsIGNhbXBvXHJcbiAgQElucHV0KCkgZGF0YTogYW55W107IC8vIGxpc3RhIGRlIHZhbG9yZXMgZXN0w6F0aWNvcyBjb24gbG8gcXVlIGluaWNpYWxpemFtb3MgZWwgc2VsZWN0XHJcbiAgQElucHV0KCkgdHJhbnNmb3JtRGF0YVZhbHVlVG86IHN0cmluZzsgLy8gaW5kaWNhIHNpIGhheSBxdWUgdHJhbnNmb3JtYXIgZWwgdmFsb3IgZGUgbG9zIElEIGRlIGxhIGxpc3RhIGRlIGRhdG9zIGRlIGVudHJhZGEgKG11Y2hhcyBsaXN0YXMgZGUgZG9taW5pbyB2aWVuZW4gY29uIGVsIElEIGVuIGZvcm1hdG8gU3RyaW5nICB5IHNlIGRlc2VhIGVuIGZvcm1hdG8gTnVtYmVyKVxyXG4gIEBJbnB1dCgpIGlkOiBhbnk7XHJcbiAgQElucHV0KCkgZXhjbHVkZWRWYWx1ZXM6IGFueVtdO1xyXG4gIEBJbnB1dCgpIGVtcHR5VGV4dDogc3RyaW5nID0gXCJiaXRuZ2xpYnJhcnkuYml0ZHJvcGRvd24uYW55XCI7IC8vdmFsb3IgcG9yIGRlZmVjdG8gc2VsZWNjaW9uYWJsZSBjb21vIHByaW1lciBlbGVtZW50b1xyXG4gIEBJbnB1dCgpIGluY2x1ZGVFbXB0eTogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gIGxpc3RhT3BjaW9uZXM6IGFueVtdID0gW107XHJcbiAgbGlzdGFPcGNpb25lc1Zpc2libGU6IGFueVtdID0gW107XHJcbiAgdmFsb3JBY3R1YWw6IGFueTsgLy8gc29sbyBzZSB1c2EgcGFyYSBoYWNlciBsYSB0cmFuc2Zvcm1hY2nDs24gY3VhbmRvIGVzIGVzdHJpY3RhbWVudGUgbmVjZXNhcmlvXHJcbiAgZW1wdHlUZXh0UmVzb2x2ZWQ6IHN0cmluZyA9IFwiXCI7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJvdGVjdGVkIHJvdXRlcjogQWN0aXZhdGVkUm91dGUsXHJcbiAgICBwcm90ZWN0ZWQgc2Vzc2lvblNoYXJlZDogU2Vzc2lvblNoYXJlZFNlcnZpY2UsXHJcbiAgICBwcm90ZWN0ZWQgYXl1ZGFTZXJ2aWNlOiBBeXVkYVNlcnZpY2UsXHJcbiAgICBwcm90ZWN0ZWQgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZVxyXG4gICkge1xyXG4gICAgc3VwZXIoYXl1ZGFTZXJ2aWNlKTtcclxuICB9XHJcblxyXG4gIC8vIGN1c3RvbSBwcm9jZXNzaW5nIGFmdGVyIHJldHJpZXZpbmcgZGF0YSBhcnJheSBmcm9tIHNlcnZpY2VcclxuICBwb3N0UmV0cmlldmVEYXRhKCkge1xyXG4gICAgY29uc29sZS5sb2coXCJsbGFtYW5kbyBhIHBvc3RSZXRyaWV2ZURhdGEgcGFyYSBcIiArIHRoaXMubm9tYnJlICsgXCJ7b3BjaW9uZXM6XCIgKyB0aGlzLmxpc3RhT3BjaW9uZXMgKyBcIn1cIik7XHJcbiAgICBpZiAodGhpcy5saXN0YU9wY2lvbmVzKSB7XHJcbiAgICAgIHRoaXMubGlzdGFPcGNpb25lc1Zpc2libGUgPSBPYmplY3QuYXNzaWduKFtdLCB0aGlzLmxpc3RhT3BjaW9uZXMpO1xyXG4gICAgICAvLyByZXBhc2Ftb3Mgc2kgaGF5IG9wY2lvbmVzIGEgZXhjbHVpciBxdWUgZGViYW1vcyBlbGltaW5hclxyXG4gICAgICBpZiAodGhpcy5leGNsdWRlZFZhbHVlcykge1xyXG4gICAgICAgIHRoaXMubGlzdGFPcGNpb25lc1Zpc2libGUgPSB0aGlzLmxpc3RhT3BjaW9uZXNWaXNpYmxlLmZpbHRlcigob3ApID0+IHRoaXMuZXhjbHVkZWRWYWx1ZXMuaW5kZXhPZihvcC52YWx1ZSkgPCAwKTtcclxuICAgICAgfVxyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy5saXN0YU9wY2lvbmVzVmlzaWJsZSA9IFtdO1xyXG4gICAgfVxyXG4gICAgLy8gZGV0ZXJtaW5hbW9zIHNpIGRlYmVtb3MgaW5jbHVpciBsYSBvcGNpw7NuIFwic2luIHNlbGVjY2nDs25cIiB5IGNvbiBxdcOpIHRleHRvXHJcbiAgICBpZiAodGhpcy5pbmNsdWRlRW1wdHkpIHtcclxuICAgICAgY29uc29sZS5sb2coXCJoYXkgdmFsb3IgZW1wdHkgcXVlIGhheSBxdWUgdHJhZHVjaXIgcGFyYSBcIiArIHRoaXMubm9tYnJlKTtcclxuICAgICAgdGhpcy50cmFuc2xhdGVTZXJ2aWNlXHJcbiAgICAgICAgLnNlbGVjdFRyYW5zbGF0ZVdpdGhDb250ZXh0KHRoaXMuZW1wdHlUZXh0KVxyXG4gICAgICAgIC5waXBlKHRha2UoMSkpXHJcbiAgICAgICAgLnN1YnNjcmliZSgodHJhbnNsYXRpb24pID0+IHtcclxuICAgICAgICAgIGNvbnNvbGUubG9nKFwic2UgcmVzdWVsdmUgbGEgdHJhZHVjY2nDs24gZGVsIGVtcHR5VGV4dCBwYXJhIFwiICsgdGhpcy5ub21icmUgKyBcIiBjb24gdmFsb3I6XCIgKyB0cmFuc2xhdGlvbik7XHJcbiAgICAgICAgICB0aGlzLmxpc3RhT3BjaW9uZXNWaXNpYmxlLnNwbGljZSgwLCAwLCB7dmFsdWU6IG51bGwsIGxhYmVsOiB0cmFuc2xhdGlvbn0pO1xyXG4gICAgICAgICAgdGhpcy5lbXB0eVRleHRSZXNvbHZlZCA9IHRyYW5zbGF0aW9uO1xyXG4gICAgICAgICAgLy9jb25zb2xlLmxvZyhcImxhIGxpc3RhIGRlIG9wY2lvbmVzIHZhbGVcIiwgdGhpcy5saXN0YU9wY2lvbmVzVmlzaWJsZSk7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiAiXX0=
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Component, Input } from "@angular/core";
|
|
2
|
+
import { take } from "rxjs/operators";
|
|
2
3
|
import { BitDropDownGeneralV2Component } from "./bit-dropdown-general-v2.component";
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@angular/router";
|
|
@@ -35,6 +36,11 @@ export class BitDropDownComponent extends BitDropDownGeneralV2Component {
|
|
|
35
36
|
let changedProp = changes[propName];
|
|
36
37
|
if (propName === "data") {
|
|
37
38
|
this.listaOpciones = changedProp.currentValue ? changedProp.currentValue.slice() : [];
|
|
39
|
+
if (this.transformDataValueTo == "number") {
|
|
40
|
+
this.listaOpciones.forEach(opcion => {
|
|
41
|
+
opcion[this.atributoValue] = Number(opcion[this.atributoValue]);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
38
44
|
hayCambios = true;
|
|
39
45
|
}
|
|
40
46
|
else if (propName === "excludedValues") {
|
|
@@ -50,6 +56,35 @@ export class BitDropDownComponent extends BitDropDownGeneralV2Component {
|
|
|
50
56
|
this.postRetrieveData();
|
|
51
57
|
}
|
|
52
58
|
}
|
|
59
|
+
// custom processing after retrieving data array from service
|
|
60
|
+
postRetrieveData() {
|
|
61
|
+
console.log("llamando a postRetrieveData para " + this.nombre + "{opciones:" + this.listaOpciones + "}");
|
|
62
|
+
if (this.listaOpciones) {
|
|
63
|
+
this.listaOpcionesVisible = Object.assign([], this.listaOpciones);
|
|
64
|
+
// repasamos si hay opciones a excluir que debamos eliminar
|
|
65
|
+
if (this.excludedValues) {
|
|
66
|
+
this.listaOpcionesVisible = this.listaOpcionesVisible.filter((op) => this.excludedValues.indexOf(op.value) < 0);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
this.listaOpcionesVisible = [];
|
|
71
|
+
}
|
|
72
|
+
// determinamos si debemos incluir la opción "sin selección" y con qué texto
|
|
73
|
+
if (this.includeEmpty) {
|
|
74
|
+
console.log("hay valor empty que hay que traducir para " + this.nombre);
|
|
75
|
+
this.translateService
|
|
76
|
+
.selectTranslateWithContext(this.emptyText)
|
|
77
|
+
.pipe(take(1))
|
|
78
|
+
.subscribe((translation) => {
|
|
79
|
+
let newOption = { value: null, label: translation };
|
|
80
|
+
newOption[this.atributoValue] = null;
|
|
81
|
+
newOption[this.atributoLabel] = translation;
|
|
82
|
+
this.listaOpcionesVisible.splice(0, 0, newOption);
|
|
83
|
+
this.emptyTextResolved = translation;
|
|
84
|
+
//console.log("la lista de opciones vale", this.listaOpcionesVisible);
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
}
|
|
53
88
|
get value_lectura() {
|
|
54
89
|
let val = this.control.value;
|
|
55
90
|
let dom = this.listaOpciones && this.listaOpciones.find((d) => d.value == val);
|
|
@@ -57,10 +92,10 @@ export class BitDropDownComponent extends BitDropDownGeneralV2Component {
|
|
|
57
92
|
}
|
|
58
93
|
}
|
|
59
94
|
BitDropDownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: BitDropDownComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.SessionSharedService }, { token: i2.AyudaService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
60
|
-
BitDropDownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: BitDropDownComponent, selector: "bit-dropdown", inputs: { filter: "filter", atributoLabel: "atributoLabel", atributoValue: "atributoValue", atributoDisabled: "atributoDisabled" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<label *ngIf=\"!hideLabel\">\r\n <ng-content></ng-content> \r\n <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span> \r\n <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\r\n</label>\r\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{value_lectura}}</p>\r\n<ng-container *ngIf=\"!readOnly && !!myForm\">\r\n<div [formGroup]=\"myForm\">\r\n <p-dropdown\r\n id=\"{{nombre}}\"\r\n [options]=\"listaOpcionesVisible\"\r\n [formControl]=\"control\"\r\n [filter]=\"filter\"\r\n \r\n [optionLabel]=\"atributoLabel\"\r\n [optionValue]=\"atributoValue\"\r\n [optionDisabled]=\"atributoDisabled\"\r\n \r\n (onFocus)=\"onFocus()\"\r\n (onBlur)=\"onBlur()\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <span [ngClass]=\"{'opcion-desactivada': item
|
|
95
|
+
BitDropDownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: BitDropDownComponent, selector: "bit-dropdown", inputs: { filter: "filter", atributoLabel: "atributoLabel", atributoValue: "atributoValue", atributoDisabled: "atributoDisabled" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<label *ngIf=\"!hideLabel\">\r\n <ng-content></ng-content> \r\n <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span> \r\n <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\r\n</label>\r\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{value_lectura}}</p>\r\n<ng-container *ngIf=\"!readOnly && !!myForm\">\r\n<div [formGroup]=\"myForm\">\r\n <p-dropdown\r\n id=\"{{nombre}}\"\r\n [options]=\"listaOpcionesVisible\"\r\n [formControl]=\"control\"\r\n [filter]=\"filter\"\r\n \r\n [optionLabel]=\"atributoLabel\"\r\n [optionValue]=\"atributoValue\"\r\n [optionDisabled]=\"atributoDisabled\"\r\n \r\n (onFocus)=\"onFocus()\"\r\n (onBlur)=\"onBlur()\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <span [ngClass]=\"{'opcion-desactivada': item[atributoDisabled]}\">{{item[atributoLabel]}}</span>\r\n </ng-template>\r\n </p-dropdown>\r\n <control-messages *ngIf=\"control!=null\" [control]=\"control\" [field]=\"id\"></control-messages>\r\n</div>\r\n</ng-container>\r\n", components: [{ type: i3.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "virtualScroll", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "disabled", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear"] }, { type: i4.BitControlMessages, selector: "control-messages", inputs: ["control", "field"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i6.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i7.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
|
|
61
96
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: BitDropDownComponent, decorators: [{
|
|
62
97
|
type: Component,
|
|
63
|
-
args: [{ selector: "bit-dropdown", template: "<label *ngIf=\"!hideLabel\">\r\n <ng-content></ng-content> \r\n <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span> \r\n <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\r\n</label>\r\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{value_lectura}}</p>\r\n<ng-container *ngIf=\"!readOnly && !!myForm\">\r\n<div [formGroup]=\"myForm\">\r\n <p-dropdown\r\n id=\"{{nombre}}\"\r\n [options]=\"listaOpcionesVisible\"\r\n [formControl]=\"control\"\r\n [filter]=\"filter\"\r\n \r\n [optionLabel]=\"atributoLabel\"\r\n [optionValue]=\"atributoValue\"\r\n [optionDisabled]=\"atributoDisabled\"\r\n \r\n (onFocus)=\"onFocus()\"\r\n (onBlur)=\"onBlur()\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <span [ngClass]=\"{'opcion-desactivada': item
|
|
98
|
+
args: [{ selector: "bit-dropdown", template: "<label *ngIf=\"!hideLabel\">\r\n <ng-content></ng-content> \r\n <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span> \r\n <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\r\n</label>\r\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{value_lectura}}</p>\r\n<ng-container *ngIf=\"!readOnly && !!myForm\">\r\n<div [formGroup]=\"myForm\">\r\n <p-dropdown\r\n id=\"{{nombre}}\"\r\n [options]=\"listaOpcionesVisible\"\r\n [formControl]=\"control\"\r\n [filter]=\"filter\"\r\n \r\n [optionLabel]=\"atributoLabel\"\r\n [optionValue]=\"atributoValue\"\r\n [optionDisabled]=\"atributoDisabled\"\r\n \r\n (onFocus)=\"onFocus()\"\r\n (onBlur)=\"onBlur()\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <span [ngClass]=\"{'opcion-desactivada': item[atributoDisabled]}\">{{item[atributoLabel]}}</span>\r\n </ng-template>\r\n </p-dropdown>\r\n <control-messages *ngIf=\"control!=null\" [control]=\"control\" [field]=\"id\"></control-messages>\r\n</div>\r\n</ng-container>\r\n" }]
|
|
64
99
|
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.SessionSharedService }, { type: i2.AyudaService }, { type: i2.TranslateService }]; }, propDecorators: { filter: [{
|
|
65
100
|
type: Input
|
|
66
101
|
}], atributoLabel: [{
|
|
@@ -70,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
70
105
|
}], atributoDisabled: [{
|
|
71
106
|
type: Input
|
|
72
107
|
}] } });
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.ts","../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAA2B,MAAM,eAAe,CAAC;AAI1E,OAAO,EAAE,6BAA6B,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;;AAEpF;;;;;;;;IAQI;AAKJ,MAAM,OAAO,oBAAqB,SAAQ,6BAA6B;IASrE,YACY,MAAsB,EACtB,aAAmC,EACnC,YAA0B,EAC1B,gBAAkC;QAE5C,KAAK,CAAC,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,gBAAgB,CAAC,CAAC;QALnD,WAAM,GAAN,MAAM,CAAgB;QACtB,kBAAa,GAAb,aAAa,CAAsB;QACnC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAZrC,WAAM,GAAY,KAAK,CAAC;QAEjC,kBAAa,GAAG,OAAO,CAAC,CAAO,kEAAkE;QAEjG,kBAAa,GAAG,OAAO,CAAC,CAAO,kEAAkE;QAEjG,qBAAgB,GAAG,UAAU,CAAC,CAAC,mFAAmF;IASlH,CAAC;IAED,WAAW,CAAC,OAA4C;QACtD,IAAI,UAAU,GAAY,KAAK,CAAC;QAChC,KAAK,IAAI,QAAQ,IAAI,OAAO,EAAE;YAC5B,IAAI,WAAW,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;YACpC,IAAI,QAAQ,KAAK,MAAM,EAAE;gBACvB,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;gBACtF,UAAU,GAAG,IAAI,CAAC;aACnB;iBAAM,IAAI,QAAQ,KAAK,gBAAgB,EAAE;gBACxC,IAAI,CAAC,cAAc,GAAG,WAAW,CAAC,YAAY,CAAC;gBAC/C,UAAU,GAAG,IAAI,CAAC;aACnB;iBAAM,IAAI,QAAQ,KAAK,cAAc,EAAE;gBACtC,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,YAAY,CAAC;gBAC7C,UAAU,GAAG,IAAI,CAAC;aACnB;SACF;QACD,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IACH,CAAC;IAED,IAAI,aAAa;QACf,IAAI,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;QAC7B,IAAI,GAAG,GAAG,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,GAAG,CAAC,CAAC;QAC/E,OAAO,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IAChC,CAAC;;iHA1CU,oBAAoB;qGAApB,oBAAoB,oOCnBjC,gwCA4BA;2FDTa,oBAAoB;kBAJhC,SAAS;+BACE,cAAc;kMAIf,MAAM;sBAAd,KAAK;gBAEN,aAAa;sBADZ,KAAK;gBAGN,aAAa;sBADZ,KAAK;gBAGN,gBAAgB;sBADf,KAAK","sourcesContent":["import { Component, Input, OnChanges, SimpleChange } from \"@angular/core\";\r\nimport { ActivatedRoute } from \"@angular/router\";\r\n\r\nimport { AyudaService, SessionSharedService, TranslateService } from '../../../services';\r\nimport { BitDropDownGeneralV2Component } from \"./bit-dropdown-general-v2.component\";\r\n\r\n/**\r\n * Clase que utiliza un custom componente para select de elementos\r\n *    <bit-dropdown [domain]=\"'DOMAIN_TIPO_LOG'\" id=\"tipolog\" [control]=\"formControl\">&nbsp;&nbsp;Tipus d'operació</bit-dropdown>\r\n *\r\n * @input data: array de objetos a mostrar en el select. Puede ser null, en cuyo caso domain no puede ser null\r\n * @input domain: nombre del dominio que contiene los datos y que nos resolverá la página cuando cargue el componente. Puede ser null, en cuyo caso data no puede ser null\r\n * @input id: identificador del componente select\r\n * @input filter: true indicará que podemos buscar dentro del select, false que no.\r\n **/\r\n@Component({\r\n  selector: \"bit-dropdown\",\r\n  templateUrl: \"bit-dropdown.component.html\"\r\n})\r\nexport class BitDropDownComponent extends BitDropDownGeneralV2Component implements OnChanges {\r\n  @Input() filter: boolean = false;\r\n  @Input()\r\n  atributoLabel = \"label\";       // El atributo de los objetos de la lista que corresponde al label\r\n  @Input()\r\n  atributoValue = \"value\";       // El atributo de los objetos de la lista que corresponde al valor\r\n  @Input()\r\n  atributoDisabled = \"inactivo\"; // El atributo de los objetos de la lista que indica si un valor está deshabilitado\r\n\r\n  constructor(\r\n    protected router: ActivatedRoute,\r\n    protected sessionShared: SessionSharedService,\r\n    protected ayudaService: AyudaService,\r\n    protected translateService: TranslateService\r\n  ) {\r\n    super(router, sessionShared, ayudaService, translateService);\r\n  }\r\n\r\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\r\n    let hayCambios: boolean = false;\r\n    for (let propName in changes) {\r\n      let changedProp = changes[propName];\r\n      if (propName === \"data\") {\r\n        this.listaOpciones = changedProp.currentValue ? changedProp.currentValue.slice() : [];\r\n        hayCambios = true;\r\n      } else if (propName === \"excludedValues\") {\r\n        this.excludedValues = changedProp.currentValue;\r\n        hayCambios = true;\r\n      } else if (propName === \"includeEmpty\") {\r\n        this.includeEmpty = changedProp.currentValue;\r\n        hayCambios = true;\r\n      }\r\n    }\r\n    if (hayCambios) {\r\n      this.postRetrieveData();\r\n    }\r\n  }\r\n\r\n  get value_lectura(): string {\r\n    let val = this.control.value;\r\n    let dom = this.listaOpciones && this.listaOpciones.find((d) => d.value == val);\r\n    return dom ? dom.label : null;\r\n  }\r\n}\r\n","<label *ngIf=\"!hideLabel\">\r\n    <ng-content></ng-content>&nbsp;\r\n    <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span>&nbsp;&nbsp;\r\n    <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\r\n</label>\r\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{value_lectura}}</p>\r\n<ng-container *ngIf=\"!readOnly && !!myForm\">\r\n<div [formGroup]=\"myForm\">\r\n    <p-dropdown\r\n        id=\"{{nombre}}\"\r\n        [options]=\"listaOpcionesVisible\"\r\n        [formControl]=\"control\"\r\n        [filter]=\"filter\"\r\n        \r\n        [optionLabel]=\"atributoLabel\"\r\n        [optionValue]=\"atributoValue\"\r\n        [optionDisabled]=\"atributoDisabled\"\r\n        \r\n        (onFocus)=\"onFocus()\"\r\n        (onBlur)=\"onBlur()\">\r\n        <ng-template let-item pTemplate=\"item\">\r\n            <span [ngClass]=\"{'opcion-desactivada': item.inactivo}\">{{item.label}}</span>\r\n            <!-- span [ngClass]=\"{'opcion-desactivada': item[this.atributoDisabled]}\">{{item[this.atributoLabel]}}</span -->\r\n        </ng-template>\r\n    </p-dropdown>\r\n    <control-messages *ngIf=\"control!=null\" [control]=\"control\" [field]=\"id\"></control-messages>\r\n</div>\r\n</ng-container>\r\n"]}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.ts","../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, SimpleChange } from \"@angular/core\";\r\nimport { ActivatedRoute } from \"@angular/router\";\r\nimport { take } from \"rxjs/operators\";\r\n\r\nimport { AyudaService, SessionSharedService, TranslateService } from '../../../services';\r\nimport { BitDropDownGeneralV2Component } from \"./bit-dropdown-general-v2.component\";\r\n\r\n/**\r\n * Clase que utiliza un custom componente para select de elementos\r\n *    <bit-dropdown [domain]=\"'DOMAIN_TIPO_LOG'\" id=\"tipolog\" [control]=\"formControl\">&nbsp;&nbsp;Tipus d'operació</bit-dropdown>\r\n *\r\n * @input data: array de objetos a mostrar en el select. Puede ser null, en cuyo caso domain no puede ser null\r\n * @input domain: nombre del dominio que contiene los datos y que nos resolverá la página cuando cargue el componente. Puede ser null, en cuyo caso data no puede ser null\r\n * @input id: identificador del componente select\r\n * @input filter: true indicará que podemos buscar dentro del select, false que no.\r\n **/\r\n@Component({\r\n  selector: \"bit-dropdown\",\r\n  templateUrl: \"bit-dropdown.component.html\"\r\n})\r\nexport class BitDropDownComponent extends BitDropDownGeneralV2Component implements OnChanges {\r\n  @Input() filter: boolean = false;\r\n  @Input()\r\n  atributoLabel = \"label\";       // El atributo de los objetos de la lista que corresponde al label\r\n  @Input()\r\n  atributoValue = \"value\";       // El atributo de los objetos de la lista que corresponde al valor\r\n  @Input()\r\n  atributoDisabled = \"inactivo\"; // El atributo de los objetos de la lista que indica si un valor está deshabilitado\r\n\r\n  constructor(\r\n    protected router: ActivatedRoute,\r\n    protected sessionShared: SessionSharedService,\r\n    protected ayudaService: AyudaService,\r\n    protected translateService: TranslateService\r\n  ) {\r\n    super(router, sessionShared, ayudaService, translateService);\r\n  }\r\n\r\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\r\n    let hayCambios: boolean = false;\r\n    for (let propName in changes) {\r\n      let changedProp = changes[propName];\r\n      if (propName === \"data\") {\r\n        this.listaOpciones = changedProp.currentValue ? changedProp.currentValue.slice() : [];\r\n        if (this.transformDataValueTo == \"number\") {\r\n          this.listaOpciones.forEach(opcion => {\r\n            opcion[this.atributoValue] = Number(opcion[this.atributoValue]);\r\n          });\r\n        }\r\n        hayCambios = true;\r\n      } else if (propName === \"excludedValues\") {\r\n        this.excludedValues = changedProp.currentValue;\r\n        hayCambios = true;\r\n      } else if (propName === \"includeEmpty\") {\r\n        this.includeEmpty = changedProp.currentValue;\r\n        hayCambios = true;\r\n      }\r\n    }\r\n    if (hayCambios) {\r\n      this.postRetrieveData();\r\n    }\r\n  }\r\n\r\n  // custom processing after retrieving data array from service\r\n  postRetrieveData() {\r\n    console.log(\"llamando a postRetrieveData para \" + this.nombre + \"{opciones:\" + this.listaOpciones + \"}\");\r\n    if (this.listaOpciones) {\r\n      this.listaOpcionesVisible = Object.assign([], this.listaOpciones);\r\n      // repasamos si hay opciones a excluir que debamos eliminar\r\n      if (this.excludedValues) {\r\n        this.listaOpcionesVisible = this.listaOpcionesVisible.filter((op) => this.excludedValues.indexOf(op.value) < 0);\r\n      }\r\n    } else {\r\n      this.listaOpcionesVisible = [];\r\n    }\r\n    // determinamos si debemos incluir la opción \"sin selección\" y con qué texto\r\n    if (this.includeEmpty) {\r\n      console.log(\"hay valor empty que hay que traducir para \" + this.nombre);\r\n      this.translateService\r\n        .selectTranslateWithContext(this.emptyText)\r\n        .pipe(take(1))\r\n        .subscribe((translation) => {\r\n          let newOption = {value: null, label: translation };\r\n          newOption[this.atributoValue] = null;\r\n          newOption[this.atributoLabel] = translation;\r\n          this.listaOpcionesVisible.splice(0, 0, newOption);\r\n          this.emptyTextResolved = translation;\r\n          //console.log(\"la lista de opciones vale\", this.listaOpcionesVisible);\r\n        });\r\n    }\r\n  }\r\n\r\n  get value_lectura(): string {\r\n    let val = this.control.value;\r\n    let dom = this.listaOpciones && this.listaOpciones.find((d) => d.value == val);\r\n    return dom ? dom.label : null;\r\n  }\r\n}\r\n","<label *ngIf=\"!hideLabel\">\r\n    <ng-content></ng-content>&nbsp;\r\n    <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span>&nbsp;&nbsp;\r\n    <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\r\n</label>\r\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{value_lectura}}</p>\r\n<ng-container *ngIf=\"!readOnly && !!myForm\">\r\n<div [formGroup]=\"myForm\">\r\n    <p-dropdown\r\n        id=\"{{nombre}}\"\r\n        [options]=\"listaOpcionesVisible\"\r\n        [formControl]=\"control\"\r\n        [filter]=\"filter\"\r\n        \r\n        [optionLabel]=\"atributoLabel\"\r\n        [optionValue]=\"atributoValue\"\r\n        [optionDisabled]=\"atributoDisabled\"\r\n        \r\n        (onFocus)=\"onFocus()\"\r\n        (onBlur)=\"onBlur()\">\r\n        <ng-template let-item pTemplate=\"item\">\r\n            <span [ngClass]=\"{'opcion-desactivada': item[atributoDisabled]}\">{{item[atributoLabel]}}</span>\r\n        </ng-template>\r\n    </p-dropdown>\r\n    <control-messages *ngIf=\"control!=null\" [control]=\"control\" [field]=\"id\"></control-messages>\r\n</div>\r\n</ng-container>\r\n"]}
|
|
@@ -4115,13 +4115,15 @@ class BitDropDownGeneralV2Component extends BitGeneralV2Component {
|
|
|
4115
4115
|
}
|
|
4116
4116
|
}
|
|
4117
4117
|
BitDropDownGeneralV2Component.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: BitDropDownGeneralV2Component, deps: [{ token: i1.ActivatedRoute }, { token: SessionSharedService }, { token: AyudaService }, { token: TranslateService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
4118
|
-
BitDropDownGeneralV2Component.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: BitDropDownGeneralV2Component, inputs: { hideLabel: "hideLabel", data: "data", id: "id", excludedValues: "excludedValues", emptyText: "emptyText", includeEmpty: "includeEmpty" }, usesInheritance: true, ngImport: i0 });
|
|
4118
|
+
BitDropDownGeneralV2Component.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: BitDropDownGeneralV2Component, inputs: { hideLabel: "hideLabel", data: "data", transformDataValueTo: "transformDataValueTo", id: "id", excludedValues: "excludedValues", emptyText: "emptyText", includeEmpty: "includeEmpty" }, usesInheritance: true, ngImport: i0 });
|
|
4119
4119
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: BitDropDownGeneralV2Component, decorators: [{
|
|
4120
4120
|
type: Directive
|
|
4121
4121
|
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: SessionSharedService }, { type: AyudaService }, { type: TranslateService }]; }, propDecorators: { hideLabel: [{
|
|
4122
4122
|
type: Input
|
|
4123
4123
|
}], data: [{
|
|
4124
4124
|
type: Input
|
|
4125
|
+
}], transformDataValueTo: [{
|
|
4126
|
+
type: Input
|
|
4125
4127
|
}], id: [{
|
|
4126
4128
|
type: Input
|
|
4127
4129
|
}], excludedValues: [{
|
|
@@ -4159,6 +4161,11 @@ class BitDropDownComponent extends BitDropDownGeneralV2Component {
|
|
|
4159
4161
|
let changedProp = changes[propName];
|
|
4160
4162
|
if (propName === "data") {
|
|
4161
4163
|
this.listaOpciones = changedProp.currentValue ? changedProp.currentValue.slice() : [];
|
|
4164
|
+
if (this.transformDataValueTo == "number") {
|
|
4165
|
+
this.listaOpciones.forEach(opcion => {
|
|
4166
|
+
opcion[this.atributoValue] = Number(opcion[this.atributoValue]);
|
|
4167
|
+
});
|
|
4168
|
+
}
|
|
4162
4169
|
hayCambios = true;
|
|
4163
4170
|
}
|
|
4164
4171
|
else if (propName === "excludedValues") {
|
|
@@ -4174,6 +4181,35 @@ class BitDropDownComponent extends BitDropDownGeneralV2Component {
|
|
|
4174
4181
|
this.postRetrieveData();
|
|
4175
4182
|
}
|
|
4176
4183
|
}
|
|
4184
|
+
// custom processing after retrieving data array from service
|
|
4185
|
+
postRetrieveData() {
|
|
4186
|
+
console.log("llamando a postRetrieveData para " + this.nombre + "{opciones:" + this.listaOpciones + "}");
|
|
4187
|
+
if (this.listaOpciones) {
|
|
4188
|
+
this.listaOpcionesVisible = Object.assign([], this.listaOpciones);
|
|
4189
|
+
// repasamos si hay opciones a excluir que debamos eliminar
|
|
4190
|
+
if (this.excludedValues) {
|
|
4191
|
+
this.listaOpcionesVisible = this.listaOpcionesVisible.filter((op) => this.excludedValues.indexOf(op.value) < 0);
|
|
4192
|
+
}
|
|
4193
|
+
}
|
|
4194
|
+
else {
|
|
4195
|
+
this.listaOpcionesVisible = [];
|
|
4196
|
+
}
|
|
4197
|
+
// determinamos si debemos incluir la opción "sin selección" y con qué texto
|
|
4198
|
+
if (this.includeEmpty) {
|
|
4199
|
+
console.log("hay valor empty que hay que traducir para " + this.nombre);
|
|
4200
|
+
this.translateService
|
|
4201
|
+
.selectTranslateWithContext(this.emptyText)
|
|
4202
|
+
.pipe(take(1))
|
|
4203
|
+
.subscribe((translation) => {
|
|
4204
|
+
let newOption = { value: null, label: translation };
|
|
4205
|
+
newOption[this.atributoValue] = null;
|
|
4206
|
+
newOption[this.atributoLabel] = translation;
|
|
4207
|
+
this.listaOpcionesVisible.splice(0, 0, newOption);
|
|
4208
|
+
this.emptyTextResolved = translation;
|
|
4209
|
+
//console.log("la lista de opciones vale", this.listaOpcionesVisible);
|
|
4210
|
+
});
|
|
4211
|
+
}
|
|
4212
|
+
}
|
|
4177
4213
|
get value_lectura() {
|
|
4178
4214
|
let val = this.control.value;
|
|
4179
4215
|
let dom = this.listaOpciones && this.listaOpciones.find((d) => d.value == val);
|
|
@@ -4181,10 +4217,10 @@ class BitDropDownComponent extends BitDropDownGeneralV2Component {
|
|
|
4181
4217
|
}
|
|
4182
4218
|
}
|
|
4183
4219
|
BitDropDownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: BitDropDownComponent, deps: [{ token: i1.ActivatedRoute }, { token: SessionSharedService }, { token: AyudaService }, { token: TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
4184
|
-
BitDropDownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: BitDropDownComponent, selector: "bit-dropdown", inputs: { filter: "filter", atributoLabel: "atributoLabel", atributoValue: "atributoValue", atributoDisabled: "atributoDisabled" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<label *ngIf=\"!hideLabel\">\r\n <ng-content></ng-content> \r\n <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span> \r\n <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\r\n</label>\r\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{value_lectura}}</p>\r\n<ng-container *ngIf=\"!readOnly && !!myForm\">\r\n<div [formGroup]=\"myForm\">\r\n <p-dropdown\r\n id=\"{{nombre}}\"\r\n [options]=\"listaOpcionesVisible\"\r\n [formControl]=\"control\"\r\n [filter]=\"filter\"\r\n \r\n [optionLabel]=\"atributoLabel\"\r\n [optionValue]=\"atributoValue\"\r\n [optionDisabled]=\"atributoDisabled\"\r\n \r\n (onFocus)=\"onFocus()\"\r\n (onBlur)=\"onBlur()\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <span [ngClass]=\"{'opcion-desactivada': item
|
|
4220
|
+
BitDropDownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: BitDropDownComponent, selector: "bit-dropdown", inputs: { filter: "filter", atributoLabel: "atributoLabel", atributoValue: "atributoValue", atributoDisabled: "atributoDisabled" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<label *ngIf=\"!hideLabel\">\r\n <ng-content></ng-content> \r\n <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span> \r\n <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\r\n</label>\r\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{value_lectura}}</p>\r\n<ng-container *ngIf=\"!readOnly && !!myForm\">\r\n<div [formGroup]=\"myForm\">\r\n <p-dropdown\r\n id=\"{{nombre}}\"\r\n [options]=\"listaOpcionesVisible\"\r\n [formControl]=\"control\"\r\n [filter]=\"filter\"\r\n \r\n [optionLabel]=\"atributoLabel\"\r\n [optionValue]=\"atributoValue\"\r\n [optionDisabled]=\"atributoDisabled\"\r\n \r\n (onFocus)=\"onFocus()\"\r\n (onBlur)=\"onBlur()\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <span [ngClass]=\"{'opcion-desactivada': item[atributoDisabled]}\">{{item[atributoLabel]}}</span>\r\n </ng-template>\r\n </p-dropdown>\r\n <control-messages *ngIf=\"control!=null\" [control]=\"control\" [field]=\"id\"></control-messages>\r\n</div>\r\n</ng-container>\r\n", components: [{ type: i3$3.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "virtualScroll", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "disabled", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear"] }, { type: BitControlMessages, selector: "control-messages", inputs: ["control", "field"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i5$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2$2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
|
|
4185
4221
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: BitDropDownComponent, decorators: [{
|
|
4186
4222
|
type: Component,
|
|
4187
|
-
args: [{ selector: "bit-dropdown", template: "<label *ngIf=\"!hideLabel\">\r\n <ng-content></ng-content> \r\n <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span> \r\n <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\r\n</label>\r\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{value_lectura}}</p>\r\n<ng-container *ngIf=\"!readOnly && !!myForm\">\r\n<div [formGroup]=\"myForm\">\r\n <p-dropdown\r\n id=\"{{nombre}}\"\r\n [options]=\"listaOpcionesVisible\"\r\n [formControl]=\"control\"\r\n [filter]=\"filter\"\r\n \r\n [optionLabel]=\"atributoLabel\"\r\n [optionValue]=\"atributoValue\"\r\n [optionDisabled]=\"atributoDisabled\"\r\n \r\n (onFocus)=\"onFocus()\"\r\n (onBlur)=\"onBlur()\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <span [ngClass]=\"{'opcion-desactivada': item
|
|
4223
|
+
args: [{ selector: "bit-dropdown", template: "<label *ngIf=\"!hideLabel\">\r\n <ng-content></ng-content> \r\n <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span> \r\n <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\r\n</label>\r\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{value_lectura}}</p>\r\n<ng-container *ngIf=\"!readOnly && !!myForm\">\r\n<div [formGroup]=\"myForm\">\r\n <p-dropdown\r\n id=\"{{nombre}}\"\r\n [options]=\"listaOpcionesVisible\"\r\n [formControl]=\"control\"\r\n [filter]=\"filter\"\r\n \r\n [optionLabel]=\"atributoLabel\"\r\n [optionValue]=\"atributoValue\"\r\n [optionDisabled]=\"atributoDisabled\"\r\n \r\n (onFocus)=\"onFocus()\"\r\n (onBlur)=\"onBlur()\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <span [ngClass]=\"{'opcion-desactivada': item[atributoDisabled]}\">{{item[atributoLabel]}}</span>\r\n </ng-template>\r\n </p-dropdown>\r\n <control-messages *ngIf=\"control!=null\" [control]=\"control\" [field]=\"id\"></control-messages>\r\n</div>\r\n</ng-container>\r\n" }]
|
|
4188
4224
|
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: SessionSharedService }, { type: AyudaService }, { type: TranslateService }]; }, propDecorators: { filter: [{
|
|
4189
4225
|
type: Input
|
|
4190
4226
|
}], atributoLabel: [{
|