myrta-ui 17.1.73 → 17.1.75
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.
|
@@ -36,44 +36,68 @@ export class PaginatorComponent {
|
|
|
36
36
|
.fill(1)
|
|
37
37
|
.map((item, index) => ({ index: index + 1, active: index + 1 === this.currentPage }));
|
|
38
38
|
}
|
|
39
|
+
// TO DO: пока оставлю для тестов
|
|
40
|
+
// public get getViewItems(): PaginatorItem[] {
|
|
41
|
+
// return this.getNumbers.filter((item, index) => {
|
|
42
|
+
// if (this.currentPage === 1 && this.currentPage < this.getItems) {
|
|
43
|
+
// return item.index === this.currentPage ||
|
|
44
|
+
// item.index === this.currentPage + 1 ||
|
|
45
|
+
// item.index === this.currentPage + 2 ||
|
|
46
|
+
// item.index === this.currentPage + 3 ||
|
|
47
|
+
// item.index === this.currentPage + 4;
|
|
48
|
+
// } else if (this.currentPage == 2 && this.currentPage < this.getItems) {
|
|
49
|
+
// return item.index === this.currentPage - 1 ||
|
|
50
|
+
// item.index === this.currentPage ||
|
|
51
|
+
// item.index === this.currentPage + 1 ||
|
|
52
|
+
// item.index === this.currentPage + 2 ||
|
|
53
|
+
// item.index === this.currentPage + 3;
|
|
54
|
+
// } else if (this.currentPage == this.getItems - 1 && this.currentPage < this.getItems) {
|
|
55
|
+
// return item.index === this.currentPage - 3 ||
|
|
56
|
+
// item.index === this.currentPage - 2 ||
|
|
57
|
+
// item.index === this.currentPage - 1 ||
|
|
58
|
+
// item.index === this.currentPage ||
|
|
59
|
+
// item.index === this.currentPage + 1;
|
|
60
|
+
// } else if (this.currentPage > 1 && this.currentPage < this.getItems) {
|
|
61
|
+
// return item.index === this.currentPage - 2 ||
|
|
62
|
+
// item.index === this.currentPage - 1 ||
|
|
63
|
+
// item.index === this.currentPage ||
|
|
64
|
+
// item.index === this.currentPage + 1 ||
|
|
65
|
+
// item.index === this.currentPage + 2;
|
|
66
|
+
// } else {
|
|
67
|
+
// return item.index === this.currentPage - 4 ||
|
|
68
|
+
// item.index === this.currentPage - 3 ||
|
|
69
|
+
// item.index === this.currentPage - 2 ||
|
|
70
|
+
// item.index === this.currentPage - 1 ||
|
|
71
|
+
// item.index === this.currentPage;
|
|
72
|
+
// }
|
|
73
|
+
// });
|
|
74
|
+
// }
|
|
75
|
+
// Упрощенная версия getViewItems()
|
|
39
76
|
get getViewItems() {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
item.index === this.currentPage - 1 ||
|
|
65
|
-
item.index === this.currentPage ||
|
|
66
|
-
item.index === this.currentPage + 1 ||
|
|
67
|
-
item.index === this.currentPage + 2;
|
|
68
|
-
}
|
|
69
|
-
else {
|
|
70
|
-
return item.index === this.currentPage - 4 ||
|
|
71
|
-
item.index === this.currentPage - 3 ||
|
|
72
|
-
item.index === this.currentPage - 2 ||
|
|
73
|
-
item.index === this.currentPage - 1 ||
|
|
74
|
-
item.index === this.currentPage;
|
|
75
|
-
}
|
|
76
|
-
});
|
|
77
|
+
const totalPages = this.getItems;
|
|
78
|
+
const current = this.currentPage;
|
|
79
|
+
const delta = 2; // количество страниц по бокам от текущей
|
|
80
|
+
const range = [];
|
|
81
|
+
for (let i = Math.max(2, current - delta); i <= Math.min(totalPages - 1, current + delta); i++) {
|
|
82
|
+
range.push(i);
|
|
83
|
+
}
|
|
84
|
+
// Добавляем первую страницу
|
|
85
|
+
if (current - delta > 1) {
|
|
86
|
+
range.unshift('...');
|
|
87
|
+
}
|
|
88
|
+
range.unshift(1);
|
|
89
|
+
// Добавляем последнюю страницу
|
|
90
|
+
if (current + delta < totalPages - 1) {
|
|
91
|
+
range.push('...');
|
|
92
|
+
}
|
|
93
|
+
if (totalPages > 1) {
|
|
94
|
+
range.push(totalPages);
|
|
95
|
+
}
|
|
96
|
+
return range.map((item, index) => ({
|
|
97
|
+
index: typeof item === 'number' ? item : index,
|
|
98
|
+
active: item === current,
|
|
99
|
+
isEllipsis: item === '...'
|
|
100
|
+
}));
|
|
77
101
|
}
|
|
78
102
|
get getFirstNumberCurrentPage() {
|
|
79
103
|
if (this.total === 0) {
|
|
@@ -100,6 +124,7 @@ export class PaginatorComponent {
|
|
|
100
124
|
});
|
|
101
125
|
}
|
|
102
126
|
onChangePageSize(value) {
|
|
127
|
+
console.log(value);
|
|
103
128
|
this.currentPage = 1;
|
|
104
129
|
this.dataStateChanged.emit({
|
|
105
130
|
currentPage: this.currentPage,
|
|
@@ -144,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
144
169
|
}], dataStateChanged: [{
|
|
145
170
|
type: Output
|
|
146
171
|
}] } });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/paginator/paginator.component.ts","../../../../../../projects/myrta-ui/src/lib/components/paginator/paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport {\r\n  PaginateOutputObject,\r\n  PaginatorItem,\r\n  PaginatorPosition, PaginatorPositionCss,\r\n} from './paginator.enum';\r\nimport { DropdownPosition } from '@ng-select/ng-select';\r\nimport { PositionEnum } from '../../enums/overlay'\r\n\r\n@Component({\r\n  selector: 'mrx-paginator',\r\n  templateUrl: './paginator.component.html',\r\n  styleUrls: ['./paginator.component.less']\r\n})\r\nexport class PaginatorComponent {\r\n  public position: PaginatorPosition | undefined = 'centered';\r\n  public withPageSize: boolean | undefined = true;\r\n\r\n  @Input() pageSizes: number[] = [20, 50, 100];\r\n  @Input() currentPage = 1;\r\n  @Input() pageSize = 20;\r\n  @Input() total = 0;\r\n  @Input() customClasses = '';\r\n\r\n  @Input() isEmptyPaginator: boolean = false;\r\n  @Input() isPaginatorText: boolean = false;\r\n  @Input() paginatorText: string = 'записи';\r\n  @Input() dropdownPosition: DropdownPosition  = 'auto'; // deprecated\r\n  @Input() popupPosition: PositionEnum = PositionEnum.BottomEnd;\r\n\r\n  @Input('position')\r\n  public set setPosition(value: PaginatorPosition | undefined) {\r\n    this.position = value || 'centered';\r\n  }\r\n\r\n  @Input('withPageSize')\r\n  public set setWithPageSize(value: boolean | undefined) {\r\n    this.withPageSize = value || false;\r\n  }\r\n\r\n  @Output() dataStateChanged: EventEmitter<PaginateOutputObject> = new EventEmitter<PaginateOutputObject>();\r\n\r\n  public get getClasses(): string {\r\n    return `${this.position && PaginatorPositionCss[this.position]} ${this.customClasses}`;\r\n  }\r\n\r\n  public get getItems(): number {\r\n    return Math.ceil(this.total / this.pageSize);\r\n  }\r\n\r\n  public get getNumbers(): PaginatorItem[] {\r\n    return Array(this.getItems)\r\n      .fill(1)\r\n      .map((item, index) => ({ index: index + 1, active: index + 1 === this.currentPage }));\r\n  }\r\n\r\n  public get getViewItems(): PaginatorItem[] {\r\n    return this.getNumbers.filter((item, index) => {\r\n      if (this.currentPage === 1 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1 ||\r\n          item.index === this.currentPage + 2 ||\r\n          item.index === this.currentPage + 3 ||\r\n          item.index === this.currentPage + 4;\r\n      } else if (this.currentPage == 2 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1 ||\r\n          item.index === this.currentPage + 2 ||\r\n          item.index === this.currentPage + 3;\r\n      } else if (this.currentPage == this.getItems - 1 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage - 3 ||\r\n          item.index === this.currentPage - 2 ||\r\n          item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1;\r\n      } else if (this.currentPage > 1 && this.currentPage < this.getItems) {\r\n        return item.index === this.currentPage - 2 ||\r\n          item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage ||\r\n          item.index === this.currentPage + 1 ||\r\n          item.index === this.currentPage + 2;\r\n      } else {\r\n        return item.index === this.currentPage - 4 ||\r\n          item.index === this.currentPage - 3 ||\r\n          item.index === this.currentPage - 2 ||\r\n          item.index === this.currentPage - 1 ||\r\n          item.index === this.currentPage;\r\n      }\r\n    });\r\n  }\r\n\r\n  public get getFirstNumberCurrentPage(): number {\r\n    if(this.total === 0) {\r\n      return 0;\r\n    }\r\n    if(this.total < this.pageSize * this.currentPage - this.pageSize + 1) {\r\n      return 1;\r\n    }\r\n\r\n    return (this.pageSize * this.currentPage - this.pageSize) + 1;\r\n  }\r\n\r\n  public get getLastNumberCurrentPage(): number {\r\n    if(this.total === 0) {\r\n      return 0;\r\n    }\r\n    if(this.total < this.pageSize * this.currentPage) {\r\n      return this.total;\r\n    }\r\n    return this.pageSize * this.currentPage;\r\n  }\r\n\r\n  public onChangeCurrentPage(value: number): void {\r\n    this.dataStateChanged.emit({\r\n      currentPage: value,\r\n      pageSize: this.pageSize\r\n    });\r\n  }\r\n\r\n  public onChangePageSize(value: number): void {\r\n    this.currentPage = 1;\r\n\r\n    this.dataStateChanged.emit({\r\n      currentPage: this.currentPage,\r\n      pageSize: value\r\n    });\r\n  }\r\n\r\n  public trackByFn(index: number, item: any) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n  <ul class=\"mrx-paginator__list\">\r\n    <li\r\n      class=\"mrx-paginator__previous\"\r\n      [class.disabled]=\"currentPage <= 1\"\r\n      (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n      <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n    </li>\r\n\r\n    <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n    <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n    <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n    <li\r\n      class=\"mrx-paginator__item\"\r\n      *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n      (click)=\"onChangeCurrentPage(item.index)\"\r\n      [class.active]=\"currentPage === item.index\"\r\n    >\r\n      {{item.index}}\r\n    </li>\r\n\r\n    <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n    <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n        (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n    <li\r\n      class=\"mrx-paginator__next\"\r\n      [class.disabled]=\"currentPage >= getItems\"\r\n      (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n      <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n    </li>\r\n  </ul>\r\n\r\n  @if (withPageSize) {\r\n    <mrx-select\r\n      [ngModel]=\"pageSize\"\r\n      [size]=\"'medium'\"\r\n      [items]=\"pageSizes\"\r\n      [clearable]=\"false\"\r\n      [searchable]=\"false\"\r\n      [popupPosition]=\"popupPosition\"\r\n      [singleChange]=\"true\"\r\n      (ngModelChange)=\"onChangePageSize($event)\"\r\n    ></mrx-select>\r\n  }\r\n\r\n  <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n    Отображены {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} из {{total}}\r\n  </div>\r\n</div>\r\n\r\n\r\n"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/paginator/paginator.component.ts","../../../../../../projects/myrta-ui/src/lib/components/paginator/paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport {\r\n  PaginateOutputObject,\r\n  PaginatorItem,\r\n  PaginatorPosition, PaginatorPositionCss,\r\n} from './paginator.enum';\r\nimport { DropdownPosition } from '@ng-select/ng-select';\r\nimport { PositionEnum } from '../../enums/overlay'\r\n\r\n@Component({\r\n  selector: 'mrx-paginator',\r\n  templateUrl: './paginator.component.html',\r\n  styleUrls: ['./paginator.component.less']\r\n})\r\nexport class PaginatorComponent {\r\n  public position: PaginatorPosition | undefined = 'centered';\r\n  public withPageSize: boolean | undefined = true;\r\n\r\n  @Input() pageSizes: number[] = [20, 50, 100];\r\n  @Input() currentPage = 1;\r\n  @Input() pageSize = 20;\r\n  @Input() total = 0;\r\n  @Input() customClasses = '';\r\n\r\n  @Input() isEmptyPaginator: boolean = false;\r\n  @Input() isPaginatorText: boolean = false;\r\n  @Input() paginatorText: string = 'записи';\r\n  @Input() dropdownPosition: DropdownPosition  = 'auto'; // deprecated\r\n  @Input() popupPosition: PositionEnum = PositionEnum.BottomEnd;\r\n\r\n  @Input('position')\r\n  public set setPosition(value: PaginatorPosition | undefined) {\r\n    this.position = value || 'centered';\r\n  }\r\n\r\n  @Input('withPageSize')\r\n  public set setWithPageSize(value: boolean | undefined) {\r\n    this.withPageSize = value || false;\r\n  }\r\n\r\n  @Output() dataStateChanged: EventEmitter<PaginateOutputObject> = new EventEmitter<PaginateOutputObject>();\r\n\r\n  public get getClasses(): string {\r\n    return `${this.position && PaginatorPositionCss[this.position]} ${this.customClasses}`;\r\n  }\r\n\r\n  public get getItems(): number {\r\n    return Math.ceil(this.total / this.pageSize);\r\n  }\r\n\r\n  public get getNumbers(): PaginatorItem[] {\r\n    return Array(this.getItems)\r\n      .fill(1)\r\n      .map((item, index) => ({ index: index + 1, active: index + 1 === this.currentPage }));\r\n  }\r\n\r\n  // TO DO: пока оставлю для тестов\r\n  // public get getViewItems(): PaginatorItem[] {\r\n  //   return this.getNumbers.filter((item, index) => {\r\n  //     if (this.currentPage === 1 && this.currentPage < this.getItems) {\r\n  //       return item.index === this.currentPage ||\r\n  //         item.index === this.currentPage + 1 ||\r\n  //         item.index === this.currentPage + 2 ||\r\n  //         item.index === this.currentPage + 3 ||\r\n  //         item.index === this.currentPage + 4;\r\n  //     } else if (this.currentPage == 2 && this.currentPage < this.getItems) {\r\n  //       return item.index === this.currentPage - 1 ||\r\n  //         item.index === this.currentPage ||\r\n  //         item.index === this.currentPage + 1 ||\r\n  //         item.index === this.currentPage + 2 ||\r\n  //         item.index === this.currentPage + 3;\r\n  //     } else if (this.currentPage == this.getItems - 1 && this.currentPage < this.getItems) {\r\n  //       return item.index === this.currentPage - 3 ||\r\n  //         item.index === this.currentPage - 2 ||\r\n  //         item.index === this.currentPage - 1 ||\r\n  //         item.index === this.currentPage ||\r\n  //         item.index === this.currentPage + 1;\r\n  //     } else if (this.currentPage > 1 && this.currentPage < this.getItems) {\r\n  //       return item.index === this.currentPage - 2 ||\r\n  //         item.index === this.currentPage - 1 ||\r\n  //         item.index === this.currentPage ||\r\n  //         item.index === this.currentPage + 1 ||\r\n  //         item.index === this.currentPage + 2;\r\n  //     } else {\r\n  //       return item.index === this.currentPage - 4 ||\r\n  //         item.index === this.currentPage - 3 ||\r\n  //         item.index === this.currentPage - 2 ||\r\n  //         item.index === this.currentPage - 1 ||\r\n  //         item.index === this.currentPage;\r\n  //     }\r\n  //   });\r\n  // }\r\n\r\n  // Упрощенная версия getViewItems()\r\n  public get getViewItems(): PaginatorItem[] {\r\n    const totalPages = this.getItems;\r\n    const current = this.currentPage;\r\n    const delta = 2; // количество страниц по бокам от текущей\r\n    const range = [];\r\n    \r\n    for (let i = Math.max(2, current - delta); i <= Math.min(totalPages - 1, current + delta); i++) {\r\n      range.push(i);\r\n    }\r\n    \r\n    // Добавляем первую страницу\r\n    if (current - delta > 1) {\r\n      range.unshift('...' as any);\r\n    }\r\n    range.unshift(1);\r\n    \r\n    // Добавляем последнюю страницу\r\n    if (current + delta < totalPages - 1) {\r\n      range.push('...' as any);\r\n    }\r\n    if (totalPages > 1) {\r\n      range.push(totalPages);\r\n    }\r\n    \r\n    return range.map((item, index) => ({\r\n      index: typeof item === 'number' ? item : index,\r\n      active: item === current,\r\n      isEllipsis: item === '...'\r\n    }));\r\n  }\r\n\r\n  public get getFirstNumberCurrentPage(): number {\r\n    if(this.total === 0) {\r\n      return 0;\r\n    }\r\n    if(this.total < this.pageSize * this.currentPage - this.pageSize + 1) {\r\n      return 1;\r\n    }\r\n\r\n    return (this.pageSize * this.currentPage - this.pageSize) + 1;\r\n  }\r\n\r\n  public get getLastNumberCurrentPage(): number {\r\n    if(this.total === 0) {\r\n      return 0;\r\n    }\r\n    if(this.total < this.pageSize * this.currentPage) {\r\n      return this.total;\r\n    }\r\n    return this.pageSize * this.currentPage;\r\n  }\r\n\r\n  public onChangeCurrentPage(value: number): void {\r\n    this.dataStateChanged.emit({\r\n      currentPage: value,\r\n      pageSize: this.pageSize\r\n    });\r\n  }\r\n\r\n  public onChangePageSize(value: number): void {\r\n    console.log(value)\r\n    this.currentPage = 1;\r\n\r\n    this.dataStateChanged.emit({\r\n      currentPage: this.currentPage,\r\n      pageSize: value\r\n    });\r\n  }\r\n\r\n  public trackByFn(index: number, item: any) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div class=\"mrx-paginator\" [class]=\"getClasses\" *ngIf=\"isEmptyPaginator || total\">\r\n  <ul class=\"mrx-paginator__list\">\r\n    <li\r\n      class=\"mrx-paginator__previous\"\r\n      [class.disabled]=\"currentPage <= 1\"\r\n      (click)=\"currentPage > 1 && onChangeCurrentPage(currentPage - 1)\">\r\n      <div class=\"mrx-icon icon-chevron-left icon-font-24\"></div>\r\n    </li>\r\n\r\n    <li *ngIf=\"getViewItems.length === 0\" class=\"mrx-paginator__item active\">1</li>\r\n\r\n    <li class=\"mrx-paginator__item\" *ngIf=\"currentPage > 3 && getItems > 5\" (click)=\"onChangeCurrentPage(1)\">1</li>\r\n    <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage > 3 && getItems > 5\">...</li>\r\n\r\n    <li\r\n      class=\"mrx-paginator__item\"\r\n      *ngFor=\"let item of getViewItems; trackBy: trackByFn\"\r\n      (click)=\"onChangeCurrentPage(item.index)\"\r\n      [class.active]=\"currentPage === item.index\"\r\n    >\r\n      {{item.index}}\r\n    </li>\r\n\r\n    <li class=\"mrx-paginator__item dots\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\">...</li>\r\n    <li class=\"mrx-paginator__item\" *ngIf=\"currentPage < getItems - 2 && getItems > 5\"\r\n        (click)=\"onChangeCurrentPage(getItems)\">{{getItems}}</li>\r\n\r\n    <li\r\n      class=\"mrx-paginator__next\"\r\n      [class.disabled]=\"currentPage >= getItems\"\r\n      (click)=\"currentPage < getItems && onChangeCurrentPage(currentPage + 1)\">\r\n      <div class=\"mrx-icon icon-chevron-right icon-font-24\"></div>\r\n    </li>\r\n  </ul>\r\n\r\n  @if (withPageSize) {\r\n    <mrx-select\r\n      [ngModel]=\"pageSize\"\r\n      [size]=\"'medium'\"\r\n      [items]=\"pageSizes\"\r\n      [clearable]=\"false\"\r\n      [searchable]=\"false\"\r\n      [popupPosition]=\"popupPosition\"\r\n      [singleChange]=\"true\"\r\n      (ngModelChange)=\"onChangePageSize($event)\"\r\n    ></mrx-select>\r\n  }\r\n\r\n  <div *ngIf=\"isPaginatorText\" class=\"mrx-paginator__text\">\r\n    Отображены {{paginatorText}} {{getFirstNumberCurrentPage}} - {{getLastNumberCurrentPage}} из {{total}}\r\n  </div>\r\n</div>\r\n\r\n\r\n"]}
|
package/fesm2022/myrta-ui.mjs
CHANGED
|
@@ -4500,44 +4500,68 @@ class PaginatorComponent {
|
|
|
4500
4500
|
.fill(1)
|
|
4501
4501
|
.map((item, index) => ({ index: index + 1, active: index + 1 === this.currentPage }));
|
|
4502
4502
|
}
|
|
4503
|
+
// TO DO: пока оставлю для тестов
|
|
4504
|
+
// public get getViewItems(): PaginatorItem[] {
|
|
4505
|
+
// return this.getNumbers.filter((item, index) => {
|
|
4506
|
+
// if (this.currentPage === 1 && this.currentPage < this.getItems) {
|
|
4507
|
+
// return item.index === this.currentPage ||
|
|
4508
|
+
// item.index === this.currentPage + 1 ||
|
|
4509
|
+
// item.index === this.currentPage + 2 ||
|
|
4510
|
+
// item.index === this.currentPage + 3 ||
|
|
4511
|
+
// item.index === this.currentPage + 4;
|
|
4512
|
+
// } else if (this.currentPage == 2 && this.currentPage < this.getItems) {
|
|
4513
|
+
// return item.index === this.currentPage - 1 ||
|
|
4514
|
+
// item.index === this.currentPage ||
|
|
4515
|
+
// item.index === this.currentPage + 1 ||
|
|
4516
|
+
// item.index === this.currentPage + 2 ||
|
|
4517
|
+
// item.index === this.currentPage + 3;
|
|
4518
|
+
// } else if (this.currentPage == this.getItems - 1 && this.currentPage < this.getItems) {
|
|
4519
|
+
// return item.index === this.currentPage - 3 ||
|
|
4520
|
+
// item.index === this.currentPage - 2 ||
|
|
4521
|
+
// item.index === this.currentPage - 1 ||
|
|
4522
|
+
// item.index === this.currentPage ||
|
|
4523
|
+
// item.index === this.currentPage + 1;
|
|
4524
|
+
// } else if (this.currentPage > 1 && this.currentPage < this.getItems) {
|
|
4525
|
+
// return item.index === this.currentPage - 2 ||
|
|
4526
|
+
// item.index === this.currentPage - 1 ||
|
|
4527
|
+
// item.index === this.currentPage ||
|
|
4528
|
+
// item.index === this.currentPage + 1 ||
|
|
4529
|
+
// item.index === this.currentPage + 2;
|
|
4530
|
+
// } else {
|
|
4531
|
+
// return item.index === this.currentPage - 4 ||
|
|
4532
|
+
// item.index === this.currentPage - 3 ||
|
|
4533
|
+
// item.index === this.currentPage - 2 ||
|
|
4534
|
+
// item.index === this.currentPage - 1 ||
|
|
4535
|
+
// item.index === this.currentPage;
|
|
4536
|
+
// }
|
|
4537
|
+
// });
|
|
4538
|
+
// }
|
|
4539
|
+
// Упрощенная версия getViewItems()
|
|
4503
4540
|
get getViewItems() {
|
|
4504
|
-
|
|
4505
|
-
|
|
4506
|
-
|
|
4507
|
-
|
|
4508
|
-
|
|
4509
|
-
|
|
4510
|
-
|
|
4511
|
-
|
|
4512
|
-
|
|
4513
|
-
|
|
4514
|
-
|
|
4515
|
-
|
|
4516
|
-
|
|
4517
|
-
|
|
4518
|
-
|
|
4519
|
-
|
|
4520
|
-
|
|
4521
|
-
|
|
4522
|
-
|
|
4523
|
-
|
|
4524
|
-
|
|
4525
|
-
|
|
4526
|
-
|
|
4527
|
-
|
|
4528
|
-
item.index === this.currentPage - 1 ||
|
|
4529
|
-
item.index === this.currentPage ||
|
|
4530
|
-
item.index === this.currentPage + 1 ||
|
|
4531
|
-
item.index === this.currentPage + 2;
|
|
4532
|
-
}
|
|
4533
|
-
else {
|
|
4534
|
-
return item.index === this.currentPage - 4 ||
|
|
4535
|
-
item.index === this.currentPage - 3 ||
|
|
4536
|
-
item.index === this.currentPage - 2 ||
|
|
4537
|
-
item.index === this.currentPage - 1 ||
|
|
4538
|
-
item.index === this.currentPage;
|
|
4539
|
-
}
|
|
4540
|
-
});
|
|
4541
|
+
const totalPages = this.getItems;
|
|
4542
|
+
const current = this.currentPage;
|
|
4543
|
+
const delta = 2; // количество страниц по бокам от текущей
|
|
4544
|
+
const range = [];
|
|
4545
|
+
for (let i = Math.max(2, current - delta); i <= Math.min(totalPages - 1, current + delta); i++) {
|
|
4546
|
+
range.push(i);
|
|
4547
|
+
}
|
|
4548
|
+
// Добавляем первую страницу
|
|
4549
|
+
if (current - delta > 1) {
|
|
4550
|
+
range.unshift('...');
|
|
4551
|
+
}
|
|
4552
|
+
range.unshift(1);
|
|
4553
|
+
// Добавляем последнюю страницу
|
|
4554
|
+
if (current + delta < totalPages - 1) {
|
|
4555
|
+
range.push('...');
|
|
4556
|
+
}
|
|
4557
|
+
if (totalPages > 1) {
|
|
4558
|
+
range.push(totalPages);
|
|
4559
|
+
}
|
|
4560
|
+
return range.map((item, index) => ({
|
|
4561
|
+
index: typeof item === 'number' ? item : index,
|
|
4562
|
+
active: item === current,
|
|
4563
|
+
isEllipsis: item === '...'
|
|
4564
|
+
}));
|
|
4541
4565
|
}
|
|
4542
4566
|
get getFirstNumberCurrentPage() {
|
|
4543
4567
|
if (this.total === 0) {
|
|
@@ -4564,6 +4588,7 @@ class PaginatorComponent {
|
|
|
4564
4588
|
});
|
|
4565
4589
|
}
|
|
4566
4590
|
onChangePageSize(value) {
|
|
4591
|
+
console.log(value);
|
|
4567
4592
|
this.currentPage = 1;
|
|
4568
4593
|
this.dataStateChanged.emit({
|
|
4569
4594
|
currentPage: this.currentPage,
|