bit-ng-library 13.1.0 → 13.1.3
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 +16 -5
- package/esm2020/lib/sharedlibrary/components/footer/bit-footer.component.mjs +18 -8
- package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.mjs +19 -14
- package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown-multiple.component.mjs +33 -14
- package/esm2020/lib/sharedlibrary/services/custom-validators.service.mjs +39 -31
- package/fesm2015/bit-ng-library.mjs +98 -55
- package/fesm2015/bit-ng-library.mjs.map +1 -1
- package/fesm2020/bit-ng-library.mjs +97 -54
- package/fesm2020/bit-ng-library.mjs.map +1 -1
- package/lib/sharedlibrary/components/footer/bit-footer.component.d.ts +1 -0
- package/lib/sharedlibrary/components/footer/bit-footer.component.d.ts.map +1 -1
- package/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.d.ts +1 -0
- package/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.d.ts.map +1 -1
- package/lib/sharedlibrary/components/form/dropdown/bit-dropdown-multiple.component.d.ts +4 -5
- package/lib/sharedlibrary/components/form/dropdown/bit-dropdown-multiple.component.d.ts.map +1 -1
- package/lib/sharedlibrary/services/custom-validators.service.d.ts +1 -1
- package/lib/sharedlibrary/services/custom-validators.service.d.ts.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -26,17 +26,28 @@ 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
|
-
|
|
30
|
-
## [13.0.2] - 2022-02-03
|
|
29
|
+
## [13.1.3] - 2022-05-18
|
|
31
30
|
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
31
|
+
Corregido bug en el bit-dropdown-multiple, por el cual no se resolvía el label por defecto y aparecía el código de etiqueta.
|
|
32
|
+
|
|
33
|
+
## [13.1.2] - 2022-05-09
|
|
34
|
+
|
|
35
|
+
Corregido bug en bit-footer al volver de un formulario a la lista, momento en que desaparecía el footer. (la solución completa del bug requiere de cambios en base-list-filter.component.ts de los proyectos)
|
|
36
|
+
|
|
37
|
+
## [13.1.1] - 2022-02-22
|
|
38
|
+
|
|
39
|
+
Corregido bug de CustomValidators cuando se usaba en forms con diversos campos de longitud limitada. Se mostraba siempre el mismo mensaje para todos, aunque se especificase un validador con longitud diferente en cada campo.
|
|
35
40
|
|
|
36
41
|
## [13.1.0] - 2022-02-03
|
|
37
42
|
|
|
38
43
|
Incluir el nuevo tipo de bit-footer para las páginas con infinity-scroll en la rama angular 13
|
|
39
44
|
|
|
45
|
+
## [13.0.2] - 2022-02-03
|
|
46
|
+
|
|
47
|
+
Se añade allowSyntheticDefaultImports a true en las opciones de compilacion de tsconfig para que se importe correctamente la librería
|
|
48
|
+
moment. También se modifica la forma de importar en el código pasando a import momento from 'moment' en vez de import \* as moment from
|
|
49
|
+
'moment'
|
|
50
|
+
|
|
40
51
|
## [13.0.1] - 2022-02-03
|
|
41
52
|
|
|
42
53
|
Se elimina moment-mini-ts al presentar problemas de carga con angular 13
|
|
@@ -80,7 +80,9 @@ export class BitFooterComponent {
|
|
|
80
80
|
if (propName === "totalItems") {
|
|
81
81
|
this.totalItems = changedProp.currentValue;
|
|
82
82
|
console.log(`new totalItems ${this.totalItems}`);
|
|
83
|
-
changedProp.previousValue !== changedProp.currentValue
|
|
83
|
+
if (changedProp.previousValue !== changedProp.currentValue) {
|
|
84
|
+
this.calculatePageLinkSize(); //recalculamos
|
|
85
|
+
}
|
|
84
86
|
this.maxCurrentItems = this.filter ? this.filter.pagina * this.filter.resultados : -1;
|
|
85
87
|
}
|
|
86
88
|
else if (propName === "filter") {
|
|
@@ -89,7 +91,12 @@ export class BitFooterComponent {
|
|
|
89
91
|
this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;
|
|
90
92
|
}
|
|
91
93
|
console.log(`new filter ${this.filter?.pagina} - ${this.maxCurrentItems}`);
|
|
92
|
-
changedProp.previousValue !== changedProp.currentValue
|
|
94
|
+
if (changedProp.previousValue !== changedProp.currentValue) {
|
|
95
|
+
this.calculatePageLinkSize(); //recalculamos
|
|
96
|
+
if (!this.filter?.pagina || this.filter.pagina <= 1) {
|
|
97
|
+
this.goToFirstPage();
|
|
98
|
+
}
|
|
99
|
+
}
|
|
93
100
|
}
|
|
94
101
|
}
|
|
95
102
|
if (this.pc && this.changeRef) {
|
|
@@ -117,11 +124,7 @@ export class BitFooterComponent {
|
|
|
117
124
|
//notificamos que los elementos por página han cambiado
|
|
118
125
|
this.onNewPageSize.emit(event.rows);
|
|
119
126
|
this.itemsPerPage = event.rows;
|
|
120
|
-
|
|
121
|
-
//volvemos a la primera página
|
|
122
|
-
this.pc._first = 1;
|
|
123
|
-
this.pc.updatePageLinks();
|
|
124
|
-
}
|
|
127
|
+
this.goToFirstPage();
|
|
125
128
|
this.calculatePageLinkSize(); // recalculamos el número de enlaces de página
|
|
126
129
|
}
|
|
127
130
|
else {
|
|
@@ -129,6 +132,13 @@ export class BitFooterComponent {
|
|
|
129
132
|
this.onPageChange.emit(event.page + 1);
|
|
130
133
|
}
|
|
131
134
|
}
|
|
135
|
+
goToFirstPage() {
|
|
136
|
+
if (this.pc) {
|
|
137
|
+
//volvemos a la primera página
|
|
138
|
+
this.pc._first = 1;
|
|
139
|
+
this.pc.updatePageLinks();
|
|
140
|
+
}
|
|
141
|
+
}
|
|
132
142
|
getStyle() {
|
|
133
143
|
if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {
|
|
134
144
|
if (this.totalItems > 0) {
|
|
@@ -251,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
251
261
|
}], onNewPageSize: [{
|
|
252
262
|
type: Output
|
|
253
263
|
}] } });
|
|
254
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-footer.component.js","sourceRoot":"","sources":["../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/footer/bit-footer.component.ts","../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/footer/bit-footer.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,EAEN,SAAS,EACV,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,oBAAoB,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AACpF,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;;;;;;;AAIpD;;IAEI;AAMJ,MAAM,OAAO,kBAAkB;IAyC7B,YAAoB,gBAAkC,EAClC,SAA4B;QAD5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,cAAS,GAAT,SAAS,CAAmB;QAzBhD,kBAAa,GAAY,IAAI,CAAC;QAE9B,UAAK,GAAY,IAAI,CAAC,CAAC,mEAAmE;QAQ1F,0BAAqB,GAAY,IAAI,CAAC;QAEtC,+BAA0B,GAAY,IAAI,CAAC;QAE3C,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC,CAAC,+CAA+C;QAE1F,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC,CAAC,8DAA8D;QAE1G,qBAAgB,GAAW,UAAU,CAAC,eAAe,CAAC,CAAC,wGAAwG;QAE/J,iBAAY,GAAW,UAAU,CAAC,eAAe,CAAC,CAAC,+CAA+C;QAElG,oBAAe,GAAW,CAAC,CAAC,CAAC;IAI7B,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,UAAU,IAAI,SAAS,EAAE;YAChC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;SAC1B;QACD,IAAI,IAAI,CAAC,SAAS,IAAI,SAAS,EAAE;YAC/B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;SACxB;QACD,6CAA6C;QAC7C,IAAI,IAAI,CAAC,QAAQ,IAAI,SAAS,EAAE;YAC9B,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,EAAE,2BAA2B,CAAC,CAAC;SAClE;IACH,CAAC;IAEO,WAAW;QACjB,OAAO,CAAC,GAAG,CAAC,sDAAsD,CAAC,CAAC;QACpE,IAAI,CAAC,QAAQ,GAAG,IAAI,GAAG,EAAsB,CAAC;QAC9C,IAAI,IAAI,CAAC,YAAY,EAAE,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE;YAChD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,EAAE,+BAA+B,CAAC,CAAC;YACpE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,SAAS,EAAE,oCAAoC,CAAC,CAAC;YAC9E,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,WAAW,EAAE,sCAAsC,CAAC,CAAC;YAClF,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,YAAY,EAAE,uCAAuC,CAAC,CAAC;YACpF,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,YAAY,EAAE,sCAAsC,CAAC,CAAA;SAC3F;aAAM,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE;YAC9B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,EAAE,+BAA+B,CAAC,CAAC;YACpE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,SAAS,EAAE,oCAAoC,CAAC,CAAC;YAC9E,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,YAAY,EAAE,uCAAuC,CAAC,CAAC;YACpF,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,QAAQ,EAAE,mCAAmC,CAAC,CAAC;SAC7E;aAAM,IAAI,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,UAAU,EAAE;YAC5D,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;SACrC;IACH,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,IAAI,IAAI,CAAC,EAAE,EAAE;YACX,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;YAC3C,OAAO,CAAC,GAAG,CAAC,0BAA0B,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,CAAC;YAChE,OAAO,CAAC,GAAG,CAAC,sBAAsB,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;YACxD,IAAI,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;YACtC,IAAI,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC;YACzD,IAAI,CAAC,EAAE,CAAC,eAAe,EAAE,CAAC;SAC3B;IACH,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,OAA4C;QACtD,KAAK,IAAI,QAAQ,IAAI,OAAO,EAAE;YAC5B,IAAI,WAAW,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;YACpC,IAAI,QAAQ,KAAK,YAAY,EAAE;gBAC7B,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,YAAY,CAAC;gBAC3C,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;gBACjD,WAAW,CAAC,aAAa,KAAK,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,cAAc;gBACjH,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aACvF;iBAAM,IAAI,QAAQ,KAAK,QAAQ,EAAE;gBAChC,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,YAAY,CAAC;gBACvC,IAAI,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI,CAAC,eAAe,EAAE;oBACxE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC;iBACtE;gBACD,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,MAAM,EAAE,MAAM,MAAM,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;gBAC3E,WAAW,CAAC,aAAa,KAAK,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,cAAc;aAClH;SACF;QACD,IAAI,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,SAAS,EAAE;YAC7B,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;YAC/B,IAAI,CAAC,EAAE,CAAC,eAAe,EAAE,CAAC;YAC1B,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC;SAChC;IACH,CAAC;IAED,0GAA0G;IAC1G,qBAAqB;QACnB,OAAO,CAAC,GAAG,CAAC,qCAAqC,IAAI,CAAC,UAAU,iBAAiB,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QACtG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;QACnE,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,EAAE;YACzB,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;SACvB;QACD,IAAI,IAAI,CAAC,YAAY,GAAG,oBAAoB,EAAE;YAC5C,IAAI,CAAC,YAAY,GAAG,oBAAoB,CAAC;SAC1C;IACH,CAAC;IAED,+JAA+J;IAC/J,QAAQ,CAAC,KAAU;QACjB,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAI,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC,YAAY,EAAE;YACpC,iDAAiD;YACjD,uDAAuD;YACvD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACpC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC;YAC/B,IAAI,IAAI,CAAC,EAAE,EAAE;gBACX,8BAA8B;gBAC9B,IAAI,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC;gBACnB,IAAI,CAAC,EAAE,CAAC,eAAe,EAAE,CAAC;aAC3B;YACD,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC,8CAA8C;SAC7E;aAAM;YACL,uDAAuD;YACvD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;SACxC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,SAAS,IAAI,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,WAAW,EAAE;YACxH,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,EAAE;gBACvB,OAAO,4BAA4B,CAAC;aACrC;iBAAM;gBACL,OAAO,+BAA+B,CAAC;aACxC;SACF;aAAM,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,SAAS,EAAE;YACzE,OAAO,iCAAiC,CAAC;SAC1C;aAAM;YACL,OAAO,QAAQ,CAAC;SACjB;IACH,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,SAAS,CAAC;IAC1D,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,WAAW,CAAC;IAC5D,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,SAAS,CAAC;IAC1D,CAAC;IAED,mDAAmD;IACnD,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,MAAM,KAAK,UAAU,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,IAAI,UAAU,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;IAC5F,CAAC;IAED,mDAAmD;IACnD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,MAAM,KAAK,UAAU,CAAC,SAAS,CAAC;IAC9C,CAAC;IAED,wDAAwD;IACxD,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,MAAM,KAAK,UAAU,CAAC,YAAY,CAAC;IACjD,CAAC;IAED,gDAAgD;IAChD,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,MAAM,IAAI,UAAU,CAAC,QAAQ,CAAC;IAC5C,CAAC;IAED,8CAA8C;IAC9C,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,IAAI,UAAU,CAAC,KAAK,CAAC;IACzC,CAAC;IAED,kCAAkC;IAClC,IAAI,WAAW;QACb,OAAO,CACL,IAAI,CAAC,MAAM,KAAK,UAAU,CAAC,YAAY;YACvC,CAAC,CAAC,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,SAAS,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;mBACrE,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,SAAS;mBAChD,CAAC,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,WAAW,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,eAAe,CAAC,CAAC,CACtG,CAAC;IACJ,CAAC;IAED,yCAAyC;IACzC,IAAI,WAAW;QACb,OAAO,CACL,IAAI,CAAC,MAAM,KAAK,UAAU,CAAC,YAAY;YACvC,CAAC,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,WAAW,IAAI,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,CAC/F,CAAC;IACJ,CAAC;IAED,+BAA+B;IAC/B,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,MAAM,KAAK,UAAU,CAAC,YAAY,IAAI,IAAI,CAAC,UAAU,KAAK,CAAC,CAAC;IAC1E,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;IACnF,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;IACxF,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,CAAC;IAC3F,CAAC;IAED,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC,CAAC;IACnG,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC;IAC1F,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;IACvF,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;IACpF,CAAC;;AA3Pa,4BAAS,GAAW,MAAO,CAAA;AAC3B,8BAAW,GAAW,QAAS,CAAA;AAC/B,4BAAS,GAAW,MAAO,CAAA;AAC3B,6BAAU,GAAW,OAAQ,CAAA;AAE7B,+BAAY,GAAG,CAAC,CAAE,CAAA;+GANrB,kBAAkB;mGAAlB,kBAAkB,kiBC3B/B,y/GA2EA;2FDhDa,kBAAkB;kBAL9B,SAAS;+BACE,YAAY,mBACL,uBAAuB,CAAC,MAAM;uIAY/C,EAAE;sBADD,SAAS;uBAAC,IAAI;gBAGf,UAAU;sBADT,KAAK;gBAGN,MAAM;sBADL,KAAK;gBAGN,SAAS;sBADR,KAAK;gBAGN,aAAa;sBADZ,KAAK;gBAGN,KAAK;sBADJ,KAAK;gBAGN,QAAQ;sBADP,KAAK;gBAGN,MAAM;sBADL,KAAK;gBAGN,UAAU;sBADT,KAAK;uBAAC,MAAM;gBAGb,qBAAqB;sBADpB,KAAK;gBAGN,0BAA0B;sBADzB,KAAK;gBAGN,YAAY;sBADX,MAAM;gBAGP,aAAa;sBADZ,MAAM","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  SimpleChange,\r\n  ViewChild\r\n} from \"@angular/core\";\r\nimport {Paginator} from \"primeng/paginator\";\r\nimport {Observable} from \"rxjs\";\r\nimport { BASE_RESULTADOS_PAGE, BaseFilter } from '../../../base/shared/base.filter';\r\nimport { PageStatus } from '../../global.constants';\r\nimport { TranslateService } from '../../services';\r\n\r\n\r\n/**\r\n * Componente que muestra un paginador en la sección footer.\r\n **/\r\n@Component({\r\n  selector: \"bit-footer\",\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  templateUrl: \"bit-footer.component.html\"\r\n})\r\nexport class BitFooterComponent implements OnInit, OnChanges {\r\n  public static TYPE_LIST: string = \"list\";\r\n  public static TYPE_SCROLL: string = \"scroll\";\r\n  public static TYPE_FORM: string = \"form\";\r\n  public static TYPE_BLANK: string = \"blank\";\r\n\r\n  public static MORE_RESULTS = -1;\r\n\r\n  @ViewChild(\"pc\")\r\n  pc: Paginator;\r\n  @Input()\r\n  totalItems: number;     // Número total de elementos recuperados de la consulta\r\n  @Input()\r\n  filter: BaseFilter;\r\n  @Input()\r\n  paginator: boolean;\r\n  @Input()\r\n  mostrarAvisos: boolean = true;\r\n  @Input()\r\n  fixed: boolean = true; // Indicará si lo queremos fijo abajo en la página. Por defecto sí.\r\n  @Input()\r\n  messages: Map<PageStatus, string>;\r\n  @Input()\r\n  status: PageStatus; // Determina en qué estado está la página: PageStatus.Init, PageStatus.SEARCHING, PageStatus.FINISH_SEARCH\r\n  @Input(\"type\")\r\n  typeFooter: string;\r\n  @Input()\r\n  mostrarEnlacesPaginas: boolean = true;\r\n  @Input()\r\n  mostrarPrimeraUltimaPagina: boolean = true;\r\n  @Output()\r\n  onPageChange = new EventEmitter<number>(); //para notificar cambios en la página a mostrar\r\n  @Output()\r\n  onNewPageSize = new EventEmitter<number>(); //para notificar cambios en los elementos a mostrar por página\r\n\r\n  baseItemsPerPage: number = BaseFilter.RESULTADOS_PAGE; // guardamos el número de resultados pre-configurados por página para mostrar la lista de x, x+10 y x+20\r\n  pageLinkSize: number; // número de enlaces en el paginador para poder navegar hacia delante o detrás\r\n  itemsPerPage: number = BaseFilter.RESULTADOS_PAGE; // número de elementos por página que mostramos\r\n\r\n  maxCurrentItems: number = -1;\r\n\r\n  constructor(private translateService: TranslateService,\r\n              private changeRef: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.typeFooter == undefined) {\r\n      this.typeFooter = \"list\";\r\n    }\r\n    if (this.paginator == undefined) {\r\n      this.paginator = false;\r\n    }\r\n    //mensajes por defecto si no vienen definidos\r\n    if (this.messages == undefined) {\r\n      this.setMessages();\r\n      this.messages.set(PageStatus.Error, \"bitnglibrary.footer.error\");\r\n    }\r\n  }\r\n\r\n  private setMessages() {\r\n    console.log(\"definimos los mensajes del footer de manera estándar\");\r\n    this.messages = new Map<PageStatus, string>();\r\n    if (this.isFooterList() || this.isFooterScroll()) {\r\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.list.init\");\r\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.list.searching\");\r\n      this.messages.set(PageStatus.EmptyResult, \"bitnglibrary.footer.list.emptyresult\");\r\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.list.finishsearch\");\r\n      this.messages.set(BitFooterComponent.MORE_RESULTS, \"bitnglibrary.footer.list.moreresults\")\r\n    } else if (this.isFooterForm()) {\r\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.form.init\");\r\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.form.searching\");\r\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.form.finishsearch\");\r\n      this.messages.set(PageStatus.ReadOnly, \"bitnglibrary.footer.list.readonly\");\r\n    } else if (this.typeFooter === BitFooterComponent.TYPE_BLANK) {\r\n      console.log(\"the footer is BLANK!\");\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cuando tengamos la referencia al componente paginator actualizamos internamente el número de página y el número de páginas\r\n   * del desplegable con la información del filtro proporcionado\r\n   */\r\n  ngAfterViewInit() {\r\n    if (this.pc) {\r\n      this.itemsPerPage = this.filter.resultados;\r\n      console.log(`this.filter.resultados ${this.filter.resultados}`);\r\n      console.log(`this.filter.pagina ${this.filter.pagina}`);\r\n      this.pc.rows = this.filter.resultados;\r\n      this.pc._first = (this.filter.pagina - 1) * this.pc.rows;\r\n      this.pc.updatePageLinks();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Escucharemos a cambios en las propiedades totalItems para actualizar el paginador con respecto a las páginas que mostramos\r\n   */\r\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\r\n    for (let propName in changes) {\r\n      let changedProp = changes[propName];\r\n      if (propName === \"totalItems\") {\r\n        this.totalItems = changedProp.currentValue;\r\n        console.log(`new totalItems ${this.totalItems}`);\r\n        changedProp.previousValue !== changedProp.currentValue ? this.calculatePageLinkSize() : undefined; //recalculamos\r\n        this.maxCurrentItems = this.filter ? this.filter.pagina * this.filter.resultados : -1;\r\n      } else if (propName === \"filter\") {\r\n        this.filter = changedProp.currentValue;\r\n        if (this.filter?.pagina * this.filter?.resultados > this.maxCurrentItems) {\r\n          this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;\r\n        }\r\n        console.log(`new filter ${this.filter?.pagina} - ${this.maxCurrentItems}`);\r\n        changedProp.previousValue !== changedProp.currentValue ? this.calculatePageLinkSize() : undefined; //recalculamos\r\n      }\r\n    }\r\n    if (this.pc && this.changeRef) {\r\n      console.log('updatePageLinks');\r\n      this.pc.updatePageLinks();\r\n      this.changeRef.detectChanges();\r\n    }\r\n  }\r\n\r\n  /** Calcula el número de enlaces visibles en el paginador (en el rango entre 1 y BASE_RESULTADOS_PAGE). */\r\n  calculatePageLinkSize() {\r\n    console.log(`calculatePageLinkSize totalItems: ${this.totalItems} itemsPerPage:${this.itemsPerPage}`);\r\n    this.pageLinkSize = Math.ceil(this.totalItems / this.itemsPerPage);\r\n    if (this.pageLinkSize < 1) {\r\n      this.pageLinkSize = 1;\r\n    }\r\n    if (this.pageLinkSize > BASE_RESULTADOS_PAGE) {\r\n      this.pageLinkSize = BASE_RESULTADOS_PAGE;\r\n    }\r\n  }\r\n\r\n  /** Establece el número de página en la visualización de resultados. Se invoca cuando el usuario cambia el número de resultados a mostrar o cambia de página */\r\n  paginate(event: any): void {\r\n    console.log(\"Page changed to\", event.page);\r\n    if (event.rows !== this.itemsPerPage) {\r\n      // han cambiado el número de elementos por página\r\n      //notificamos que los elementos por página han cambiado\r\n      this.onNewPageSize.emit(event.rows);\r\n      this.itemsPerPage = event.rows;\r\n      if (this.pc) {\r\n        //volvemos a la primera página\r\n        this.pc._first = 1;\r\n        this.pc.updatePageLinks();\r\n      }\r\n      this.calculatePageLinkSize(); // recalculamos el número de enlaces de página\r\n    } else {\r\n      // notificamos a nuestro papá que la página ha cambiado\r\n      this.onPageChange.emit(event.page + 1);\r\n    }\r\n  }\r\n\r\n  getStyle() {\r\n    if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {\r\n      if (this.totalItems > 0) {\r\n        return \"footer navbar-fixed-bottom\";\r\n      } else {\r\n        return \"footer navbar-fixed-bottom-60\";\r\n      }\r\n    } else if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_FORM) {\r\n      return \"footer navbar-fixed-bottom-form\";\r\n    } else {\r\n      return \"footer\";\r\n    }\r\n  }\r\n\r\n  isFooterList() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_LIST;\r\n  }\r\n\r\n  isFooterScroll() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_SCROLL;\r\n  }\r\n\r\n  isFooterForm() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_FORM;\r\n  }\r\n\r\n  /** Flag: la página está realizando la búsqueda. */\r\n  get searchInitiated() {\r\n    return this.status === PageStatus.Init || this.status == PageStatus.Reset || !this.status;\r\n  }\r\n\r\n  /** Flag: la página está realizando la búsqueda. */\r\n  get searching() {\r\n    return this.status === PageStatus.Searching;\r\n  }\r\n\r\n  /** Flag: la página ha finalizado la última búsqueda. */\r\n  get searchFinished() {\r\n    return this.status === PageStatus.FinishSearch;\r\n  }\r\n\r\n  /** Flag: la página está en modo solo lectura */\r\n  get readOnly() {\r\n    return this.status == PageStatus.ReadOnly;\r\n  }\r\n\r\n  /** Flag: la página ha finalizado con error */\r\n  get error() {\r\n    return this.status == PageStatus.Error;\r\n  }\r\n\r\n  /** Flag: encontrado resultado. */\r\n  get foundResult() {\r\n    return (\r\n      this.status === PageStatus.FinishSearch &&\r\n      ((this.typeFooter === BitFooterComponent.TYPE_LIST && this.totalItems > 0)\r\n        || this.typeFooter === BitFooterComponent.TYPE_FORM\r\n        || (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems <= this.maxCurrentItems))\r\n    );\r\n  }\r\n\r\n  /** Flag: hay más resultados (scroll). */\r\n  get moreResults() {\r\n    return (\r\n      this.status === PageStatus.FinishSearch &&\r\n      (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems > this.maxCurrentItems)\r\n    );\r\n  }\r\n\r\n  /** Flag: no hay resultados. */\r\n  get emptyResult() {\r\n    return this.status === PageStatus.FinishSearch && this.totalItems === 0;\r\n  }\r\n\r\n  get initMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Init));\r\n  }\r\n\r\n  get searchingMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Searching));\r\n  }\r\n\r\n  get finishMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.FinishSearch));\r\n  }\r\n\r\n  get moreResultsMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(BitFooterComponent.MORE_RESULTS));\r\n  }\r\n\r\n  get emptyMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.EmptyResult));\r\n  }\r\n\r\n  get readOnlyMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.ReadOnly));\r\n  }\r\n\r\n  get errorMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Error));\r\n  }\r\n}\r\n","<footer [class]=\"getStyle()\">\r\n  <div class=\"grid\">\r\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"typeFooter === 'list'\" [hidden]=\"!this.status || emptyResult\">\r\n      <div class=\"numero-resultados\">\r\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\r\n        <span>{{totalItems}}</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"typeFooter === 'scroll'\" [hidden]=\"!this.status || emptyResult\">\r\n      <div class=\"numero-resultados-scroll\">\r\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\r\n        <span *ngIf=\"maxCurrentItems >= totalItems\">{{totalItems}}</span>\r\n        <span *ngIf=\"maxCurrentItems < totalItems\">{{maxCurrentItems}} / {{totalItems}}</span>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"col-12 md:col-7 lg:col-7 p-text-center\" *ngIf=\"typeFooter === 'list'\"\r\n         [hidden]=\"!this.status || emptyResult\">\r\n      <p-paginator *ngIf=\"paginator\" #pc\r\n                   [rows]=\"itemsPerPage\"\r\n                   [totalRecords]=\"totalItems\"\r\n                   [pageLinkSize]=\"mostrarEnlacesPaginas ? pageLinkSize : 1\"\r\n                   [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\r\n                   [showPageLinks]=\"true\"\r\n                   [showJumpToPageDropdown]=\"false\"\r\n                   [showFirstLastIcon]=\"mostrarPrimeraUltimaPagina ? true : maxCurrentItems >= totalItems\"\r\n                   (onPageChange)=\"paginate($event)\"></p-paginator>\r\n    </div>\r\n    <div class=\"col-12 md:col-3 lg:col-3\">\r\n      <div *ngIf=\"searchInitiated\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{initMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"searching\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{searchingMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"readOnly\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{readOnlyMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"foundResult\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{finishMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"moreResults\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{moreResultsMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"emptyResult\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-exclamation\"></i>\r\n        <span>{{emptyMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"error\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-exclamation-triangle\"></i>\r\n        <span>{{errorMessage | async}}</span>\r\n      </div>\r\n\r\n      <bit-help></bit-help>\r\n    </div>\r\n  </div>\r\n</footer>\r\n"]}
|
|
264
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-footer.component.js","sourceRoot":"","sources":["../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/footer/bit-footer.component.ts","../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/footer/bit-footer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  SimpleChange,\r\n  ViewChild\r\n} from \"@angular/core\";\r\nimport {Paginator} from \"primeng/paginator\";\r\nimport {Observable} from \"rxjs\";\r\nimport { BASE_RESULTADOS_PAGE, BaseFilter } from '../../../base/shared/base.filter';\r\nimport { PageStatus } from '../../global.constants';\r\nimport { TranslateService } from '../../services';\r\n\r\n\r\n/**\r\n * Componente que muestra un paginador en la sección footer.\r\n **/\r\n@Component({\r\n  selector: \"bit-footer\",\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  templateUrl: \"bit-footer.component.html\"\r\n})\r\nexport class BitFooterComponent implements OnInit, OnChanges {\r\n  public static TYPE_LIST: string = \"list\";\r\n  public static TYPE_SCROLL: string = \"scroll\";\r\n  public static TYPE_FORM: string = \"form\";\r\n  public static TYPE_BLANK: string = \"blank\";\r\n\r\n  public static MORE_RESULTS = -1;\r\n\r\n  @ViewChild(\"pc\")\r\n  pc: Paginator;\r\n  @Input()\r\n  totalItems: number;     // Número total de elementos recuperados de la consulta\r\n  @Input()\r\n  filter: BaseFilter;\r\n  @Input()\r\n  paginator: boolean;\r\n  @Input()\r\n  mostrarAvisos: boolean = true;\r\n  @Input()\r\n  fixed: boolean = true; // Indicará si lo queremos fijo abajo en la página. Por defecto sí.\r\n  @Input()\r\n  messages: Map<PageStatus, string>;\r\n  @Input()\r\n  status: PageStatus; // Determina en qué estado está la página: PageStatus.Init, PageStatus.SEARCHING, PageStatus.FINISH_SEARCH\r\n  @Input(\"type\")\r\n  typeFooter: string;\r\n  @Input()\r\n  mostrarEnlacesPaginas: boolean = true;\r\n  @Input()\r\n  mostrarPrimeraUltimaPagina: boolean = true;\r\n  @Output()\r\n  onPageChange = new EventEmitter<number>(); //para notificar cambios en la página a mostrar\r\n  @Output()\r\n  onNewPageSize = new EventEmitter<number>(); //para notificar cambios en los elementos a mostrar por página\r\n\r\n  baseItemsPerPage: number = BaseFilter.RESULTADOS_PAGE; // guardamos el número de resultados pre-configurados por página para mostrar la lista de x, x+10 y x+20\r\n  pageLinkSize: number; // número de enlaces en el paginador para poder navegar hacia delante o detrás\r\n  itemsPerPage: number = BaseFilter.RESULTADOS_PAGE; // número de elementos por página que mostramos\r\n\r\n  maxCurrentItems: number = -1;\r\n\r\n  constructor(private translateService: TranslateService,\r\n              private changeRef: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.typeFooter == undefined) {\r\n      this.typeFooter = \"list\";\r\n    }\r\n    if (this.paginator == undefined) {\r\n      this.paginator = false;\r\n    }\r\n    //mensajes por defecto si no vienen definidos\r\n    if (this.messages == undefined) {\r\n      this.setMessages();\r\n      this.messages.set(PageStatus.Error, \"bitnglibrary.footer.error\");\r\n    }\r\n  }\r\n\r\n  private setMessages() {\r\n    console.log(\"definimos los mensajes del footer de manera estándar\");\r\n    this.messages = new Map<PageStatus, string>();\r\n    if (this.isFooterList() || this.isFooterScroll()) {\r\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.list.init\");\r\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.list.searching\");\r\n      this.messages.set(PageStatus.EmptyResult, \"bitnglibrary.footer.list.emptyresult\");\r\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.list.finishsearch\");\r\n      this.messages.set(BitFooterComponent.MORE_RESULTS, \"bitnglibrary.footer.list.moreresults\")\r\n    } else if (this.isFooterForm()) {\r\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.form.init\");\r\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.form.searching\");\r\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.form.finishsearch\");\r\n      this.messages.set(PageStatus.ReadOnly, \"bitnglibrary.footer.list.readonly\");\r\n    } else if (this.typeFooter === BitFooterComponent.TYPE_BLANK) {\r\n      console.log(\"the footer is BLANK!\");\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cuando tengamos la referencia al componente paginator actualizamos internamente el número de página y el número de páginas\r\n   * del desplegable con la información del filtro proporcionado\r\n   */\r\n  ngAfterViewInit() {\r\n    if (this.pc) {\r\n      this.itemsPerPage = this.filter.resultados;\r\n      console.log(`this.filter.resultados ${this.filter.resultados}`);\r\n      console.log(`this.filter.pagina ${this.filter.pagina}`);\r\n      this.pc.rows = this.filter.resultados;\r\n      this.pc._first = (this.filter.pagina - 1) * this.pc.rows;\r\n      this.pc.updatePageLinks();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Escucharemos a cambios en las propiedades totalItems para actualizar el paginador con respecto a las páginas que mostramos\r\n   */\r\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\r\n    for (let propName in changes) {\r\n      let changedProp = changes[propName];\r\n      if (propName === \"totalItems\") {\r\n        this.totalItems = changedProp.currentValue;\r\n        console.log(`new totalItems ${this.totalItems}`);\r\n        if (changedProp.previousValue !== changedProp.currentValue) {\r\n          this.calculatePageLinkSize();     //recalculamos\r\n        }\r\n        this.maxCurrentItems = this.filter ? this.filter.pagina * this.filter.resultados : -1;\r\n      } else if (propName === \"filter\") {\r\n        this.filter = changedProp.currentValue;\r\n        if (this.filter?.pagina * this.filter?.resultados > this.maxCurrentItems) {\r\n          this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;\r\n        }\r\n        console.log(`new filter ${this.filter?.pagina} - ${this.maxCurrentItems}`);\r\n        if (changedProp.previousValue !== changedProp.currentValue) {\r\n          this.calculatePageLinkSize();     //recalculamos\r\n          if (!this.filter?.pagina || this.filter.pagina <= 1) {\r\n            this.goToFirstPage();\r\n          }\r\n        }\r\n      }\r\n    }\r\n    if (this.pc && this.changeRef) {\r\n      console.log('updatePageLinks');\r\n      this.pc.updatePageLinks();\r\n      this.changeRef.detectChanges();\r\n    }\r\n  }\r\n\r\n  /** Calcula el número de enlaces visibles en el paginador (en el rango entre 1 y BASE_RESULTADOS_PAGE). */\r\n  calculatePageLinkSize() {\r\n    console.log(`calculatePageLinkSize totalItems: ${this.totalItems} itemsPerPage:${this.itemsPerPage}`);\r\n    this.pageLinkSize = Math.ceil(this.totalItems / this.itemsPerPage);\r\n    if (this.pageLinkSize < 1) {\r\n      this.pageLinkSize = 1;\r\n    }\r\n    if (this.pageLinkSize > BASE_RESULTADOS_PAGE) {\r\n      this.pageLinkSize = BASE_RESULTADOS_PAGE;\r\n    }\r\n  }\r\n\r\n  /** Establece el número de página en la visualización de resultados. Se invoca cuando el usuario cambia el número de resultados a mostrar o cambia de página */\r\n  paginate(event: any): void {\r\n    console.log(\"Page changed to\", event.page);\r\n    if (event.rows !== this.itemsPerPage) {\r\n      // han cambiado el número de elementos por página\r\n      //notificamos que los elementos por página han cambiado\r\n      this.onNewPageSize.emit(event.rows);\r\n      this.itemsPerPage = event.rows;\r\n      this.goToFirstPage();\r\n      this.calculatePageLinkSize(); // recalculamos el número de enlaces de página\r\n    } else {\r\n      // notificamos a nuestro papá que la página ha cambiado\r\n      this.onPageChange.emit(event.page + 1);\r\n    }\r\n  }\r\n\r\n  private goToFirstPage() {\r\n    if (this.pc) {\r\n      //volvemos a la primera página\r\n      this.pc._first = 1;\r\n      this.pc.updatePageLinks();\r\n    }\r\n  }\r\n\r\n  getStyle() {\r\n    if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {\r\n      if (this.totalItems > 0) {\r\n        return \"footer navbar-fixed-bottom\";\r\n      } else {\r\n        return \"footer navbar-fixed-bottom-60\";\r\n      }\r\n    } else if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_FORM) {\r\n      return \"footer navbar-fixed-bottom-form\";\r\n    } else {\r\n      return \"footer\";\r\n    }\r\n  }\r\n\r\n  isFooterList() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_LIST;\r\n  }\r\n\r\n  isFooterScroll() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_SCROLL;\r\n  }\r\n\r\n  isFooterForm() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_FORM;\r\n  }\r\n\r\n  /** Flag: la página está realizando la búsqueda. */\r\n  get searchInitiated() {\r\n    return this.status === PageStatus.Init || this.status == PageStatus.Reset || !this.status;\r\n  }\r\n\r\n  /** Flag: la página está realizando la búsqueda. */\r\n  get searching() {\r\n    return this.status === PageStatus.Searching;\r\n  }\r\n\r\n  /** Flag: la página ha finalizado la última búsqueda. */\r\n  get searchFinished() {\r\n    return this.status === PageStatus.FinishSearch;\r\n  }\r\n\r\n  /** Flag: la página está en modo solo lectura */\r\n  get readOnly() {\r\n    return this.status == PageStatus.ReadOnly;\r\n  }\r\n\r\n  /** Flag: la página ha finalizado con error */\r\n  get error() {\r\n    return this.status == PageStatus.Error;\r\n  }\r\n\r\n  /** Flag: encontrado resultado. */\r\n  get foundResult() {\r\n    return (\r\n      this.status === PageStatus.FinishSearch &&\r\n      ((this.typeFooter === BitFooterComponent.TYPE_LIST && this.totalItems > 0)\r\n        || this.typeFooter === BitFooterComponent.TYPE_FORM\r\n        || (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems <= this.maxCurrentItems))\r\n    );\r\n  }\r\n\r\n  /** Flag: hay más resultados (scroll). */\r\n  get moreResults() {\r\n    return (\r\n      this.status === PageStatus.FinishSearch &&\r\n      (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems > this.maxCurrentItems)\r\n    );\r\n  }\r\n\r\n  /** Flag: no hay resultados. */\r\n  get emptyResult() {\r\n    return this.status === PageStatus.FinishSearch && this.totalItems === 0;\r\n  }\r\n\r\n  get initMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Init));\r\n  }\r\n\r\n  get searchingMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Searching));\r\n  }\r\n\r\n  get finishMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.FinishSearch));\r\n  }\r\n\r\n  get moreResultsMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(BitFooterComponent.MORE_RESULTS));\r\n  }\r\n\r\n  get emptyMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.EmptyResult));\r\n  }\r\n\r\n  get readOnlyMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.ReadOnly));\r\n  }\r\n\r\n  get errorMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Error));\r\n  }\r\n}\r\n","<footer [class]=\"getStyle()\">\r\n  <div class=\"grid\">\r\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"typeFooter === 'list'\" [hidden]=\"!this.status || emptyResult\">\r\n      <div class=\"numero-resultados\">\r\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\r\n        <span>{{totalItems}}</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"typeFooter === 'scroll'\" [hidden]=\"!this.status || emptyResult\">\r\n      <div class=\"numero-resultados-scroll\">\r\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\r\n        <span *ngIf=\"maxCurrentItems >= totalItems\">{{totalItems}}</span>\r\n        <span *ngIf=\"maxCurrentItems < totalItems\">{{maxCurrentItems}} / {{totalItems}}</span>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"col-12 md:col-7 lg:col-7 p-text-center\" *ngIf=\"typeFooter === 'list'\"\r\n         [hidden]=\"!this.status || emptyResult\">\r\n      <p-paginator *ngIf=\"paginator\" #pc\r\n                   [rows]=\"itemsPerPage\"\r\n                   [totalRecords]=\"totalItems\"\r\n                   [pageLinkSize]=\"mostrarEnlacesPaginas ? pageLinkSize : 1\"\r\n                   [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\r\n                   [showPageLinks]=\"true\"\r\n                   [showJumpToPageDropdown]=\"false\"\r\n                   [showFirstLastIcon]=\"mostrarPrimeraUltimaPagina ? true : maxCurrentItems >= totalItems\"\r\n                   (onPageChange)=\"paginate($event)\"></p-paginator>\r\n    </div>\r\n    <div class=\"col-12 md:col-3 lg:col-3\">\r\n      <div *ngIf=\"searchInitiated\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{initMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"searching\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{searchingMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"readOnly\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{readOnlyMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"foundResult\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{finishMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"moreResults\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{moreResultsMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"emptyResult\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-exclamation\"></i>\r\n        <span>{{emptyMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"error\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-exclamation-triangle\"></i>\r\n        <span>{{errorMessage | async}}</span>\r\n      </div>\r\n\r\n      <bit-help></bit-help>\r\n    </div>\r\n  </div>\r\n</footer>\r\n"]}
|
package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.mjs
CHANGED
|
@@ -27,6 +27,7 @@ export class BitDropDownGeneralComponent extends BitCustomComponent {
|
|
|
27
27
|
this.includeEmpty = true;
|
|
28
28
|
this.listaOpciones = [];
|
|
29
29
|
this.listaOpcionesVisible = [];
|
|
30
|
+
this.emptyTextResolved = "";
|
|
30
31
|
}
|
|
31
32
|
/** Si se dan las condiciones, transforma los valores de number a string (o viceversa). */
|
|
32
33
|
transformValue() {
|
|
@@ -50,26 +51,30 @@ export class BitDropDownGeneralComponent extends BitCustomComponent {
|
|
|
50
51
|
}
|
|
51
52
|
// custom processing after retrieving data array from service
|
|
52
53
|
postRetrieveData() {
|
|
53
|
-
console.log("llamando a postRetrieveData para " + this.nombre);
|
|
54
|
+
console.log("llamando a postRetrieveData para " + this.nombre + "{opciones:" + this.listaOpciones + "}");
|
|
54
55
|
if (this.listaOpciones) {
|
|
55
56
|
this.listaOpcionesVisible = Object.assign([], this.listaOpciones);
|
|
56
|
-
// determinamos si debemos incluir la opción "sin selección" y con qué texto
|
|
57
|
-
if (this.includeEmpty) {
|
|
58
|
-
console.log("hay valor empty que hay que traducir para " + this.nombre);
|
|
59
|
-
this.translateService
|
|
60
|
-
.selectTranslateWithContext(this.emptyText)
|
|
61
|
-
.pipe(take(1))
|
|
62
|
-
.subscribe((translation) => {
|
|
63
|
-
console.log("se resuelve la traducción del emptyText para " + this.nombre + " con valor:" + translation);
|
|
64
|
-
this.listaOpcionesVisible.splice(0, 0, { value: null, label: translation });
|
|
65
|
-
//console.log("la lista de opciones vale", this.listaOpcionesVisible);
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
57
|
// repasamos si hay opciones a excluir que debamos eliminar
|
|
69
58
|
if (this.excludedValues) {
|
|
70
59
|
this.listaOpcionesVisible = this.listaOpcionesVisible.filter((op) => this.excludedValues.indexOf(op.value) < 0);
|
|
71
60
|
}
|
|
72
61
|
}
|
|
62
|
+
else {
|
|
63
|
+
this.listaOpcionesVisible = [];
|
|
64
|
+
}
|
|
65
|
+
// determinamos si debemos incluir la opción "sin selección" y con qué texto
|
|
66
|
+
if (this.includeEmpty) {
|
|
67
|
+
console.log("hay valor empty que hay que traducir para " + this.nombre);
|
|
68
|
+
this.translateService
|
|
69
|
+
.selectTranslateWithContext(this.emptyText)
|
|
70
|
+
.pipe(take(1))
|
|
71
|
+
.subscribe((translation) => {
|
|
72
|
+
console.log("se resuelve la traducción del emptyText para " + this.nombre + " con valor:" + translation);
|
|
73
|
+
this.listaOpcionesVisible.splice(0, 0, { value: null, label: translation });
|
|
74
|
+
this.emptyTextResolved = translation;
|
|
75
|
+
//console.log("la lista de opciones vale", this.listaOpcionesVisible);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
73
78
|
}
|
|
74
79
|
onBlur() {
|
|
75
80
|
this.onTouchedCallback();
|
|
@@ -97,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
97
102
|
}], includeEmpty: [{
|
|
98
103
|
type: Input
|
|
99
104
|
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-dropdown-general.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnInit, Input, ChangeDetectorRef, Directive } from \"@angular/core\";\r\nimport { ActivatedRoute } from \"@angular/router\";\r\nimport { take } from \"rxjs/operators\";\r\n\r\nimport { BitCustomComponent } from \"../bit-custom.component\";\r\nimport { AyudaService, TranslateService, SessionSharedService } from \"../../../services\";\r\n\r\n/**\r\n * Clase que utiliza un custom componente para select de elementos\r\n * Utiliza la interfaz ControlValueAccessor\r\n *    <bit-select [domain]=\"'DOMAIN_TIPO_LOG'\" id=\"tipolog\" [control]=\"formControl\">&nbsp;&nbsp;Tipus d'operació</bit-select>\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@Directive()\r\nexport abstract class BitDropDownGeneralComponent extends BitCustomComponent implements OnInit {\r\n  @Input() hideLabel: boolean = false; // forzar no reservar espacio para el nombre del campo\r\n  @Input() data: any[]; // lista de valores estáticos con lo que inicializamos el select\r\n  @Input() valueAs: string; // indica si hay que transformar el valor de entrada a un tipo de dato: \"string\", \"number\"\r\n  @Input() id: any;\r\n  @Input() excludedValues: any[];\r\n  @Input() emptyText: string = \"bitnglibrary.bitdropdown.any\"; //valor por defecto seleccionable como primer elemento\r\n  @Input() includeEmpty: boolean = true;\r\n\r\n  listaOpciones: any[] = [];\r\n  listaOpcionesVisible: any[] = [];\r\n  valorActual: any; // solo se usa para hacer la transformación cuando es estrictamente necesario\r\n\r\n  constructor(\r\n    protected router: ActivatedRoute,\r\n    protected sessionShared: SessionSharedService,\r\n    protected ayudaService: AyudaService,\r\n    protected changeDetectorRef: ChangeDetectorRef,\r\n    protected translateService: TranslateService\r\n  ) {\r\n    super(ayudaService, changeDetectorRef);\r\n  }\r\n\r\n  /** Si se dan las condiciones, transforma los valores de number a string (o viceversa). */\r\n  protected transformValue() {\r\n    if (this.control.value !== this.valorActual) {\r\n      if (!this.control.value || this.control.value.length === 0) {\r\n        this.valorActual = this.control.value;\r\n      }\r\n      // si es necesario, realizamos la transformación y aplicamos el nuevo valor\r\n      else if (this.valueAs === \"string\" && typeof this.control.value[0] !== \"string\") {\r\n        this.valorActual = this.control.value.map(String);\r\n        this.control.setValue(this.valorActual, { emitEvent: false });\r\n      } else if (this.valueAs === \"number\" && typeof this.control.value[0] !== \"number\") {\r\n        this.valorActual = this.control.value.map(Number);\r\n        this.control.setValue(this.valorActual, { emitEvent: false });\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    super.ngOnInit();\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);\r\n    if (this.listaOpciones) {\r\n      this.listaOpcionesVisible = Object.assign([], this.listaOpciones);\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            console.log(\"se resuelve la traducción del emptyText para \" + this.nombre + \" con valor:\" + translation);\r\n            this.listaOpcionesVisible.splice(0, 0, { value: null, label: translation });\r\n            //console.log(\"la lista de opciones vale\", this.listaOpcionesVisible);\r\n          });\r\n      }\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    }\r\n  }\r\n\r\n  onBlur() {\r\n    this.onTouchedCallback();\r\n  }\r\n\r\n  onFocus() {\r\n    this.onTouchedCallback();\r\n  }\r\n}\r\n"]}
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-dropdown-general.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnInit, Input, ChangeDetectorRef, Directive } from \"@angular/core\";\r\nimport { ActivatedRoute } from \"@angular/router\";\r\nimport { take } from \"rxjs/operators\";\r\n\r\nimport { BitCustomComponent } from \"../bit-custom.component\";\r\nimport { AyudaService, TranslateService, SessionSharedService } from \"../../../services\";\r\n\r\n/**\r\n * Clase que utiliza un custom componente para select de elementos\r\n * Utiliza la interfaz ControlValueAccessor\r\n *    <bit-select [domain]=\"'DOMAIN_TIPO_LOG'\" id=\"tipolog\" [control]=\"formControl\">&nbsp;&nbsp;Tipus d'operació</bit-select>\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@Directive()\r\nexport abstract class BitDropDownGeneralComponent extends BitCustomComponent implements OnInit {\r\n  @Input() hideLabel: boolean = false; // forzar no reservar espacio para el nombre del campo\r\n  @Input() data: any[]; // lista de valores estáticos con lo que inicializamos el select\r\n  @Input() valueAs: string; // indica si hay que transformar el valor de entrada a un tipo de dato: \"string\", \"number\"\r\n  @Input() id: any;\r\n  @Input() excludedValues: any[];\r\n  @Input() emptyText: string = \"bitnglibrary.bitdropdown.any\"; //valor por defecto seleccionable como primer elemento\r\n  @Input() includeEmpty: boolean = true;\r\n\r\n  listaOpciones: any[] = [];\r\n  listaOpcionesVisible: any[] = [];\r\n  valorActual: any; // solo se usa para hacer la transformación cuando es estrictamente necesario\r\n  emptyTextResolved: string = \"\";\r\n\r\n  constructor(\r\n    protected router: ActivatedRoute,\r\n    protected sessionShared: SessionSharedService,\r\n    protected ayudaService: AyudaService,\r\n    protected changeDetectorRef: ChangeDetectorRef,\r\n    protected translateService: TranslateService\r\n  ) {\r\n    super(ayudaService, changeDetectorRef);\r\n  }\r\n\r\n  /** Si se dan las condiciones, transforma los valores de number a string (o viceversa). */\r\n  protected transformValue() {\r\n    if (this.control.value !== this.valorActual) {\r\n      if (!this.control.value || this.control.value.length === 0) {\r\n        this.valorActual = this.control.value;\r\n      }\r\n      // si es necesario, realizamos la transformación y aplicamos el nuevo valor\r\n      else if (this.valueAs === \"string\" && typeof this.control.value[0] !== \"string\") {\r\n        this.valorActual = this.control.value.map(String);\r\n        this.control.setValue(this.valorActual, {emitEvent: false});\r\n      } else if (this.valueAs === \"number\" && typeof this.control.value[0] !== \"number\") {\r\n        this.valorActual = this.control.value.map(Number);\r\n        this.control.setValue(this.valorActual, {emitEvent: false});\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    super.ngOnInit();\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          console.log(\"se resuelve la traducción del emptyText para \" + this.nombre + \" con valor:\" + translation);\r\n          this.listaOpcionesVisible.splice(0, 0, {value: null, label: translation});\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  onBlur() {\r\n    this.onTouchedCallback();\r\n  }\r\n\r\n  onFocus() {\r\n    this.onTouchedCallback();\r\n  }\r\n}\r\n"]}
|
package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown-multiple.component.mjs
CHANGED
|
@@ -1,14 +1,13 @@
|
|
|
1
|
-
import { Component, forwardRef, Input } from
|
|
2
|
-
import { NG_VALUE_ACCESSOR } from
|
|
3
|
-
import { BitDropDownGeneralComponent } from
|
|
1
|
+
import { Component, forwardRef, Input } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { BitDropDownGeneralComponent } from './bit-dropdown-general.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/router";
|
|
6
6
|
import * as i2 from "../../../services";
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "
|
|
9
|
-
import * as i5 from "
|
|
10
|
-
import * as i6 from "@angular/
|
|
11
|
-
import * as i7 from "@angular/forms";
|
|
7
|
+
import * as i3 from "primeng/multiselect";
|
|
8
|
+
import * as i4 from "../../contol-messages/bit-control-messages.component";
|
|
9
|
+
import * as i5 from "@angular/common";
|
|
10
|
+
import * as i6 from "@angular/forms";
|
|
12
11
|
export const CUSTOM_DROPDOWN_MULTIPLE_CONTROL_VALUE_ACCESSOR = {
|
|
13
12
|
provide: NG_VALUE_ACCESSOR,
|
|
14
13
|
useExisting: forwardRef(() => BitDropDownMultipleComponent),
|
|
@@ -40,11 +39,24 @@ export class BitDropDownMultipleComponent extends BitDropDownGeneralComponent {
|
|
|
40
39
|
super.ngOnInit();
|
|
41
40
|
}
|
|
42
41
|
ngOnChanges(changes) {
|
|
42
|
+
let hayCambios = false;
|
|
43
43
|
for (let propName in changes) {
|
|
44
44
|
let changedProp = changes[propName];
|
|
45
45
|
if (propName === "data") {
|
|
46
46
|
this.listaOpciones = changedProp.currentValue ? changedProp.currentValue.slice() : [];
|
|
47
|
+
hayCambios = true;
|
|
47
48
|
}
|
|
49
|
+
else if (propName === "excludedValues") {
|
|
50
|
+
this.excludedValues = changedProp.currentValue;
|
|
51
|
+
hayCambios = true;
|
|
52
|
+
}
|
|
53
|
+
else if (propName === "includeEmpty") {
|
|
54
|
+
this.includeEmpty = changedProp.currentValue;
|
|
55
|
+
hayCambios = true;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
if (hayCambios) {
|
|
59
|
+
this.postRetrieveData();
|
|
48
60
|
}
|
|
49
61
|
}
|
|
50
62
|
get value_lectura() {
|
|
@@ -53,7 +65,14 @@ export class BitDropDownMultipleComponent extends BitDropDownGeneralComponent {
|
|
|
53
65
|
return labels ? labels.join(", ") : null;
|
|
54
66
|
}
|
|
55
67
|
labelSelectedItem(id) {
|
|
56
|
-
|
|
68
|
+
let label = "";
|
|
69
|
+
if (this.listaOpciones) {
|
|
70
|
+
let selected = this.listaOpciones.find((c) => c.value == id);
|
|
71
|
+
if (selected) {
|
|
72
|
+
label = selected.label;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
return label;
|
|
57
76
|
}
|
|
58
77
|
deleteSelectedItem(event, item) {
|
|
59
78
|
event.preventDefault();
|
|
@@ -63,12 +82,12 @@ export class BitDropDownMultipleComponent extends BitDropDownGeneralComponent {
|
|
|
63
82
|
this.value = this.value.slice(0);
|
|
64
83
|
}
|
|
65
84
|
}
|
|
66
|
-
BitDropDownMultipleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: BitDropDownMultipleComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.SessionSharedService }, { token:
|
|
67
|
-
BitDropDownMultipleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: BitDropDownMultipleComponent, selector: "bit-dropdown-multiple", inputs: { maxSelectedLabels: "maxSelectedLabels", showSeparateSelectedLabels: "showSeparateSelectedLabels", title: "title", filter: "filter" }, providers: [CUSTOM_DROPDOWN_MULTIPLE_CONTROL_VALUE_ACCESSOR], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"row separador\" *ngIf=\"showSeparateSelectedLabels; else normalBitSelectMultiple\">\r\n <div> <!-- class=\"col-sm-4\"-->\r\n <ng-container *ngTemplateOutlet=\"normalBitSelectMultiple\"></ng-container>\r\n </div>\r\n <div><!-- elementos seleccionados -->\r\n <label> </label>\r\n <div class=\"multiselect-labels\">\r\n <div class=\"label label-primary multiselect-labels-lg\" *ngFor=\"let item of value\">\r\n <span>{{labelSelectedItem(item)}}</span>\r\n <a (click)=\"deleteSelectedItem($event, item)\" title=\"{{title}}}\"> <i class=\"fa fa-times\"></i></a>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n<ng-template #normalBitSelectMultiple>\r\n <label *ngIf=\"!hideLabel\"><ng-content></ng-content> <span *ngIf=\"obligatorio\" class=\"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\">{{value_lectura}}</p>\r\n <div *ngIf=\"!readOnly\">\r\n <p-multiSelect
|
|
85
|
+
BitDropDownMultipleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: BitDropDownMultipleComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.SessionSharedService }, { token: i2.AyudaService }, { token: i0.ChangeDetectorRef }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
86
|
+
BitDropDownMultipleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: BitDropDownMultipleComponent, selector: "bit-dropdown-multiple", inputs: { maxSelectedLabels: "maxSelectedLabels", showSeparateSelectedLabels: "showSeparateSelectedLabels", title: "title", filter: "filter" }, providers: [CUSTOM_DROPDOWN_MULTIPLE_CONTROL_VALUE_ACCESSOR], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"row separador\" *ngIf=\"showSeparateSelectedLabels; else normalBitSelectMultiple\">\r\n <div> <!-- class=\"col-sm-4\"-->\r\n <ng-container *ngTemplateOutlet=\"normalBitSelectMultiple\"></ng-container>\r\n </div>\r\n <div><!-- elementos seleccionados -->\r\n <label> </label>\r\n <div class=\"multiselect-labels\">\r\n <div class=\"label label-primary multiselect-labels-lg\" *ngFor=\"let item of value\">\r\n <span>{{labelSelectedItem(item)}}</span>\r\n <a (click)=\"deleteSelectedItem($event, item)\" title=\"{{title}}}\"> <i class=\"fa fa-times\"></i></a>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n<ng-template #normalBitSelectMultiple>\r\n <label *ngIf=\"!hideLabel\"><ng-content></ng-content> <span *ngIf=\"obligatorio\" class=\"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\">{{value_lectura}}</p>\r\n <div *ngIf=\"!readOnly\">\r\n <p-multiSelect\r\n *ngIf=\"!readOnly\"\r\n id=\"{{id}}\"\r\n [filter]=\"filter\"\r\n [(ngModel)]=\"value\"\r\n [options]=\"listaOpciones\"\r\n [defaultLabel]=\"emptyTextResolved\"\r\n [maxSelectedLabels]=\"maxSelectedLabels\"\r\n selectedItemsLabel=\"{0} elements seleccionats\"\r\n (onFocus)=\"onFocus()\"\r\n (onBlur)=\"onBlur()\">\r\n </p-multiSelect>\r\n <control-messages *ngIf=\"control!=null\" [control]=\"control\" [field]=\"id\"></control-messages>\r\n </div>\r\n</ng-template>\r\n", components: [{ type: i3.MultiSelect, selector: "p-multiSelect", inputs: ["style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "autoZIndex", "baseZIndex", "filterBy", "virtualScroll", "itemSize", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "scrollHeight", "defaultLabel", "placeholder", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onPanelShow", "onPanelHide"] }, { type: i4.BitControlMessages, selector: "control-messages", inputs: ["control", "field"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
68
87
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: BitDropDownMultipleComponent, decorators: [{
|
|
69
88
|
type: Component,
|
|
70
|
-
args: [{ selector: "bit-dropdown-multiple", providers: [CUSTOM_DROPDOWN_MULTIPLE_CONTROL_VALUE_ACCESSOR], template: "<div class=\"row separador\" *ngIf=\"showSeparateSelectedLabels; else normalBitSelectMultiple\">\r\n <div> <!-- class=\"col-sm-4\"-->\r\n <ng-container *ngTemplateOutlet=\"normalBitSelectMultiple\"></ng-container>\r\n </div>\r\n <div><!-- elementos seleccionados -->\r\n <label> </label>\r\n <div class=\"multiselect-labels\">\r\n <div class=\"label label-primary multiselect-labels-lg\" *ngFor=\"let item of value\">\r\n <span>{{labelSelectedItem(item)}}</span>\r\n <a (click)=\"deleteSelectedItem($event, item)\" title=\"{{title}}}\"> <i class=\"fa fa-times\"></i></a>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n<ng-template #normalBitSelectMultiple>\r\n <label *ngIf=\"!hideLabel\"><ng-content></ng-content> <span *ngIf=\"obligatorio\" class=\"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\">{{value_lectura}}</p>\r\n <div *ngIf=\"!readOnly\">\r\n <p-multiSelect
|
|
71
|
-
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.SessionSharedService }, { type:
|
|
89
|
+
args: [{ selector: "bit-dropdown-multiple", providers: [CUSTOM_DROPDOWN_MULTIPLE_CONTROL_VALUE_ACCESSOR], template: "<div class=\"row separador\" *ngIf=\"showSeparateSelectedLabels; else normalBitSelectMultiple\">\r\n <div> <!-- class=\"col-sm-4\"-->\r\n <ng-container *ngTemplateOutlet=\"normalBitSelectMultiple\"></ng-container>\r\n </div>\r\n <div><!-- elementos seleccionados -->\r\n <label> </label>\r\n <div class=\"multiselect-labels\">\r\n <div class=\"label label-primary multiselect-labels-lg\" *ngFor=\"let item of value\">\r\n <span>{{labelSelectedItem(item)}}</span>\r\n <a (click)=\"deleteSelectedItem($event, item)\" title=\"{{title}}}\"> <i class=\"fa fa-times\"></i></a>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n<ng-template #normalBitSelectMultiple>\r\n <label *ngIf=\"!hideLabel\"><ng-content></ng-content> <span *ngIf=\"obligatorio\" class=\"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\">{{value_lectura}}</p>\r\n <div *ngIf=\"!readOnly\">\r\n <p-multiSelect\r\n *ngIf=\"!readOnly\"\r\n id=\"{{id}}\"\r\n [filter]=\"filter\"\r\n [(ngModel)]=\"value\"\r\n [options]=\"listaOpciones\"\r\n [defaultLabel]=\"emptyTextResolved\"\r\n [maxSelectedLabels]=\"maxSelectedLabels\"\r\n selectedItemsLabel=\"{0} elements seleccionats\"\r\n (onFocus)=\"onFocus()\"\r\n (onBlur)=\"onBlur()\">\r\n </p-multiSelect>\r\n <control-messages *ngIf=\"control!=null\" [control]=\"control\" [field]=\"id\"></control-messages>\r\n </div>\r\n</ng-template>\r\n" }]
|
|
90
|
+
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.SessionSharedService }, { type: i2.AyudaService }, { type: i0.ChangeDetectorRef }, { type: i2.TranslateService }]; }, propDecorators: { maxSelectedLabels: [{
|
|
72
91
|
type: Input
|
|
73
92
|
}], showSeparateSelectedLabels: [{
|
|
74
93
|
type: Input
|
|
@@ -77,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
77
96
|
}], filter: [{
|
|
78
97
|
type: Input
|
|
79
98
|
}] } });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-dropdown-multiple.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown-multiple.component.ts","../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown-multiple.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, OnChanges, Input, SimpleChange, ChangeDetectorRef } from \"@angular/core\";\r\nimport { NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { ActivatedRoute } from \"@angular/router\";\r\n\r\nimport { AyudaService } from \"../../../services/ayuda.service\";\r\nimport { TranslateService, SessionSharedService } from \"../../../services\";\r\nimport { BitDropDownGeneralComponent } from \"./bit-dropdown-general.component\";\r\n\r\nexport const CUSTOM_DROPDOWN_MULTIPLE_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => BitDropDownMultipleComponent),\r\n  multi: true\r\n};\r\n\r\n/**\r\n * Clase que utiliza un custom componente para select múltiple de elementos\r\n * Utiliza la interfaz ControlValueAccessor\r\n *    <bit-select [domain]=\"'DOMAIN_TIPO_LOG'\" id=\"tipolog\" [control]=\"formControl\"\">&nbsp;&nbsp;Tipus d'operació</bit-select>\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 **/\r\n\r\n@Component({\r\n  selector: \"bit-dropdown-multiple\",\r\n  templateUrl: \"bit-dropdown-multiple.component.html\",\r\n  providers: [CUSTOM_DROPDOWN_MULTIPLE_CONTROL_VALUE_ACCESSOR]\r\n})\r\nexport class BitDropDownMultipleComponent extends BitDropDownGeneralComponent implements OnChanges {\r\n  @Input() maxSelectedLabels: number = 3;\r\n  @Input() showSeparateSelectedLabels: boolean = false; // indica si se muestran los elementos seleccionados en una columna separada\r\n  @Input() title: string; //título que aparece en el link para eliminar un elemento una vez seleccionado\r\n  @Input() filter: boolean;\r\n  // Si se pueden seleccionar muchos elementos, que el label de los elementos seleccionados no\r\n  // aparezca dentro del select, y hacerlo como una lista fuera del select.\r\n\r\n  constructor(\r\n    protected router: ActivatedRoute,\r\n    protected sessionShared: SessionSharedService,\r\n    protected ayudaService: AyudaService,\r\n    protected changeDetectorRef: ChangeDetectorRef,\r\n    protected translateService: TranslateService\r\n  ) {\r\n    super(router, sessionShared, ayudaService, changeDetectorRef, translateService);\r\n  }\r\n\r\n  ngOnInit() {\r\n    super.ngOnInit();\r\n  }\r\n\r\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\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      }\r\n    }\r\n  }\r\n\r\n  get value_lectura(): any {\r\n    let val = this.value;\r\n    let labels: any[] = this.listaOpciones && this.listaOpciones.filter((d) => val && val.indexOf(d.value) > -1).map((d) => d.label);\r\n    return labels ? labels.join(\", \") : null;\r\n  }\r\n\r\n  labelSelectedItem(id): string {\r\n    return this.listaOpciones.find((c) => c.value == id).label;\r\n  }\r\n\r\n  deleteSelectedItem(event, item) {\r\n    event.preventDefault();\r\n    let index = this.value.indexOf(item);\r\n    this.value.splice(index, 1);\r\n    // se clona el array. Si no, el texto \"{0} elementos seleccionados\" del select de Prime no se actualiza.\r\n    this.value = this.value.slice(0);\r\n  }\r\n}\r\n","<div class=\"row separador\" *ngIf=\"showSeparateSelectedLabels; else normalBitSelectMultiple\">\r\n    <div> <!-- class=\"col-sm-4\"-->\r\n        <ng-container *ngTemplateOutlet=\"normalBitSelectMultiple\"></ng-container>\r\n    </div>\r\n    <div><!-- elementos seleccionados -->\r\n        <label>&nbsp;</label>\r\n        <div class=\"multiselect-labels\">\r\n            <div class=\"label label-primary multiselect-labels-lg\" *ngFor=\"let item of value\">\r\n            <span>{{labelSelectedItem(item)}}</span>\r\n            <a (click)=\"deleteSelectedItem($event, item)\" title=\"{{title}}}\"> <i class=\"fa fa-times\"></i></a>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>\r\n<ng-template #normalBitSelectMultiple>\r\n    <label *ngIf=\"!hideLabel\"><ng-content></ng-content>&nbsp;<span *ngIf=\"obligatorio\" class=\"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\">{{value_lectura}}</p>\r\n    <div *ngIf=\"!readOnly\">\r\n        <p-multiSelect \r\n            *ngIf=\"!readOnly\" \r\n            id=\"{{id}}\"\r\n            [filter]=\"filter\" \r\n            [(ngModel)]=\"value\"             \r\n            [options]=\"listaOpciones\" \r\n            [defaultLabel]=\"emptyText\"             \r\n            [maxSelectedLabels]=\"maxSelectedLabels\"\r\n            selectedItemsLabel=\"{0} elements seleccionats\"\r\n            (onFocus)=\"onFocus()\" \r\n            (onBlur)=\"onBlur()\">             \r\n        </p-multiSelect>\r\n    <control-messages *ngIf=\"control!=null\" [control]=\"control\" [field]=\"id\"></control-messages>\r\n    </div>\r\n</ng-template>"]}
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-dropdown-multiple.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown-multiple.component.ts","../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown-multiple.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, forwardRef, Input, OnChanges, SimpleChange } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { ActivatedRoute } from '@angular/router';\r\n\r\nimport { AyudaService, SessionSharedService, TranslateService } from '../../../services';\r\nimport { BitDropDownGeneralComponent } from './bit-dropdown-general.component';\r\n\r\nexport const CUSTOM_DROPDOWN_MULTIPLE_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => BitDropDownMultipleComponent),\r\n  multi: true\r\n};\r\n\r\n/**\r\n * Clase que utiliza un custom componente para select múltiple de elementos\r\n * Utiliza la interfaz ControlValueAccessor\r\n *    <bit-select [domain]=\"'DOMAIN_TIPO_LOG'\" id=\"tipolog\" [control]=\"formControl\"\">&nbsp;&nbsp;Tipus d'operació</bit-select>\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 **/\r\n\r\n@Component({\r\n  selector: \"bit-dropdown-multiple\",\r\n  templateUrl: \"bit-dropdown-multiple.component.html\",\r\n  providers: [CUSTOM_DROPDOWN_MULTIPLE_CONTROL_VALUE_ACCESSOR]\r\n})\r\nexport class BitDropDownMultipleComponent extends BitDropDownGeneralComponent implements OnChanges {\r\n  @Input() maxSelectedLabels: number = 3;\r\n  @Input() showSeparateSelectedLabels: boolean = false; // indica si se muestran los elementos seleccionados en una columna separada\r\n  @Input() title: string; //título que aparece en el link para eliminar un elemento una vez seleccionado\r\n  @Input() filter: boolean;\r\n  // Si se pueden seleccionar muchos elementos, que el label de los elementos seleccionados no\r\n  // aparezca dentro del select, y hacerlo como una lista fuera del select.\r\n\r\n  constructor(\r\n    protected router: ActivatedRoute,\r\n    protected sessionShared: SessionSharedService,\r\n    protected ayudaService: AyudaService,\r\n    protected changeDetectorRef: ChangeDetectorRef,\r\n    protected translateService: TranslateService\r\n  ) {\r\n    super(router, sessionShared, ayudaService, changeDetectorRef, translateService);\r\n  }\r\n\r\n  ngOnInit() {\r\n    super.ngOnInit();\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(): any {\r\n    let val = this.value;\r\n    let labels: any[] = this.listaOpciones && this.listaOpciones.filter((d) => val && val.indexOf(d.value) > -1).map((d) => d.label);\r\n    return labels ? labels.join(\", \") : null;\r\n  }\r\n\r\n  labelSelectedItem(id): string {\r\n    let label: string = \"\";\r\n    if (this.listaOpciones) {\r\n      let selected = this.listaOpciones.find((c) => c.value == id);\r\n      if (selected) {\r\n        label = selected.label;\r\n      }\r\n    }\r\n    return label;\r\n  }\r\n\r\n  deleteSelectedItem(event, item) {\r\n    event.preventDefault();\r\n    let index = this.value.indexOf(item);\r\n    this.value.splice(index, 1);\r\n    // se clona el array. Si no, el texto \"{0} elementos seleccionados\" del select de Prime no se actualiza.\r\n    this.value = this.value.slice(0);\r\n  }\r\n}\r\n","<div class=\"row separador\" *ngIf=\"showSeparateSelectedLabels; else normalBitSelectMultiple\">\r\n    <div> <!-- class=\"col-sm-4\"-->\r\n        <ng-container *ngTemplateOutlet=\"normalBitSelectMultiple\"></ng-container>\r\n    </div>\r\n    <div><!-- elementos seleccionados -->\r\n        <label>&nbsp;</label>\r\n        <div class=\"multiselect-labels\">\r\n            <div class=\"label label-primary multiselect-labels-lg\" *ngFor=\"let item of value\">\r\n            <span>{{labelSelectedItem(item)}}</span>\r\n            <a (click)=\"deleteSelectedItem($event, item)\" title=\"{{title}}}\"> <i class=\"fa fa-times\"></i></a>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>\r\n<ng-template #normalBitSelectMultiple>\r\n    <label *ngIf=\"!hideLabel\"><ng-content></ng-content>&nbsp;<span *ngIf=\"obligatorio\" class=\"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\">{{value_lectura}}</p>\r\n    <div *ngIf=\"!readOnly\">\r\n        <p-multiSelect\r\n            *ngIf=\"!readOnly\"\r\n            id=\"{{id}}\"\r\n            [filter]=\"filter\"\r\n            [(ngModel)]=\"value\"\r\n            [options]=\"listaOpciones\"\r\n            [defaultLabel]=\"emptyTextResolved\"\r\n            [maxSelectedLabels]=\"maxSelectedLabels\"\r\n            selectedItemsLabel=\"{0} elements seleccionats\"\r\n            (onFocus)=\"onFocus()\"\r\n            (onBlur)=\"onBlur()\">\r\n        </p-multiSelect>\r\n    <control-messages *ngIf=\"control!=null\" [control]=\"control\" [field]=\"id\"></control-messages>\r\n    </div>\r\n</ng-template>\r\n"]}
|