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 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, ViewChild } from "@angular/core";
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, changeRef) {
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(`new status ${this.status}`);
70
+ console.log("status:" + this.status);
84
71
  }
85
72
  else if (propName === "totalItems") {
86
73
  this.totalItems = changedProp.currentValue;
87
- console.log(`new totalItems ${this.totalItems}`);
74
+ console.log("totalItems:" + this.totalItems);
88
75
  if (changedProp.previousValue !== changedProp.currentValue) {
89
76
  this.calculatePageLinkSize(); //recalculamos
90
77
  }
91
- this.maxCurrentItems = this.filter ? this.filter.pagina * this.filter.resultados : -1;
78
+ this.calculateMaxCurrentItems();
92
79
  }
93
80
  else if (propName === "filter") {
94
81
  this.filter = changedProp.currentValue;
95
- if (this.filter?.pagina * this.filter?.resultados > this.maxCurrentItems) {
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
- return this.typeFooter === 'list' && this.status == PageStatus.FinishSearch;
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.status != null;
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
- console.log(`calculatePageLinkSize totalItems: ${this.totalItems} itemsPerPage:${this.itemsPerPage}`);
122
- this.pageLinkSize = Math.ceil(this.totalItems / this.itemsPerPage);
123
- if (this.pageLinkSize < 1) {
124
- this.pageLinkSize = 1;
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
- if (this.pageLinkSize > BASE_RESULTADOS_PAGE) {
127
- this.pageLinkSize = BASE_RESULTADOS_PAGE;
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", event.page);
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
- if (this.pc) {
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
- if (this.totalItems > 0) {
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 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
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" }, outputs: { onPageChange: "onPageChange", onNewPageSize: "onNewPageSize" }, viewQueries: [{ propertyName: "pc", first: true, predicate: ["pc"], descendants: true }], 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>{{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", 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 });
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=\"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" }]
246
- }], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { pc: [{
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"]}