myrta-ui 17.1.72 → 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.
@@ -17,7 +17,6 @@ export class AlertComponent {
17
17
  return `${AlertIconClasses[this.color]}`;
18
18
  }
19
19
  onCloseClick() {
20
- console.log(1);
21
20
  this.close.emit(null);
22
21
  }
23
22
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
@@ -43,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
43
42
  }], close: [{
44
43
  type: Output
45
44
  }] } });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL2FsZXJ0L2FsZXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9hbGVydC9hbGVydC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hHLE9BQU8sRUFBRSxpQkFBaUIsRUFBZSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7QUFRaEYsTUFBTSxPQUFPLGNBQWM7SUFDaEIsYUFBYSxHQUFXLEVBQUUsQ0FBQztJQUMzQixLQUFLLEdBQWdCLFNBQVMsQ0FBQztJQUMvQixXQUFXLEdBQVcsRUFBRSxDQUFDO0lBQ3pCLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDYixLQUFLLEdBQUcsRUFBRSxDQUFDO0lBQ1gsUUFBUSxHQUFHLEtBQUssQ0FBQztJQUNqQixRQUFRLEdBQUcsS0FBSyxDQUFDO0lBRWhCLEtBQUssR0FBMEIsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUU1RCxJQUFXLFVBQVU7UUFDbkIsT0FBTyxHQUFHLGlCQUFpQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3hFLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDckIsT0FBTyxHQUFHLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO0lBQzNDLENBQUM7SUFFTSxZQUFZO1FBQ2pCLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFDZCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4QixDQUFDO3dHQXRCVSxjQUFjOzRGQUFkLGNBQWMsc1BDVDNCLDRyQkFtQkE7OzRGRFZhLGNBQWM7a0JBTjFCLFNBQVM7K0JBQ0UsV0FBVyxtQkFHSix1QkFBdUIsQ0FBQyxNQUFNOzhCQUd0QyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUVJLEtBQUs7c0JBQWQsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBbGVydENvbG9yQ2xhc3NlcywgQWxlcnRDb2xvcnMsIEFsZXJ0SWNvbkNsYXNzZXMgfSBmcm9tICcuL2FsZXJ0LmVudW0nO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdtcngtYWxlcnQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnYWxlcnQuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2FsZXJ0LmNvbXBvbmVudC5sZXNzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBbGVydENvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgY3VzdG9tQ2xhc3Nlczogc3RyaW5nID0gJyc7XHJcbiAgQElucHV0KCkgY29sb3I6IEFsZXJ0Q29sb3JzID0gJ2RlZmF1bHQnO1xyXG4gIEBJbnB1dCgpIGN1c3RvbUNvbG9yOiBzdHJpbmcgPSAnJztcclxuICBASW5wdXQoKSBtZXNzYWdlID0gJyc7XHJcbiAgQElucHV0KCkgdGl0bGUgPSAnJztcclxuICBASW5wdXQoKSBjbG9zYWJsZSA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIHNob3dJY29uID0gZmFsc2U7XHJcblxyXG4gIEBPdXRwdXQoKSBjbG9zZTogRXZlbnRFbWl0dGVyPHVua25vd24+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG5cclxuICBwdWJsaWMgZ2V0IGdldENsYXNzZXMoKSB7XHJcbiAgICByZXR1cm4gYCR7QWxlcnRDb2xvckNsYXNzZXNbdGhpcy5jb2xvcl0gPz8gJyd9ICR7dGhpcy5jdXN0b21DbGFzc2VzfWA7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IGdldEljb25DbGFzcygpIHtcclxuICAgIHJldHVybiBgJHtBbGVydEljb25DbGFzc2VzW3RoaXMuY29sb3JdfWA7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25DbG9zZUNsaWNrKCk6IHZvaWQge1xyXG4gICAgY29uc29sZS5sb2coMSlcclxuICAgIHRoaXMuY2xvc2UuZW1pdChudWxsKTtcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cIm1yeC1hbGVydFwiIFtjbGFzc109XCJnZXRDbGFzc2VzXCIgW3N0eWxlXT1cIntiYWNrZ3JvdW5kQ29sb3I6IGN1c3RvbUNvbG9yfVwiPlxyXG4gIEBpZiAoY2xvc2FibGUpIHtcclxuICAgIDxzcGFuIGNsYXNzPVwibXJ4LWljb24gaWNvbi1jbG9zZSBpY29uLWZvbnQtMTZcIiAoY2xpY2spPVwib25DbG9zZUNsaWNrKClcIj48L3NwYW4+XHJcbiAgfVxyXG5cclxuICBAaWYgKHRpdGxlIHx8IG1lc3NhZ2UgfHwgc2hvd0ljb24pIHtcclxuICAgIDxzcGFuIFtjbGFzc109XCJnZXRJY29uQ2xhc3NcIiBzdHlsZT1cIm1hcmdpbi10b3A6IDFweFwiIGNsYXNzPVwibXJ4LWljb24gaWNvbi1hbGVydCBpY29uLWZvbnQtMTYgbXItMlwiPjwvc3Bhbj5cclxuICB9XHJcblxyXG4gIEBpZiAodGl0bGUpIHtcclxuICAgIDxkaXYgY2xhc3M9XCJtcngtYWxlcnQtdGl0bGUgbWItMVwiIFtjbGFzcy5tbC00XT1cImdldEljb25DbGFzc1wiIFtpbm5lckhUTUxdPVwidGl0bGVcIj48L2Rpdj5cclxuICB9XHJcblxyXG4gIEBpZiAobWVzc2FnZSkge1xyXG4gICAgPGRpdiBjbGFzcz1cIm1yeC1hbGVydC1tZXNzYWdlXCIgW2NsYXNzLm1sLTRdPVwiZ2V0SWNvbkNsYXNzXCIgW2lubmVySFRNTF09XCJtZXNzYWdlXCI+PC9kaXY+XHJcbiAgfVxyXG5cclxuICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbjwvZGl2PlxyXG4iXX0=
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL2FsZXJ0L2FsZXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9hbGVydC9hbGVydC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hHLE9BQU8sRUFBRSxpQkFBaUIsRUFBZSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7QUFRaEYsTUFBTSxPQUFPLGNBQWM7SUFDaEIsYUFBYSxHQUFXLEVBQUUsQ0FBQztJQUMzQixLQUFLLEdBQWdCLFNBQVMsQ0FBQztJQUMvQixXQUFXLEdBQVcsRUFBRSxDQUFDO0lBQ3pCLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDYixLQUFLLEdBQUcsRUFBRSxDQUFDO0lBQ1gsUUFBUSxHQUFHLEtBQUssQ0FBQztJQUNqQixRQUFRLEdBQUcsS0FBSyxDQUFDO0lBRWhCLEtBQUssR0FBMEIsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUU1RCxJQUFXLFVBQVU7UUFDbkIsT0FBTyxHQUFHLGlCQUFpQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3hFLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDckIsT0FBTyxHQUFHLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO0lBQzNDLENBQUM7SUFFTSxZQUFZO1FBQ2pCLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hCLENBQUM7d0dBckJVLGNBQWM7NEZBQWQsY0FBYyxzUENUM0IsNHJCQW1CQTs7NEZEVmEsY0FBYztrQkFOMUIsU0FBUzsrQkFDRSxXQUFXLG1CQUdKLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBRUksS0FBSztzQkFBZCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFsZXJ0Q29sb3JDbGFzc2VzLCBBbGVydENvbG9ycywgQWxlcnRJY29uQ2xhc3NlcyB9IGZyb20gJy4vYWxlcnQuZW51bSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ21yeC1hbGVydCcsXHJcbiAgdGVtcGxhdGVVcmw6ICdhbGVydC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vYWxlcnQuY29tcG9uZW50Lmxlc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFsZXJ0Q29tcG9uZW50IHtcclxuICBASW5wdXQoKSBjdXN0b21DbGFzc2VzOiBzdHJpbmcgPSAnJztcclxuICBASW5wdXQoKSBjb2xvcjogQWxlcnRDb2xvcnMgPSAnZGVmYXVsdCc7XHJcbiAgQElucHV0KCkgY3VzdG9tQ29sb3I6IHN0cmluZyA9ICcnO1xyXG4gIEBJbnB1dCgpIG1lc3NhZ2UgPSAnJztcclxuICBASW5wdXQoKSB0aXRsZSA9ICcnO1xyXG4gIEBJbnB1dCgpIGNsb3NhYmxlID0gZmFsc2U7XHJcbiAgQElucHV0KCkgc2hvd0ljb24gPSBmYWxzZTtcclxuXHJcbiAgQE91dHB1dCgpIGNsb3NlOiBFdmVudEVtaXR0ZXI8dW5rbm93bj4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcblxyXG4gIHB1YmxpYyBnZXQgZ2V0Q2xhc3NlcygpIHtcclxuICAgIHJldHVybiBgJHtBbGVydENvbG9yQ2xhc3Nlc1t0aGlzLmNvbG9yXSA/PyAnJ30gJHt0aGlzLmN1c3RvbUNsYXNzZXN9YDtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgZ2V0SWNvbkNsYXNzKCkge1xyXG4gICAgcmV0dXJuIGAke0FsZXJ0SWNvbkNsYXNzZXNbdGhpcy5jb2xvcl19YDtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvbkNsb3NlQ2xpY2soKTogdm9pZCB7XHJcbiAgICB0aGlzLmNsb3NlLmVtaXQobnVsbCk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJtcngtYWxlcnRcIiBbY2xhc3NdPVwiZ2V0Q2xhc3Nlc1wiIFtzdHlsZV09XCJ7YmFja2dyb3VuZENvbG9yOiBjdXN0b21Db2xvcn1cIj5cclxuICBAaWYgKGNsb3NhYmxlKSB7XHJcbiAgICA8c3BhbiBjbGFzcz1cIm1yeC1pY29uIGljb24tY2xvc2UgaWNvbi1mb250LTE2XCIgKGNsaWNrKT1cIm9uQ2xvc2VDbGljaygpXCI+PC9zcGFuPlxyXG4gIH1cclxuXHJcbiAgQGlmICh0aXRsZSB8fCBtZXNzYWdlIHx8IHNob3dJY29uKSB7XHJcbiAgICA8c3BhbiBbY2xhc3NdPVwiZ2V0SWNvbkNsYXNzXCIgc3R5bGU9XCJtYXJnaW4tdG9wOiAxcHhcIiBjbGFzcz1cIm1yeC1pY29uIGljb24tYWxlcnQgaWNvbi1mb250LTE2IG1yLTJcIj48L3NwYW4+XHJcbiAgfVxyXG5cclxuICBAaWYgKHRpdGxlKSB7XHJcbiAgICA8ZGl2IGNsYXNzPVwibXJ4LWFsZXJ0LXRpdGxlIG1iLTFcIiBbY2xhc3MubWwtNF09XCJnZXRJY29uQ2xhc3NcIiBbaW5uZXJIVE1MXT1cInRpdGxlXCI+PC9kaXY+XHJcbiAgfVxyXG5cclxuICBAaWYgKG1lc3NhZ2UpIHtcclxuICAgIDxkaXYgY2xhc3M9XCJtcngtYWxlcnQtbWVzc2FnZVwiIFtjbGFzcy5tbC00XT1cImdldEljb25DbGFzc1wiIFtpbm5lckhUTUxdPVwibWVzc2FnZVwiPjwvZGl2PlxyXG4gIH1cclxuXHJcbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG48L2Rpdj5cclxuIl19
@@ -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"]}
@@ -1,111 +1,72 @@
1
- import { Directive, HostBinding, HostListener, Input } from '@angular/core';
1
+ import { Directive, HostBinding, Input } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  export class AutosizeDirective {
4
4
  elem;
5
5
  renderer;
6
- ngZone;
7
6
  overflow = 'hidden';
8
7
  rows = 1;
9
- set autosize(value) {
10
- this._autosize = value;
11
- if (!value) {
12
- this.overflow = 'auto';
13
- this.setHeight('auto');
14
- }
15
- }
16
- get autosize() {
17
- return this._autosize;
18
- }
19
- _autosize = true;
20
- observer = null;
21
- resizeTimeout;
22
- lastHeight = 0;
23
- constructor(elem, renderer, ngZone) {
8
+ autosize = true;
9
+ isInitialized = false;
10
+ constructor(elem, renderer) {
24
11
  this.elem = elem;
25
12
  this.renderer = renderer;
26
- this.ngZone = ngZone;
27
13
  }
28
14
  ngAfterViewInit() {
29
- this.setupAutoResize();
30
- // Первоначальный расчет
31
- setTimeout(() => this.resize(), 0);
32
- }
33
- ngOnDestroy() {
34
- this.cleanup();
35
- }
36
- setupAutoResize() {
37
- if (!this.autosize)
38
- return;
39
- const textarea = this.elem.nativeElement;
40
- // Используем MutationObserver вместо ngDoCheck
41
- this.ngZone.runOutsideAngular(() => {
42
- this.observer = new MutationObserver(() => {
43
- this.scheduleResize();
44
- });
45
- this.observer.observe(textarea, {
46
- characterData: true,
47
- childList: true,
48
- subtree: true
49
- });
50
- });
51
- // Также следим за resize окна
52
- this.renderer.listen('window', 'resize', () => this.scheduleResize());
53
- }
54
- scheduleResize() {
55
- if (!this.autosize)
56
- return;
57
- // Debounce для оптимизации
58
- clearTimeout(this.resizeTimeout);
59
- this.resizeTimeout = setTimeout(() => {
60
- this.ngZone.run(() => this.resize());
61
- }, 50); // Задержка 50мс
15
+ this.isInitialized = true;
16
+ setTimeout(() => this.resize(), 0); // Инициализация после рендера
62
17
  }
63
18
  onInput() {
64
- this.scheduleResize();
19
+ if (this.autosize && this.isInitialized) {
20
+ this.resize();
21
+ }
65
22
  }
66
23
  resize() {
67
24
  if (!this.autosize) {
68
25
  this.overflow = 'auto';
26
+ this.setHeight('auto');
69
27
  return;
70
28
  }
71
29
  const textarea = this.elem.nativeElement;
72
- // Временно отключаем transition для предотвращения скачков
30
+ // Сохраняем текущее значение и стили
31
+ const originalValue = textarea.value;
73
32
  const originalTransition = textarea.style.transition;
33
+ const originalOverflow = textarea.style.overflow;
34
+ // Временно убираем transition для мгновенного расчета
74
35
  this.renderer.setStyle(textarea, 'transition', 'none');
36
+ this.renderer.setStyle(textarea, 'overflow', 'hidden');
37
+ // Сбрасываем высоту для корректного расчета
38
+ this.renderer.setStyle(textarea, 'height', 'auto');
75
39
  // Рассчитываем новую высоту
76
40
  const borderHeight = textarea.offsetHeight - textarea.clientHeight;
77
- this.setHeight('auto');
78
41
  const scrollHeight = textarea.scrollHeight;
79
- const newHeight = scrollHeight + borderHeight;
80
- // Изменяем высоту только если она действительно изменилась
81
- if (Math.abs(newHeight - this.lastHeight) > 2) { // Порог 2px
82
- this.setHeight(`${newHeight}px`);
83
- this.lastHeight = newHeight;
84
- }
85
- // Восстанавливаем transition
42
+ const newHeight = Math.max(textarea.clientHeight, // минимальная высота
43
+ scrollHeight + borderHeight);
44
+ // Устанавливаем новую высоту
45
+ this.renderer.setStyle(textarea, 'height', `${newHeight}px`);
46
+ // Восстанавливаем стили
86
47
  setTimeout(() => {
87
48
  this.renderer.setStyle(textarea, 'transition', originalTransition);
49
+ this.renderer.setStyle(textarea, 'overflow', originalOverflow);
88
50
  }, 0);
89
51
  }
90
52
  setHeight(value) {
91
53
  this.renderer.setStyle(this.elem.nativeElement, 'height', value);
92
54
  }
93
- cleanup() {
94
- if (this.observer) {
95
- this.observer.disconnect();
96
- this.observer = null;
97
- }
98
- clearTimeout(this.resizeTimeout);
99
- }
100
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AutosizeDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
101
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: AutosizeDirective, selector: "[mrxAutosize]", inputs: { rows: "rows", autosize: "autosize" }, host: { listeners: { "input": "onInput()" }, properties: { "style.overflow": "this.overflow", "rows": "this.rows" } }, ngImport: i0 });
55
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AutosizeDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
56
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: AutosizeDirective, selector: "[mrxAutosize]", inputs: { rows: "rows", autosize: "autosize" }, host: { listeners: { "input": "onInput()", "paste": "onInput()", "cut": "onInput()", "change": "onInput()" }, properties: { "style.overflow": "this.overflow", "rows": "this.rows" } }, ngImport: i0 });
102
57
  }
103
58
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AutosizeDirective, decorators: [{
104
59
  type: Directive,
105
60
  args: [{
106
- selector: '[mrxAutosize]'
61
+ selector: '[mrxAutosize]',
62
+ host: {
63
+ '(input)': 'onInput()',
64
+ '(paste)': 'onInput()',
65
+ '(cut)': 'onInput()',
66
+ '(change)': 'onInput()'
67
+ }
107
68
  }]
108
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.NgZone }], propDecorators: { overflow: [{
69
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { overflow: [{
109
70
  type: HostBinding,
110
71
  args: ['style.overflow']
111
72
  }], rows: [{
@@ -115,8 +76,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
115
76
  args: ['rows']
116
77
  }], autosize: [{
117
78
  type: Input
118
- }], onInput: [{
119
- type: HostListener,
120
- args: ['input']
121
79
  }] } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autosize.directive.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/directives/autosize/autosize.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Directive,\r\n  ElementRef,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  Renderer2,\r\n  NgZone\r\n} from '@angular/core';\r\n\r\n@Directive({\r\n  selector: '[mrxAutosize]'\r\n})\r\nexport class AutosizeDirective implements AfterViewInit, OnDestroy {\r\n  @HostBinding('style.overflow')\r\n  public overflow = 'hidden';\r\n\r\n  @Input()\r\n  @HostBinding('rows')\r\n  public rows = 1;\r\n\r\n  @Input()\r\n  public set autosize(value: boolean) {\r\n    this._autosize = value;\r\n    if (!value) {\r\n      this.overflow = 'auto';\r\n      this.setHeight('auto');\r\n    }\r\n  }\r\n  public get autosize(): boolean {\r\n    return this._autosize;\r\n  }\r\n  private _autosize = true;\r\n\r\n  private observer: MutationObserver | null = null;\r\n  private resizeTimeout: any;\r\n  private lastHeight = 0;\r\n\r\n  constructor(\r\n    private elem: ElementRef,\r\n    private renderer: Renderer2,\r\n    private ngZone: NgZone\r\n  ) {}\r\n\r\n  public ngAfterViewInit() {\r\n    this.setupAutoResize();\r\n    // Первоначальный расчет\r\n    setTimeout(() => this.resize(), 0);\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    this.cleanup();\r\n  }\r\n\r\n  private setupAutoResize() {\r\n    if (!this.autosize) return;\r\n\r\n    const textarea = this.elem.nativeElement as HTMLTextAreaElement;\r\n    \r\n    // Используем MutationObserver вместо ngDoCheck\r\n    this.ngZone.runOutsideAngular(() => {\r\n      this.observer = new MutationObserver(() => {\r\n        this.scheduleResize();\r\n      });\r\n      \r\n      this.observer.observe(textarea, {\r\n        characterData: true,\r\n        childList: true,\r\n        subtree: true\r\n      });\r\n    });\r\n\r\n    // Также следим за resize окна\r\n    this.renderer.listen('window', 'resize', () => this.scheduleResize());\r\n  }\r\n\r\n  private scheduleResize() {\r\n    if (!this.autosize) return;\r\n\r\n    // Debounce для оптимизации\r\n    clearTimeout(this.resizeTimeout);\r\n    this.resizeTimeout = setTimeout(() => {\r\n      this.ngZone.run(() => this.resize());\r\n    }, 50); // Задержка 50мс\r\n  }\r\n\r\n  @HostListener('input')\r\n  private onInput() {\r\n    this.scheduleResize();\r\n  }\r\n\r\n  private resize() {\r\n    if (!this.autosize) {\r\n      this.overflow = 'auto';\r\n      return;\r\n    }\r\n\r\n    const textarea = this.elem.nativeElement as HTMLTextAreaElement;\r\n    \r\n    // Временно отключаем transition для предотвращения скачков\r\n    const originalTransition = textarea.style.transition;\r\n    this.renderer.setStyle(textarea, 'transition', 'none');\r\n    \r\n    // Рассчитываем новую высоту\r\n    const borderHeight = textarea.offsetHeight - textarea.clientHeight;\r\n    this.setHeight('auto');\r\n    const scrollHeight = textarea.scrollHeight;\r\n    const newHeight = scrollHeight + borderHeight;\r\n    \r\n    // Изменяем высоту только если она действительно изменилась\r\n    if (Math.abs(newHeight - this.lastHeight) > 2) { // Порог 2px\r\n      this.setHeight(`${newHeight}px`);\r\n      this.lastHeight = newHeight;\r\n    }\r\n    \r\n    // Восстанавливаем transition\r\n    setTimeout(() => {\r\n      this.renderer.setStyle(textarea, 'transition', originalTransition);\r\n    }, 0);\r\n  }\r\n\r\n  private setHeight(value: string) {\r\n    this.renderer.setStyle(this.elem.nativeElement, 'height', value);\r\n  }\r\n\r\n  private cleanup() {\r\n    if (this.observer) {\r\n      this.observer.disconnect();\r\n      this.observer = null;\r\n    }\r\n    clearTimeout(this.resizeTimeout);\r\n  }\r\n}"]}
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b3NpemUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9kaXJlY3RpdmVzL2F1dG9zaXplL2F1dG9zaXplLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlCLFNBQVMsRUFBYyxXQUFXLEVBQUUsS0FBSyxFQUFhLE1BQU0sZUFBZSxDQUFDOztBQVdwRyxNQUFNLE9BQU8saUJBQWlCO0lBYVI7SUFBMEI7SUFYdkMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUlwQixJQUFJLEdBQUcsQ0FBQyxDQUFDO0lBR1QsUUFBUSxHQUFHLElBQUksQ0FBQztJQUVmLGFBQWEsR0FBRyxLQUFLLENBQUM7SUFFOUIsWUFBb0IsSUFBZ0IsRUFBVSxRQUFtQjtRQUE3QyxTQUFJLEdBQUosSUFBSSxDQUFZO1FBQVUsYUFBUSxHQUFSLFFBQVEsQ0FBVztJQUFHLENBQUM7SUFFOUQsZUFBZTtRQUNwQixJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQztRQUMxQixVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsOEJBQThCO0lBQ3BFLENBQUM7SUFFTSxPQUFPO1FBQ1osSUFBSSxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUN4QyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDaEIsQ0FBQztJQUNILENBQUM7SUFFTyxNQUFNO1FBQ1osSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNuQixJQUFJLENBQUMsUUFBUSxHQUFHLE1BQU0sQ0FBQztZQUN2QixJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3ZCLE9BQU87UUFDVCxDQUFDO1FBRUQsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFvQyxDQUFDO1FBRWhFLHFDQUFxQztRQUNyQyxNQUFNLGFBQWEsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDO1FBQ3JDLE1BQU0sa0JBQWtCLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUM7UUFDckQsTUFBTSxnQkFBZ0IsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUVqRCxzREFBc0Q7UUFDdEQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLFlBQVksRUFBRSxNQUFNLENBQUMsQ0FBQztRQUN2RCxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsVUFBVSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBRXZELDRDQUE0QztRQUM1QyxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBRW5ELDRCQUE0QjtRQUM1QixNQUFNLFlBQVksR0FBRyxRQUFRLENBQUMsWUFBWSxHQUFHLFFBQVEsQ0FBQyxZQUFZLENBQUM7UUFDbkUsTUFBTSxZQUFZLEdBQUcsUUFBUSxDQUFDLFlBQVksQ0FBQztRQUMzQyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUN4QixRQUFRLENBQUMsWUFBWSxFQUFFLHFCQUFxQjtRQUM1QyxZQUFZLEdBQUcsWUFBWSxDQUM1QixDQUFDO1FBRUYsNkJBQTZCO1FBQzdCLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsR0FBRyxTQUFTLElBQUksQ0FBQyxDQUFDO1FBRTdELHdCQUF3QjtRQUN4QixVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLFlBQVksRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO1lBQ25FLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRSxVQUFVLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztRQUNqRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDUixDQUFDO0lBRU8sU0FBUyxDQUFDLEtBQWE7UUFDN0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsUUFBUSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ25FLENBQUM7d0dBbkVVLGlCQUFpQjs0RkFBakIsaUJBQWlCOzs0RkFBakIsaUJBQWlCO2tCQVQ3QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxlQUFlO29CQUN6QixJQUFJLEVBQUU7d0JBQ0osU0FBUyxFQUFFLFdBQVc7d0JBQ3RCLFNBQVMsRUFBRSxXQUFXO3dCQUN0QixPQUFPLEVBQUUsV0FBVzt3QkFDcEIsVUFBVSxFQUFFLFdBQVc7cUJBQ3hCO2lCQUNGO3VHQUdRLFFBQVE7c0JBRGQsV0FBVzt1QkFBQyxnQkFBZ0I7Z0JBS3RCLElBQUk7c0JBRlYsS0FBSzs7c0JBQ0wsV0FBVzt1QkFBQyxNQUFNO2dCQUlaLFFBQVE7c0JBRGQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFmdGVyVmlld0luaXQsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdEJpbmRpbmcsIElucHV0LCBSZW5kZXJlcjIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbbXJ4QXV0b3NpemVdJyxcclxuICBob3N0OiB7XHJcbiAgICAnKGlucHV0KSc6ICdvbklucHV0KCknLFxyXG4gICAgJyhwYXN0ZSknOiAnb25JbnB1dCgpJyxcclxuICAgICcoY3V0KSc6ICdvbklucHV0KCknLFxyXG4gICAgJyhjaGFuZ2UpJzogJ29uSW5wdXQoKSdcclxuICB9XHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBdXRvc2l6ZURpcmVjdGl2ZSBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xyXG4gIEBIb3N0QmluZGluZygnc3R5bGUub3ZlcmZsb3cnKVxyXG4gIHB1YmxpYyBvdmVyZmxvdyA9ICdoaWRkZW4nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIEBIb3N0QmluZGluZygncm93cycpXHJcbiAgcHVibGljIHJvd3MgPSAxO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBhdXRvc2l6ZSA9IHRydWU7XHJcblxyXG4gIHByaXZhdGUgaXNJbml0aWFsaXplZCA9IGZhbHNlO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsZW06IEVsZW1lbnRSZWYsIHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMikge31cclxuXHJcbiAgcHVibGljIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcclxuICAgIHRoaXMuaXNJbml0aWFsaXplZCA9IHRydWU7XHJcbiAgICBzZXRUaW1lb3V0KCgpID0+IHRoaXMucmVzaXplKCksIDApOyAvLyDQmNC90LjRhtC40LDQu9C40LfQsNGG0LjRjyDQv9C+0YHQu9C1INGA0LXQvdC00LXRgNCwXHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25JbnB1dCgpIHtcclxuICAgIGlmICh0aGlzLmF1dG9zaXplICYmIHRoaXMuaXNJbml0aWFsaXplZCkge1xyXG4gICAgICB0aGlzLnJlc2l6ZSgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSByZXNpemUoKSB7XHJcbiAgICBpZiAoIXRoaXMuYXV0b3NpemUpIHtcclxuICAgICAgdGhpcy5vdmVyZmxvdyA9ICdhdXRvJztcclxuICAgICAgdGhpcy5zZXRIZWlnaHQoJ2F1dG8nKTtcclxuICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IHRleHRhcmVhID0gdGhpcy5lbGVtLm5hdGl2ZUVsZW1lbnQgYXMgSFRNTFRleHRBcmVhRWxlbWVudDtcclxuICAgIFxyXG4gICAgLy8g0KHQvtGF0YDQsNC90Y/QtdC8INGC0LXQutGD0YnQtdC1INC30L3QsNGH0LXQvdC40LUg0Lgg0YHRgtC40LvQuFxyXG4gICAgY29uc3Qgb3JpZ2luYWxWYWx1ZSA9IHRleHRhcmVhLnZhbHVlO1xyXG4gICAgY29uc3Qgb3JpZ2luYWxUcmFuc2l0aW9uID0gdGV4dGFyZWEuc3R5bGUudHJhbnNpdGlvbjtcclxuICAgIGNvbnN0IG9yaWdpbmFsT3ZlcmZsb3cgPSB0ZXh0YXJlYS5zdHlsZS5vdmVyZmxvdztcclxuICAgIFxyXG4gICAgLy8g0JLRgNC10LzQtdC90L3QviDRg9Cx0LjRgNCw0LXQvCB0cmFuc2l0aW9uINC00LvRjyDQvNCz0L3QvtCy0LXQvdC90L7Qs9C+INGA0LDRgdGH0LXRgtCwXHJcbiAgICB0aGlzLnJlbmRlcmVyLnNldFN0eWxlKHRleHRhcmVhLCAndHJhbnNpdGlvbicsICdub25lJyk7XHJcbiAgICB0aGlzLnJlbmRlcmVyLnNldFN0eWxlKHRleHRhcmVhLCAnb3ZlcmZsb3cnLCAnaGlkZGVuJyk7XHJcbiAgICBcclxuICAgIC8vINCh0LHRgNCw0YHRi9Cy0LDQtdC8INCy0YvRgdC+0YLRgyDQtNC70Y8g0LrQvtGA0YDQtdC60YLQvdC+0LPQviDRgNCw0YHRh9C10YLQsFxyXG4gICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZSh0ZXh0YXJlYSwgJ2hlaWdodCcsICdhdXRvJyk7XHJcbiAgICBcclxuICAgIC8vINCg0LDRgdGB0YfQuNGC0YvQstCw0LXQvCDQvdC+0LLRg9GOINCy0YvRgdC+0YLRg1xyXG4gICAgY29uc3QgYm9yZGVySGVpZ2h0ID0gdGV4dGFyZWEub2Zmc2V0SGVpZ2h0IC0gdGV4dGFyZWEuY2xpZW50SGVpZ2h0O1xyXG4gICAgY29uc3Qgc2Nyb2xsSGVpZ2h0ID0gdGV4dGFyZWEuc2Nyb2xsSGVpZ2h0O1xyXG4gICAgY29uc3QgbmV3SGVpZ2h0ID0gTWF0aC5tYXgoXHJcbiAgICAgIHRleHRhcmVhLmNsaWVudEhlaWdodCwgLy8g0LzQuNC90LjQvNCw0LvRjNC90LDRjyDQstGL0YHQvtGC0LBcclxuICAgICAgc2Nyb2xsSGVpZ2h0ICsgYm9yZGVySGVpZ2h0XHJcbiAgICApO1xyXG4gICAgXHJcbiAgICAvLyDQo9GB0YLQsNC90LDQstC70LjQstCw0LXQvCDQvdC+0LLRg9GOINCy0YvRgdC+0YLRg1xyXG4gICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZSh0ZXh0YXJlYSwgJ2hlaWdodCcsIGAke25ld0hlaWdodH1weGApO1xyXG4gICAgXHJcbiAgICAvLyDQktC+0YHRgdGC0LDQvdCw0LLQu9C40LLQsNC10Lwg0YHRgtC40LvQuFxyXG4gICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUodGV4dGFyZWEsICd0cmFuc2l0aW9uJywgb3JpZ2luYWxUcmFuc2l0aW9uKTtcclxuICAgICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZSh0ZXh0YXJlYSwgJ292ZXJmbG93Jywgb3JpZ2luYWxPdmVyZmxvdyk7XHJcbiAgICB9LCAwKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgc2V0SGVpZ2h0KHZhbHVlOiBzdHJpbmcpIHtcclxuICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUodGhpcy5lbGVtLm5hdGl2ZUVsZW1lbnQsICdoZWlnaHQnLCB2YWx1ZSk7XHJcbiAgfVxyXG59Il19