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
- return this.getNumbers.filter((item, index) => {
41
- if (this.currentPage === 1 && this.currentPage < this.getItems) {
42
- return item.index === this.currentPage ||
43
- item.index === this.currentPage + 1 ||
44
- item.index === this.currentPage + 2 ||
45
- item.index === this.currentPage + 3 ||
46
- item.index === this.currentPage + 4;
47
- }
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
- }
55
- else if (this.currentPage == this.getItems - 1 && this.currentPage < this.getItems) {
56
- return item.index === this.currentPage - 3 ||
57
- item.index === this.currentPage - 2 ||
58
- item.index === this.currentPage - 1 ||
59
- item.index === this.currentPage ||
60
- item.index === this.currentPage + 1;
61
- }
62
- else if (this.currentPage > 1 && this.currentPage < this.getItems) {
63
- return item.index === this.currentPage - 2 ||
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"]}
@@ -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
- return this.getNumbers.filter((item, index) => {
4505
- if (this.currentPage === 1 && this.currentPage < this.getItems) {
4506
- return item.index === this.currentPage ||
4507
- item.index === this.currentPage + 1 ||
4508
- item.index === this.currentPage + 2 ||
4509
- item.index === this.currentPage + 3 ||
4510
- item.index === this.currentPage + 4;
4511
- }
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
- }
4519
- else if (this.currentPage == this.getItems - 1 && this.currentPage < this.getItems) {
4520
- return item.index === this.currentPage - 3 ||
4521
- item.index === this.currentPage - 2 ||
4522
- item.index === this.currentPage - 1 ||
4523
- item.index === this.currentPage ||
4524
- item.index === this.currentPage + 1;
4525
- }
4526
- else if (this.currentPage > 1 && this.currentPage < this.getItems) {
4527
- return item.index === this.currentPage - 2 ||
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,