bit-ng-library 13.1.1 → 13.1.2
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 +4 -0
- package/esm2020/lib/sharedlibrary/components/footer/bit-footer.component.mjs +18 -8
- package/fesm2015/bit-ng-library.mjs +18 -8
- package/fesm2015/bit-ng-library.mjs.map +1 -1
- package/fesm2020/bit-ng-library.mjs +17 -7
- package/fesm2020/bit-ng-library.mjs.map +1 -1
- package/lib/sharedlibrary/components/footer/bit-footer.component.d.ts +1 -0
- package/lib/sharedlibrary/components/footer/bit-footer.component.d.ts.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -26,6 +26,10 @@ To get more help on the Angular CLI use `ng help` or go check out the [Angular C
|
|
|
26
26
|
|
|
27
27
|
## changelog
|
|
28
28
|
|
|
29
|
+
## [13.1.2] - 2022-05-09
|
|
30
|
+
|
|
31
|
+
Corregido bug de bug en bit-footer al volver de un formulario a la lista, momento en que desaparecía el footer. (la solución completa del bug requiere de cambios en base-list-filter.component.ts de los proyectos)
|
|
32
|
+
|
|
29
33
|
## [13.1.1] - 2022-02-22
|
|
30
34
|
|
|
31
35
|
Corregido bug de CustomValidators cuando se usaba en forms con diversos campos de longitud limitada. Se mostraba siempre el mismo mensaje para todos, aunque se especificase un validador con longitud diferente en cada campo.
|
|
@@ -80,7 +80,9 @@ export class BitFooterComponent {
|
|
|
80
80
|
if (propName === "totalItems") {
|
|
81
81
|
this.totalItems = changedProp.currentValue;
|
|
82
82
|
console.log(`new totalItems ${this.totalItems}`);
|
|
83
|
-
changedProp.previousValue !== changedProp.currentValue
|
|
83
|
+
if (changedProp.previousValue !== changedProp.currentValue) {
|
|
84
|
+
this.calculatePageLinkSize(); //recalculamos
|
|
85
|
+
}
|
|
84
86
|
this.maxCurrentItems = this.filter ? this.filter.pagina * this.filter.resultados : -1;
|
|
85
87
|
}
|
|
86
88
|
else if (propName === "filter") {
|
|
@@ -89,7 +91,12 @@ export class BitFooterComponent {
|
|
|
89
91
|
this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;
|
|
90
92
|
}
|
|
91
93
|
console.log(`new filter ${this.filter?.pagina} - ${this.maxCurrentItems}`);
|
|
92
|
-
changedProp.previousValue !== changedProp.currentValue
|
|
94
|
+
if (changedProp.previousValue !== changedProp.currentValue) {
|
|
95
|
+
this.calculatePageLinkSize(); //recalculamos
|
|
96
|
+
if (!this.filter?.pagina || this.filter.pagina <= 1) {
|
|
97
|
+
this.goToFirstPage();
|
|
98
|
+
}
|
|
99
|
+
}
|
|
93
100
|
}
|
|
94
101
|
}
|
|
95
102
|
if (this.pc && this.changeRef) {
|
|
@@ -117,11 +124,7 @@ export class BitFooterComponent {
|
|
|
117
124
|
//notificamos que los elementos por página han cambiado
|
|
118
125
|
this.onNewPageSize.emit(event.rows);
|
|
119
126
|
this.itemsPerPage = event.rows;
|
|
120
|
-
|
|
121
|
-
//volvemos a la primera página
|
|
122
|
-
this.pc._first = 1;
|
|
123
|
-
this.pc.updatePageLinks();
|
|
124
|
-
}
|
|
127
|
+
this.goToFirstPage();
|
|
125
128
|
this.calculatePageLinkSize(); // recalculamos el número de enlaces de página
|
|
126
129
|
}
|
|
127
130
|
else {
|
|
@@ -129,6 +132,13 @@ export class BitFooterComponent {
|
|
|
129
132
|
this.onPageChange.emit(event.page + 1);
|
|
130
133
|
}
|
|
131
134
|
}
|
|
135
|
+
goToFirstPage() {
|
|
136
|
+
if (this.pc) {
|
|
137
|
+
//volvemos a la primera página
|
|
138
|
+
this.pc._first = 1;
|
|
139
|
+
this.pc.updatePageLinks();
|
|
140
|
+
}
|
|
141
|
+
}
|
|
132
142
|
getStyle() {
|
|
133
143
|
if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {
|
|
134
144
|
if (this.totalItems > 0) {
|
|
@@ -251,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
251
261
|
}], onNewPageSize: [{
|
|
252
262
|
type: Output
|
|
253
263
|
}] } });
|
|
254
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-footer.component.js","sourceRoot":"","sources":["../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/footer/bit-footer.component.ts","../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/footer/bit-footer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  SimpleChange,\r\n  ViewChild\r\n} from \"@angular/core\";\r\nimport {Paginator} from \"primeng/paginator\";\r\nimport {Observable} from \"rxjs\";\r\nimport { BASE_RESULTADOS_PAGE, BaseFilter } from '../../../base/shared/base.filter';\r\nimport { PageStatus } from '../../global.constants';\r\nimport { TranslateService } from '../../services';\r\n\r\n\r\n/**\r\n * Componente que muestra un paginador en la sección footer.\r\n **/\r\n@Component({\r\n  selector: \"bit-footer\",\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  templateUrl: \"bit-footer.component.html\"\r\n})\r\nexport class BitFooterComponent implements OnInit, OnChanges {\r\n  public static TYPE_LIST: string = \"list\";\r\n  public static TYPE_SCROLL: string = \"scroll\";\r\n  public static TYPE_FORM: string = \"form\";\r\n  public static TYPE_BLANK: string = \"blank\";\r\n\r\n  public static MORE_RESULTS = -1;\r\n\r\n  @ViewChild(\"pc\")\r\n  pc: Paginator;\r\n  @Input()\r\n  totalItems: number;     // Número total de elementos recuperados de la consulta\r\n  @Input()\r\n  filter: BaseFilter;\r\n  @Input()\r\n  paginator: boolean;\r\n  @Input()\r\n  mostrarAvisos: boolean = true;\r\n  @Input()\r\n  fixed: boolean = true; // Indicará si lo queremos fijo abajo en la página. Por defecto sí.\r\n  @Input()\r\n  messages: Map<PageStatus, string>;\r\n  @Input()\r\n  status: PageStatus; // Determina en qué estado está la página: PageStatus.Init, PageStatus.SEARCHING, PageStatus.FINISH_SEARCH\r\n  @Input(\"type\")\r\n  typeFooter: string;\r\n  @Input()\r\n  mostrarEnlacesPaginas: boolean = true;\r\n  @Input()\r\n  mostrarPrimeraUltimaPagina: boolean = true;\r\n  @Output()\r\n  onPageChange = new EventEmitter<number>(); //para notificar cambios en la página a mostrar\r\n  @Output()\r\n  onNewPageSize = new EventEmitter<number>(); //para notificar cambios en los elementos a mostrar por página\r\n\r\n  baseItemsPerPage: number = BaseFilter.RESULTADOS_PAGE; // guardamos el número de resultados pre-configurados por página para mostrar la lista de x, x+10 y x+20\r\n  pageLinkSize: number; // número de enlaces en el paginador para poder navegar hacia delante o detrás\r\n  itemsPerPage: number = BaseFilter.RESULTADOS_PAGE; // número de elementos por página que mostramos\r\n\r\n  maxCurrentItems: number = -1;\r\n\r\n  constructor(private translateService: TranslateService,\r\n              private changeRef: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.typeFooter == undefined) {\r\n      this.typeFooter = \"list\";\r\n    }\r\n    if (this.paginator == undefined) {\r\n      this.paginator = false;\r\n    }\r\n    //mensajes por defecto si no vienen definidos\r\n    if (this.messages == undefined) {\r\n      this.setMessages();\r\n      this.messages.set(PageStatus.Error, \"bitnglibrary.footer.error\");\r\n    }\r\n  }\r\n\r\n  private setMessages() {\r\n    console.log(\"definimos los mensajes del footer de manera estándar\");\r\n    this.messages = new Map<PageStatus, string>();\r\n    if (this.isFooterList() || this.isFooterScroll()) {\r\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.list.init\");\r\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.list.searching\");\r\n      this.messages.set(PageStatus.EmptyResult, \"bitnglibrary.footer.list.emptyresult\");\r\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.list.finishsearch\");\r\n      this.messages.set(BitFooterComponent.MORE_RESULTS, \"bitnglibrary.footer.list.moreresults\")\r\n    } else if (this.isFooterForm()) {\r\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.form.init\");\r\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.form.searching\");\r\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.form.finishsearch\");\r\n      this.messages.set(PageStatus.ReadOnly, \"bitnglibrary.footer.list.readonly\");\r\n    } else if (this.typeFooter === BitFooterComponent.TYPE_BLANK) {\r\n      console.log(\"the footer is BLANK!\");\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cuando tengamos la referencia al componente paginator actualizamos internamente el número de página y el número de páginas\r\n   * del desplegable con la información del filtro proporcionado\r\n   */\r\n  ngAfterViewInit() {\r\n    if (this.pc) {\r\n      this.itemsPerPage = this.filter.resultados;\r\n      console.log(`this.filter.resultados ${this.filter.resultados}`);\r\n      console.log(`this.filter.pagina ${this.filter.pagina}`);\r\n      this.pc.rows = this.filter.resultados;\r\n      this.pc._first = (this.filter.pagina - 1) * this.pc.rows;\r\n      this.pc.updatePageLinks();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Escucharemos a cambios en las propiedades totalItems para actualizar el paginador con respecto a las páginas que mostramos\r\n   */\r\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\r\n    for (let propName in changes) {\r\n      let changedProp = changes[propName];\r\n      if (propName === \"totalItems\") {\r\n        this.totalItems = changedProp.currentValue;\r\n        console.log(`new totalItems ${this.totalItems}`);\r\n        changedProp.previousValue !== changedProp.currentValue ? this.calculatePageLinkSize() : undefined; //recalculamos\r\n        this.maxCurrentItems = this.filter ? this.filter.pagina * this.filter.resultados : -1;\r\n      } else if (propName === \"filter\") {\r\n        this.filter = changedProp.currentValue;\r\n        if (this.filter?.pagina * this.filter?.resultados > this.maxCurrentItems) {\r\n          this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;\r\n        }\r\n        console.log(`new filter ${this.filter?.pagina} - ${this.maxCurrentItems}`);\r\n        changedProp.previousValue !== changedProp.currentValue ? this.calculatePageLinkSize() : undefined; //recalculamos\r\n      }\r\n    }\r\n    if (this.pc && this.changeRef) {\r\n      console.log('updatePageLinks');\r\n      this.pc.updatePageLinks();\r\n      this.changeRef.detectChanges();\r\n    }\r\n  }\r\n\r\n  /** Calcula el número de enlaces visibles en el paginador (en el rango entre 1 y BASE_RESULTADOS_PAGE). */\r\n  calculatePageLinkSize() {\r\n    console.log(`calculatePageLinkSize totalItems: ${this.totalItems} itemsPerPage:${this.itemsPerPage}`);\r\n    this.pageLinkSize = Math.ceil(this.totalItems / this.itemsPerPage);\r\n    if (this.pageLinkSize < 1) {\r\n      this.pageLinkSize = 1;\r\n    }\r\n    if (this.pageLinkSize > BASE_RESULTADOS_PAGE) {\r\n      this.pageLinkSize = BASE_RESULTADOS_PAGE;\r\n    }\r\n  }\r\n\r\n  /** Establece el número de página en la visualización de resultados. Se invoca cuando el usuario cambia el número de resultados a mostrar o cambia de página */\r\n  paginate(event: any): void {\r\n    console.log(\"Page changed to\", event.page);\r\n    if (event.rows !== this.itemsPerPage) {\r\n      // han cambiado el número de elementos por página\r\n      //notificamos que los elementos por página han cambiado\r\n      this.onNewPageSize.emit(event.rows);\r\n      this.itemsPerPage = event.rows;\r\n      if (this.pc) {\r\n        //volvemos a la primera página\r\n        this.pc._first = 1;\r\n        this.pc.updatePageLinks();\r\n      }\r\n      this.calculatePageLinkSize(); // recalculamos el número de enlaces de página\r\n    } else {\r\n      // notificamos a nuestro papá que la página ha cambiado\r\n      this.onPageChange.emit(event.page + 1);\r\n    }\r\n  }\r\n\r\n  getStyle() {\r\n    if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {\r\n      if (this.totalItems > 0) {\r\n        return \"footer navbar-fixed-bottom\";\r\n      } else {\r\n        return \"footer navbar-fixed-bottom-60\";\r\n      }\r\n    } else if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_FORM) {\r\n      return \"footer navbar-fixed-bottom-form\";\r\n    } else {\r\n      return \"footer\";\r\n    }\r\n  }\r\n\r\n  isFooterList() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_LIST;\r\n  }\r\n\r\n  isFooterScroll() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_SCROLL;\r\n  }\r\n\r\n  isFooterForm() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_FORM;\r\n  }\r\n\r\n  /** Flag: la página está realizando la búsqueda. */\r\n  get searchInitiated() {\r\n    return this.status === PageStatus.Init || this.status == PageStatus.Reset || !this.status;\r\n  }\r\n\r\n  /** Flag: la página está realizando la búsqueda. */\r\n  get searching() {\r\n    return this.status === PageStatus.Searching;\r\n  }\r\n\r\n  /** Flag: la página ha finalizado la última búsqueda. */\r\n  get searchFinished() {\r\n    return this.status === PageStatus.FinishSearch;\r\n  }\r\n\r\n  /** Flag: la página está en modo solo lectura */\r\n  get readOnly() {\r\n    return this.status == PageStatus.ReadOnly;\r\n  }\r\n\r\n  /** Flag: la página ha finalizado con error */\r\n  get error() {\r\n    return this.status == PageStatus.Error;\r\n  }\r\n\r\n  /** Flag: encontrado resultado. */\r\n  get foundResult() {\r\n    return (\r\n      this.status === PageStatus.FinishSearch &&\r\n      ((this.typeFooter === BitFooterComponent.TYPE_LIST && this.totalItems > 0)\r\n        || this.typeFooter === BitFooterComponent.TYPE_FORM\r\n        || (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems <= this.maxCurrentItems))\r\n    );\r\n  }\r\n\r\n  /** Flag: hay más resultados (scroll). */\r\n  get moreResults() {\r\n    return (\r\n      this.status === PageStatus.FinishSearch &&\r\n      (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems > this.maxCurrentItems)\r\n    );\r\n  }\r\n\r\n  /** Flag: no hay resultados. */\r\n  get emptyResult() {\r\n    return this.status === PageStatus.FinishSearch && this.totalItems === 0;\r\n  }\r\n\r\n  get initMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Init));\r\n  }\r\n\r\n  get searchingMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Searching));\r\n  }\r\n\r\n  get finishMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.FinishSearch));\r\n  }\r\n\r\n  get moreResultsMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(BitFooterComponent.MORE_RESULTS));\r\n  }\r\n\r\n  get emptyMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.EmptyResult));\r\n  }\r\n\r\n  get readOnlyMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.ReadOnly));\r\n  }\r\n\r\n  get errorMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Error));\r\n  }\r\n}\r\n","<footer [class]=\"getStyle()\">\r\n  <div class=\"grid\">\r\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"typeFooter === 'list'\" [hidden]=\"!this.status || emptyResult\">\r\n      <div class=\"numero-resultados\">\r\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\r\n        <span>{{totalItems}}</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"typeFooter === 'scroll'\" [hidden]=\"!this.status || emptyResult\">\r\n      <div class=\"numero-resultados-scroll\">\r\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\r\n        <span *ngIf=\"maxCurrentItems >= totalItems\">{{totalItems}}</span>\r\n        <span *ngIf=\"maxCurrentItems < totalItems\">{{maxCurrentItems}} / {{totalItems}}</span>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"col-12 md:col-7 lg:col-7 p-text-center\" *ngIf=\"typeFooter === 'list'\"\r\n         [hidden]=\"!this.status || emptyResult\">\r\n      <p-paginator *ngIf=\"paginator\" #pc\r\n                   [rows]=\"itemsPerPage\"\r\n                   [totalRecords]=\"totalItems\"\r\n                   [pageLinkSize]=\"mostrarEnlacesPaginas ? pageLinkSize : 1\"\r\n                   [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\r\n                   [showPageLinks]=\"true\"\r\n                   [showJumpToPageDropdown]=\"false\"\r\n                   [showFirstLastIcon]=\"mostrarPrimeraUltimaPagina ? true : maxCurrentItems >= totalItems\"\r\n                   (onPageChange)=\"paginate($event)\"></p-paginator>\r\n    </div>\r\n    <div class=\"col-12 md:col-3 lg:col-3\">\r\n      <div *ngIf=\"searchInitiated\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{initMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"searching\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{searchingMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"readOnly\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{readOnlyMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"foundResult\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{finishMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"moreResults\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{moreResultsMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"emptyResult\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-exclamation\"></i>\r\n        <span>{{emptyMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"error\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-exclamation-triangle\"></i>\r\n        <span>{{errorMessage | async}}</span>\r\n      </div>\r\n\r\n      <bit-help></bit-help>\r\n    </div>\r\n  </div>\r\n</footer>\r\n"]}
|
|
264
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-footer.component.js","sourceRoot":"","sources":["../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/footer/bit-footer.component.ts","../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/footer/bit-footer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  SimpleChange,\r\n  ViewChild\r\n} from \"@angular/core\";\r\nimport {Paginator} from \"primeng/paginator\";\r\nimport {Observable} from \"rxjs\";\r\nimport { BASE_RESULTADOS_PAGE, BaseFilter } from '../../../base/shared/base.filter';\r\nimport { PageStatus } from '../../global.constants';\r\nimport { TranslateService } from '../../services';\r\n\r\n\r\n/**\r\n * Componente que muestra un paginador en la sección footer.\r\n **/\r\n@Component({\r\n  selector: \"bit-footer\",\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  templateUrl: \"bit-footer.component.html\"\r\n})\r\nexport class BitFooterComponent implements OnInit, OnChanges {\r\n  public static TYPE_LIST: string = \"list\";\r\n  public static TYPE_SCROLL: string = \"scroll\";\r\n  public static TYPE_FORM: string = \"form\";\r\n  public static TYPE_BLANK: string = \"blank\";\r\n\r\n  public static MORE_RESULTS = -1;\r\n\r\n  @ViewChild(\"pc\")\r\n  pc: Paginator;\r\n  @Input()\r\n  totalItems: number;     // Número total de elementos recuperados de la consulta\r\n  @Input()\r\n  filter: BaseFilter;\r\n  @Input()\r\n  paginator: boolean;\r\n  @Input()\r\n  mostrarAvisos: boolean = true;\r\n  @Input()\r\n  fixed: boolean = true; // Indicará si lo queremos fijo abajo en la página. Por defecto sí.\r\n  @Input()\r\n  messages: Map<PageStatus, string>;\r\n  @Input()\r\n  status: PageStatus; // Determina en qué estado está la página: PageStatus.Init, PageStatus.SEARCHING, PageStatus.FINISH_SEARCH\r\n  @Input(\"type\")\r\n  typeFooter: string;\r\n  @Input()\r\n  mostrarEnlacesPaginas: boolean = true;\r\n  @Input()\r\n  mostrarPrimeraUltimaPagina: boolean = true;\r\n  @Output()\r\n  onPageChange = new EventEmitter<number>(); //para notificar cambios en la página a mostrar\r\n  @Output()\r\n  onNewPageSize = new EventEmitter<number>(); //para notificar cambios en los elementos a mostrar por página\r\n\r\n  baseItemsPerPage: number = BaseFilter.RESULTADOS_PAGE; // guardamos el número de resultados pre-configurados por página para mostrar la lista de x, x+10 y x+20\r\n  pageLinkSize: number; // número de enlaces en el paginador para poder navegar hacia delante o detrás\r\n  itemsPerPage: number = BaseFilter.RESULTADOS_PAGE; // número de elementos por página que mostramos\r\n\r\n  maxCurrentItems: number = -1;\r\n\r\n  constructor(private translateService: TranslateService,\r\n              private changeRef: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.typeFooter == undefined) {\r\n      this.typeFooter = \"list\";\r\n    }\r\n    if (this.paginator == undefined) {\r\n      this.paginator = false;\r\n    }\r\n    //mensajes por defecto si no vienen definidos\r\n    if (this.messages == undefined) {\r\n      this.setMessages();\r\n      this.messages.set(PageStatus.Error, \"bitnglibrary.footer.error\");\r\n    }\r\n  }\r\n\r\n  private setMessages() {\r\n    console.log(\"definimos los mensajes del footer de manera estándar\");\r\n    this.messages = new Map<PageStatus, string>();\r\n    if (this.isFooterList() || this.isFooterScroll()) {\r\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.list.init\");\r\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.list.searching\");\r\n      this.messages.set(PageStatus.EmptyResult, \"bitnglibrary.footer.list.emptyresult\");\r\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.list.finishsearch\");\r\n      this.messages.set(BitFooterComponent.MORE_RESULTS, \"bitnglibrary.footer.list.moreresults\")\r\n    } else if (this.isFooterForm()) {\r\n      this.messages.set(PageStatus.Init, \"bitnglibrary.footer.form.init\");\r\n      this.messages.set(PageStatus.Searching, \"bitnglibrary.footer.form.searching\");\r\n      this.messages.set(PageStatus.FinishSearch, \"bitnglibrary.footer.form.finishsearch\");\r\n      this.messages.set(PageStatus.ReadOnly, \"bitnglibrary.footer.list.readonly\");\r\n    } else if (this.typeFooter === BitFooterComponent.TYPE_BLANK) {\r\n      console.log(\"the footer is BLANK!\");\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cuando tengamos la referencia al componente paginator actualizamos internamente el número de página y el número de páginas\r\n   * del desplegable con la información del filtro proporcionado\r\n   */\r\n  ngAfterViewInit() {\r\n    if (this.pc) {\r\n      this.itemsPerPage = this.filter.resultados;\r\n      console.log(`this.filter.resultados ${this.filter.resultados}`);\r\n      console.log(`this.filter.pagina ${this.filter.pagina}`);\r\n      this.pc.rows = this.filter.resultados;\r\n      this.pc._first = (this.filter.pagina - 1) * this.pc.rows;\r\n      this.pc.updatePageLinks();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Escucharemos a cambios en las propiedades totalItems para actualizar el paginador con respecto a las páginas que mostramos\r\n   */\r\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\r\n    for (let propName in changes) {\r\n      let changedProp = changes[propName];\r\n      if (propName === \"totalItems\") {\r\n        this.totalItems = changedProp.currentValue;\r\n        console.log(`new totalItems ${this.totalItems}`);\r\n        if (changedProp.previousValue !== changedProp.currentValue) {\r\n          this.calculatePageLinkSize();     //recalculamos\r\n        }\r\n        this.maxCurrentItems = this.filter ? this.filter.pagina * this.filter.resultados : -1;\r\n      } else if (propName === \"filter\") {\r\n        this.filter = changedProp.currentValue;\r\n        if (this.filter?.pagina * this.filter?.resultados > this.maxCurrentItems) {\r\n          this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;\r\n        }\r\n        console.log(`new filter ${this.filter?.pagina} - ${this.maxCurrentItems}`);\r\n        if (changedProp.previousValue !== changedProp.currentValue) {\r\n          this.calculatePageLinkSize();     //recalculamos\r\n          if (!this.filter?.pagina || this.filter.pagina <= 1) {\r\n            this.goToFirstPage();\r\n          }\r\n        }\r\n      }\r\n    }\r\n    if (this.pc && this.changeRef) {\r\n      console.log('updatePageLinks');\r\n      this.pc.updatePageLinks();\r\n      this.changeRef.detectChanges();\r\n    }\r\n  }\r\n\r\n  /** Calcula el número de enlaces visibles en el paginador (en el rango entre 1 y BASE_RESULTADOS_PAGE). */\r\n  calculatePageLinkSize() {\r\n    console.log(`calculatePageLinkSize totalItems: ${this.totalItems} itemsPerPage:${this.itemsPerPage}`);\r\n    this.pageLinkSize = Math.ceil(this.totalItems / this.itemsPerPage);\r\n    if (this.pageLinkSize < 1) {\r\n      this.pageLinkSize = 1;\r\n    }\r\n    if (this.pageLinkSize > BASE_RESULTADOS_PAGE) {\r\n      this.pageLinkSize = BASE_RESULTADOS_PAGE;\r\n    }\r\n  }\r\n\r\n  /** Establece el número de página en la visualización de resultados. Se invoca cuando el usuario cambia el número de resultados a mostrar o cambia de página */\r\n  paginate(event: any): void {\r\n    console.log(\"Page changed to\", event.page);\r\n    if (event.rows !== this.itemsPerPage) {\r\n      // han cambiado el número de elementos por página\r\n      //notificamos que los elementos por página han cambiado\r\n      this.onNewPageSize.emit(event.rows);\r\n      this.itemsPerPage = event.rows;\r\n      this.goToFirstPage();\r\n      this.calculatePageLinkSize(); // recalculamos el número de enlaces de página\r\n    } else {\r\n      // notificamos a nuestro papá que la página ha cambiado\r\n      this.onPageChange.emit(event.page + 1);\r\n    }\r\n  }\r\n\r\n  private goToFirstPage() {\r\n    if (this.pc) {\r\n      //volvemos a la primera página\r\n      this.pc._first = 1;\r\n      this.pc.updatePageLinks();\r\n    }\r\n  }\r\n\r\n  getStyle() {\r\n    if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {\r\n      if (this.totalItems > 0) {\r\n        return \"footer navbar-fixed-bottom\";\r\n      } else {\r\n        return \"footer navbar-fixed-bottom-60\";\r\n      }\r\n    } else if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_FORM) {\r\n      return \"footer navbar-fixed-bottom-form\";\r\n    } else {\r\n      return \"footer\";\r\n    }\r\n  }\r\n\r\n  isFooterList() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_LIST;\r\n  }\r\n\r\n  isFooterScroll() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_SCROLL;\r\n  }\r\n\r\n  isFooterForm() {\r\n    return this.typeFooter === BitFooterComponent.TYPE_FORM;\r\n  }\r\n\r\n  /** Flag: la página está realizando la búsqueda. */\r\n  get searchInitiated() {\r\n    return this.status === PageStatus.Init || this.status == PageStatus.Reset || !this.status;\r\n  }\r\n\r\n  /** Flag: la página está realizando la búsqueda. */\r\n  get searching() {\r\n    return this.status === PageStatus.Searching;\r\n  }\r\n\r\n  /** Flag: la página ha finalizado la última búsqueda. */\r\n  get searchFinished() {\r\n    return this.status === PageStatus.FinishSearch;\r\n  }\r\n\r\n  /** Flag: la página está en modo solo lectura */\r\n  get readOnly() {\r\n    return this.status == PageStatus.ReadOnly;\r\n  }\r\n\r\n  /** Flag: la página ha finalizado con error */\r\n  get error() {\r\n    return this.status == PageStatus.Error;\r\n  }\r\n\r\n  /** Flag: encontrado resultado. */\r\n  get foundResult() {\r\n    return (\r\n      this.status === PageStatus.FinishSearch &&\r\n      ((this.typeFooter === BitFooterComponent.TYPE_LIST && this.totalItems > 0)\r\n        || this.typeFooter === BitFooterComponent.TYPE_FORM\r\n        || (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems <= this.maxCurrentItems))\r\n    );\r\n  }\r\n\r\n  /** Flag: hay más resultados (scroll). */\r\n  get moreResults() {\r\n    return (\r\n      this.status === PageStatus.FinishSearch &&\r\n      (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems > this.maxCurrentItems)\r\n    );\r\n  }\r\n\r\n  /** Flag: no hay resultados. */\r\n  get emptyResult() {\r\n    return this.status === PageStatus.FinishSearch && this.totalItems === 0;\r\n  }\r\n\r\n  get initMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Init));\r\n  }\r\n\r\n  get searchingMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Searching));\r\n  }\r\n\r\n  get finishMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.FinishSearch));\r\n  }\r\n\r\n  get moreResultsMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(BitFooterComponent.MORE_RESULTS));\r\n  }\r\n\r\n  get emptyMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.EmptyResult));\r\n  }\r\n\r\n  get readOnlyMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.ReadOnly));\r\n  }\r\n\r\n  get errorMessage(): Observable<string> {\r\n    return this.translateService.selectTranslate(this.messages.get(PageStatus.Error));\r\n  }\r\n}\r\n","<footer [class]=\"getStyle()\">\r\n  <div class=\"grid\">\r\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"typeFooter === 'list'\" [hidden]=\"!this.status || emptyResult\">\r\n      <div class=\"numero-resultados\">\r\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\r\n        <span>{{totalItems}}</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"col-12 md:col-2 lg:col-2\" *ngIf=\"typeFooter === 'scroll'\" [hidden]=\"!this.status || emptyResult\">\r\n      <div class=\"numero-resultados-scroll\">\r\n        <label>{{\"bitnglibrary.footer.results\" | transloco}}</label>\r\n        <span *ngIf=\"maxCurrentItems >= totalItems\">{{totalItems}}</span>\r\n        <span *ngIf=\"maxCurrentItems < totalItems\">{{maxCurrentItems}} / {{totalItems}}</span>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"col-12 md:col-7 lg:col-7 p-text-center\" *ngIf=\"typeFooter === 'list'\"\r\n         [hidden]=\"!this.status || emptyResult\">\r\n      <p-paginator *ngIf=\"paginator\" #pc\r\n                   [rows]=\"itemsPerPage\"\r\n                   [totalRecords]=\"totalItems\"\r\n                   [pageLinkSize]=\"mostrarEnlacesPaginas ? pageLinkSize : 1\"\r\n                   [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\r\n                   [showPageLinks]=\"true\"\r\n                   [showJumpToPageDropdown]=\"false\"\r\n                   [showFirstLastIcon]=\"mostrarPrimeraUltimaPagina ? true : maxCurrentItems >= totalItems\"\r\n                   (onPageChange)=\"paginate($event)\"></p-paginator>\r\n    </div>\r\n    <div class=\"col-12 md:col-3 lg:col-3\">\r\n      <div *ngIf=\"searchInitiated\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{initMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"searching\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{searchingMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"readOnly\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{readOnlyMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"foundResult\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{finishMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"moreResults\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-info\"></i>\r\n        <span>{{moreResultsMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"emptyResult\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-exclamation\"></i>\r\n        <span>{{emptyMessage | async}}</span>\r\n      </div>\r\n\r\n      <div *ngIf=\"error\"\r\n           [className]=\"typeFooter === 'scroll' ? 'mensaje-scroll mensaje-info' : 'mensaje mensaje-info'\">\r\n        <i class=\"fa fa-exclamation-triangle\"></i>\r\n        <span>{{errorMessage | async}}</span>\r\n      </div>\r\n\r\n      <bit-help></bit-help>\r\n    </div>\r\n  </div>\r\n</footer>\r\n"]}
|
|
@@ -2642,13 +2642,15 @@ class BitFooterComponent {
|
|
|
2642
2642
|
* Escucharemos a cambios en las propiedades totalItems para actualizar el paginador con respecto a las páginas que mostramos
|
|
2643
2643
|
*/
|
|
2644
2644
|
ngOnChanges(changes) {
|
|
2645
|
-
var _a, _b, _c, _d, _e;
|
|
2645
|
+
var _a, _b, _c, _d, _e, _f;
|
|
2646
2646
|
for (let propName in changes) {
|
|
2647
2647
|
let changedProp = changes[propName];
|
|
2648
2648
|
if (propName === "totalItems") {
|
|
2649
2649
|
this.totalItems = changedProp.currentValue;
|
|
2650
2650
|
console.log(`new totalItems ${this.totalItems}`);
|
|
2651
|
-
changedProp.previousValue !== changedProp.currentValue
|
|
2651
|
+
if (changedProp.previousValue !== changedProp.currentValue) {
|
|
2652
|
+
this.calculatePageLinkSize(); //recalculamos
|
|
2653
|
+
}
|
|
2652
2654
|
this.maxCurrentItems = this.filter ? this.filter.pagina * this.filter.resultados : -1;
|
|
2653
2655
|
}
|
|
2654
2656
|
else if (propName === "filter") {
|
|
@@ -2657,7 +2659,12 @@ class BitFooterComponent {
|
|
|
2657
2659
|
this.maxCurrentItems = ((_c = this.filter) === null || _c === void 0 ? void 0 : _c.pagina) * ((_d = this.filter) === null || _d === void 0 ? void 0 : _d.resultados);
|
|
2658
2660
|
}
|
|
2659
2661
|
console.log(`new filter ${(_e = this.filter) === null || _e === void 0 ? void 0 : _e.pagina} - ${this.maxCurrentItems}`);
|
|
2660
|
-
changedProp.previousValue !== changedProp.currentValue
|
|
2662
|
+
if (changedProp.previousValue !== changedProp.currentValue) {
|
|
2663
|
+
this.calculatePageLinkSize(); //recalculamos
|
|
2664
|
+
if (!((_f = this.filter) === null || _f === void 0 ? void 0 : _f.pagina) || this.filter.pagina <= 1) {
|
|
2665
|
+
this.goToFirstPage();
|
|
2666
|
+
}
|
|
2667
|
+
}
|
|
2661
2668
|
}
|
|
2662
2669
|
}
|
|
2663
2670
|
if (this.pc && this.changeRef) {
|
|
@@ -2685,11 +2692,7 @@ class BitFooterComponent {
|
|
|
2685
2692
|
//notificamos que los elementos por página han cambiado
|
|
2686
2693
|
this.onNewPageSize.emit(event.rows);
|
|
2687
2694
|
this.itemsPerPage = event.rows;
|
|
2688
|
-
|
|
2689
|
-
//volvemos a la primera página
|
|
2690
|
-
this.pc._first = 1;
|
|
2691
|
-
this.pc.updatePageLinks();
|
|
2692
|
-
}
|
|
2695
|
+
this.goToFirstPage();
|
|
2693
2696
|
this.calculatePageLinkSize(); // recalculamos el número de enlaces de página
|
|
2694
2697
|
}
|
|
2695
2698
|
else {
|
|
@@ -2697,6 +2700,13 @@ class BitFooterComponent {
|
|
|
2697
2700
|
this.onPageChange.emit(event.page + 1);
|
|
2698
2701
|
}
|
|
2699
2702
|
}
|
|
2703
|
+
goToFirstPage() {
|
|
2704
|
+
if (this.pc) {
|
|
2705
|
+
//volvemos a la primera página
|
|
2706
|
+
this.pc._first = 1;
|
|
2707
|
+
this.pc.updatePageLinks();
|
|
2708
|
+
}
|
|
2709
|
+
}
|
|
2700
2710
|
getStyle() {
|
|
2701
2711
|
if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {
|
|
2702
2712
|
if (this.totalItems > 0) {
|