mapa-library-ui 0.0.35 → 0.0.37

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/esm2020/lib/core/directives/custom-paginator-legacy.directive.mjs +227 -0
  2. package/esm2020/public-api.mjs +2 -2
  3. package/esm2020/src/lib/components/capability/lib/components/tag/src/tag.component.mjs +3 -3
  4. package/esm2020/src/lib/components/dropdown/lib/components/dropdown/src/dropdown.component.mjs +4 -5
  5. package/esm2020/src/lib/components/table/lib/components/table/src/table.component.mjs +3 -3
  6. package/esm2020/src/lib/components/table/lib/components/table/src/table.module.mjs +1 -4
  7. package/esm2020/src/lib/components/table/lib/core/directives/custom-paginator-legacy.directive.mjs +4 -4
  8. package/esm2020/src/lib/components/table/table.mjs +1 -2
  9. package/esm2020/src/lib/components/tag/src/tag.component.mjs +3 -3
  10. package/fesm2015/mapa-library-ui-src-lib-components-capability.mjs +2 -2
  11. package/fesm2015/mapa-library-ui-src-lib-components-capability.mjs.map +1 -1
  12. package/fesm2015/mapa-library-ui-src-lib-components-dropdown.mjs +3 -4
  13. package/fesm2015/mapa-library-ui-src-lib-components-dropdown.mjs.map +1 -1
  14. package/fesm2015/mapa-library-ui-src-lib-components-table.mjs +7 -191
  15. package/fesm2015/mapa-library-ui-src-lib-components-table.mjs.map +1 -1
  16. package/fesm2015/mapa-library-ui-src-lib-components-tag.mjs +2 -2
  17. package/fesm2015/mapa-library-ui-src-lib-components-tag.mjs.map +1 -1
  18. package/fesm2015/mapa-library-ui.mjs +211 -166
  19. package/fesm2015/mapa-library-ui.mjs.map +1 -1
  20. package/fesm2020/mapa-library-ui-src-lib-components-capability.mjs +2 -2
  21. package/fesm2020/mapa-library-ui-src-lib-components-capability.mjs.map +1 -1
  22. package/fesm2020/mapa-library-ui-src-lib-components-dropdown.mjs +3 -4
  23. package/fesm2020/mapa-library-ui-src-lib-components-dropdown.mjs.map +1 -1
  24. package/fesm2020/mapa-library-ui-src-lib-components-table.mjs +7 -190
  25. package/fesm2020/mapa-library-ui-src-lib-components-table.mjs.map +1 -1
  26. package/fesm2020/mapa-library-ui-src-lib-components-tag.mjs +2 -2
  27. package/fesm2020/mapa-library-ui-src-lib-components-tag.mjs.map +1 -1
  28. package/fesm2020/mapa-library-ui.mjs +208 -165
  29. package/fesm2020/mapa-library-ui.mjs.map +1 -1
  30. package/lib/core/directives/custom-paginator-legacy.directive.d.ts +27 -0
  31. package/mapa-library-ui-0.0.37.tgz +0 -0
  32. package/package.json +1 -1
  33. package/public-api.d.ts +1 -1
  34. package/src/lib/components/capability/lib/components/tag/src/tag.component.d.ts +1 -1
  35. package/src/lib/components/table/lib/components/table/src/table.module.d.ts +3 -4
  36. package/src/lib/components/table/lib/core/directives/custom-paginator-legacy.directive.d.ts +1 -1
  37. package/src/lib/components/table/table.d.ts +0 -1
  38. package/src/lib/components/tag/src/tag.component.d.ts +1 -1
  39. package/esm2020/lib/core/directives/custom-paginator.directive.mjs +0 -184
  40. package/esm2020/src/lib/components/table/lib/core/directives/custom-paginator.directive.mjs +0 -184
  41. package/lib/core/directives/custom-paginator.directive.d.ts +0 -33
  42. package/mapa-library-ui-0.0.35.tgz +0 -0
  43. package/src/lib/components/table/lib/core/directives/custom-paginator.directive.d.ts +0 -33
@@ -1,3 +1,2 @@
1
- export * from './lib/core/directives/custom-paginator.directive';
2
1
  export * from './lib/core/directives/custom-paginator-legacy.directive';
3
2
  export * from './lib/components/table/public-api';
@@ -1,6 +1,6 @@
1
1
  import * as i0 from "@angular/core";
2
2
  export declare class TagComponent {
3
- color: 'highlight' | null | undefined;
3
+ color: 'highlight' | 'selected' | null | undefined;
4
4
  size?: 'small' | null | undefined;
5
5
  static ɵfac: i0.ɵɵFactoryDeclaration<TagComponent, never>;
6
6
  static ɵcmp: i0.ɵɵComponentDeclaration<TagComponent, "mapa-tag", never, { "color": "color"; "size": "size"; }, {}, never, ["*"], false, never>;
@@ -1,184 +0,0 @@
1
- import { Directive, EventEmitter, Input, Output, } from "@angular/core";
2
- import { map } from "rxjs/internal/operators/map";
3
- import { startWith } from "rxjs/internal/operators/startWith";
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/material/paginator";
6
- export class BubblePaginationDirective {
7
- constructor(matPag, elementRef, ren) {
8
- this.matPag = matPag;
9
- this.elementRef = elementRef;
10
- this.ren = ren;
11
- this.pageIndexChangeEmitter = new EventEmitter();
12
- this.showFirstButton = true;
13
- this.showLastButton = true;
14
- this.renderButtonsNumber = 2;
15
- this.appCustomLength = 0;
16
- this.hideDefaultArrows = false;
17
- this.buttonsRef = [];
18
- }
19
- ngAfterViewInit() {
20
- this.styleDefaultPagination();
21
- this.createBubbleDivRef();
22
- this.renderButtons();
23
- }
24
- ngOnChanges(changes) {
25
- if (!changes?.["appCustomLength"]?.firstChange) {
26
- this.removeButtons();
27
- this.switchPage(0);
28
- this.renderButtons();
29
- }
30
- }
31
- renderButtons() {
32
- this.buildButtons();
33
- this.matPag.page
34
- .pipe(map((e) => [e.previousPageIndex ?? 0, e.pageIndex]), startWith([0, 0]))
35
- .subscribe(([prev, curr]) => {
36
- this.changeActiveButtonStyles(prev, curr);
37
- this.updateButtonsOnPageEvent();
38
- });
39
- }
40
- changeActiveButtonStyles(previousIndex, newIndex) {
41
- const previouslyActive = this.buttonsRef[previousIndex];
42
- const currentActive = this.buttonsRef[newIndex];
43
- try {
44
- this.ren.removeClass(previouslyActive, "g-bubble__active");
45
- this.ren.addClass(currentActive, "g-bubble__active");
46
- }
47
- catch { }
48
- this.buttonsRef.forEach((button) => this.ren.setStyle(button, "display", "none"));
49
- const renderElements = this.renderButtonsNumber;
50
- const endDots = newIndex < this.buttonsRef.length - renderElements - 1;
51
- const startDots = newIndex - renderElements > 0;
52
- const firstButton = this.buttonsRef[0];
53
- const lastButton = this.buttonsRef[this.buttonsRef.length - 1];
54
- try {
55
- if (this.showLastButton) {
56
- this.ren.setStyle(this.dotsEndRef, "display", endDots ? "block" : "none");
57
- this.ren.setStyle(lastButton, "display", endDots ? "flex" : "none");
58
- }
59
- }
60
- catch { }
61
- try {
62
- if (this.showFirstButton) {
63
- this.ren.setStyle(this.dotsStartRef, "display", startDots ? "block" : "none");
64
- this.ren.setStyle(firstButton, "display", startDots ? "flex" : "none");
65
- }
66
- }
67
- catch { }
68
- const startingIndex = startDots ? newIndex - renderElements : 0;
69
- const endingIndex = endDots
70
- ? newIndex + renderElements
71
- : this.buttonsRef.length - 1;
72
- for (let i = startingIndex; i <= endingIndex; i++) {
73
- const button = this.buttonsRef[i];
74
- this.ren.setStyle(button, "display", "flex");
75
- }
76
- }
77
- styleDefaultPagination() {
78
- const nativeElement = this.elementRef.nativeElement;
79
- const itemsPerPage = nativeElement.querySelector(".mat-mdc-paginator-page-size");
80
- const howManyDisplayedEl = nativeElement.querySelector(".mat-mdc-paginator-range-label");
81
- const previousButton = nativeElement.querySelector("button.mat-mdc-paginator-navigation-previous");
82
- const nextButtonDefault = nativeElement.querySelector("button.mat-mdc-paginator-navigation-next");
83
- if (this.hideDefaultArrows) {
84
- this.ren.setStyle(previousButton, "display", "none");
85
- this.ren.setStyle(nextButtonDefault, "display", "none");
86
- }
87
- }
88
- createBubbleDivRef() {
89
- const actionContainer = this.elementRef.nativeElement.querySelector("div.mat-mdc-paginator-range-actions");
90
- const nextButtonDefault = this.elementRef.nativeElement.querySelector("button.mat-mdc-paginator-navigation-next");
91
- this.bubbleContainerRef = this.ren.createElement("div");
92
- this.ren.addClass(this.bubbleContainerRef, "g-bubble-container");
93
- this.ren.insertBefore(actionContainer, this.bubbleContainerRef, nextButtonDefault);
94
- }
95
- buildButtons() {
96
- const neededButtons = Math.ceil(this.appCustomLength / this.matPag.pageSize);
97
- if (neededButtons === 1) {
98
- this.ren.setStyle(this.elementRef.nativeElement, "display", "none");
99
- return;
100
- }
101
- this.buttonsRef = [this.createButton(0)];
102
- this.dotsStartRef = this.createDotsElement();
103
- for (let index = 1; index < neededButtons - 1; index++) {
104
- this.buttonsRef = [...this.buttonsRef, this.createButton(index)];
105
- }
106
- this.dotsEndRef = this.createDotsElement();
107
- this.buttonsRef = [
108
- ...this.buttonsRef,
109
- this.createButton(neededButtons - 1),
110
- ];
111
- }
112
- removeButtons() {
113
- this.bubbleContainerRef.innerHTML = '';
114
- this.buttonsRef.forEach((button) => {
115
- this.ren.removeChild(this.bubbleContainerRef, button);
116
- });
117
- this.buttonsRef = [];
118
- this.buttonsRef.length = 0;
119
- }
120
- createButton(i) {
121
- const bubbleButton = this.ren.createElement("div");
122
- const text = this.ren.createText(String(i + 1));
123
- this.ren.addClass(bubbleButton, "g-bubble");
124
- this.ren.setStyle(bubbleButton, "margin-right", "8px");
125
- this.ren.appendChild(bubbleButton, text);
126
- this.ren.listen(bubbleButton, "click", () => {
127
- this.switchPage(i);
128
- });
129
- this.ren.appendChild(this.bubbleContainerRef, bubbleButton);
130
- this.ren.setStyle(bubbleButton, "display", "none");
131
- return bubbleButton;
132
- }
133
- createDotsElement() {
134
- const dotsEl = this.ren.createElement("span");
135
- const dotsText = this.ren.createText(".....");
136
- this.ren.setStyle(dotsEl, "font-size", "18px");
137
- this.ren.setStyle(dotsEl, "margin-right", "8px");
138
- this.ren.setStyle(dotsEl, "padding-top", "6px");
139
- this.ren.setStyle(dotsEl, "color", "#919191");
140
- this.ren.appendChild(dotsEl, dotsText);
141
- this.ren.appendChild(this.bubbleContainerRef, dotsEl);
142
- this.ren.setStyle(dotsEl, "display", "none");
143
- return dotsEl;
144
- }
145
- switchPage(i) {
146
- const previousPageIndex = this.matPag.pageIndex;
147
- this.matPag.pageIndex = i;
148
- try {
149
- this.matPag["_emitPageEvent"](previousPageIndex);
150
- }
151
- catch { }
152
- this.pageIndexChangeEmitter.emit(i);
153
- }
154
- updateButtonsOnPageEvent() {
155
- const neededButtons = Math.ceil(this.appCustomLength / this.matPag.pageSize);
156
- if (neededButtons === this.buttonsRef.length) {
157
- return;
158
- }
159
- this.removeButtons();
160
- this.buildButtons();
161
- }
162
- }
163
- 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 });
164
- 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 });
165
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BubblePaginationDirective, decorators: [{
166
- type: Directive,
167
- args: [{
168
- selector: "[appBubblePagination]",
169
- standalone: true,
170
- }]
171
- }], ctorParameters: function () { return [{ type: i1.MatPaginator }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { pageIndexChangeEmitter: [{
172
- type: Output
173
- }], showFirstButton: [{
174
- type: Input
175
- }], showLastButton: [{
176
- type: Input
177
- }], renderButtonsNumber: [{
178
- type: Input
179
- }], appCustomLength: [{
180
- type: Input
181
- }], hideDefaultArrows: [{
182
- type: Input
183
- }] } });
184
- //# 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 } from \"rxjs/internal/operators/map\";\nimport { startWith } from \"rxjs/internal/operators/startWith\";\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,184 +0,0 @@
1
- import { Directive, EventEmitter, Input, Output, } from "@angular/core";
2
- import { map } from "rxjs/internal/operators/map";
3
- import { startWith } from "rxjs/internal/operators/startWith";
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/material/paginator";
6
- export class BubblePaginationDirective {
7
- constructor(matPag, elementRef, ren) {
8
- this.matPag = matPag;
9
- this.elementRef = elementRef;
10
- this.ren = ren;
11
- this.pageIndexChangeEmitter = new EventEmitter();
12
- this.showFirstButton = true;
13
- this.showLastButton = true;
14
- this.renderButtonsNumber = 2;
15
- this.appCustomLength = 0;
16
- this.hideDefaultArrows = false;
17
- this.buttonsRef = [];
18
- }
19
- ngAfterViewInit() {
20
- this.styleDefaultPagination();
21
- this.createBubbleDivRef();
22
- this.renderButtons();
23
- }
24
- ngOnChanges(changes) {
25
- if (!changes?.["appCustomLength"]?.firstChange) {
26
- this.removeButtons();
27
- this.switchPage(0);
28
- this.renderButtons();
29
- }
30
- }
31
- renderButtons() {
32
- this.buildButtons();
33
- this.matPag.page
34
- .pipe(map((e) => [e.previousPageIndex ?? 0, e.pageIndex]), startWith([0, 0]))
35
- .subscribe(([prev, curr]) => {
36
- this.changeActiveButtonStyles(prev, curr);
37
- this.updateButtonsOnPageEvent();
38
- });
39
- }
40
- changeActiveButtonStyles(previousIndex, newIndex) {
41
- const previouslyActive = this.buttonsRef[previousIndex];
42
- const currentActive = this.buttonsRef[newIndex];
43
- try {
44
- this.ren.removeClass(previouslyActive, "g-bubble__active");
45
- this.ren.addClass(currentActive, "g-bubble__active");
46
- }
47
- catch { }
48
- this.buttonsRef.forEach((button) => this.ren.setStyle(button, "display", "none"));
49
- const renderElements = this.renderButtonsNumber;
50
- const endDots = newIndex < this.buttonsRef.length - renderElements - 1;
51
- const startDots = newIndex - renderElements > 0;
52
- const firstButton = this.buttonsRef[0];
53
- const lastButton = this.buttonsRef[this.buttonsRef.length - 1];
54
- try {
55
- if (this.showLastButton) {
56
- this.ren.setStyle(this.dotsEndRef, "display", endDots ? "block" : "none");
57
- this.ren.setStyle(lastButton, "display", endDots ? "flex" : "none");
58
- }
59
- }
60
- catch { }
61
- try {
62
- if (this.showFirstButton) {
63
- this.ren.setStyle(this.dotsStartRef, "display", startDots ? "block" : "none");
64
- this.ren.setStyle(firstButton, "display", startDots ? "flex" : "none");
65
- }
66
- }
67
- catch { }
68
- const startingIndex = startDots ? newIndex - renderElements : 0;
69
- const endingIndex = endDots
70
- ? newIndex + renderElements
71
- : this.buttonsRef.length - 1;
72
- for (let i = startingIndex; i <= endingIndex; i++) {
73
- const button = this.buttonsRef[i];
74
- this.ren.setStyle(button, "display", "flex");
75
- }
76
- }
77
- styleDefaultPagination() {
78
- const nativeElement = this.elementRef.nativeElement;
79
- const itemsPerPage = nativeElement.querySelector(".mat-mdc-paginator-page-size");
80
- const howManyDisplayedEl = nativeElement.querySelector(".mat-mdc-paginator-range-label");
81
- const previousButton = nativeElement.querySelector("button.mat-mdc-paginator-navigation-previous");
82
- const nextButtonDefault = nativeElement.querySelector("button.mat-mdc-paginator-navigation-next");
83
- if (this.hideDefaultArrows) {
84
- this.ren.setStyle(previousButton, "display", "none");
85
- this.ren.setStyle(nextButtonDefault, "display", "none");
86
- }
87
- }
88
- createBubbleDivRef() {
89
- const actionContainer = this.elementRef.nativeElement.querySelector("div.mat-mdc-paginator-range-actions");
90
- const nextButtonDefault = this.elementRef.nativeElement.querySelector("button.mat-mdc-paginator-navigation-next");
91
- this.bubbleContainerRef = this.ren.createElement("div");
92
- this.ren.addClass(this.bubbleContainerRef, "g-bubble-container");
93
- this.ren.insertBefore(actionContainer, this.bubbleContainerRef, nextButtonDefault);
94
- }
95
- buildButtons() {
96
- const neededButtons = Math.ceil(this.appCustomLength / this.matPag.pageSize);
97
- if (neededButtons === 1) {
98
- this.ren.setStyle(this.elementRef.nativeElement, "display", "none");
99
- return;
100
- }
101
- this.buttonsRef = [this.createButton(0)];
102
- this.dotsStartRef = this.createDotsElement();
103
- for (let index = 1; index < neededButtons - 1; index++) {
104
- this.buttonsRef = [...this.buttonsRef, this.createButton(index)];
105
- }
106
- this.dotsEndRef = this.createDotsElement();
107
- this.buttonsRef = [
108
- ...this.buttonsRef,
109
- this.createButton(neededButtons - 1),
110
- ];
111
- }
112
- removeButtons() {
113
- this.bubbleContainerRef.innerHTML = '';
114
- this.buttonsRef.forEach((button) => {
115
- this.ren.removeChild(this.bubbleContainerRef, button);
116
- });
117
- this.buttonsRef = [];
118
- this.buttonsRef.length = 0;
119
- }
120
- createButton(i) {
121
- const bubbleButton = this.ren.createElement("div");
122
- const text = this.ren.createText(String(i + 1));
123
- this.ren.addClass(bubbleButton, "g-bubble");
124
- this.ren.setStyle(bubbleButton, "margin-right", "8px");
125
- this.ren.appendChild(bubbleButton, text);
126
- this.ren.listen(bubbleButton, "click", () => {
127
- this.switchPage(i);
128
- });
129
- this.ren.appendChild(this.bubbleContainerRef, bubbleButton);
130
- this.ren.setStyle(bubbleButton, "display", "none");
131
- return bubbleButton;
132
- }
133
- createDotsElement() {
134
- const dotsEl = this.ren.createElement("span");
135
- const dotsText = this.ren.createText(".....");
136
- this.ren.setStyle(dotsEl, "font-size", "18px");
137
- this.ren.setStyle(dotsEl, "margin-right", "8px");
138
- this.ren.setStyle(dotsEl, "padding-top", "6px");
139
- this.ren.setStyle(dotsEl, "color", "#919191");
140
- this.ren.appendChild(dotsEl, dotsText);
141
- this.ren.appendChild(this.bubbleContainerRef, dotsEl);
142
- this.ren.setStyle(dotsEl, "display", "none");
143
- return dotsEl;
144
- }
145
- switchPage(i) {
146
- const previousPageIndex = this.matPag.pageIndex;
147
- this.matPag.pageIndex = i;
148
- try {
149
- this.matPag["_emitPageEvent"](previousPageIndex);
150
- }
151
- catch { }
152
- this.pageIndexChangeEmitter.emit(i);
153
- }
154
- updateButtonsOnPageEvent() {
155
- const neededButtons = Math.ceil(this.appCustomLength / this.matPag.pageSize);
156
- if (neededButtons === this.buttonsRef.length) {
157
- return;
158
- }
159
- this.removeButtons();
160
- this.buildButtons();
161
- }
162
- }
163
- 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 });
164
- 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 });
165
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BubblePaginationDirective, decorators: [{
166
- type: Directive,
167
- args: [{
168
- selector: "[appBubblePagination]",
169
- standalone: true,
170
- }]
171
- }], ctorParameters: function () { return [{ type: i1.MatPaginator }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { pageIndexChangeEmitter: [{
172
- type: Output
173
- }], showFirstButton: [{
174
- type: Input
175
- }], showLastButton: [{
176
- type: Input
177
- }], renderButtonsNumber: [{
178
- type: Input
179
- }], appCustomLength: [{
180
- type: Input
181
- }], hideDefaultArrows: [{
182
- type: Input
183
- }] } });
184
- //# 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 } from \"rxjs/internal/operators/map\";\nimport { startWith } from \"rxjs/internal/operators/startWith\";\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,33 +0,0 @@
1
- import { AfterViewInit, ElementRef, EventEmitter, OnChanges, Renderer2, SimpleChanges } from "@angular/core";
2
- import { MatPaginator } from "@angular/material/paginator";
3
- import * as i0 from "@angular/core";
4
- export declare class BubblePaginationDirective implements AfterViewInit, OnChanges {
5
- private readonly matPag;
6
- private elementRef;
7
- private ren;
8
- pageIndexChangeEmitter: EventEmitter<number>;
9
- showFirstButton: boolean;
10
- showLastButton: boolean;
11
- renderButtonsNumber: number;
12
- appCustomLength: number;
13
- hideDefaultArrows: boolean;
14
- private dotsEndRef;
15
- private dotsStartRef;
16
- private bubbleContainerRef;
17
- private buttonsRef;
18
- constructor(matPag: MatPaginator, elementRef: ElementRef, ren: Renderer2);
19
- ngAfterViewInit(): void;
20
- ngOnChanges(changes: SimpleChanges): void;
21
- private renderButtons;
22
- private changeActiveButtonStyles;
23
- private styleDefaultPagination;
24
- private createBubbleDivRef;
25
- private buildButtons;
26
- private removeButtons;
27
- private createButton;
28
- private createDotsElement;
29
- private switchPage;
30
- private updateButtonsOnPageEvent;
31
- static ɵfac: i0.ɵɵFactoryDeclaration<BubblePaginationDirective, never>;
32
- static ɵdir: i0.ɵɵDirectiveDeclaration<BubblePaginationDirective, "[appBubblePagination]", never, { "showFirstButton": "showFirstButton"; "showLastButton": "showLastButton"; "renderButtonsNumber": "renderButtonsNumber"; "appCustomLength": "appCustomLength"; "hideDefaultArrows": "hideDefaultArrows"; }, { "pageIndexChangeEmitter": "pageIndexChangeEmitter"; }, never, never, true, never>;
33
- }
Binary file
@@ -1,33 +0,0 @@
1
- import { AfterViewInit, ElementRef, EventEmitter, OnChanges, Renderer2, SimpleChanges } from "@angular/core";
2
- import { MatPaginator } from "@angular/material/paginator";
3
- import * as i0 from "@angular/core";
4
- export declare class BubblePaginationDirective implements AfterViewInit, OnChanges {
5
- private readonly matPag;
6
- private elementRef;
7
- private ren;
8
- pageIndexChangeEmitter: EventEmitter<number>;
9
- showFirstButton: boolean;
10
- showLastButton: boolean;
11
- renderButtonsNumber: number;
12
- appCustomLength: number;
13
- hideDefaultArrows: boolean;
14
- private dotsEndRef;
15
- private dotsStartRef;
16
- private bubbleContainerRef;
17
- private buttonsRef;
18
- constructor(matPag: MatPaginator, elementRef: ElementRef, ren: Renderer2);
19
- ngAfterViewInit(): void;
20
- ngOnChanges(changes: SimpleChanges): void;
21
- private renderButtons;
22
- private changeActiveButtonStyles;
23
- private styleDefaultPagination;
24
- private createBubbleDivRef;
25
- private buildButtons;
26
- private removeButtons;
27
- private createButton;
28
- private createDotsElement;
29
- private switchPage;
30
- private updateButtonsOnPageEvent;
31
- static ɵfac: i0.ɵɵFactoryDeclaration<BubblePaginationDirective, never>;
32
- static ɵdir: i0.ɵɵDirectiveDeclaration<BubblePaginationDirective, "[appBubblePagination]", never, { "showFirstButton": "showFirstButton"; "showLastButton": "showLastButton"; "renderButtonsNumber": "renderButtonsNumber"; "appCustomLength": "appCustomLength"; "hideDefaultArrows": "hideDefaultArrows"; }, { "pageIndexChangeEmitter": "pageIndexChangeEmitter"; }, never, never, true, never>;
33
- }