bit-ng-library 14.0.6 → 14.0.7
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 +6 -0
- package/esm2020/lib/sharedlibrary/components/footer/bit-footer.component.mjs +45 -57
- package/fesm2015/bit-ng-library.mjs +47 -58
- package/fesm2015/bit-ng-library.mjs.map +1 -1
- package/fesm2020/bit-ng-library.mjs +44 -56
- package/fesm2020/bit-ng-library.mjs.map +1 -1
- package/lib/sharedlibrary/components/footer/bit-footer.component.d.ts +9 -13
- package/lib/sharedlibrary/components/footer/bit-footer.component.d.ts.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -26,6 +26,12 @@ 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
|
+
## [14.0.7] - 2022-02-02
|
|
30
|
+
|
|
31
|
+
nueva versión del footer con dos parámetros nuevos:
|
|
32
|
+
visible: que por defecto será true y en el caso de indicar false hará que el footer no se muestre
|
|
33
|
+
forcePageLinkSize: permite forzar a que solo se muestre un número máximo de links de páginas en el paginador. En el caso de que no se especifique el valor será 1
|
|
34
|
+
|
|
29
35
|
## [14.0.6] - 2022-01-25
|
|
30
36
|
|
|
31
37
|
se formatean los campos bit-date y bit-datetime cuando está en modo readonly a formato humano en vez de ISO
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from "@angular/core";
|
|
2
2
|
import { BaseFilter, BASE_RESULTADOS_PAGE } from "../../../base/shared/base.filter";
|
|
3
3
|
import { PageStatus } from "../../global.constants";
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -11,14 +11,15 @@ import * as i5 from "@ngneat/transloco";
|
|
|
11
11
|
* Componente que muestra un paginador en la sección footer.
|
|
12
12
|
**/
|
|
13
13
|
export class BitFooterComponent {
|
|
14
|
-
constructor(translateService
|
|
14
|
+
constructor(translateService) {
|
|
15
15
|
this.translateService = translateService;
|
|
16
|
-
this.changeRef = changeRef;
|
|
17
16
|
this.mostrarAvisos = true;
|
|
18
17
|
this.fixed = true; // Indicará si lo queremos fijo abajo en la página. Por defecto sí.
|
|
19
18
|
this.status = PageStatus.Init; // Determina en qué estado está la página: PageStatus.Init, PageStatus.SEARCHING, PageStatus.FINISH_SEARCH
|
|
20
19
|
this.mostrarEnlacesPaginas = true;
|
|
21
20
|
this.mostrarPrimeraUltimaPagina = true;
|
|
21
|
+
this.visible = true;
|
|
22
|
+
this.forcePageLinkSize = 1; // número de enlaces en el paginador para poder navegar hacia delante o detrás que forzamos a que haya
|
|
22
23
|
this.onPageChange = new EventEmitter(); //para notificar cambios en la página a mostrar
|
|
23
24
|
this.onNewPageSize = new EventEmitter(); //para notificar cambios en los elementos a mostrar por página
|
|
24
25
|
this.baseItemsPerPage = 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
|
|
@@ -58,20 +59,6 @@ export class BitFooterComponent {
|
|
|
58
59
|
console.log("the footer is BLANK!");
|
|
59
60
|
}
|
|
60
61
|
}
|
|
61
|
-
/**
|
|
62
|
-
* Cuando tengamos la referencia al componente paginator actualizamos internamente el número de página y el número de páginas
|
|
63
|
-
* del desplegable con la información del filtro proporcionado
|
|
64
|
-
*/
|
|
65
|
-
ngAfterViewInit() {
|
|
66
|
-
if (this.pc) {
|
|
67
|
-
this.itemsPerPage = this.filter.resultados;
|
|
68
|
-
console.log(`this.filter.resultados ${this.filter.resultados}`);
|
|
69
|
-
console.log(`this.filter.pagina ${this.filter.pagina}`);
|
|
70
|
-
this.pc.rows = this.filter.resultados;
|
|
71
|
-
this.pc._first = (this.filter.pagina - 1) * this.pc.rows;
|
|
72
|
-
this.pc.updatePageLinks();
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
62
|
/**
|
|
76
63
|
* Escucharemos a cambios en las propiedades totalItems para actualizar el paginador con respecto a las páginas que mostramos
|
|
77
64
|
*/
|
|
@@ -80,56 +67,65 @@ export class BitFooterComponent {
|
|
|
80
67
|
let changedProp = changes[propName];
|
|
81
68
|
if (propName === "status") {
|
|
82
69
|
this.status = changedProp.currentValue;
|
|
83
|
-
console.log(
|
|
70
|
+
console.log("status:" + this.status);
|
|
84
71
|
}
|
|
85
72
|
else if (propName === "totalItems") {
|
|
86
73
|
this.totalItems = changedProp.currentValue;
|
|
87
|
-
console.log(
|
|
74
|
+
console.log("totalItems:" + this.totalItems);
|
|
88
75
|
if (changedProp.previousValue !== changedProp.currentValue) {
|
|
89
76
|
this.calculatePageLinkSize(); //recalculamos
|
|
90
77
|
}
|
|
91
|
-
this.
|
|
78
|
+
this.calculateMaxCurrentItems();
|
|
92
79
|
}
|
|
93
80
|
else if (propName === "filter") {
|
|
94
81
|
this.filter = changedProp.currentValue;
|
|
95
|
-
|
|
96
|
-
this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;
|
|
97
|
-
}
|
|
98
|
-
console.log(`new filter ${this.filter?.pagina} - ${this.maxCurrentItems}`);
|
|
82
|
+
this.calculateMaxCurrentItems();
|
|
99
83
|
if (changedProp.previousValue !== changedProp.currentValue) {
|
|
100
84
|
this.calculatePageLinkSize(); //recalculamos
|
|
101
85
|
if (!this.filter?.pagina || this.filter.pagina <= 1) {
|
|
102
86
|
this.goToFirstPage();
|
|
87
|
+
console.log("goToFirstPage");
|
|
103
88
|
}
|
|
104
89
|
}
|
|
90
|
+
this.first = (this.filter.pagina - 1) * this.filter.resultados;
|
|
91
|
+
console.log("first:" + this.first);
|
|
105
92
|
}
|
|
106
93
|
}
|
|
107
|
-
if (this.pc && this.changeRef) {
|
|
108
|
-
console.log('updatePageLinks');
|
|
109
|
-
this.pc.updatePageLinks();
|
|
110
|
-
this.changeRef.detectChanges();
|
|
111
|
-
}
|
|
112
94
|
}
|
|
113
95
|
showFooter() {
|
|
114
|
-
|
|
96
|
+
// Problema. Estamos obteniendo un status a null cuando regresamos de una ficha
|
|
97
|
+
// status es null porque realmente no se está lanzando ninguna búsqueda por lo que el método updatePageStatus retorna null
|
|
98
|
+
return this.typeFooter === 'list' && this.visible;
|
|
115
99
|
}
|
|
116
100
|
showScroll() {
|
|
117
|
-
return this.typeFooter === 'scroll' && this.
|
|
101
|
+
return this.typeFooter === 'scroll' && this.visible;
|
|
118
102
|
}
|
|
119
103
|
/** Calcula el número de enlaces visibles en el paginador (en el rango entre 1 y BASE_RESULTADOS_PAGE). */
|
|
120
104
|
calculatePageLinkSize() {
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
this.pageLinkSize
|
|
105
|
+
if (this.forcePageLinkSize == 0) {
|
|
106
|
+
console.log(`calculatePageLinkSize totalItems: ${this.totalItems} itemsPerPage:${this.itemsPerPage}`);
|
|
107
|
+
this.pageLinkSize = Math.ceil(this.totalItems / this.itemsPerPage);
|
|
108
|
+
if (this.pageLinkSize < 1) {
|
|
109
|
+
this.pageLinkSize = 1;
|
|
110
|
+
}
|
|
111
|
+
if (this.pageLinkSize > BASE_RESULTADOS_PAGE) {
|
|
112
|
+
this.pageLinkSize = BASE_RESULTADOS_PAGE;
|
|
113
|
+
}
|
|
125
114
|
}
|
|
126
|
-
|
|
127
|
-
this.pageLinkSize =
|
|
115
|
+
else {
|
|
116
|
+
this.pageLinkSize = this.forcePageLinkSize;
|
|
117
|
+
}
|
|
118
|
+
console.log("pageLinkSize", this.pageLinkSize);
|
|
119
|
+
}
|
|
120
|
+
calculateMaxCurrentItems() {
|
|
121
|
+
this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;
|
|
122
|
+
if (this.maxCurrentItems > this.totalItems) {
|
|
123
|
+
this.maxCurrentItems = this.totalItems;
|
|
128
124
|
}
|
|
129
125
|
}
|
|
130
126
|
/** 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 */
|
|
131
127
|
paginate(event) {
|
|
132
|
-
console.log("Page changed to"
|
|
128
|
+
console.log("Page changed to:" + event.page + " maxCurrentItems:" + this.maxCurrentItems + " firstElement:" + this.first);
|
|
133
129
|
if (event.rows !== this.itemsPerPage) {
|
|
134
130
|
// han cambiado el número de elementos por página
|
|
135
131
|
//notificamos que los elementos por página han cambiado
|
|
@@ -144,20 +140,11 @@ export class BitFooterComponent {
|
|
|
144
140
|
}
|
|
145
141
|
}
|
|
146
142
|
goToFirstPage() {
|
|
147
|
-
|
|
148
|
-
//volvemos a la primera página
|
|
149
|
-
this.pc._first = 1;
|
|
150
|
-
this.pc.updatePageLinks();
|
|
151
|
-
}
|
|
143
|
+
this.first = 1;
|
|
152
144
|
}
|
|
153
145
|
getStyle() {
|
|
154
146
|
if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {
|
|
155
|
-
|
|
156
|
-
return "footer navbar-fixed-bottom";
|
|
157
|
-
}
|
|
158
|
-
else {
|
|
159
|
-
return "footer navbar-fixed-bottom-60";
|
|
160
|
-
}
|
|
147
|
+
return "footer navbar-fixed-bottom";
|
|
161
148
|
}
|
|
162
149
|
else if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_FORM) {
|
|
163
150
|
return "footer navbar-fixed-bottom-form";
|
|
@@ -238,15 +225,12 @@ BitFooterComponent.TYPE_SCROLL = "scroll";
|
|
|
238
225
|
BitFooterComponent.TYPE_FORM = "form";
|
|
239
226
|
BitFooterComponent.TYPE_BLANK = "blank";
|
|
240
227
|
BitFooterComponent.MORE_RESULTS = -1;
|
|
241
|
-
BitFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: BitFooterComponent, deps: [{ token: i1.TranslateService }
|
|
242
|
-
BitFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.8", type: BitFooterComponent, selector: "bit-footer", inputs: { totalItems: "totalItems", filter: "filter", paginator: "paginator", mostrarAvisos: "mostrarAvisos", fixed: "fixed", messages: "messages", status: "status", typeFooter: ["type", "typeFooter"], mostrarEnlacesPaginas: "mostrarEnlacesPaginas", mostrarPrimeraUltimaPagina: "mostrarPrimeraUltimaPagina"
|
|
228
|
+
BitFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: BitFooterComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
229
|
+
BitFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.8", type: BitFooterComponent, selector: "bit-footer", inputs: { totalItems: "totalItems", filter: "filter", paginator: "paginator", mostrarAvisos: "mostrarAvisos", fixed: "fixed", messages: "messages", status: "status", typeFooter: ["type", "typeFooter"], mostrarEnlacesPaginas: "mostrarEnlacesPaginas", mostrarPrimeraUltimaPagina: "mostrarPrimeraUltimaPagina", visible: "visible", forcePageLinkSize: "forcePageLinkSize" }, outputs: { onPageChange: "onPageChange", onNewPageSize: "onNewPageSize" }, usesOnChanges: true, ngImport: i0, template: "<footer [class]=\"getStyle()\">\n <div class=\"grid\">\n <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"showFooter()\">\n <div class=\"numero-resultados\">\n <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\n <span>{{maxCurrentItems}} / {{totalItems}}</span>\n </div>\n </div>\n <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"showScroll()\">\n <div class=\"numero-resultados-scroll\">\n <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\n <span *ngIf=\"maxCurrentItems >= totalItems\">{{totalItems}}</span>\n <span *ngIf=\"maxCurrentItems < totalItems\">{{maxCurrentItems}} / {{totalItems}}</span>\n </div>\n </div>\n\n <div class=\"col-12 md:col-7 lg:col-7 p-text-center\" *ngIf=\"showFooter()\">\n <p-paginator *ngIf=\"paginator\"\n [first]=\"first\"\n [rows]=\"itemsPerPage\"\n [totalRecords]=\"totalItems\"\n [pageLinkSize]=\"mostrarEnlacesPaginas ? pageLinkSize : 1\"\n [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\n [showPageLinks]=\"mostrarEnlacesPaginas\"\n [showJumpToPageDropdown]=\"false\"\n [showFirstLastIcon]=\"mostrarPrimeraUltimaPagina ? true : maxCurrentItems >= totalItems\"\n (onPageChange)=\"paginate($event)\"></p-paginator>\n </div>\n <div class=\"col-12 md:col-3 lg:col-3\">\n <div *ngIf=\"searchInitiated\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-info\"></i>\n <span>{{initMessage | async}}</span>\n </div>\n\n <div *ngIf=\"searching\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-info\"></i>\n <span>{{searchingMessage | async}}</span>\n </div>\n\n <div *ngIf=\"readOnly\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-info\"></i>\n <span>{{readOnlyMessage | async}}</span>\n </div>\n\n <div *ngIf=\"foundResult\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-info\"></i>\n <span>{{finishMessage | async}}</span>\n </div>\n\n <div *ngIf=\"moreResults\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-info\"></i>\n <span>{{moreResultsMessage | async}}</span>\n </div>\n\n <div *ngIf=\"emptyResult\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-exclamation\"></i>\n <span>{{emptyMessage | async}}</span>\n </div>\n\n <div *ngIf=\"error\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-exclamation-triangle\"></i>\n <span>{{errorMessage | async}}</span>\n </div>\n\n <bit-help></bit-help>\n </div>\n </div>\n</footer>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.Paginator, selector: "p-paginator", inputs: ["pageLinkSize", "style", "styleClass", "alwaysShow", "templateLeft", "templateRight", "dropdownAppendTo", "dropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showFirstLastIcon", "totalRecords", "rows", "rowsPerPageOptions", "showJumpToPageDropdown", "showJumpToPageInput", "showPageLinks", "dropdownItemTemplate", "first"], outputs: ["onPageChange"] }, { kind: "component", type: i4.BitHelpComponent, selector: "bit-help" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.TranslocoPipe, name: "transloco" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
243
230
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: BitFooterComponent, decorators: [{
|
|
244
231
|
type: Component,
|
|
245
|
-
args: [{ selector: "bit-footer", changeDetection: ChangeDetectionStrategy.OnPush, template: "<footer [class]=\"getStyle()\">\n <div class=\"grid\">\n <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"showFooter()\">\n <div class=\"numero-resultados\">\n <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\n <span>{{totalItems}}</span>\n </div>\n </div>\n <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"showScroll()\">\n <div class=\"numero-resultados-scroll\">\n <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\n <span *ngIf=\"maxCurrentItems >= totalItems\">{{totalItems}}</span>\n <span *ngIf=\"maxCurrentItems < totalItems\">{{maxCurrentItems}} / {{totalItems}}</span>\n </div>\n </div>\n\n <div class=\"col-12 md:col-7 lg:col-7 p-text-center\" *ngIf=\"
|
|
246
|
-
}], ctorParameters: function () { return [{ type: i1.TranslateService }
|
|
247
|
-
type: ViewChild,
|
|
248
|
-
args: ["pc"]
|
|
249
|
-
}], totalItems: [{
|
|
232
|
+
args: [{ selector: "bit-footer", changeDetection: ChangeDetectionStrategy.OnPush, template: "<footer [class]=\"getStyle()\">\n <div class=\"grid\">\n <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"showFooter()\">\n <div class=\"numero-resultados\">\n <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\n <span>{{maxCurrentItems}} / {{totalItems}}</span>\n </div>\n </div>\n <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"showScroll()\">\n <div class=\"numero-resultados-scroll\">\n <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\n <span *ngIf=\"maxCurrentItems >= totalItems\">{{totalItems}}</span>\n <span *ngIf=\"maxCurrentItems < totalItems\">{{maxCurrentItems}} / {{totalItems}}</span>\n </div>\n </div>\n\n <div class=\"col-12 md:col-7 lg:col-7 p-text-center\" *ngIf=\"showFooter()\">\n <p-paginator *ngIf=\"paginator\"\n [first]=\"first\"\n [rows]=\"itemsPerPage\"\n [totalRecords]=\"totalItems\"\n [pageLinkSize]=\"mostrarEnlacesPaginas ? pageLinkSize : 1\"\n [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\n [showPageLinks]=\"mostrarEnlacesPaginas\"\n [showJumpToPageDropdown]=\"false\"\n [showFirstLastIcon]=\"mostrarPrimeraUltimaPagina ? true : maxCurrentItems >= totalItems\"\n (onPageChange)=\"paginate($event)\"></p-paginator>\n </div>\n <div class=\"col-12 md:col-3 lg:col-3\">\n <div *ngIf=\"searchInitiated\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-info\"></i>\n <span>{{initMessage | async}}</span>\n </div>\n\n <div *ngIf=\"searching\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-info\"></i>\n <span>{{searchingMessage | async}}</span>\n </div>\n\n <div *ngIf=\"readOnly\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-info\"></i>\n <span>{{readOnlyMessage | async}}</span>\n </div>\n\n <div *ngIf=\"foundResult\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-info\"></i>\n <span>{{finishMessage | async}}</span>\n </div>\n\n <div *ngIf=\"moreResults\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-info\"></i>\n <span>{{moreResultsMessage | async}}</span>\n </div>\n\n <div *ngIf=\"emptyResult\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-exclamation\"></i>\n <span>{{emptyMessage | async}}</span>\n </div>\n\n <div *ngIf=\"error\"\n [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n <i class=\"fa fa-exclamation-triangle\"></i>\n <span>{{errorMessage | async}}</span>\n </div>\n\n <bit-help></bit-help>\n </div>\n </div>\n</footer>\n" }]
|
|
233
|
+
}], ctorParameters: function () { return [{ type: i1.TranslateService }]; }, propDecorators: { totalItems: [{
|
|
250
234
|
type: Input
|
|
251
235
|
}], filter: [{
|
|
252
236
|
type: Input
|
|
@@ -267,9 +251,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
|
|
|
267
251
|
type: Input
|
|
268
252
|
}], mostrarPrimeraUltimaPagina: [{
|
|
269
253
|
type: Input
|
|
254
|
+
}], visible: [{
|
|
255
|
+
type: Input
|
|
256
|
+
}], forcePageLinkSize: [{
|
|
257
|
+
type: Input
|
|
270
258
|
}], onPageChange: [{
|
|
271
259
|
type: Output
|
|
272
260
|
}], onNewPageSize: [{
|
|
273
261
|
type: Output
|
|
274
262
|
}] } });
|
|
275
|
-
//# 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 {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChange,\n  ViewChild\n} from \"@angular/core\";\nimport {Paginator} from \"primeng/paginator\";\nimport {Observable} from \"rxjs\";\nimport { BaseFilter, BASE_RESULTADOS_PAGE } from \"../../../base/shared/base.filter\";\nimport { PageStatus } from \"../../global.constants\";\nimport { TranslateService } from \"../../services\";\n\n/**\n * Componente que muestra un paginador en la sección footer.\n **/\n@Component({\n  selector: \"bit-footer\",\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: \"bit-footer.component.html\"\n})\nexport class BitFooterComponent implements OnInit, OnChanges {\n  public static TYPE_LIST: string = \"list\";\n  public static TYPE_SCROLL: string = \"scroll\";\n  public static TYPE_FORM: string = \"form\";\n  public static TYPE_BLANK: string = \"blank\";\n\n  public static MORE_RESULTS = -1;\n\n  @ViewChild(\"pc\")\n  pc: Paginator;\n  @Input()\n  totalItems: number;     // Número total de elementos recuperados de la consulta\n  @Input()\n  filter: BaseFilter;\n  @Input()\n  paginator: boolean;\n  @Input()\n  mostrarAvisos: boolean = true;\n  @Input()\n  fixed: boolean = true; // Indicará si lo queremos fijo abajo en la página. Por defecto sí.\n  @Input()\n  messages: Map<PageStatus, string>;\n  @Input()\n  status: PageStatus = PageStatus.Init; // Determina en qué estado está la página: PageStatus.Init, PageStatus.SEARCHING, PageStatus.FINISH_SEARCH\n  @Input(\"type\")\n  typeFooter: string;\n  @Input()\n  mostrarEnlacesPaginas: boolean = true;\n  @Input()\n  mostrarPrimeraUltimaPagina: boolean = true;\n  @Output()\n  onPageChange = new EventEmitter<number>(); //para notificar cambios en la página a mostrar\n  @Output()\n  onNewPageSize = new EventEmitter<number>(); //para notificar cambios en los elementos a mostrar por página\n\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\n  pageLinkSize: number; // número de enlaces en el paginador para poder navegar hacia delante o detrás\n  itemsPerPage: number = BaseFilter.RESULTADOS_PAGE; // número de elementos por página que mostramos\n\n  maxCurrentItems: number = -1;\n\n  constructor(private translateService: TranslateService,\n              private changeRef: ChangeDetectorRef) {\n  }\n\n  ngOnInit(): void {\n    if (this.typeFooter == undefined) {\n      this.typeFooter = \"list\";\n    }\n    if (this.paginator == undefined) {\n      this.paginator = false;\n    }\n    //mensajes por defecto si no vienen definidos\n    if (this.messages == undefined) {\n      this.setMessages();\n      this.messages.set(PageStatus.Error, \"bitnglibrary.footer.error\");\n    }\n  }\n\n  private setMessages() {\n    console.log(\"definimos los mensajes del footer de manera estándar\");\n    this.messages = new Map<PageStatus, string>();\n    if (this.isFooterList() || this.isFooterScroll()) {\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.list.init\");\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.list.searching\");\n      this.messages.set(PageStatus.EmptyResult, \"bitnglibrary.footer.list.emptyresult\");\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.list.finishsearch\");\n      this.messages.set(BitFooterComponent.MORE_RESULTS, \"bitnglibrary.footer.list.moreresults\")\n    } else if (this.isFooterForm()) {\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.form.init\");\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.form.searching\");\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.form.finishsearch\");\n      this.messages.set(PageStatus.ReadOnly, \"bitnglibrary.footer.list.readonly\");\n    } else if (this.typeFooter === BitFooterComponent.TYPE_BLANK) {\n      console.log(\"the footer is BLANK!\");\n    }\n  }\n\n  /**\n   * Cuando tengamos la referencia al componente paginator actualizamos internamente el número de página y el número de páginas\n   * del desplegable con la información del filtro proporcionado\n   */\n  ngAfterViewInit() {\n    if (this.pc) {\n      this.itemsPerPage = this.filter.resultados;\n      console.log(`this.filter.resultados ${this.filter.resultados}`);\n      console.log(`this.filter.pagina ${this.filter.pagina}`);\n      this.pc.rows = this.filter.resultados;\n      this.pc._first = (this.filter.pagina - 1) * this.pc.rows;\n      this.pc.updatePageLinks();\n    }\n  }\n\n  /**\n   * Escucharemos a cambios en las propiedades totalItems para actualizar el paginador con respecto a las páginas que mostramos\n   */\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    for (let propName in changes) {\n      let changedProp = changes[propName];\n      if (propName === \"status\") {\n        this.status = changedProp.currentValue;\n        console.log(`new status ${this.status}`);\n      } else if (propName === \"totalItems\") {\n        this.totalItems = changedProp.currentValue;\n        console.log(`new totalItems ${this.totalItems}`);\n        if (changedProp.previousValue !== changedProp.currentValue) {\n          this.calculatePageLinkSize();     //recalculamos\n        }\n        this.maxCurrentItems = this.filter ? this.filter.pagina * this.filter.resultados : -1;\n      } else if (propName === \"filter\") {\n        this.filter = changedProp.currentValue;\n        if (this.filter?.pagina * this.filter?.resultados > this.maxCurrentItems) {\n          this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;\n        }\n        console.log(`new filter ${this.filter?.pagina} - ${this.maxCurrentItems}`);\n        if (changedProp.previousValue !== changedProp.currentValue) {\n          this.calculatePageLinkSize();     //recalculamos\n          if (!this.filter?.pagina || this.filter.pagina <= 1) {\n            this.goToFirstPage();\n          }\n        }\n      }\n    }\n    if (this.pc && this.changeRef) {\n      console.log('updatePageLinks');\n      this.pc.updatePageLinks();\n      this.changeRef.detectChanges();\n    }\n  }\n\n  showFooter() {\n    return this.typeFooter === 'list' && this.status == PageStatus.FinishSearch;\n  }\n\n  showScroll(): boolean {\n    return this.typeFooter === 'scroll' && this.status != null;\n  }\n\n  /** Calcula el número de enlaces visibles en el paginador (en el rango entre 1 y BASE_RESULTADOS_PAGE). */\n  calculatePageLinkSize() {\n    console.log(`calculatePageLinkSize totalItems: ${this.totalItems} itemsPerPage:${this.itemsPerPage}`);\n    this.pageLinkSize = Math.ceil(this.totalItems / this.itemsPerPage);\n    if (this.pageLinkSize < 1) {\n      this.pageLinkSize = 1;\n    }\n    if (this.pageLinkSize > BASE_RESULTADOS_PAGE) {\n      this.pageLinkSize = BASE_RESULTADOS_PAGE;\n    }\n  }\n\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 */\n  paginate(event: any): void {\n    console.log(\"Page changed to\", event.page);\n    if (event.rows !== this.itemsPerPage) {\n      // han cambiado el número de elementos por página\n      //notificamos que los elementos por página han cambiado\n      this.onNewPageSize.emit(event.rows);\n      this.itemsPerPage = event.rows;\n      this.goToFirstPage();\n      this.calculatePageLinkSize(); // recalculamos el número de enlaces de página\n    } else {\n      // notificamos a nuestro papá que la página ha cambiado\n      this.onPageChange.emit(event.page + 1);\n    }\n  }\n\n  private goToFirstPage() {\n    if (this.pc) {\n      //volvemos a la primera página\n      this.pc._first = 1;\n      this.pc.updatePageLinks();\n    }\n  }\n\n  getStyle() {\n    if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {\n      if (this.totalItems > 0) {\n        return \"footer navbar-fixed-bottom\";\n      } else {\n        return \"footer navbar-fixed-bottom-60\";\n      }\n    } else if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_FORM) {\n      return \"footer navbar-fixed-bottom-form\";\n    } else {\n      return \"footer\";\n    }\n  }\n\n  isFooterList() {\n    return this.typeFooter === BitFooterComponent.TYPE_LIST;\n  }\n\n  isFooterScroll() {\n    return this.typeFooter === BitFooterComponent.TYPE_SCROLL;\n  }\n\n  isFooterForm() {\n    return this.typeFooter === BitFooterComponent.TYPE_FORM;\n  }\n\n  /** Flag: la página está realizando la búsqueda. */\n  get searchInitiated() {\n    return this.status === PageStatus.Init || this.status == PageStatus.Reset || !this.status;\n  }\n\n  /** Flag: la página está realizando la búsqueda. */\n  get searching() {\n    return this.status === PageStatus.Searching;\n  }\n\n  /** Flag: la página ha finalizado la última búsqueda. */\n  get searchFinished() {\n    return this.status === PageStatus.FinishSearch;\n  }\n\n  /** Flag: la página está en modo solo lectura */\n  get readOnly() {\n    return this.status == PageStatus.ReadOnly;\n  }\n\n  /** Flag: la página ha finalizado con error */\n  get error() {\n    return this.status == PageStatus.Error;\n  }\n\n  /** Flag: encontrado resultado. */\n  get foundResult() {\n    return (\n      this.status === PageStatus.FinishSearch &&\n      ((this.typeFooter === BitFooterComponent.TYPE_LIST && this.totalItems > 0)\n        || this.typeFooter === BitFooterComponent.TYPE_FORM\n        || (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems <= this.maxCurrentItems))\n    );\n  }\n\n  /** Flag: hay más resultados (scroll). */\n  get moreResults() {\n    return (\n      this.status === PageStatus.FinishSearch &&\n      (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems > this.maxCurrentItems)\n    );\n  }\n\n  /** Flag: no hay resultados. */\n  get emptyResult() {\n    return this.status === PageStatus.FinishSearch && this.totalItems === 0;\n  }\n\n  get initMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Init));\n  }\n\n  get searchingMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Searching));\n  }\n\n  get finishMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.FinishSearch));\n  }\n\n  get moreResultsMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(BitFooterComponent.MORE_RESULTS));\n  }\n\n  get emptyMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.EmptyResult));\n  }\n\n  get readOnlyMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.ReadOnly));\n  }\n\n  get errorMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Error));\n  }\n}\n","<footer [class]=\"getStyle()\">\n  <div class=\"grid\">\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"showFooter()\">\n      <div class=\"numero-resultados\">\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\n        <span>{{totalItems}}</span>\n      </div>\n    </div>\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"showScroll()\">\n      <div class=\"numero-resultados-scroll\">\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\n        <span *ngIf=\"maxCurrentItems >= totalItems\">{{totalItems}}</span>\n        <span *ngIf=\"maxCurrentItems < totalItems\">{{maxCurrentItems}} / {{totalItems}}</span>\n      </div>\n    </div>\n\n    <div class=\"col-12 md:col-7 lg:col-7 p-text-center\" *ngIf=\"showScroll()\">\n      <p-paginator *ngIf=\"paginator\" #pc\n                   [rows]=\"itemsPerPage\"\n                   [totalRecords]=\"totalItems\"\n                   [pageLinkSize]=\"mostrarEnlacesPaginas ? pageLinkSize : 1\"\n                   [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\n                   [showPageLinks]=\"true\"\n                   [showJumpToPageDropdown]=\"false\"\n                   [showFirstLastIcon]=\"mostrarPrimeraUltimaPagina ? true : maxCurrentItems >= totalItems\"\n                   (onPageChange)=\"paginate($event)\"></p-paginator>\n    </div>\n    <div class=\"col-12 md:col-3 lg:col-3\">\n      <div *ngIf=\"searchInitiated\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-info\"></i>\n        <span>{{initMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"searching\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-info\"></i>\n        <span>{{searchingMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"readOnly\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-info\"></i>\n        <span>{{readOnlyMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"foundResult\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-info\"></i>\n        <span>{{finishMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"moreResults\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-info\"></i>\n        <span>{{moreResultsMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"emptyResult\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-exclamation\"></i>\n        <span>{{emptyMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"error\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-exclamation-triangle\"></i>\n        <span>{{errorMessage | async}}</span>\n      </div>\n\n      <bit-help></bit-help>\n    </div>\n  </div>\n</footer>\n"]}
|
|
263
|
+
//# 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 {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChange,\n} from \"@angular/core\";\nimport {Observable} from \"rxjs\";\nimport { BaseFilter, BASE_RESULTADOS_PAGE } from \"../../../base/shared/base.filter\";\nimport { PageStatus } from \"../../global.constants\";\nimport { TranslateService } from \"../../services\";\n\n/**\n * Componente que muestra un paginador en la sección footer.\n **/\n@Component({\n  selector: \"bit-footer\",\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: \"bit-footer.component.html\"\n})\nexport class BitFooterComponent implements OnInit, OnChanges {\n  public static TYPE_LIST: string = \"list\";\n  public static TYPE_SCROLL: string = \"scroll\";\n  public static TYPE_FORM: string = \"form\";\n  public static TYPE_BLANK: string = \"blank\";\n\n  public static MORE_RESULTS = -1;\n\n  @Input()\n  totalItems: number;     // Número total de elementos recuperados de la consulta\n  @Input()\n  filter: BaseFilter;\n  @Input()\n  paginator: boolean;\n  @Input()\n  mostrarAvisos: boolean = true;\n  @Input()\n  fixed: boolean = true; // Indicará si lo queremos fijo abajo en la página. Por defecto sí.\n  @Input()\n  messages: Map<PageStatus, string>;\n  @Input()\n  status: PageStatus = PageStatus.Init; // Determina en qué estado está la página: PageStatus.Init, PageStatus.SEARCHING, PageStatus.FINISH_SEARCH\n  @Input(\"type\")\n  typeFooter: string;\n  @Input()\n  mostrarEnlacesPaginas: boolean = true;\n  @Input()\n  mostrarPrimeraUltimaPagina: boolean = true;\n  @Input()\n  visible: boolean = true;\n  @Input()\n  forcePageLinkSize: number = 1; // número de enlaces en el paginador para poder navegar hacia delante o detrás que forzamos a que haya\n  @Output()\n  onPageChange = new EventEmitter<number>(); //para notificar cambios en la página a mostrar\n  @Output()\n  onNewPageSize = new EventEmitter<number>(); //para notificar cambios en los elementos a mostrar por página\n\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\n  itemsPerPage: number = BaseFilter.RESULTADOS_PAGE; // número de elementos por página que mostramos\n  first: number;\n  pageLinkSize: number; // número de enlaces en el paginador para poder navegar hacia delante o detrás\n  maxCurrentItems: number = -1;\n\n  constructor(private translateService: TranslateService) {\n  }\n\n  ngOnInit(): void {\n    if (this.typeFooter == undefined) {\n      this.typeFooter = \"list\";\n    }\n    if (this.paginator == undefined) {\n      this.paginator = false;\n    }\n    //mensajes por defecto si no vienen definidos\n    if (this.messages == undefined) {\n      this.setMessages();\n      this.messages.set(PageStatus.Error, \"bitnglibrary.footer.error\");\n    }\n  }\n\n  private setMessages() {\n    console.log(\"definimos los mensajes del footer de manera estándar\");\n    this.messages = new Map<PageStatus, string>();\n    if (this.isFooterList() || this.isFooterScroll()) {\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.list.init\");\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.list.searching\");\n      this.messages.set(PageStatus.EmptyResult, \"bitnglibrary.footer.list.emptyresult\");\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.list.finishsearch\");\n      this.messages.set(BitFooterComponent.MORE_RESULTS, \"bitnglibrary.footer.list.moreresults\")\n    } else if (this.isFooterForm()) {\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.form.init\");\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.form.searching\");\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.form.finishsearch\");\n      this.messages.set(PageStatus.ReadOnly, \"bitnglibrary.footer.list.readonly\");\n    } else if (this.typeFooter === BitFooterComponent.TYPE_BLANK) {\n      console.log(\"the footer is BLANK!\");\n    }\n  }\n\n  /**\n   * Escucharemos a cambios en las propiedades totalItems para actualizar el paginador con respecto a las páginas que mostramos\n   */\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    for (let propName in changes) {\n      let changedProp = changes[propName];\n      if (propName === \"status\") {\n        this.status = changedProp.currentValue;\n        console.log(\"status:\" + this.status);\n      } else if (propName === \"totalItems\") {\n        this.totalItems = changedProp.currentValue;\n        console.log(\"totalItems:\" + this.totalItems);\n        if (changedProp.previousValue !== changedProp.currentValue) {\n          this.calculatePageLinkSize();     //recalculamos\n        }\n        this.calculateMaxCurrentItems();\n      } else if (propName === \"filter\") {\n        this.filter = changedProp.currentValue;\n        this.calculateMaxCurrentItems();\n        if (changedProp.previousValue !== changedProp.currentValue) {\n          this.calculatePageLinkSize();     //recalculamos\n          if (!this.filter?.pagina || this.filter.pagina <= 1) {\n            this.goToFirstPage();\n            console.log(\"goToFirstPage\");\n          }\n        }\n        this.first = (this.filter.pagina - 1) * this.filter.resultados;\n        console.log(\"first:\" + this.first);\n      }\n    }\n  }\n\n  showFooter() {\n    // Problema. Estamos obteniendo un status a null cuando regresamos de una ficha\n    // status es null porque realmente no se está lanzando ninguna búsqueda por lo que el método updatePageStatus retorna  null\n    return this.typeFooter === 'list' && this.visible;\n  }\n\n  showScroll(): boolean {\n    return this.typeFooter === 'scroll' && this.visible;\n  }\n\n  /** Calcula el número de enlaces visibles en el paginador (en el rango entre 1 y BASE_RESULTADOS_PAGE). */\n  calculatePageLinkSize() {\n    if (this.forcePageLinkSize == 0) {\n      console.log(`calculatePageLinkSize totalItems: ${this.totalItems} itemsPerPage:${this.itemsPerPage}`);\n      this.pageLinkSize = Math.ceil(this.totalItems / this.itemsPerPage);\n      if (this.pageLinkSize < 1) {\n        this.pageLinkSize = 1;\n      }\n      if (this.pageLinkSize > BASE_RESULTADOS_PAGE) {\n        this.pageLinkSize = BASE_RESULTADOS_PAGE;\n      }\n    } else {\n      this.pageLinkSize = this.forcePageLinkSize;\n    }\n    console.log(\"pageLinkSize\", this.pageLinkSize);\n  }\n\n  calculateMaxCurrentItems() {\n    this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;\n    if (this.maxCurrentItems > this.totalItems) {\n      this.maxCurrentItems = this.totalItems;\n    }\n  }\n\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 */\n  paginate(event: any): void {\n    console.log(\"Page changed to:\" + event.page + \" maxCurrentItems:\" + this.maxCurrentItems + \" firstElement:\" + this.first);\n    if (event.rows !== this.itemsPerPage) {\n      // han cambiado el número de elementos por página\n      //notificamos que los elementos por página han cambiado\n      this.onNewPageSize.emit(event.rows);\n      this.itemsPerPage = event.rows;\n      this.goToFirstPage();\n      this.calculatePageLinkSize(); // recalculamos el número de enlaces de página\n    } else {\n      // notificamos a nuestro papá que la página ha cambiado\n      this.onPageChange.emit(event.page + 1);\n    }\n  }\n\n  private goToFirstPage() {\n    this.first = 1;\n  }\n\n  getStyle() {\n    if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {\n      return \"footer navbar-fixed-bottom\";\n    } else if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_FORM) {\n      return \"footer navbar-fixed-bottom-form\";\n    } else {\n      return \"footer\";\n    }\n  }\n\n  isFooterList() {\n    return this.typeFooter === BitFooterComponent.TYPE_LIST;\n  }\n\n  isFooterScroll() {\n    return this.typeFooter === BitFooterComponent.TYPE_SCROLL;\n  }\n\n  isFooterForm() {\n    return this.typeFooter === BitFooterComponent.TYPE_FORM;\n  }\n\n  /** Flag: la página está realizando la búsqueda. */\n  get searchInitiated() {\n    return this.status === PageStatus.Init || this.status == PageStatus.Reset || !this.status;\n  }\n\n  /** Flag: la página está realizando la búsqueda. */\n  get searching() {\n    return this.status === PageStatus.Searching;\n  }\n\n  /** Flag: la página ha finalizado la última búsqueda. */\n  get searchFinished() {\n    return this.status === PageStatus.FinishSearch;\n  }\n\n  /** Flag: la página está en modo solo lectura */\n  get readOnly() {\n    return this.status == PageStatus.ReadOnly;\n  }\n\n  /** Flag: la página ha finalizado con error */\n  get error() {\n    return this.status == PageStatus.Error;\n  }\n\n  /** Flag: encontrado resultado. */\n  get foundResult() {\n    return (\n      this.status === PageStatus.FinishSearch &&\n      ((this.typeFooter === BitFooterComponent.TYPE_LIST && this.totalItems > 0)\n        || this.typeFooter === BitFooterComponent.TYPE_FORM\n        || (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems <= this.maxCurrentItems))\n    );\n  }\n\n  /** Flag: hay más resultados (scroll). */\n  get moreResults() {\n    return (\n      this.status === PageStatus.FinishSearch &&\n      (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems > this.maxCurrentItems)\n    );\n  }\n\n  /** Flag: no hay resultados. */\n  get emptyResult() {\n    return this.status === PageStatus.FinishSearch && this.totalItems === 0;\n  }\n\n  get initMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Init));\n  }\n\n  get searchingMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Searching));\n  }\n\n  get finishMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.FinishSearch));\n  }\n\n  get moreResultsMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(BitFooterComponent.MORE_RESULTS));\n  }\n\n  get emptyMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.EmptyResult));\n  }\n\n  get readOnlyMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.ReadOnly));\n  }\n\n  get errorMessage(): Observable<string> {\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Error));\n  }\n}\n","<footer [class]=\"getStyle()\">\n  <div class=\"grid\">\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"showFooter()\">\n      <div class=\"numero-resultados\">\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\n        <span>{{maxCurrentItems}} / {{totalItems}}</span>\n      </div>\n    </div>\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"showScroll()\">\n      <div class=\"numero-resultados-scroll\">\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\n        <span *ngIf=\"maxCurrentItems >= totalItems\">{{totalItems}}</span>\n        <span *ngIf=\"maxCurrentItems < totalItems\">{{maxCurrentItems}} / {{totalItems}}</span>\n      </div>\n    </div>\n\n    <div class=\"col-12 md:col-7 lg:col-7 p-text-center\" *ngIf=\"showFooter()\">\n      <p-paginator *ngIf=\"paginator\"\n          [first]=\"first\"\n          [rows]=\"itemsPerPage\"\n          [totalRecords]=\"totalItems\"\n          [pageLinkSize]=\"mostrarEnlacesPaginas ? pageLinkSize : 1\"\n          [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\n          [showPageLinks]=\"mostrarEnlacesPaginas\"\n          [showJumpToPageDropdown]=\"false\"\n          [showFirstLastIcon]=\"mostrarPrimeraUltimaPagina ? true : maxCurrentItems >= totalItems\"\n          (onPageChange)=\"paginate($event)\"></p-paginator>\n    </div>\n    <div class=\"col-12 md:col-3 lg:col-3\">\n      <div *ngIf=\"searchInitiated\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-info\"></i>\n        <span>{{initMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"searching\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-info\"></i>\n        <span>{{searchingMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"readOnly\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-info\"></i>\n        <span>{{readOnlyMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"foundResult\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-info\"></i>\n        <span>{{finishMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"moreResults\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-info\"></i>\n        <span>{{moreResultsMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"emptyResult\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-exclamation\"></i>\n        <span>{{emptyMessage | async}}</span>\n      </div>\n\n      <div *ngIf=\"error\"\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\n        <i class=\"fa fa-exclamation-triangle\"></i>\n        <span>{{errorMessage | async}}</span>\n      </div>\n\n      <bit-help></bit-help>\n    </div>\n  </div>\n</footer>\n"]}
|