mapa-library-ui 0.0.23 → 0.0.24
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/esm2020/src/lib/components/capability/lib/components/filters/src/filters.component.mjs +2 -2
- package/esm2020/src/lib/components/filters/lib/components/filters/src/filters.component.mjs +2 -2
- package/esm2020/src/lib/components/table/lib/components/table/public-api.mjs +6 -0
- package/esm2020/src/lib/components/table/lib/components/table/src/paginator_customization.mjs +21 -0
- package/esm2020/src/lib/components/table/lib/components/table/src/table.component.mjs +121 -0
- package/esm2020/src/lib/components/table/lib/components/table/src/table.module.mjs +59 -0
- package/esm2020/src/lib/components/table/lib/core/directives/custom-paginator-legacy.directive.mjs +227 -0
- package/esm2020/src/lib/components/table/lib/core/directives/custom-paginator.directive.mjs +183 -0
- package/esm2020/src/lib/components/table/mapa-library-ui-src-lib-components-table.mjs +2 -2
- package/esm2020/src/lib/components/table/table.mjs +7 -0
- package/fesm2015/mapa-library-ui-src-lib-components-capability.mjs +2 -2
- package/fesm2015/mapa-library-ui-src-lib-components-capability.mjs.map +1 -1
- package/fesm2015/mapa-library-ui-src-lib-components-filters.mjs +2 -2
- package/fesm2015/mapa-library-ui-src-lib-components-filters.mjs.map +1 -1
- package/fesm2015/mapa-library-ui-src-lib-components-table.mjs +470 -38
- package/fesm2015/mapa-library-ui-src-lib-components-table.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-capability.mjs +2 -2
- package/fesm2020/mapa-library-ui-src-lib-components-capability.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-filters.mjs +2 -2
- package/fesm2020/mapa-library-ui-src-lib-components-filters.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-table.mjs +466 -38
- package/fesm2020/mapa-library-ui-src-lib-components-table.mjs.map +1 -1
- package/mapa-library-ui-0.0.24.tgz +0 -0
- package/package.json +1 -1
- package/src/lib/components/table/index.d.ts +1 -1
- package/src/lib/components/table/{src → lib/components/table/src}/table.component.d.ts +14 -8
- package/src/lib/components/table/{src → lib/components/table/src}/table.module.d.ts +4 -2
- package/src/lib/components/table/lib/core/directives/custom-paginator-legacy.directive.d.ts +27 -0
- package/src/lib/components/table/lib/core/directives/custom-paginator.directive.d.ts +33 -0
- package/src/lib/components/table/table.d.ts +3 -0
- package/esm2020/src/lib/components/table/public-api.mjs +0 -6
- package/esm2020/src/lib/components/table/src/paginator_customization.mjs +0 -9
- package/esm2020/src/lib/components/table/src/table.component.mjs +0 -120
- package/esm2020/src/lib/components/table/src/table.module.mjs +0 -49
- package/mapa-library-ui-0.0.23.tgz +0 -0
- /package/src/lib/components/table/{public-api.d.ts → lib/components/table/public-api.d.ts} +0 -0
- /package/src/lib/components/table/{src → lib/components/table/src}/paginator_customization.d.ts +0 -0
package/esm2020/src/lib/components/table/lib/core/directives/custom-paginator-legacy.directive.mjs
ADDED
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
import { Directive, Host, Optional, Self, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/material/paginator";
|
|
4
|
+
export class PaginatorLegacyDirective {
|
|
5
|
+
constructor(matPag, ViewContainer, renderer) {
|
|
6
|
+
this.matPag = matPag;
|
|
7
|
+
this.ViewContainer = ViewContainer;
|
|
8
|
+
this.renderer = renderer;
|
|
9
|
+
this.buttons = [];
|
|
10
|
+
this.buildPageNumbers = () => {
|
|
11
|
+
let dots;
|
|
12
|
+
let page;
|
|
13
|
+
let pageDifference;
|
|
14
|
+
let startIndex;
|
|
15
|
+
let totalPages;
|
|
16
|
+
totalPages = this.matPag.getNumberOfPages();
|
|
17
|
+
// Container div with paginator elements
|
|
18
|
+
const actionContainer = this.ViewContainer.element.nativeElement.querySelector('div.mat-paginator-range-actions');
|
|
19
|
+
// Button that triggers the next page action
|
|
20
|
+
const nextPageNode = this.ViewContainer.element.nativeElement.querySelector('button.mat-paginator-navigation-next');
|
|
21
|
+
// Label showing the page range
|
|
22
|
+
const pageRange = this.ViewContainer.element.nativeElement.querySelector('div.mat-paginator-range-label');
|
|
23
|
+
let prevButtonCount = this.buttons.length;
|
|
24
|
+
// Remove buttons before creating new ones
|
|
25
|
+
if (prevButtonCount > 0) {
|
|
26
|
+
this.buttons.forEach((button) => {
|
|
27
|
+
this.renderer.removeChild(actionContainer, button);
|
|
28
|
+
});
|
|
29
|
+
// Empty state array
|
|
30
|
+
prevButtonCount = 0;
|
|
31
|
+
}
|
|
32
|
+
this.renderer.addClass(pageRange, 'custom-paginator-counter');
|
|
33
|
+
this.renderer.addClass(actionContainer, 'custom-paginator-container');
|
|
34
|
+
// Initialize next page and last page buttons
|
|
35
|
+
if (prevButtonCount === 0) {
|
|
36
|
+
const nodeArray = actionContainer.childNodes;
|
|
37
|
+
setTimeout(() => {
|
|
38
|
+
for (const node of nodeArray) {
|
|
39
|
+
if (node.nodeName === 'BUTTON') {
|
|
40
|
+
// Next Button styles
|
|
41
|
+
if (node.innerHTML.length > 100 && node.disabled) {
|
|
42
|
+
this.renderer.addClass(node, 'custom-paginator-arrow-disabled');
|
|
43
|
+
this.renderer.removeClass(node, 'custom-paginator-arrow-enabled');
|
|
44
|
+
}
|
|
45
|
+
else if (node.innerHTML.length > 100 && !node.disabled) {
|
|
46
|
+
this.renderer.addClass(node, 'custom-paginator-arrow-enabled');
|
|
47
|
+
this.renderer.removeClass(node, 'custom-paginator-arrow-disabled');
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
dots = [false, false];
|
|
54
|
+
if (totalPages > 0) {
|
|
55
|
+
this.renderer.insertBefore(actionContainer, this.createButton('0', this.matPag.pageIndex), nextPageNode);
|
|
56
|
+
}
|
|
57
|
+
page = this.showTotalPages + 2;
|
|
58
|
+
pageDifference = totalPages - page;
|
|
59
|
+
startIndex = Math.max(this.currentPage - this.showTotalPages - 2, 1);
|
|
60
|
+
for (let index = startIndex; index < totalPages - 1; index = index + 1) {
|
|
61
|
+
if ((index < page && this.currentPage <= this.showTotalPages) ||
|
|
62
|
+
(index >= this.rangeStart && index <= this.rangeEnd) ||
|
|
63
|
+
(this.currentPage > pageDifference && index >= pageDifference) ||
|
|
64
|
+
totalPages < this.showTotalPages + page) {
|
|
65
|
+
this.renderer.insertBefore(actionContainer, this.createButton(`${index}`, this.matPag.pageIndex), nextPageNode);
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
if (index > this.rangeEnd && !dots[0]) {
|
|
69
|
+
this.renderer.insertBefore(actionContainer, this.createButton(this.pageGapTxt[0], this.matPag.pageIndex), nextPageNode);
|
|
70
|
+
dots[0] = true;
|
|
71
|
+
break;
|
|
72
|
+
}
|
|
73
|
+
if (index < this.rangeEnd && !dots[1]) {
|
|
74
|
+
this.renderer.insertBefore(actionContainer, this.createButton(this.pageGapTxt[1], this.matPag.pageIndex), nextPageNode);
|
|
75
|
+
dots[1] = true;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
if (totalPages > 1) {
|
|
80
|
+
this.renderer.insertBefore(actionContainer, this.createButton(`${totalPages - 1}`, this.matPag.pageIndex), nextPageNode);
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
this.currentPage = 1;
|
|
84
|
+
this.pageGapTxt = ['•••', '---'];
|
|
85
|
+
this.showTotalPages = 2;
|
|
86
|
+
this.checkPage = [0, 0, 0];
|
|
87
|
+
// Display custom range label text
|
|
88
|
+
this.matPag._intl.getRangeLabel = (page, pageSize, length) => {
|
|
89
|
+
const startIndex = page * pageSize;
|
|
90
|
+
const endIndex = startIndex < length
|
|
91
|
+
? Math.min(startIndex + pageSize, length)
|
|
92
|
+
: startIndex + pageSize;
|
|
93
|
+
if (length === 0) {
|
|
94
|
+
return 'Mostrando 0 – 0 de 0 item';
|
|
95
|
+
}
|
|
96
|
+
if (length === 1) {
|
|
97
|
+
return ('Mostrando ' +
|
|
98
|
+
(startIndex + 1) +
|
|
99
|
+
' – ' +
|
|
100
|
+
endIndex +
|
|
101
|
+
' de ' +
|
|
102
|
+
length +
|
|
103
|
+
' item');
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
return ('Mostrando ' +
|
|
107
|
+
(startIndex + 1) +
|
|
108
|
+
' – ' +
|
|
109
|
+
endIndex +
|
|
110
|
+
' de ' +
|
|
111
|
+
length +
|
|
112
|
+
' itens');
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
// Subscribe to rerender buttons when next page and last page button is used
|
|
116
|
+
this.matPag.page.subscribe((paginator) => {
|
|
117
|
+
this.currentPage = paginator.pageIndex;
|
|
118
|
+
this.matPag.pageIndex = paginator.pageIndex;
|
|
119
|
+
this.initPageRange();
|
|
120
|
+
});
|
|
121
|
+
this.matPag._intl.itemsPerPageLabel = 'Itens por página';
|
|
122
|
+
const paginatorIntl = this.matPag._intl;
|
|
123
|
+
paginatorIntl.nextPageLabel = '';
|
|
124
|
+
paginatorIntl.previousPageLabel = '';
|
|
125
|
+
}
|
|
126
|
+
ngDoCheck() {
|
|
127
|
+
// Reset paginator if the pageSize, pageIndex, length changes
|
|
128
|
+
if (this.matPag?.length !== this.checkPage[0] ||
|
|
129
|
+
this.matPag?.pageSize !== this.checkPage[1] ||
|
|
130
|
+
this.matPag?.pageIndex !== this.checkPage[2]) {
|
|
131
|
+
const pageCount = this.matPag.getNumberOfPages();
|
|
132
|
+
if (this.currentPage > pageCount && pageCount !== 0) {
|
|
133
|
+
this.currentPage = 1;
|
|
134
|
+
this.matPag.pageIndex = 0;
|
|
135
|
+
}
|
|
136
|
+
this.currentPage = this.matPag.pageIndex;
|
|
137
|
+
this.initPageRange();
|
|
138
|
+
this.checkPage = [
|
|
139
|
+
this.matPag.length,
|
|
140
|
+
this.matPag.pageSize,
|
|
141
|
+
this.matPag.pageIndex,
|
|
142
|
+
];
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
createButton(index, pageIndex) {
|
|
146
|
+
const linkBtn = this.renderer.createElement('button');
|
|
147
|
+
this.renderer.setAttribute(linkBtn, 'class', 'custom-paginator-page');
|
|
148
|
+
this.renderer.addClass(linkBtn, 'custom-paginator-page-enabled');
|
|
149
|
+
if (index === this.pageGapTxt[0] || index === this.pageGapTxt[1]) {
|
|
150
|
+
this.renderer.addClass(linkBtn, 'custom-paginator-arrow-enabled');
|
|
151
|
+
}
|
|
152
|
+
const pagingTxt = isNaN(+index) ? this.pageGapTxt[0] : +index + 1;
|
|
153
|
+
const text = this.renderer.createText(pagingTxt + '');
|
|
154
|
+
this.renderer.addClass(linkBtn, 'mat-custom-page');
|
|
155
|
+
switch (index) {
|
|
156
|
+
case `${pageIndex}`:
|
|
157
|
+
this.renderer.setAttribute(linkBtn, 'disabled', 'disabled');
|
|
158
|
+
this.renderer.removeClass(linkBtn, 'custom-paginator-page-enabled');
|
|
159
|
+
this.renderer.addClass(linkBtn, 'custom-paginator-page-disabled');
|
|
160
|
+
break;
|
|
161
|
+
case this.pageGapTxt[0]:
|
|
162
|
+
this.renderer.listen(linkBtn, 'click', () => {
|
|
163
|
+
this.switchPage(this.currentPage < this.showTotalPages + 1
|
|
164
|
+
? this.showTotalPages + 2
|
|
165
|
+
: this.currentPage + this.showTotalPages - 1);
|
|
166
|
+
});
|
|
167
|
+
break;
|
|
168
|
+
case this.pageGapTxt[1]:
|
|
169
|
+
this.renderer.listen(linkBtn, 'click', () => {
|
|
170
|
+
this.switchPage(this.currentPage >
|
|
171
|
+
this.matPag.getNumberOfPages() - this.showTotalPages - 2
|
|
172
|
+
? this.matPag.getNumberOfPages() - this.showTotalPages - 3
|
|
173
|
+
: this.currentPage - this.showTotalPages + 1);
|
|
174
|
+
});
|
|
175
|
+
break;
|
|
176
|
+
default:
|
|
177
|
+
this.renderer.listen(linkBtn, 'click', () => {
|
|
178
|
+
this.switchPage(+index);
|
|
179
|
+
});
|
|
180
|
+
break;
|
|
181
|
+
}
|
|
182
|
+
this.renderer.appendChild(linkBtn, text);
|
|
183
|
+
// Add button to private array for state
|
|
184
|
+
this.buttons.push(linkBtn);
|
|
185
|
+
return linkBtn;
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* @description calculates the button range based on class input parameters and based on current page index value.
|
|
189
|
+
*/
|
|
190
|
+
initPageRange() {
|
|
191
|
+
this.rangeStart = this.currentPage - this.showTotalPages / 2;
|
|
192
|
+
this.rangeEnd = this.currentPage + this.showTotalPages / 2;
|
|
193
|
+
this.buildPageNumbers();
|
|
194
|
+
}
|
|
195
|
+
switchPage(index) {
|
|
196
|
+
this.matPag.pageIndex = index;
|
|
197
|
+
this.matPag.page.emit({
|
|
198
|
+
previousPageIndex: this.currentPage,
|
|
199
|
+
pageIndex: index,
|
|
200
|
+
pageSize: this.matPag.pageSize,
|
|
201
|
+
length: this.matPag.length,
|
|
202
|
+
});
|
|
203
|
+
this.currentPage = index;
|
|
204
|
+
this.initPageRange();
|
|
205
|
+
}
|
|
206
|
+
ngAfterViewInit() {
|
|
207
|
+
this.rangeStart = 0;
|
|
208
|
+
this.rangeEnd = this.showTotalPages - 1;
|
|
209
|
+
this.initPageRange();
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
PaginatorLegacyDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PaginatorLegacyDirective, deps: [{ token: i1.MatPaginator, host: true, optional: true, self: true }, { token: i0.ViewContainerRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
213
|
+
PaginatorLegacyDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: PaginatorLegacyDirective, isStandalone: true, selector: "[appStylePaginator]", ngImport: i0 });
|
|
214
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PaginatorLegacyDirective, decorators: [{
|
|
215
|
+
type: Directive,
|
|
216
|
+
args: [{
|
|
217
|
+
selector: '[appStylePaginator]',
|
|
218
|
+
standalone: true,
|
|
219
|
+
}]
|
|
220
|
+
}], ctorParameters: function () { return [{ type: i1.MatPaginator, decorators: [{
|
|
221
|
+
type: Host
|
|
222
|
+
}, {
|
|
223
|
+
type: Self
|
|
224
|
+
}, {
|
|
225
|
+
type: Optional
|
|
226
|
+
}] }, { type: i0.ViewContainerRef }, { type: i0.Renderer2 }]; } });
|
|
227
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-paginator-legacy.directive.js","sourceRoot":"","sources":["../../../../../../../../../../projects/mapa-library-ui/src/lib/core/directives/custom-paginator-legacy.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  DoCheck,\n  Host,\n  Optional,\n  Renderer2,\n  Self,\n  ViewContainerRef,\n} from '@angular/core';\nimport { MatPaginator, PageEvent } from '@angular/material/paginator';\nimport { MatButton } from '@angular/material/button';\n\n@Directive({\n  selector: '[appStylePaginator]',\n  standalone: true,\n})\nexport class PaginatorLegacyDirective implements DoCheck, AfterViewInit {\n  private currentPage: number;\n  private pageGapTxt: string[];\n  private rangeStart!: number;\n  private rangeEnd!: number;\n  private buttons: MatButton[] = [];\n  private showTotalPages: number;\n  private checkPage: number[];\n\n  constructor(\n    @Host() @Self() @Optional() private readonly matPag: MatPaginator,\n    private readonly ViewContainer: ViewContainerRef,\n    private readonly renderer: Renderer2\n  ) {\n    this.currentPage = 1;\n    this.pageGapTxt = ['•••', '---'];\n    this.showTotalPages = 2;\n    this.checkPage = [0, 0, 0];\n    // Display custom range label text\n    this.matPag._intl.getRangeLabel = (\n      page: number,\n      pageSize: number,\n      length: number\n    ): string => {\n      const startIndex = page * pageSize;\n      const endIndex =\n        startIndex < length\n          ? Math.min(startIndex + pageSize, length)\n          : startIndex + pageSize;\n      if (length === 0) {\n        return 'Mostrando 0 – 0 de 0 item';\n      }\n      if (length === 1) {\n        return (\n          'Mostrando ' +\n          (startIndex + 1) +\n          ' – ' +\n          endIndex +\n          ' de ' +\n          length +\n          ' item'\n        );\n      } else {\n        return (\n          'Mostrando ' +\n          (startIndex + 1) +\n          ' – ' +\n          endIndex +\n          ' de ' +\n          length +\n          ' itens'\n        );\n      }\n    };\n    // Subscribe to rerender buttons when next page and last page button is used\n    this.matPag.page.subscribe((paginator: PageEvent) => {\n      this.currentPage = paginator.pageIndex;\n      this.matPag.pageIndex = paginator.pageIndex;\n      this.initPageRange();\n    });\n    this.matPag._intl.itemsPerPageLabel = 'Itens por página';\n    const paginatorIntl = this.matPag._intl;\n    paginatorIntl.nextPageLabel = '';\n    paginatorIntl.previousPageLabel = '';\n  }\n\n  ngDoCheck(): void {\n    // Reset paginator if the pageSize, pageIndex, length changes\n    if (\n      this.matPag?.length !== this.checkPage[0] ||\n      this.matPag?.pageSize !== this.checkPage[1] ||\n      this.matPag?.pageIndex !== this.checkPage[2]\n    ) {\n      const pageCount = this.matPag.getNumberOfPages();\n      if (this.currentPage > pageCount && pageCount !== 0) {\n        this.currentPage = 1;\n        this.matPag.pageIndex = 0;\n      }\n      this.currentPage = this.matPag.pageIndex;\n      this.initPageRange();\n      this.checkPage = [\n        this.matPag.length,\n        this.matPag.pageSize,\n        this.matPag.pageIndex,\n      ];\n    }\n  }\n\n  private buildPageNumbers = () => {\n    let dots: boolean[];\n    let page: number;\n    let pageDifference: number;\n    let startIndex: number;\n    let totalPages: number;\n    totalPages = this.matPag.getNumberOfPages();\n    // Container div with paginator elements\n    const actionContainer =\n      this.ViewContainer.element.nativeElement.querySelector(\n        'div.mat-paginator-range-actions'\n      );\n    // Button that triggers the next page action\n    const nextPageNode = this.ViewContainer.element.nativeElement.querySelector(\n      'button.mat-paginator-navigation-next'\n    );\n    // Label showing the page range\n    const pageRange = this.ViewContainer.element.nativeElement.querySelector(\n      'div.mat-paginator-range-label'\n    );\n\n    let prevButtonCount = this.buttons.length;\n\n    // Remove buttons before creating new ones\n    if (prevButtonCount > 0) {\n      this.buttons.forEach((button) => {\n        this.renderer.removeChild(actionContainer, button);\n      });\n      // Empty state array\n      prevButtonCount = 0;\n    }\n\n    this.renderer.addClass(pageRange, 'custom-paginator-counter');\n    this.renderer.addClass(actionContainer, 'custom-paginator-container');\n\n    // Initialize next page and last page buttons\n    if (prevButtonCount === 0) {\n      const nodeArray = actionContainer.childNodes;\n      setTimeout(() => {\n        for (const node of nodeArray) {\n          if (node.nodeName === 'BUTTON') {\n            // Next Button styles\n            if (node.innerHTML.length > 100 && node.disabled) {\n              this.renderer.addClass(node, 'custom-paginator-arrow-disabled');\n              this.renderer.removeClass(node, 'custom-paginator-arrow-enabled');\n            } else if (node.innerHTML.length > 100 && !node.disabled) {\n              this.renderer.addClass(node, 'custom-paginator-arrow-enabled');\n              this.renderer.removeClass(\n                node,\n                'custom-paginator-arrow-disabled'\n              );\n            }\n          }\n        }\n      });\n    }\n\n    dots = [false, false];\n\n    if (totalPages > 0) {\n      this.renderer.insertBefore(\n        actionContainer,\n        this.createButton('0', this.matPag.pageIndex),\n        nextPageNode\n      );\n    }\n\n    page = this.showTotalPages + 2;\n    pageDifference = totalPages - page;\n    startIndex = Math.max(this.currentPage - this.showTotalPages - 2, 1);\n\n    for (let index = startIndex; index < totalPages - 1; index = index + 1) {\n      if (\n        (index < page && this.currentPage <= this.showTotalPages) ||\n        (index >= this.rangeStart && index <= this.rangeEnd) ||\n        (this.currentPage > pageDifference && index >= pageDifference) ||\n        totalPages < this.showTotalPages + page\n      ) {\n        this.renderer.insertBefore(\n          actionContainer,\n          this.createButton(`${index}`, this.matPag.pageIndex),\n          nextPageNode\n        );\n      } else {\n        if (index > this.rangeEnd && !dots[0]) {\n          this.renderer.insertBefore(\n            actionContainer,\n            this.createButton(this.pageGapTxt[0], this.matPag.pageIndex),\n            nextPageNode\n          );\n          dots[0] = true;\n          break;\n        }\n        if (index < this.rangeEnd && !dots[1]) {\n          this.renderer.insertBefore(\n            actionContainer,\n            this.createButton(this.pageGapTxt[1], this.matPag.pageIndex),\n            nextPageNode\n          );\n          dots[1] = true;\n        }\n      }\n    }\n\n    if (totalPages > 1) {\n      this.renderer.insertBefore(\n        actionContainer,\n        this.createButton(`${totalPages - 1}`, this.matPag.pageIndex),\n        nextPageNode\n      );\n    }\n  };\n\n  private createButton(index: string, pageIndex: number): MatButton {\n    const linkBtn: MatButton = this.renderer.createElement('button');\n    this.renderer.setAttribute(linkBtn, 'class', 'custom-paginator-page');\n    this.renderer.addClass(linkBtn, 'custom-paginator-page-enabled');\n    if (index === this.pageGapTxt[0] || index === this.pageGapTxt[1]) {\n      this.renderer.addClass(linkBtn, 'custom-paginator-arrow-enabled');\n    }\n    const pagingTxt = isNaN(+index) ? this.pageGapTxt[0] : +index + 1;\n    const text = this.renderer.createText(pagingTxt + '');\n    this.renderer.addClass(linkBtn, 'mat-custom-page');\n    switch (index) {\n      case `${pageIndex}`:\n        this.renderer.setAttribute(linkBtn, 'disabled', 'disabled');\n        this.renderer.removeClass(linkBtn, 'custom-paginator-page-enabled');\n        this.renderer.addClass(linkBtn, 'custom-paginator-page-disabled');\n        break;\n      case this.pageGapTxt[0]:\n        this.renderer.listen(linkBtn, 'click', () => {\n          this.switchPage(\n            this.currentPage < this.showTotalPages + 1\n              ? this.showTotalPages + 2\n              : this.currentPage + this.showTotalPages - 1\n          );\n        });\n        break;\n      case this.pageGapTxt[1]:\n        this.renderer.listen(linkBtn, 'click', () => {\n          this.switchPage(\n            this.currentPage >\n              this.matPag.getNumberOfPages() - this.showTotalPages - 2\n              ? this.matPag.getNumberOfPages() - this.showTotalPages - 3\n              : this.currentPage - this.showTotalPages + 1\n          );\n        });\n        break;\n      default:\n        this.renderer.listen(linkBtn, 'click', () => {\n          this.switchPage(+index);\n        });\n        break;\n    }\n    this.renderer.appendChild(linkBtn, text);\n    // Add button to private array for state\n    this.buttons.push(linkBtn);\n    return linkBtn;\n  }\n\n  /**\n   * @description calculates the button range based on class input parameters and based on current page index value.\n   */\n  private initPageRange(): void {\n    this.rangeStart = this.currentPage - this.showTotalPages / 2;\n    this.rangeEnd = this.currentPage + this.showTotalPages / 2;\n    this.buildPageNumbers();\n  }\n\n  private switchPage(index: number): void {\n    this.matPag.pageIndex = index;\n    this.matPag.page.emit({\n      previousPageIndex: this.currentPage,\n      pageIndex: index,\n      pageSize: this.matPag.pageSize,\n      length: this.matPag.length,\n    });\n    this.currentPage = index;\n    this.initPageRange();\n  }\n\n  public ngAfterViewInit(): void {\n    this.rangeStart = 0;\n    this.rangeEnd = this.showTotalPages - 1;\n    this.initPageRange();\n  }\n}\n"]}
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import { Directive, EventEmitter, Input, Output, } from "@angular/core";
|
|
2
|
+
import { map, startWith } from "rxjs";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/material/paginator";
|
|
5
|
+
export class BubblePaginationDirective {
|
|
6
|
+
constructor(matPag, elementRef, ren) {
|
|
7
|
+
this.matPag = matPag;
|
|
8
|
+
this.elementRef = elementRef;
|
|
9
|
+
this.ren = ren;
|
|
10
|
+
this.pageIndexChangeEmitter = new EventEmitter();
|
|
11
|
+
this.showFirstButton = true;
|
|
12
|
+
this.showLastButton = true;
|
|
13
|
+
this.renderButtonsNumber = 2;
|
|
14
|
+
this.appCustomLength = 0;
|
|
15
|
+
this.hideDefaultArrows = false;
|
|
16
|
+
this.buttonsRef = [];
|
|
17
|
+
}
|
|
18
|
+
ngAfterViewInit() {
|
|
19
|
+
this.styleDefaultPagination();
|
|
20
|
+
this.createBubbleDivRef();
|
|
21
|
+
this.renderButtons();
|
|
22
|
+
}
|
|
23
|
+
ngOnChanges(changes) {
|
|
24
|
+
if (!changes?.["appCustomLength"]?.firstChange) {
|
|
25
|
+
this.removeButtons();
|
|
26
|
+
this.switchPage(0);
|
|
27
|
+
this.renderButtons();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
renderButtons() {
|
|
31
|
+
this.buildButtons();
|
|
32
|
+
this.matPag.page
|
|
33
|
+
.pipe(map((e) => [e.previousPageIndex ?? 0, e.pageIndex]), startWith([0, 0]))
|
|
34
|
+
.subscribe(([prev, curr]) => {
|
|
35
|
+
this.changeActiveButtonStyles(prev, curr);
|
|
36
|
+
this.updateButtonsOnPageEvent();
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
changeActiveButtonStyles(previousIndex, newIndex) {
|
|
40
|
+
const previouslyActive = this.buttonsRef[previousIndex];
|
|
41
|
+
const currentActive = this.buttonsRef[newIndex];
|
|
42
|
+
try {
|
|
43
|
+
this.ren.removeClass(previouslyActive, "g-bubble__active");
|
|
44
|
+
this.ren.addClass(currentActive, "g-bubble__active");
|
|
45
|
+
}
|
|
46
|
+
catch { }
|
|
47
|
+
this.buttonsRef.forEach((button) => this.ren.setStyle(button, "display", "none"));
|
|
48
|
+
const renderElements = this.renderButtonsNumber;
|
|
49
|
+
const endDots = newIndex < this.buttonsRef.length - renderElements - 1;
|
|
50
|
+
const startDots = newIndex - renderElements > 0;
|
|
51
|
+
const firstButton = this.buttonsRef[0];
|
|
52
|
+
const lastButton = this.buttonsRef[this.buttonsRef.length - 1];
|
|
53
|
+
try {
|
|
54
|
+
if (this.showLastButton) {
|
|
55
|
+
this.ren.setStyle(this.dotsEndRef, "display", endDots ? "block" : "none");
|
|
56
|
+
this.ren.setStyle(lastButton, "display", endDots ? "flex" : "none");
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
catch { }
|
|
60
|
+
try {
|
|
61
|
+
if (this.showFirstButton) {
|
|
62
|
+
this.ren.setStyle(this.dotsStartRef, "display", startDots ? "block" : "none");
|
|
63
|
+
this.ren.setStyle(firstButton, "display", startDots ? "flex" : "none");
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
catch { }
|
|
67
|
+
const startingIndex = startDots ? newIndex - renderElements : 0;
|
|
68
|
+
const endingIndex = endDots
|
|
69
|
+
? newIndex + renderElements
|
|
70
|
+
: this.buttonsRef.length - 1;
|
|
71
|
+
for (let i = startingIndex; i <= endingIndex; i++) {
|
|
72
|
+
const button = this.buttonsRef[i];
|
|
73
|
+
this.ren.setStyle(button, "display", "flex");
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
styleDefaultPagination() {
|
|
77
|
+
const nativeElement = this.elementRef.nativeElement;
|
|
78
|
+
const itemsPerPage = nativeElement.querySelector(".mat-mdc-paginator-page-size");
|
|
79
|
+
const howManyDisplayedEl = nativeElement.querySelector(".mat-mdc-paginator-range-label");
|
|
80
|
+
const previousButton = nativeElement.querySelector("button.mat-mdc-paginator-navigation-previous");
|
|
81
|
+
const nextButtonDefault = nativeElement.querySelector("button.mat-mdc-paginator-navigation-next");
|
|
82
|
+
if (this.hideDefaultArrows) {
|
|
83
|
+
this.ren.setStyle(previousButton, "display", "none");
|
|
84
|
+
this.ren.setStyle(nextButtonDefault, "display", "none");
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
createBubbleDivRef() {
|
|
88
|
+
const actionContainer = this.elementRef.nativeElement.querySelector("div.mat-mdc-paginator-range-actions");
|
|
89
|
+
const nextButtonDefault = this.elementRef.nativeElement.querySelector("button.mat-mdc-paginator-navigation-next");
|
|
90
|
+
this.bubbleContainerRef = this.ren.createElement("div");
|
|
91
|
+
this.ren.addClass(this.bubbleContainerRef, "g-bubble-container");
|
|
92
|
+
this.ren.insertBefore(actionContainer, this.bubbleContainerRef, nextButtonDefault);
|
|
93
|
+
}
|
|
94
|
+
buildButtons() {
|
|
95
|
+
const neededButtons = Math.ceil(this.appCustomLength / this.matPag.pageSize);
|
|
96
|
+
if (neededButtons === 1) {
|
|
97
|
+
this.ren.setStyle(this.elementRef.nativeElement, "display", "none");
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
this.buttonsRef = [this.createButton(0)];
|
|
101
|
+
this.dotsStartRef = this.createDotsElement();
|
|
102
|
+
for (let index = 1; index < neededButtons - 1; index++) {
|
|
103
|
+
this.buttonsRef = [...this.buttonsRef, this.createButton(index)];
|
|
104
|
+
}
|
|
105
|
+
this.dotsEndRef = this.createDotsElement();
|
|
106
|
+
this.buttonsRef = [
|
|
107
|
+
...this.buttonsRef,
|
|
108
|
+
this.createButton(neededButtons - 1),
|
|
109
|
+
];
|
|
110
|
+
}
|
|
111
|
+
removeButtons() {
|
|
112
|
+
this.bubbleContainerRef.innerHTML = '';
|
|
113
|
+
this.buttonsRef.forEach((button) => {
|
|
114
|
+
this.ren.removeChild(this.bubbleContainerRef, button);
|
|
115
|
+
});
|
|
116
|
+
this.buttonsRef = [];
|
|
117
|
+
this.buttonsRef.length = 0;
|
|
118
|
+
}
|
|
119
|
+
createButton(i) {
|
|
120
|
+
const bubbleButton = this.ren.createElement("div");
|
|
121
|
+
const text = this.ren.createText(String(i + 1));
|
|
122
|
+
this.ren.addClass(bubbleButton, "g-bubble");
|
|
123
|
+
this.ren.setStyle(bubbleButton, "margin-right", "8px");
|
|
124
|
+
this.ren.appendChild(bubbleButton, text);
|
|
125
|
+
this.ren.listen(bubbleButton, "click", () => {
|
|
126
|
+
this.switchPage(i);
|
|
127
|
+
});
|
|
128
|
+
this.ren.appendChild(this.bubbleContainerRef, bubbleButton);
|
|
129
|
+
this.ren.setStyle(bubbleButton, "display", "none");
|
|
130
|
+
return bubbleButton;
|
|
131
|
+
}
|
|
132
|
+
createDotsElement() {
|
|
133
|
+
const dotsEl = this.ren.createElement("span");
|
|
134
|
+
const dotsText = this.ren.createText(".....");
|
|
135
|
+
this.ren.setStyle(dotsEl, "font-size", "18px");
|
|
136
|
+
this.ren.setStyle(dotsEl, "margin-right", "8px");
|
|
137
|
+
this.ren.setStyle(dotsEl, "padding-top", "6px");
|
|
138
|
+
this.ren.setStyle(dotsEl, "color", "#919191");
|
|
139
|
+
this.ren.appendChild(dotsEl, dotsText);
|
|
140
|
+
this.ren.appendChild(this.bubbleContainerRef, dotsEl);
|
|
141
|
+
this.ren.setStyle(dotsEl, "display", "none");
|
|
142
|
+
return dotsEl;
|
|
143
|
+
}
|
|
144
|
+
switchPage(i) {
|
|
145
|
+
const previousPageIndex = this.matPag.pageIndex;
|
|
146
|
+
this.matPag.pageIndex = i;
|
|
147
|
+
try {
|
|
148
|
+
this.matPag["_emitPageEvent"](previousPageIndex);
|
|
149
|
+
}
|
|
150
|
+
catch { }
|
|
151
|
+
this.pageIndexChangeEmitter.emit(i);
|
|
152
|
+
}
|
|
153
|
+
updateButtonsOnPageEvent() {
|
|
154
|
+
const neededButtons = Math.ceil(this.appCustomLength / this.matPag.pageSize);
|
|
155
|
+
if (neededButtons === this.buttonsRef.length) {
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
this.removeButtons();
|
|
159
|
+
this.buildButtons();
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
BubblePaginationDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BubblePaginationDirective, deps: [{ token: i1.MatPaginator }, { token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
163
|
+
BubblePaginationDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: BubblePaginationDirective, isStandalone: true, selector: "[appBubblePagination]", inputs: { showFirstButton: "showFirstButton", showLastButton: "showLastButton", renderButtonsNumber: "renderButtonsNumber", appCustomLength: "appCustomLength", hideDefaultArrows: "hideDefaultArrows" }, outputs: { pageIndexChangeEmitter: "pageIndexChangeEmitter" }, usesOnChanges: true, ngImport: i0 });
|
|
164
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BubblePaginationDirective, decorators: [{
|
|
165
|
+
type: Directive,
|
|
166
|
+
args: [{
|
|
167
|
+
selector: "[appBubblePagination]",
|
|
168
|
+
standalone: true,
|
|
169
|
+
}]
|
|
170
|
+
}], ctorParameters: function () { return [{ type: i1.MatPaginator }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { pageIndexChangeEmitter: [{
|
|
171
|
+
type: Output
|
|
172
|
+
}], showFirstButton: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], showLastButton: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], renderButtonsNumber: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], appCustomLength: [{
|
|
179
|
+
type: Input
|
|
180
|
+
}], hideDefaultArrows: [{
|
|
181
|
+
type: Input
|
|
182
|
+
}] } });
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-paginator.directive.js","sourceRoot":"","sources":["../../../../../../../../../../projects/mapa-library-ui/src/lib/core/directives/custom-paginator.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  Renderer2,\n  SimpleChanges,\n} from \"@angular/core\";\nimport { MatPaginator } from \"@angular/material/paginator\";\nimport { map, startWith } from \"rxjs\";\n\n@Directive({\n  selector: \"[appBubblePagination]\",\n  standalone: true,\n})\nexport class BubblePaginationDirective implements AfterViewInit, OnChanges {\n  @Output() pageIndexChangeEmitter: EventEmitter<number> = new EventEmitter<number>();\n  @Input() showFirstButton = true;\n  @Input() showLastButton = true;\n  @Input() renderButtonsNumber = 2;\n  @Input() appCustomLength: number = 0;\n  @Input() hideDefaultArrows = false;\n  private dotsEndRef!: HTMLElement;\n  private dotsStartRef!: HTMLElement;\n  private bubbleContainerRef!: HTMLElement;\n  private buttonsRef: HTMLElement[] = [];\n\n  constructor(\n    private readonly matPag: MatPaginator,\n    private elementRef: ElementRef,\n    private ren: Renderer2\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.styleDefaultPagination();\n    this.createBubbleDivRef();\n    this.renderButtons();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (!changes?.[\"appCustomLength\"]?.firstChange) {\n      this.removeButtons();\n      this.switchPage(0);\n      this.renderButtons();\n    }\n  }\n\n  private renderButtons(): void {\n    this.buildButtons();\n\n    this.matPag.page\n      .pipe(\n        map((e) => [e.previousPageIndex ?? 0, e.pageIndex]),\n        startWith([0, 0])\n      )\n      .subscribe(([prev, curr]) => {\n        this.changeActiveButtonStyles(prev, curr);\n        this.updateButtonsOnPageEvent();\n      });\n  }\n\n  private changeActiveButtonStyles(previousIndex: number, newIndex: number) {\n    const previouslyActive = this.buttonsRef[previousIndex];\n    const currentActive = this.buttonsRef[newIndex];\n\n    try {\n      this.ren.removeClass(previouslyActive, \"g-bubble__active\");\n      this.ren.addClass(currentActive, \"g-bubble__active\");\n    } catch {}\n\n    this.buttonsRef.forEach((button) =>\n      this.ren.setStyle(button, \"display\", \"none\")\n    );\n\n    const renderElements = this.renderButtonsNumber;\n    const endDots = newIndex < this.buttonsRef.length - renderElements - 1;\n    const startDots = newIndex - renderElements > 0;\n\n    const firstButton = this.buttonsRef[0];\n    const lastButton = this.buttonsRef[this.buttonsRef.length - 1];\n\n    try {\n      if (this.showLastButton) {\n        this.ren.setStyle(this.dotsEndRef, \"display\", endDots ? \"block\" : \"none\");\n        this.ren.setStyle(lastButton, \"display\", endDots ? \"flex\" : \"none\");\n      }\n    } catch {}\n\n    try {\n      if (this.showFirstButton) {\n        this.ren.setStyle(\n          this.dotsStartRef,\n          \"display\",\n          startDots ? \"block\" : \"none\"\n        );\n        this.ren.setStyle(firstButton, \"display\", startDots ? \"flex\" : \"none\");\n      }\n    } catch {}\n\n    const startingIndex = startDots ? newIndex - renderElements : 0;\n    const endingIndex = endDots\n      ? newIndex + renderElements\n      : this.buttonsRef.length - 1;\n\n    for (let i = startingIndex; i <= endingIndex; i++) {\n      const button = this.buttonsRef[i];\n      this.ren.setStyle(button, \"display\", \"flex\");\n    }\n  }\n\n  private styleDefaultPagination() {\n    const nativeElement = this.elementRef.nativeElement;\n    const itemsPerPage = nativeElement.querySelector(\n      \".mat-mdc-paginator-page-size\"\n    );\n    const howManyDisplayedEl = nativeElement.querySelector(\n      \".mat-mdc-paginator-range-label\"\n    );\n    const previousButton = nativeElement.querySelector(\n      \"button.mat-mdc-paginator-navigation-previous\"\n    );\n    const nextButtonDefault = nativeElement.querySelector(\n      \"button.mat-mdc-paginator-navigation-next\"\n    );\n\n    if (this.hideDefaultArrows) {\n      this.ren.setStyle(previousButton, \"display\", \"none\");\n      this.ren.setStyle(nextButtonDefault, \"display\", \"none\");\n    }\n  }\n\n  private createBubbleDivRef(): void {\n    const actionContainer = this.elementRef.nativeElement.querySelector(\n      \"div.mat-mdc-paginator-range-actions\"\n    );\n    const nextButtonDefault = this.elementRef.nativeElement.querySelector(\n      \"button.mat-mdc-paginator-navigation-next\"\n    );\n\n    this.bubbleContainerRef = this.ren.createElement(\"div\") as HTMLElement;\n    this.ren.addClass(this.bubbleContainerRef, \"g-bubble-container\");\n\n    this.ren.insertBefore(\n      actionContainer,\n      this.bubbleContainerRef,\n      nextButtonDefault\n    );\n  }\n\n  private buildButtons(): void {\n    const neededButtons = Math.ceil(\n      this.appCustomLength / this.matPag.pageSize\n    );\n\n    if (neededButtons === 1) {\n      this.ren.setStyle(this.elementRef.nativeElement, \"display\", \"none\");\n      return;\n    }\n\n    this.buttonsRef = [this.createButton(0)];\n    this.dotsStartRef = this.createDotsElement();\n\n    for (let index = 1; index < neededButtons - 1; index++) {\n      this.buttonsRef = [...this.buttonsRef, this.createButton(index)];\n    }\n\n    this.dotsEndRef = this.createDotsElement();\n\n    this.buttonsRef = [\n      ...this.buttonsRef,\n      this.createButton(neededButtons - 1),\n    ];\n  }\n\n  private removeButtons(): void {\n    this.bubbleContainerRef.innerHTML = '';\n    this.buttonsRef.forEach((button) => {\n      this.ren.removeChild(this.bubbleContainerRef, button);\n    });\n    this.buttonsRef = [];\n    this.buttonsRef.length = 0;\n  }\n\n  private createButton(i: number): HTMLElement {\n    const bubbleButton = this.ren.createElement(\"div\");\n    const text = this.ren.createText(String(i + 1));\n\n    this.ren.addClass(bubbleButton, \"g-bubble\");\n    this.ren.setStyle(bubbleButton, \"margin-right\", \"8px\");\n    this.ren.appendChild(bubbleButton, text);\n\n    this.ren.listen(bubbleButton, \"click\", () => {\n      this.switchPage(i);\n    });\n\n    this.ren.appendChild(this.bubbleContainerRef, bubbleButton);\n    this.ren.setStyle(bubbleButton, \"display\", \"none\");\n\n    return bubbleButton;\n  }\n\n  private createDotsElement(): HTMLElement {\n    const dotsEl = this.ren.createElement(\"span\");\n    const dotsText = this.ren.createText(\".....\");\n\n    this.ren.setStyle(dotsEl, \"font-size\", \"18px\");\n    this.ren.setStyle(dotsEl, \"margin-right\", \"8px\");\n    this.ren.setStyle(dotsEl, \"padding-top\", \"6px\");\n    this.ren.setStyle(dotsEl, \"color\", \"#919191\");\n\n    this.ren.appendChild(dotsEl, dotsText);\n    this.ren.appendChild(this.bubbleContainerRef, dotsEl);\n    this.ren.setStyle(dotsEl, \"display\", \"none\");\n\n    return dotsEl;\n  }\n\n  private switchPage(i: number): void {\n    const previousPageIndex = this.matPag.pageIndex;\n    this.matPag.pageIndex = i;\n    try {\n      this.matPag[\"_emitPageEvent\"](previousPageIndex);\n    } catch {}\n\n    this.pageIndexChangeEmitter.emit(i);\n  }\n\n  private updateButtonsOnPageEvent(): void {\n    const neededButtons = Math.ceil(\n      this.appCustomLength / this.matPag.pageSize\n    );\n    if (neededButtons === this.buttonsRef.length) {\n      return;\n    }\n\n    this.removeButtons();\n    this.buildButtons();\n  }\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Generated bundle index. Do not edit.
|
|
3
3
|
*/
|
|
4
|
-
export * from './
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
export * from './table';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYS1saWJyYXJ5LXVpLXNyYy1saWItY29tcG9uZW50cy10YWJsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hcGEtbGlicmFyeS11aS9zcmMvbWFwYS1saWJyYXJ5LXVpLXNyYy1saWItY29tcG9uZW50cy10YWJsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3RhYmxlJztcbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of mapa-library-ui table
|
|
3
|
+
*/
|
|
4
|
+
export * from './lib/core/directives/custom-paginator.directive';
|
|
5
|
+
export * from './lib/core/directives/custom-paginator-legacy.directive';
|
|
6
|
+
export * from './lib/components/table/public-api';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXBhLWxpYnJhcnktdWkvc3JjL3RhYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsbUNBQW1DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG1hcGEtbGlicmFyeS11aSB0YWJsZVxuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb3JlL2RpcmVjdGl2ZXMvY3VzdG9tLXBhZ2luYXRvci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29yZS9kaXJlY3RpdmVzL2N1c3RvbS1wYWdpbmF0b3ItbGVnYWN5LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RhYmxlL3B1YmxpYy1hcGknO1xuIl19
|
|
@@ -600,10 +600,10 @@ class FiltersComponent {
|
|
|
600
600
|
}
|
|
601
601
|
}
|
|
602
602
|
FiltersComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: FiltersComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
603
|
-
FiltersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: FiltersComponent, selector: "mapa-filters", inputs: { form: "form", elements: "elements" }, outputs: { selectedValues: "selectedValues" }, ngImport: i0, template: "<div class=\"filter\">\n <div *ngFor=\"let filter of elements\">\n <div *ngIf=\"filter.controlType === 'checkbox'\" class=\"filter__item--resizable\">\n <mapa-checkbox [formControl]=\"getFormControl(filter.key)\"></mapa-checkbox>\n </div>\n <div *ngIf=\"filter.controlType === 'dropdown'\" class=\"filter__item--resizable\">\n <mapa-dropdown\n [formControl]=\"getFormControl(filter.key)\"\n [element]=\"filter\"\n ></mapa-dropdown>\n </div>\n <div *ngIf=\"filter.controlType === 'input'\" class=\"filter__item\">\n <mapa-input\n [formControl]=\"getFormControl(filter.key)\"\n [element]=\"filter\"\n ></mapa-input>\n </div>\n </div>\n <div class=\"filter__item\">\n <mapa-button [color]=\"'basic'\" (clicked)=\"clearFilters()\">\n Limpar filtros\n </mapa-button>\n <mapa-button\n [color]=\"'primary'\"\n [disabled]=\"!!form.invalid\"\n (clicked)=\"emitSelectedValues()\"\n >\n Filtrar\n </mapa-button>\n </div>\n</div>\n<!--\n<div class=\"input\" *ngIf=\"containsInputText\">\n <div class=\"overlay\"></div>\n <div class=\"inputBackground\">\n <mapa-input\n [formControl]=\"formControlSearchAutoresize\"\n [element]=\"inputTextSearchAutoresize\"\n ></mapa-input>\n </div>\n</div>\n-->\n", styles: [".filter{display:
|
|
603
|
+
FiltersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: FiltersComponent, selector: "mapa-filters", inputs: { form: "form", elements: "elements" }, outputs: { selectedValues: "selectedValues" }, ngImport: i0, template: "<div class=\"filter\">\n <div *ngFor=\"let filter of elements\">\n <div *ngIf=\"filter.controlType === 'checkbox'\" class=\"filter__item--resizable\">\n <mapa-checkbox [formControl]=\"getFormControl(filter.key)\"></mapa-checkbox>\n </div>\n <div *ngIf=\"filter.controlType === 'dropdown'\" class=\"filter__item--resizable\">\n <mapa-dropdown\n [formControl]=\"getFormControl(filter.key)\"\n [element]=\"filter\"\n ></mapa-dropdown>\n </div>\n <div *ngIf=\"filter.controlType === 'input'\" class=\"filter__item\">\n <mapa-input\n [formControl]=\"getFormControl(filter.key)\"\n [element]=\"filter\"\n ></mapa-input>\n </div>\n </div>\n <div class=\"filter__item\">\n <mapa-button [color]=\"'basic'\" (clicked)=\"clearFilters()\">\n Limpar filtros\n </mapa-button>\n <mapa-button\n [color]=\"'primary'\"\n [disabled]=\"!!form.invalid\"\n (clicked)=\"emitSelectedValues()\"\n >\n Filtrar\n </mapa-button>\n </div>\n</div>\n<!--\n<div class=\"input\" *ngIf=\"containsInputText\">\n <div class=\"overlay\"></div>\n <div class=\"inputBackground\">\n <mapa-input\n [formControl]=\"formControlSearchAutoresize\"\n [element]=\"inputTextSearchAutoresize\"\n ></mapa-input>\n </div>\n</div>\n-->\n", styles: [".filter{display:flex;align-items:center;flex-wrap:wrap;background-color:#f6f7f7;padding:32px;width:95vw;gap:30px}.filter__item{display:flex}.input{position:relative}.overlay{position:absolute;top:0;left:2%;width:96%;height:100%;border-bottom:1px solid #d2d7da;z-index:-1}.inputBackground{background-color:#fff;padding:32px 30px;position:relative}button{border:none;background-color:transparent;color:#ea561d;margin-top:30px}::ng-deep mapa-dropdown .mapa-dropdown{max-width:none;min-width:10vw}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2$1.ButtonComponent, selector: "mapa-button", inputs: ["color", "disabled"], outputs: ["clicked"] }, { kind: "component", type: i3.CheckboxComponent, selector: "mapa-checkbox", inputs: ["color", "formControl"] }, { kind: "component", type: i4.MapaDropdownComponent, selector: "mapa-dropdown", inputs: ["formControl", "formControlSearch", "element", "border"] }, { kind: "component", type: i5.MapaInputComponent, selector: "mapa-input", inputs: ["formControl", "element"] }] });
|
|
604
604
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: FiltersComponent, decorators: [{
|
|
605
605
|
type: Component,
|
|
606
|
-
args: [{ selector: 'mapa-filters', template: "<div class=\"filter\">\n <div *ngFor=\"let filter of elements\">\n <div *ngIf=\"filter.controlType === 'checkbox'\" class=\"filter__item--resizable\">\n <mapa-checkbox [formControl]=\"getFormControl(filter.key)\"></mapa-checkbox>\n </div>\n <div *ngIf=\"filter.controlType === 'dropdown'\" class=\"filter__item--resizable\">\n <mapa-dropdown\n [formControl]=\"getFormControl(filter.key)\"\n [element]=\"filter\"\n ></mapa-dropdown>\n </div>\n <div *ngIf=\"filter.controlType === 'input'\" class=\"filter__item\">\n <mapa-input\n [formControl]=\"getFormControl(filter.key)\"\n [element]=\"filter\"\n ></mapa-input>\n </div>\n </div>\n <div class=\"filter__item\">\n <mapa-button [color]=\"'basic'\" (clicked)=\"clearFilters()\">\n Limpar filtros\n </mapa-button>\n <mapa-button\n [color]=\"'primary'\"\n [disabled]=\"!!form.invalid\"\n (clicked)=\"emitSelectedValues()\"\n >\n Filtrar\n </mapa-button>\n </div>\n</div>\n<!--\n<div class=\"input\" *ngIf=\"containsInputText\">\n <div class=\"overlay\"></div>\n <div class=\"inputBackground\">\n <mapa-input\n [formControl]=\"formControlSearchAutoresize\"\n [element]=\"inputTextSearchAutoresize\"\n ></mapa-input>\n </div>\n</div>\n-->\n", styles: [".filter{display:
|
|
606
|
+
args: [{ selector: 'mapa-filters', template: "<div class=\"filter\">\n <div *ngFor=\"let filter of elements\">\n <div *ngIf=\"filter.controlType === 'checkbox'\" class=\"filter__item--resizable\">\n <mapa-checkbox [formControl]=\"getFormControl(filter.key)\"></mapa-checkbox>\n </div>\n <div *ngIf=\"filter.controlType === 'dropdown'\" class=\"filter__item--resizable\">\n <mapa-dropdown\n [formControl]=\"getFormControl(filter.key)\"\n [element]=\"filter\"\n ></mapa-dropdown>\n </div>\n <div *ngIf=\"filter.controlType === 'input'\" class=\"filter__item\">\n <mapa-input\n [formControl]=\"getFormControl(filter.key)\"\n [element]=\"filter\"\n ></mapa-input>\n </div>\n </div>\n <div class=\"filter__item\">\n <mapa-button [color]=\"'basic'\" (clicked)=\"clearFilters()\">\n Limpar filtros\n </mapa-button>\n <mapa-button\n [color]=\"'primary'\"\n [disabled]=\"!!form.invalid\"\n (clicked)=\"emitSelectedValues()\"\n >\n Filtrar\n </mapa-button>\n </div>\n</div>\n<!--\n<div class=\"input\" *ngIf=\"containsInputText\">\n <div class=\"overlay\"></div>\n <div class=\"inputBackground\">\n <mapa-input\n [formControl]=\"formControlSearchAutoresize\"\n [element]=\"inputTextSearchAutoresize\"\n ></mapa-input>\n </div>\n</div>\n-->\n", styles: [".filter{display:flex;align-items:center;flex-wrap:wrap;background-color:#f6f7f7;padding:32px;width:95vw;gap:30px}.filter__item{display:flex}.input{position:relative}.overlay{position:absolute;top:0;left:2%;width:96%;height:100%;border-bottom:1px solid #d2d7da;z-index:-1}.inputBackground{background-color:#fff;padding:32px 30px;position:relative}button{border:none;background-color:transparent;color:#ea561d;margin-top:30px}::ng-deep mapa-dropdown .mapa-dropdown{max-width:none;min-width:10vw}\n"] }]
|
|
607
607
|
}], propDecorators: { form: [{
|
|
608
608
|
type: Input
|
|
609
609
|
}], elements: [{
|