bit-ng-library 14.0.8 → 14.1.0

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.
Files changed (29) hide show
  1. package/README.md +12 -1
  2. package/esm2020/lib/sharedlibrary/components/footer/bit-footer-messages.component.mjs +155 -0
  3. package/esm2020/lib/sharedlibrary/components/footer/bit-footer.component.mjs +24 -167
  4. package/esm2020/lib/sharedlibrary/components/footer/bit-pagijator.component.mjs +64 -0
  5. package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.mjs +5 -2
  6. package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown-multiple.component.mjs +3 -3
  7. package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.mjs +3 -3
  8. package/esm2020/lib/sharedlibrary/global.constants.mjs +6 -1
  9. package/esm2020/lib/sharedlibrary/sharedlibrary.module.mjs +23 -5
  10. package/esm2020/public-api.mjs +3 -1
  11. package/fesm2015/bit-ng-library.mjs +259 -173
  12. package/fesm2015/bit-ng-library.mjs.map +1 -1
  13. package/fesm2020/bit-ng-library.mjs +258 -171
  14. package/fesm2020/bit-ng-library.mjs.map +1 -1
  15. package/lib/sharedlibrary/components/footer/bit-footer-messages.component.d.ts +47 -0
  16. package/lib/sharedlibrary/components/footer/bit-footer-messages.component.d.ts.map +1 -0
  17. package/lib/sharedlibrary/components/footer/bit-footer.component.d.ts +4 -45
  18. package/lib/sharedlibrary/components/footer/bit-footer.component.d.ts.map +1 -1
  19. package/lib/sharedlibrary/components/footer/bit-pagijator.component.d.ts +22 -0
  20. package/lib/sharedlibrary/components/footer/bit-pagijator.component.d.ts.map +1 -0
  21. package/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.d.ts +2 -1
  22. package/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.d.ts.map +1 -1
  23. package/lib/sharedlibrary/global.constants.d.ts +5 -0
  24. package/lib/sharedlibrary/global.constants.d.ts.map +1 -1
  25. package/lib/sharedlibrary/sharedlibrary.module.d.ts +59 -55
  26. package/lib/sharedlibrary/sharedlibrary.module.d.ts.map +1 -1
  27. package/package.json +1 -1
  28. package/public-api.d.ts +2 -0
  29. package/public-api.d.ts.map +1 -1
package/README.md CHANGED
@@ -26,7 +26,18 @@ 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.8] - 2023-02-02
29
+ ## [14.1.0] - 2023-02-08
30
+
31
+ nuevo footer con un nuevo paginator
32
+
33
+ ## [14.0.9] - 2023-02-07
34
+
35
+ se añade a los dropbox una nueva propiedad appendTo que por defecto valdrá body
36
+ Se añade:
37
+ import {SplitterModule} from 'primeng/splitter';
38
+ import {ScrollPanelModule} from 'primeng/scrollpanel';
39
+
40
+ ## [14.0.8] - 2023-02-07
30
41
 
31
42
  se añade a los calendarios una nueva propiedad appendTo que por defecto valdrá body
32
43
 
@@ -0,0 +1,155 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { of } from 'rxjs';
3
+ import { MORE_RESULTS, PageStatus, TYPE_BLANK, TYPE_FORM, TYPE_LIST, TYPE_SCROLL } from '../../global.constants';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../services";
6
+ import * as i2 from "../help/bit-help.component";
7
+ import * as i3 from "@angular/common";
8
+ export class BitFooterMessagesComponent {
9
+ constructor(translateService) {
10
+ this.translateService = translateService;
11
+ this.status = PageStatus.Init; // Determina en qué estado está la página: PageStatus.Init, PageStatus.SEARCHING, PageStatus.FINISH_SEARCH
12
+ }
13
+ ngOnInit() {
14
+ if (this.typeFooter == undefined) {
15
+ this.typeFooter = "list";
16
+ }
17
+ //mensajes por defecto si no vienen definidos
18
+ if (this.messages == undefined) {
19
+ this.setMessages();
20
+ this.messages.set(PageStatus.Error, "bitnglibrary.footer.error");
21
+ }
22
+ }
23
+ setMessages() {
24
+ console.log("definimos los mensajes del footer de manera estándar");
25
+ this.messages = new Map();
26
+ if (this.isFooterList() || this.isFooterScroll()) {
27
+ this.messages.set(PageStatus.Init, "bitnglibrary.footer.list.init");
28
+ this.messages.set(PageStatus.Searching, "bitnglibrary.footer.list.searching");
29
+ this.messages.set(PageStatus.EmptyResult, "bitnglibrary.footer.list.emptyresult");
30
+ this.messages.set(PageStatus.FinishSearch, "bitnglibrary.footer.list.finishsearch");
31
+ this.messages.set(MORE_RESULTS, "bitnglibrary.footer.list.moreresults");
32
+ }
33
+ else if (this.isFooterForm()) {
34
+ this.messages.set(PageStatus.Init, "bitnglibrary.footer.form.init");
35
+ this.messages.set(PageStatus.Searching, "bitnglibrary.footer.form.searching");
36
+ this.messages.set(PageStatus.FinishSearch, "bitnglibrary.footer.form.finishsearch");
37
+ this.messages.set(PageStatus.ReadOnly, "bitnglibrary.footer.list.readonly");
38
+ }
39
+ else if (this.typeFooter === TYPE_BLANK) {
40
+ console.log("the footer is BLANK!");
41
+ }
42
+ }
43
+ getStyle(error = false) {
44
+ let type = error ? "error" : "info";
45
+ if (this.isFooterList()) {
46
+ return `mensaje-list mensaje-${type}`;
47
+ }
48
+ else if (this.isFooterScroll()) {
49
+ return `mensaje-scroll mensaje-${type}`;
50
+ }
51
+ else if (this.isFooterForm()) {
52
+ return `mensaje-form mensaje-${type}`;
53
+ }
54
+ }
55
+ isFooterList() {
56
+ return this.typeFooter === TYPE_LIST;
57
+ }
58
+ isFooterScroll() {
59
+ return this.typeFooter === TYPE_SCROLL;
60
+ }
61
+ isFooterForm() {
62
+ return this.typeFooter === TYPE_FORM;
63
+ }
64
+ /** Flag: la página está realizando la búsqueda. */
65
+ get searchInitiated() {
66
+ return this.status === PageStatus.Init || this.status == PageStatus.Reset || !this.status;
67
+ }
68
+ /** Flag: la página está realizando la búsqueda. */
69
+ get searching() {
70
+ return this.status === PageStatus.Searching;
71
+ }
72
+ /** Flag: la página ha finalizado la última búsqueda. */
73
+ get searchFinished() {
74
+ return this.status === PageStatus.FinishSearch;
75
+ }
76
+ /** Flag: la página está en modo solo lectura */
77
+ get readOnly() {
78
+ return this.status == PageStatus.ReadOnly;
79
+ }
80
+ /** Flag: la página ha finalizado con error */
81
+ get error() {
82
+ return this.status == PageStatus.Error;
83
+ }
84
+ /** Flag: encontrado resultado. */
85
+ get foundResult() {
86
+ return (this.status === PageStatus.FinishSearch &&
87
+ ((this.typeFooter === TYPE_LIST && this.totalItems > 0)
88
+ || this.typeFooter === TYPE_FORM
89
+ || (this.typeFooter === TYPE_SCROLL && this.totalItems <= this.maxCurrentItems)));
90
+ }
91
+ /** Flag: hay más resultados (scroll). */
92
+ get moreResults() {
93
+ return (this.status === PageStatus.FinishSearch &&
94
+ (this.typeFooter === TYPE_SCROLL && this.totalItems > this.maxCurrentItems));
95
+ }
96
+ /** Flag: no hay resultados. */
97
+ get emptyResult() {
98
+ return this.status === PageStatus.FinishSearch && this.totalItems === 0;
99
+ }
100
+ get message() {
101
+ if (this.searchInitiated)
102
+ return this.initMessage;
103
+ if (this.searching)
104
+ return this.searchingMessage;
105
+ if (this.readOnly)
106
+ return this.readOnlyMessage;
107
+ if (this.foundResult)
108
+ return this.finishMessage;
109
+ if (this.moreResults)
110
+ return this.moreResultsMessage;
111
+ if (this.emptyResult)
112
+ return this.emptyMessage;
113
+ if (this.error)
114
+ return this.errorMessage;
115
+ return of("");
116
+ }
117
+ get initMessage() {
118
+ return this.translateService.selectTranslate(this.messages.get(PageStatus.Init));
119
+ }
120
+ get searchingMessage() {
121
+ return this.translateService.selectTranslate(this.messages.get(PageStatus.Searching));
122
+ }
123
+ get finishMessage() {
124
+ return this.translateService.selectTranslate(this.messages.get(PageStatus.FinishSearch));
125
+ }
126
+ get moreResultsMessage() {
127
+ return this.translateService.selectTranslate(this.messages.get(MORE_RESULTS));
128
+ }
129
+ get emptyMessage() {
130
+ return this.translateService.selectTranslate(this.messages.get(PageStatus.EmptyResult));
131
+ }
132
+ get readOnlyMessage() {
133
+ return this.translateService.selectTranslate(this.messages.get(PageStatus.ReadOnly));
134
+ }
135
+ get errorMessage() {
136
+ return this.translateService.selectTranslate(this.messages.get(PageStatus.Error));
137
+ }
138
+ }
139
+ BitFooterMessagesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: BitFooterMessagesComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
140
+ BitFooterMessagesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.8", type: BitFooterMessagesComponent, selector: "bit-footer-messages", inputs: { messages: "messages", status: "status", typeFooter: "typeFooter", maxCurrentItems: "maxCurrentItems", totalItems: "totalItems" }, ngImport: i0, template: "<div>\n <div [class]=\"getStyle()\">\n <i class=\"fa fa-info\"></i>\n <span>{{message | async}}</span>\n </div>\n\n <bit-help></bit-help>\n</div>", dependencies: [{ kind: "component", type: i2.BitHelpComponent, selector: "bit-help" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
141
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: BitFooterMessagesComponent, decorators: [{
142
+ type: Component,
143
+ args: [{ selector: 'bit-footer-messages', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div>\n <div [class]=\"getStyle()\">\n <i class=\"fa fa-info\"></i>\n <span>{{message | async}}</span>\n </div>\n\n <bit-help></bit-help>\n</div>" }]
144
+ }], ctorParameters: function () { return [{ type: i1.TranslateService }]; }, propDecorators: { messages: [{
145
+ type: Input
146
+ }], status: [{
147
+ type: Input
148
+ }], typeFooter: [{
149
+ type: Input
150
+ }], maxCurrentItems: [{
151
+ type: Input
152
+ }], totalItems: [{
153
+ type: Input
154
+ }] } });
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-footer-messages.component.js","sourceRoot":"","sources":["../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/footer/bit-footer-messages.component.ts","../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/footer/bit-footer-messages.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnInit } from '@angular/core';\nimport { Observable, of } from 'rxjs';\n\nimport { MORE_RESULTS, PageStatus, TYPE_BLANK, TYPE_FORM, TYPE_LIST, TYPE_SCROLL } from '../../global.constants';\nimport { TranslateService } from '../../services';\n\n@Component({\n  selector: 'bit-footer-messages',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: 'bit-footer-messages.component.html'\n})\n\nexport class BitFooterMessagesComponent implements OnInit {\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()\n  typeFooter: string;\n  @Input()\n  maxCurrentItems: number;\n  @Input()\n  totalItems: number;\n\n  constructor(private translateService: TranslateService) { }\n\n  ngOnInit(): void {\n    if (this.typeFooter == undefined) {\n      this.typeFooter = \"list\";\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(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 === TYPE_BLANK) {\n      console.log(\"the footer is BLANK!\");\n    }\n  }\n\n  getStyle(error: boolean = false): string {\n    let type = error ? \"error\" : \"info\";\n    if (this.isFooterList()) {\n      return `mensaje-list mensaje-${type}`;\n    } else if (this.isFooterScroll()) {\n      return `mensaje-scroll mensaje-${type}`;\n    } else if (this.isFooterForm()) {\n      return `mensaje-form mensaje-${type}`;\n    }\n  }\n\n  isFooterList() {\n    return this.typeFooter === TYPE_LIST;\n  }\n\n  isFooterScroll() {\n    return this.typeFooter === TYPE_SCROLL;\n  }\n\n  isFooterForm() {\n    return this.typeFooter === 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 === TYPE_LIST && this.totalItems > 0)\n        || this.typeFooter === TYPE_FORM\n        || (this.typeFooter === 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 === 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 message(): Observable<string> {\n    if (this.searchInitiated) return this.initMessage;\n    if (this.searching) return this.searchingMessage;\n    if (this.readOnly) return this.readOnlyMessage;\n    if (this.foundResult) return this.finishMessage;\n    if (this.moreResults) return this.moreResultsMessage;\n    if (this.emptyResult) return this.emptyMessage;\n    if (this.error) return this.errorMessage;\n    return of(\"\");\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(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}","<div>\n  <div [class]=\"getStyle()\">\n    <i class=\"fa fa-info\"></i>\n    <span>{{message | async}}</span>\n  </div>\n\n  <bit-help></bit-help>\n</div>"]}
@@ -1,30 +1,27 @@
1
1
  import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from "@angular/core";
2
- import { BaseFilter, BASE_RESULTADOS_PAGE } from "../../../base/shared/base.filter";
3
- import { PageStatus } from "../../global.constants";
2
+ import { BaseFilter } from "../../../base/shared/base.filter";
3
+ import { PageStatus, TYPE_FORM, TYPE_LIST, TYPE_SCROLL } from "../../global.constants";
4
4
  import * as i0 from "@angular/core";
5
- import * as i1 from "../../services";
6
- import * as i2 from "@angular/common";
7
- import * as i3 from "primeng/paginator";
8
- import * as i4 from "../help/bit-help.component";
9
- import * as i5 from "@ngneat/transloco";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "./bit-pagijator.component";
7
+ import * as i3 from "./bit-footer-messages.component";
8
+ import * as i4 from "@ngneat/transloco";
10
9
  /**
11
10
  * Componente que muestra un paginador en la sección footer.
12
11
  **/
13
12
  export class BitFooterComponent {
14
- constructor(translateService) {
15
- this.translateService = translateService;
13
+ constructor() {
16
14
  this.mostrarAvisos = true;
17
15
  this.fixed = true; // Indicará si lo queremos fijo abajo en la página. Por defecto sí.
18
16
  this.status = PageStatus.Init; // Determina en qué estado está la página: PageStatus.Init, PageStatus.SEARCHING, PageStatus.FINISH_SEARCH
19
- this.mostrarEnlacesPaginas = true;
20
- this.mostrarPrimeraUltimaPagina = true;
17
+ this.mostrarEnlacesPaginas = true; //deprecated
18
+ this.mostrarPrimeraUltimaPagina = true; //deprecated
21
19
  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
20
+ this.forcePageLinkSize = 1; //deprecated número de enlaces en el paginador para poder navegar hacia delante o detrás que forzamos a que haya
23
21
  this.onPageChange = new EventEmitter(); //para notificar cambios en la página a mostrar
24
22
  this.onNewPageSize = new EventEmitter(); //para notificar cambios en los elementos a mostrar por página
25
23
  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
26
- this.itemsPerPage = BaseFilter.RESULTADOS_PAGE; // número de elementos por página que mostramos
27
- this.maxCurrentItems = -1;
24
+ this.maxCurrentItems = -1; // número de elementos que mostramos en pantalla. Necesario para el modo scroll
28
25
  }
29
26
  ngOnInit() {
30
27
  if (this.typeFooter == undefined) {
@@ -33,31 +30,6 @@ export class BitFooterComponent {
33
30
  if (this.paginator == undefined) {
34
31
  this.paginator = false;
35
32
  }
36
- //mensajes por defecto si no vienen definidos
37
- if (this.messages == undefined) {
38
- this.setMessages();
39
- this.messages.set(PageStatus.Error, "bitnglibrary.footer.error");
40
- }
41
- }
42
- setMessages() {
43
- console.log("definimos los mensajes del footer de manera estándar");
44
- this.messages = new Map();
45
- if (this.isFooterList() || this.isFooterScroll()) {
46
- this.messages.set(PageStatus.Init, "bitnglibrary.footer.list.init");
47
- this.messages.set(PageStatus.Searching, "bitnglibrary.footer.list.searching");
48
- this.messages.set(PageStatus.EmptyResult, "bitnglibrary.footer.list.emptyresult");
49
- this.messages.set(PageStatus.FinishSearch, "bitnglibrary.footer.list.finishsearch");
50
- this.messages.set(BitFooterComponent.MORE_RESULTS, "bitnglibrary.footer.list.moreresults");
51
- }
52
- else if (this.isFooterForm()) {
53
- this.messages.set(PageStatus.Init, "bitnglibrary.footer.form.init");
54
- this.messages.set(PageStatus.Searching, "bitnglibrary.footer.form.searching");
55
- this.messages.set(PageStatus.FinishSearch, "bitnglibrary.footer.form.finishsearch");
56
- this.messages.set(PageStatus.ReadOnly, "bitnglibrary.footer.list.readonly");
57
- }
58
- else if (this.typeFooter === BitFooterComponent.TYPE_BLANK) {
59
- console.log("the footer is BLANK!");
60
- }
61
33
  }
62
34
  /**
63
35
  * Escucharemos a cambios en las propiedades totalItems para actualizar el paginador con respecto a las páginas que mostramos
@@ -72,165 +44,50 @@ export class BitFooterComponent {
72
44
  else if (propName === "totalItems") {
73
45
  this.totalItems = changedProp.currentValue;
74
46
  console.log("totalItems:" + this.totalItems);
75
- if (changedProp.previousValue !== changedProp.currentValue) {
76
- this.calculatePageLinkSize(); //recalculamos
77
- }
78
47
  this.calculateMaxCurrentItems();
79
48
  }
80
49
  else if (propName === "filter") {
81
50
  this.filter = changedProp.currentValue;
82
51
  this.calculateMaxCurrentItems();
83
- if (changedProp.previousValue !== changedProp.currentValue) {
84
- this.calculatePageLinkSize(); //recalculamos
85
- if (!this.filter?.pagina || this.filter.pagina <= 1) {
86
- this.goToFirstPage();
87
- console.log("goToFirstPage");
88
- }
89
- }
90
- this.first = (this.filter.pagina - 1) * this.filter.resultados;
91
- console.log("first:" + this.first);
92
52
  }
93
53
  }
94
54
  }
95
- showFooter() {
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;
55
+ showPagijator() {
56
+ return this.typeFooter === 'list' && this.visible && this.paginator;
99
57
  }
100
58
  showScroll() {
101
59
  return this.typeFooter === 'scroll' && this.visible;
102
60
  }
103
- /** Calcula el número de enlaces visibles en el paginador (en el rango entre 1 y BASE_RESULTADOS_PAGE). */
104
- calculatePageLinkSize() {
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
- }
114
- }
115
- else {
116
- this.pageLinkSize = this.forcePageLinkSize;
117
- }
118
- console.log("pageLinkSize", this.pageLinkSize);
119
- }
120
61
  calculateMaxCurrentItems() {
121
62
  this.maxCurrentItems = this.filter?.pagina * this.filter?.resultados;
122
63
  if (this.maxCurrentItems > this.totalItems) {
123
64
  this.maxCurrentItems = this.totalItems;
124
65
  }
125
66
  }
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 */
127
- paginate(event) {
128
- console.log("Page changed to:" + event.page + " maxCurrentItems:" + this.maxCurrentItems + " firstElement:" + this.first);
129
- if (event.rows !== this.itemsPerPage) {
130
- // han cambiado el número de elementos por página
131
- //notificamos que los elementos por página han cambiado
132
- this.onNewPageSize.emit(event.rows);
133
- this.itemsPerPage = event.rows;
134
- this.goToFirstPage();
135
- this.calculatePageLinkSize(); // recalculamos el número de enlaces de página
136
- }
137
- else {
138
- // notificamos a nuestro papá que la página ha cambiado
139
- this.onPageChange.emit(event.page + 1);
140
- }
67
+ pageChange(page) {
68
+ this.onPageChange.emit(page);
141
69
  }
142
- goToFirstPage() {
143
- this.first = 1;
70
+ pageSizeChange(pageSize) {
71
+ this.onNewPageSize.emit(pageSize);
144
72
  }
145
73
  getStyle() {
146
- if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_LIST || this.typeFooter === BitFooterComponent.TYPE_SCROLL) {
74
+ if (this.fixed && this.typeFooter === TYPE_LIST || this.typeFooter === TYPE_SCROLL) {
147
75
  return "footer navbar-fixed-bottom";
148
76
  }
149
- else if (this.fixed && this.typeFooter === BitFooterComponent.TYPE_FORM) {
77
+ else if (this.fixed && this.typeFooter === TYPE_FORM) {
150
78
  return "footer navbar-fixed-bottom-form";
151
79
  }
152
80
  else {
153
81
  return "footer";
154
82
  }
155
83
  }
156
- isFooterList() {
157
- return this.typeFooter === BitFooterComponent.TYPE_LIST;
158
- }
159
- isFooterScroll() {
160
- return this.typeFooter === BitFooterComponent.TYPE_SCROLL;
161
- }
162
- isFooterForm() {
163
- return this.typeFooter === BitFooterComponent.TYPE_FORM;
164
- }
165
- /** Flag: la página está realizando la búsqueda. */
166
- get searchInitiated() {
167
- return this.status === PageStatus.Init || this.status == PageStatus.Reset || !this.status;
168
- }
169
- /** Flag: la página está realizando la búsqueda. */
170
- get searching() {
171
- return this.status === PageStatus.Searching;
172
- }
173
- /** Flag: la página ha finalizado la última búsqueda. */
174
- get searchFinished() {
175
- return this.status === PageStatus.FinishSearch;
176
- }
177
- /** Flag: la página está en modo solo lectura */
178
- get readOnly() {
179
- return this.status == PageStatus.ReadOnly;
180
- }
181
- /** Flag: la página ha finalizado con error */
182
- get error() {
183
- return this.status == PageStatus.Error;
184
- }
185
- /** Flag: encontrado resultado. */
186
- get foundResult() {
187
- return (this.status === PageStatus.FinishSearch &&
188
- ((this.typeFooter === BitFooterComponent.TYPE_LIST && this.totalItems > 0)
189
- || this.typeFooter === BitFooterComponent.TYPE_FORM
190
- || (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems <= this.maxCurrentItems)));
191
- }
192
- /** Flag: hay más resultados (scroll). */
193
- get moreResults() {
194
- return (this.status === PageStatus.FinishSearch &&
195
- (this.typeFooter === BitFooterComponent.TYPE_SCROLL && this.totalItems > this.maxCurrentItems));
196
- }
197
- /** Flag: no hay resultados. */
198
- get emptyResult() {
199
- return this.status === PageStatus.FinishSearch && this.totalItems === 0;
200
- }
201
- get initMessage() {
202
- return this.translateService.selectTranslate(this.messages.get(PageStatus.Init));
203
- }
204
- get searchingMessage() {
205
- return this.translateService.selectTranslate(this.messages.get(PageStatus.Searching));
206
- }
207
- get finishMessage() {
208
- return this.translateService.selectTranslate(this.messages.get(PageStatus.FinishSearch));
209
- }
210
- get moreResultsMessage() {
211
- return this.translateService.selectTranslate(this.messages.get(BitFooterComponent.MORE_RESULTS));
212
- }
213
- get emptyMessage() {
214
- return this.translateService.selectTranslate(this.messages.get(PageStatus.EmptyResult));
215
- }
216
- get readOnlyMessage() {
217
- return this.translateService.selectTranslate(this.messages.get(PageStatus.ReadOnly));
218
- }
219
- get errorMessage() {
220
- return this.translateService.selectTranslate(this.messages.get(PageStatus.Error));
221
- }
222
84
  }
223
- BitFooterComponent.TYPE_LIST = "list";
224
- BitFooterComponent.TYPE_SCROLL = "scroll";
225
- BitFooterComponent.TYPE_FORM = "form";
226
- BitFooterComponent.TYPE_BLANK = "blank";
227
- BitFooterComponent.MORE_RESULTS = -1;
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 });
85
+ BitFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: BitFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
86
+ 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\n <div class=\"scroll-outer-container\" *ngIf=\"showScroll()\">\n <div class=\"pagijator-container\">\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 <bit-pagijator *ngIf=\"showPagijator()\"\n [totalItems]=\"totalItems\"\n [page]=\"filter ? filter.pagina : 1\"\n [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\n (onPageChange)=\"pageChange($event)\"\n (onPageSizeChange)=\"pageSizeChange($event)\"></bit-pagijator>\n\n <bit-footer-messages *ngIf=\"mostrarAvisos\"\n [messages]=\"messages\"\n [typeFooter]=\"typeFooter\"\n [status]=\"status\"\n [maxCurrentItems]=\"maxCurrentItems\"\n [totalItems]=\"totalItems\"></bit-footer-messages>\n\n</footer>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.BitPagijatorComponent, selector: "bit-pagijator", inputs: ["page", "totalItems", "itemsPerPage", "rowsPerPageOptions"], outputs: ["onPageChange", "onPageSizeChange"] }, { kind: "component", type: i3.BitFooterMessagesComponent, selector: "bit-footer-messages", inputs: ["messages", "status", "typeFooter", "maxCurrentItems", "totalItems"] }, { kind: "pipe", type: i4.TranslocoPipe, name: "transloco" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
230
87
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: BitFooterComponent, decorators: [{
231
88
  type: Component,
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: [{
89
+ args: [{ selector: "bit-footer", changeDetection: ChangeDetectionStrategy.OnPush, template: "<footer [class]=\"getStyle()\">\n\n <div class=\"scroll-outer-container\" *ngIf=\"showScroll()\">\n <div class=\"pagijator-container\">\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 <bit-pagijator *ngIf=\"showPagijator()\"\n [totalItems]=\"totalItems\"\n [page]=\"filter ? filter.pagina : 1\"\n [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\n (onPageChange)=\"pageChange($event)\"\n (onPageSizeChange)=\"pageSizeChange($event)\"></bit-pagijator>\n\n <bit-footer-messages *ngIf=\"mostrarAvisos\"\n [messages]=\"messages\"\n [typeFooter]=\"typeFooter\"\n [status]=\"status\"\n [maxCurrentItems]=\"maxCurrentItems\"\n [totalItems]=\"totalItems\"></bit-footer-messages>\n\n</footer>\n" }]
90
+ }], ctorParameters: function () { return []; }, propDecorators: { totalItems: [{
234
91
  type: Input
235
92
  }], filter: [{
236
93
  type: Input
@@ -260,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
260
117
  }], onNewPageSize: [{
261
118
  type: Output
262
119
  }] } });
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"]}
120
+ //# 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 { BaseFilter } from \"../../../base/shared/base.filter\";\nimport { PageStatus, TYPE_FORM, TYPE_LIST, TYPE_SCROLL } from \"../../global.constants\";\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  @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;  //deprecated\n  @Input()\n  mostrarPrimeraUltimaPagina: boolean = true; //deprecated\n  @Input()\n  visible: boolean = true;\n  @Input()\n  forcePageLinkSize: number = 1; //deprecated 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  maxCurrentItems: number = -1;   // número de elementos que mostramos en pantalla. Necesario para el modo scroll\n\n  constructor() {\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  }\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        this.calculateMaxCurrentItems();\n      } else if (propName === \"filter\") {\n        this.filter = changedProp.currentValue;\n        this.calculateMaxCurrentItems();\n      }\n    }\n  }\n\n  showPagijator() {\n    return this.typeFooter === 'list' && this.visible && this.paginator;\n  }\n\n  showScroll(): boolean {\n    return this.typeFooter === 'scroll' && this.visible;\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  pageChange(page: number): void {\n    this.onPageChange.emit(page);\n  }\n\n  pageSizeChange(pageSize: number): void {\n    this.onNewPageSize.emit(pageSize);\n  }\n\n  getStyle() {\n    if (this.fixed && this.typeFooter === TYPE_LIST || this.typeFooter === TYPE_SCROLL) {\n      return \"footer navbar-fixed-bottom\";\n    } else if (this.fixed && this.typeFooter === TYPE_FORM) {\n      return \"footer navbar-fixed-bottom-form\";\n    } else {\n      return \"footer\";\n    }\n  }\n\n}\n","<footer [class]=\"getStyle()\">\n\n  <div class=\"scroll-outer-container\" *ngIf=\"showScroll()\">\n    <div class=\"pagijator-container\">\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  <bit-pagijator *ngIf=\"showPagijator()\"\n    [totalItems]=\"totalItems\"\n    [page]=\"filter ? filter.pagina : 1\"\n    [rowsPerPageOptions]=\"[baseItemsPerPage,baseItemsPerPage*5,baseItemsPerPage*25,baseItemsPerPage*50]\"\n    (onPageChange)=\"pageChange($event)\"\n    (onPageSizeChange)=\"pageSizeChange($event)\"></bit-pagijator>\n\n  <bit-footer-messages *ngIf=\"mostrarAvisos\"\n    [messages]=\"messages\"\n    [typeFooter]=\"typeFooter\"\n    [status]=\"status\"\n    [maxCurrentItems]=\"maxCurrentItems\"\n    [totalItems]=\"totalItems\"></bit-footer-messages>\n\n</footer>\n"]}