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.
- package/README.md +12 -1
- package/esm2020/lib/sharedlibrary/components/footer/bit-footer-messages.component.mjs +155 -0
- package/esm2020/lib/sharedlibrary/components/footer/bit-footer.component.mjs +24 -167
- package/esm2020/lib/sharedlibrary/components/footer/bit-pagijator.component.mjs +64 -0
- package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.mjs +5 -2
- package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown-multiple.component.mjs +3 -3
- package/esm2020/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.mjs +3 -3
- package/esm2020/lib/sharedlibrary/global.constants.mjs +6 -1
- package/esm2020/lib/sharedlibrary/sharedlibrary.module.mjs +23 -5
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/bit-ng-library.mjs +259 -173
- package/fesm2015/bit-ng-library.mjs.map +1 -1
- package/fesm2020/bit-ng-library.mjs +258 -171
- package/fesm2020/bit-ng-library.mjs.map +1 -1
- package/lib/sharedlibrary/components/footer/bit-footer-messages.component.d.ts +47 -0
- package/lib/sharedlibrary/components/footer/bit-footer-messages.component.d.ts.map +1 -0
- package/lib/sharedlibrary/components/footer/bit-footer.component.d.ts +4 -45
- package/lib/sharedlibrary/components/footer/bit-footer.component.d.ts.map +1 -1
- package/lib/sharedlibrary/components/footer/bit-pagijator.component.d.ts +22 -0
- package/lib/sharedlibrary/components/footer/bit-pagijator.component.d.ts.map +1 -0
- package/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.d.ts +2 -1
- package/lib/sharedlibrary/components/form/dropdown/bit-dropdown-general.component.d.ts.map +1 -1
- package/lib/sharedlibrary/global.constants.d.ts +5 -0
- package/lib/sharedlibrary/global.constants.d.ts.map +1 -1
- package/lib/sharedlibrary/sharedlibrary.module.d.ts +59 -55
- package/lib/sharedlibrary/sharedlibrary.module.d.ts.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- 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
|
|
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
|
|
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 "
|
|
6
|
-
import * as i2 from "
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "
|
|
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(
|
|
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.
|
|
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
|
-
|
|
96
|
-
|
|
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
|
-
|
|
127
|
-
|
|
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
|
-
|
|
143
|
-
this.
|
|
70
|
+
pageSizeChange(pageSize) {
|
|
71
|
+
this.onNewPageSize.emit(pageSize);
|
|
144
72
|
}
|
|
145
73
|
getStyle() {
|
|
146
|
-
if (this.fixed && this.typeFooter ===
|
|
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 ===
|
|
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
|
|
224
|
-
BitFooterComponent
|
|
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
|
|
233
|
-
}], ctorParameters: function () { return [
|
|
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":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,GAEP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAC9D,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;;;;;;AAEvF;;IAEI;AAMJ,MAAM,OAAO,kBAAkB;IAiC7B;QAzBA,kBAAa,GAAY,IAAI,CAAC;QAE9B,UAAK,GAAY,IAAI,CAAC,CAAC,mEAAmE;QAI1F,WAAM,GAAe,UAAU,CAAC,IAAI,CAAC,CAAC,0GAA0G;QAIhJ,0BAAqB,GAAY,IAAI,CAAC,CAAE,YAAY;QAEpD,+BAA0B,GAAY,IAAI,CAAC,CAAC,YAAY;QAExD,YAAO,GAAY,IAAI,CAAC;QAExB,sBAAiB,GAAW,CAAC,CAAC,CAAC,gHAAgH;QAE/I,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC,CAAC,+CAA+C;QAE1F,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC,CAAC,8DAA8D;QAE1G,qBAAgB,GAAW,UAAU,CAAC,eAAe,CAAC,CAAC,wGAAwG;QAC/J,oBAAe,GAAW,CAAC,CAAC,CAAC,CAAG,+EAA+E;IAG/G,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,UAAU,IAAI,SAAS,EAAE;YAChC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;SAC1B;QACD,IAAI,IAAI,CAAC,SAAS,IAAI,SAAS,EAAE;YAC/B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;SACxB;IACH,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,OAA4C;QACtD,KAAK,IAAI,QAAQ,IAAI,OAAO,EAAE;YAC5B,IAAI,WAAW,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;YACpC,IAAI,QAAQ,KAAK,QAAQ,EAAE;gBACzB,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,YAAY,CAAC;gBACvC,OAAO,CAAC,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;aACtC;iBAAM,IAAI,QAAQ,KAAK,YAAY,EAAE;gBACpC,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,YAAY,CAAC;gBAC3C,OAAO,CAAC,GAAG,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC7C,IAAI,CAAC,wBAAwB,EAAE,CAAC;aACjC;iBAAM,IAAI,QAAQ,KAAK,QAAQ,EAAE;gBAChC,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,YAAY,CAAC;gBACvC,IAAI,CAAC,wBAAwB,EAAE,CAAC;aACjC;SACF;IACH,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,UAAU,KAAK,MAAM,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC;IACtE,CAAC;IAED,UAAU;QACR,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC;IACtD,CAAC;IAED,wBAAwB;QACtB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC;QACrE,IAAI,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,EAAE;YAC1C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC;SACxC;IACH,CAAC;IAED,UAAU,CAAC,IAAY;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,cAAc,CAAC,QAAgB;QAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,IAAI,IAAI,CAAC,UAAU,KAAK,WAAW,EAAE;YAClF,OAAO,4BAA4B,CAAC;SACrC;aAAM,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE;YACtD,OAAO,iCAAiC,CAAC;SAC1C;aAAM;YACL,OAAO,QAAQ,CAAC;SACjB;IACH,CAAC;;+GAhGU,kBAAkB;mGAAlB,kBAAkB,ogBCrB/B,o+BAyBA;2FDJa,kBAAkB;kBAL9B,SAAS;+BACE,YAAY,mBACL,uBAAuB,CAAC,MAAM;0EAK/C,UAAU;sBADT,KAAK;gBAGN,MAAM;sBADL,KAAK;gBAGN,SAAS;sBADR,KAAK;gBAGN,aAAa;sBADZ,KAAK;gBAGN,KAAK;sBADJ,KAAK;gBAGN,QAAQ;sBADP,KAAK;gBAGN,MAAM;sBADL,KAAK;gBAGN,UAAU;sBADT,KAAK;uBAAC,MAAM;gBAGb,qBAAqB;sBADpB,KAAK;gBAGN,0BAA0B;sBADzB,KAAK;gBAGN,OAAO;sBADN,KAAK;gBAGN,iBAAiB;sBADhB,KAAK;gBAGN,YAAY;sBADX,MAAM;gBAGP,aAAa;sBADZ,MAAM","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"]}
|