myrta-ui 17.1.71 → 17.1.72

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,6 +17,7 @@ export class AlertComponent {
17
17
  return `${AlertIconClasses[this.color]}`;
18
18
  }
19
19
  onCloseClick() {
20
+ console.log(1);
20
21
  this.close.emit(null);
21
22
  }
22
23
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
@@ -42,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
42
43
  }], close: [{
43
44
  type: Output
44
45
  }] } });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL2FsZXJ0L2FsZXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9hbGVydC9hbGVydC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hHLE9BQU8sRUFBRSxpQkFBaUIsRUFBZSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7QUFRaEYsTUFBTSxPQUFPLGNBQWM7SUFDaEIsYUFBYSxHQUFXLEVBQUUsQ0FBQztJQUMzQixLQUFLLEdBQWdCLFNBQVMsQ0FBQztJQUMvQixXQUFXLEdBQVcsRUFBRSxDQUFDO0lBQ3pCLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDYixLQUFLLEdBQUcsRUFBRSxDQUFDO0lBQ1gsUUFBUSxHQUFHLEtBQUssQ0FBQztJQUNqQixRQUFRLEdBQUcsS0FBSyxDQUFDO0lBRWhCLEtBQUssR0FBMEIsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUU1RCxJQUFXLFVBQVU7UUFDbkIsT0FBTyxHQUFHLGlCQUFpQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3hFLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDckIsT0FBTyxHQUFHLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO0lBQzNDLENBQUM7SUFFTSxZQUFZO1FBQ2pCLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hCLENBQUM7d0dBckJVLGNBQWM7NEZBQWQsY0FBYyxzUENUM0IsNHJCQW1CQTs7NEZEVmEsY0FBYztrQkFOMUIsU0FBUzsrQkFDRSxXQUFXLG1CQUdKLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBRUksS0FBSztzQkFBZCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFsZXJ0Q29sb3JDbGFzc2VzLCBBbGVydENvbG9ycywgQWxlcnRJY29uQ2xhc3NlcyB9IGZyb20gJy4vYWxlcnQuZW51bSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ21yeC1hbGVydCcsXHJcbiAgdGVtcGxhdGVVcmw6ICdhbGVydC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vYWxlcnQuY29tcG9uZW50Lmxlc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFsZXJ0Q29tcG9uZW50IHtcclxuICBASW5wdXQoKSBjdXN0b21DbGFzc2VzOiBzdHJpbmcgPSAnJztcclxuICBASW5wdXQoKSBjb2xvcjogQWxlcnRDb2xvcnMgPSAnZGVmYXVsdCc7XHJcbiAgQElucHV0KCkgY3VzdG9tQ29sb3I6IHN0cmluZyA9ICcnO1xyXG4gIEBJbnB1dCgpIG1lc3NhZ2UgPSAnJztcclxuICBASW5wdXQoKSB0aXRsZSA9ICcnO1xyXG4gIEBJbnB1dCgpIGNsb3NhYmxlID0gZmFsc2U7XHJcbiAgQElucHV0KCkgc2hvd0ljb24gPSBmYWxzZTtcclxuXHJcbiAgQE91dHB1dCgpIGNsb3NlOiBFdmVudEVtaXR0ZXI8dW5rbm93bj4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcblxyXG4gIHB1YmxpYyBnZXQgZ2V0Q2xhc3NlcygpIHtcclxuICAgIHJldHVybiBgJHtBbGVydENvbG9yQ2xhc3Nlc1t0aGlzLmNvbG9yXSA/PyAnJ30gJHt0aGlzLmN1c3RvbUNsYXNzZXN9YDtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgZ2V0SWNvbkNsYXNzKCkge1xyXG4gICAgcmV0dXJuIGAke0FsZXJ0SWNvbkNsYXNzZXNbdGhpcy5jb2xvcl19YDtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvbkNsb3NlQ2xpY2soKTogdm9pZCB7XHJcbiAgICB0aGlzLmNsb3NlLmVtaXQobnVsbCk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJtcngtYWxlcnRcIiBbY2xhc3NdPVwiZ2V0Q2xhc3Nlc1wiIFtzdHlsZV09XCJ7YmFja2dyb3VuZENvbG9yOiBjdXN0b21Db2xvcn1cIj5cclxuICBAaWYgKGNsb3NhYmxlKSB7XHJcbiAgICA8c3BhbiBjbGFzcz1cIm1yeC1pY29uIGljb24tY2xvc2UgaWNvbi1mb250LTE2XCIgKGNsaWNrKT1cIm9uQ2xvc2VDbGljaygpXCI+PC9zcGFuPlxyXG4gIH1cclxuXHJcbiAgQGlmICh0aXRsZSB8fCBtZXNzYWdlIHx8IHNob3dJY29uKSB7XHJcbiAgICA8c3BhbiBbY2xhc3NdPVwiZ2V0SWNvbkNsYXNzXCIgc3R5bGU9XCJtYXJnaW4tdG9wOiAxcHhcIiBjbGFzcz1cIm1yeC1pY29uIGljb24tYWxlcnQgaWNvbi1mb250LTE2IG1yLTJcIj48L3NwYW4+XHJcbiAgfVxyXG5cclxuICBAaWYgKHRpdGxlKSB7XHJcbiAgICA8ZGl2IGNsYXNzPVwibXJ4LWFsZXJ0LXRpdGxlIG1iLTFcIiBbY2xhc3MubWwtNF09XCJnZXRJY29uQ2xhc3NcIiBbaW5uZXJIVE1MXT1cInRpdGxlXCI+PC9kaXY+XHJcbiAgfVxyXG5cclxuICBAaWYgKG1lc3NhZ2UpIHtcclxuICAgIDxkaXYgY2xhc3M9XCJtcngtYWxlcnQtbWVzc2FnZVwiIFtjbGFzcy5tbC00XT1cImdldEljb25DbGFzc1wiIFtpbm5lckhUTUxdPVwibWVzc2FnZVwiPjwvZGl2PlxyXG4gIH1cclxuXHJcbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG48L2Rpdj5cclxuIl19
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL2FsZXJ0L2FsZXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9hbGVydC9hbGVydC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hHLE9BQU8sRUFBRSxpQkFBaUIsRUFBZSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7QUFRaEYsTUFBTSxPQUFPLGNBQWM7SUFDaEIsYUFBYSxHQUFXLEVBQUUsQ0FBQztJQUMzQixLQUFLLEdBQWdCLFNBQVMsQ0FBQztJQUMvQixXQUFXLEdBQVcsRUFBRSxDQUFDO0lBQ3pCLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDYixLQUFLLEdBQUcsRUFBRSxDQUFDO0lBQ1gsUUFBUSxHQUFHLEtBQUssQ0FBQztJQUNqQixRQUFRLEdBQUcsS0FBSyxDQUFDO0lBRWhCLEtBQUssR0FBMEIsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUU1RCxJQUFXLFVBQVU7UUFDbkIsT0FBTyxHQUFHLGlCQUFpQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3hFLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDckIsT0FBTyxHQUFHLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO0lBQzNDLENBQUM7SUFFTSxZQUFZO1FBQ2pCLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFDZCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4QixDQUFDO3dHQXRCVSxjQUFjOzRGQUFkLGNBQWMsc1BDVDNCLDRyQkFtQkE7OzRGRFZhLGNBQWM7a0JBTjFCLFNBQVM7K0JBQ0UsV0FBVyxtQkFHSix1QkFBdUIsQ0FBQyxNQUFNOzhCQUd0QyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUVJLEtBQUs7c0JBQWQsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBbGVydENvbG9yQ2xhc3NlcywgQWxlcnRDb2xvcnMsIEFsZXJ0SWNvbkNsYXNzZXMgfSBmcm9tICcuL2FsZXJ0LmVudW0nO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdtcngtYWxlcnQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnYWxlcnQuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2FsZXJ0LmNvbXBvbmVudC5sZXNzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBbGVydENvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgY3VzdG9tQ2xhc3Nlczogc3RyaW5nID0gJyc7XHJcbiAgQElucHV0KCkgY29sb3I6IEFsZXJ0Q29sb3JzID0gJ2RlZmF1bHQnO1xyXG4gIEBJbnB1dCgpIGN1c3RvbUNvbG9yOiBzdHJpbmcgPSAnJztcclxuICBASW5wdXQoKSBtZXNzYWdlID0gJyc7XHJcbiAgQElucHV0KCkgdGl0bGUgPSAnJztcclxuICBASW5wdXQoKSBjbG9zYWJsZSA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIHNob3dJY29uID0gZmFsc2U7XHJcblxyXG4gIEBPdXRwdXQoKSBjbG9zZTogRXZlbnRFbWl0dGVyPHVua25vd24+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG5cclxuICBwdWJsaWMgZ2V0IGdldENsYXNzZXMoKSB7XHJcbiAgICByZXR1cm4gYCR7QWxlcnRDb2xvckNsYXNzZXNbdGhpcy5jb2xvcl0gPz8gJyd9ICR7dGhpcy5jdXN0b21DbGFzc2VzfWA7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IGdldEljb25DbGFzcygpIHtcclxuICAgIHJldHVybiBgJHtBbGVydEljb25DbGFzc2VzW3RoaXMuY29sb3JdfWA7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25DbG9zZUNsaWNrKCk6IHZvaWQge1xyXG4gICAgY29uc29sZS5sb2coMSlcclxuICAgIHRoaXMuY2xvc2UuZW1pdChudWxsKTtcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cIm1yeC1hbGVydFwiIFtjbGFzc109XCJnZXRDbGFzc2VzXCIgW3N0eWxlXT1cIntiYWNrZ3JvdW5kQ29sb3I6IGN1c3RvbUNvbG9yfVwiPlxyXG4gIEBpZiAoY2xvc2FibGUpIHtcclxuICAgIDxzcGFuIGNsYXNzPVwibXJ4LWljb24gaWNvbi1jbG9zZSBpY29uLWZvbnQtMTZcIiAoY2xpY2spPVwib25DbG9zZUNsaWNrKClcIj48L3NwYW4+XHJcbiAgfVxyXG5cclxuICBAaWYgKHRpdGxlIHx8IG1lc3NhZ2UgfHwgc2hvd0ljb24pIHtcclxuICAgIDxzcGFuIFtjbGFzc109XCJnZXRJY29uQ2xhc3NcIiBzdHlsZT1cIm1hcmdpbi10b3A6IDFweFwiIGNsYXNzPVwibXJ4LWljb24gaWNvbi1hbGVydCBpY29uLWZvbnQtMTYgbXItMlwiPjwvc3Bhbj5cclxuICB9XHJcblxyXG4gIEBpZiAodGl0bGUpIHtcclxuICAgIDxkaXYgY2xhc3M9XCJtcngtYWxlcnQtdGl0bGUgbWItMVwiIFtjbGFzcy5tbC00XT1cImdldEljb25DbGFzc1wiIFtpbm5lckhUTUxdPVwidGl0bGVcIj48L2Rpdj5cclxuICB9XHJcblxyXG4gIEBpZiAobWVzc2FnZSkge1xyXG4gICAgPGRpdiBjbGFzcz1cIm1yeC1hbGVydC1tZXNzYWdlXCIgW2NsYXNzLm1sLTRdPVwiZ2V0SWNvbkNsYXNzXCIgW2lubmVySFRNTF09XCJtZXNzYWdlXCI+PC9kaXY+XHJcbiAgfVxyXG5cclxuICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbjwvZGl2PlxyXG4iXX0=
@@ -3,18 +3,65 @@ import * as i0 from "@angular/core";
3
3
  export class AutosizeDirective {
4
4
  elem;
5
5
  renderer;
6
+ ngZone;
6
7
  overflow = 'hidden';
7
8
  rows = 1;
8
- autosize = true;
9
- constructor(elem, renderer) {
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) {
10
24
  this.elem = elem;
11
25
  this.renderer = renderer;
26
+ this.ngZone = ngZone;
12
27
  }
13
28
  ngAfterViewInit() {
14
- this.resize();
29
+ this.setupAutoResize();
30
+ // Первоначальный расчет
31
+ setTimeout(() => this.resize(), 0);
15
32
  }
16
- ngDoCheck() {
17
- this.resize();
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мс
62
+ }
63
+ onInput() {
64
+ this.scheduleResize();
18
65
  }
19
66
  resize() {
20
67
  if (!this.autosize) {
@@ -22,25 +69,43 @@ export class AutosizeDirective {
22
69
  return;
23
70
  }
24
71
  const textarea = this.elem.nativeElement;
25
- // Calculate border height which is not included in scrollHeight
72
+ // Временно отключаем transition для предотвращения скачков
73
+ const originalTransition = textarea.style.transition;
74
+ this.renderer.setStyle(textarea, 'transition', 'none');
75
+ // Рассчитываем новую высоту
26
76
  const borderHeight = textarea.offsetHeight - textarea.clientHeight;
27
- // Reset textarea height to auto that correctly calculate the new height
28
77
  this.setHeight('auto');
29
- // Set new height
30
- this.setHeight(`${textarea.scrollHeight + borderHeight}px`);
78
+ 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
86
+ setTimeout(() => {
87
+ this.renderer.setStyle(textarea, 'transition', originalTransition);
88
+ }, 0);
31
89
  }
32
90
  setHeight(value) {
33
91
  this.renderer.setStyle(this.elem.nativeElement, 'height', value);
34
92
  }
35
- 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 });
36
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: AutosizeDirective, selector: "[mrxAutosize]", inputs: { rows: "rows", autosize: "autosize" }, host: { listeners: { "input": "resize()" }, properties: { "style.overflow": "this.overflow", "rows": "this.rows" } }, ngImport: i0 });
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 });
37
102
  }
38
103
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AutosizeDirective, decorators: [{
39
104
  type: Directive,
40
105
  args: [{
41
106
  selector: '[mrxAutosize]'
42
107
  }]
43
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { overflow: [{
108
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.NgZone }], propDecorators: { overflow: [{
44
109
  type: HostBinding,
45
110
  args: ['style.overflow']
46
111
  }], rows: [{
@@ -50,8 +115,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
50
115
  args: ['rows']
51
116
  }], autosize: [{
52
117
  type: Input
53
- }], resize: [{
118
+ }], onInput: [{
54
119
  type: HostListener,
55
120
  args: ['input']
56
121
  }] } });
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b3NpemUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9kaXJlY3RpdmVzL2F1dG9zaXplL2F1dG9zaXplLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUdULFdBQVcsRUFDWCxZQUFZLEVBQ1osS0FBSyxFQUVOLE1BQU0sZUFBZSxDQUFDOztBQUt2QixNQUFNLE9BQU8saUJBQWlCO0lBV1I7SUFBMEI7SUFUdkMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUlwQixJQUFJLEdBQUcsQ0FBQyxDQUFDO0lBR1QsUUFBUSxHQUFHLElBQUksQ0FBQztJQUV2QixZQUFvQixJQUFnQixFQUFVLFFBQW1CO1FBQTdDLFNBQUksR0FBSixJQUFJLENBQVk7UUFBVSxhQUFRLEdBQVIsUUFBUSxDQUFXO0lBQUcsQ0FBQztJQUU5RCxlQUFlO1FBQ3BCLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBRU0sU0FBUztRQUNkLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBR08sTUFBTTtRQUNaLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLFFBQVEsR0FBRyxNQUFNLENBQUE7WUFDdEIsT0FBTTtRQUNSLENBQUM7UUFFRCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQW9DLENBQUM7UUFDaEUsZ0VBQWdFO1FBQ2hFLE1BQU0sWUFBWSxHQUFHLFFBQVEsQ0FBQyxZQUFZLEdBQUcsUUFBUSxDQUFDLFlBQVksQ0FBQztRQUNuRSx3RUFBd0U7UUFDeEUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN2QixpQkFBaUI7UUFDakIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxZQUFZLEdBQUcsWUFBWSxJQUFJLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRU8sU0FBUyxDQUFDLEtBQWE7UUFDN0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsUUFBUSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ25FLENBQUM7d0dBdkNVLGlCQUFpQjs0RkFBakIsaUJBQWlCOzs0RkFBakIsaUJBQWlCO2tCQUg3QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxlQUFlO2lCQUMxQjt1R0FHUSxRQUFRO3NCQURkLFdBQVc7dUJBQUMsZ0JBQWdCO2dCQUt0QixJQUFJO3NCQUZWLEtBQUs7O3NCQUNMLFdBQVc7dUJBQUMsTUFBTTtnQkFJWixRQUFRO3NCQURkLEtBQUs7Z0JBY0UsTUFBTTtzQkFEYixZQUFZO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIEFmdGVyVmlld0luaXQsXHJcbiAgRGlyZWN0aXZlLFxyXG4gIERvQ2hlY2ssXHJcbiAgRWxlbWVudFJlZixcclxuICBIb3N0QmluZGluZyxcclxuICBIb3N0TGlzdGVuZXIsXHJcbiAgSW5wdXQsXHJcbiAgUmVuZGVyZXIyXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1ttcnhBdXRvc2l6ZV0nXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBdXRvc2l6ZURpcmVjdGl2ZSBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIERvQ2hlY2sge1xyXG4gIEBIb3N0QmluZGluZygnc3R5bGUub3ZlcmZsb3cnKVxyXG4gIHB1YmxpYyBvdmVyZmxvdyA9ICdoaWRkZW4nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIEBIb3N0QmluZGluZygncm93cycpXHJcbiAgcHVibGljIHJvd3MgPSAxO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBhdXRvc2l6ZSA9IHRydWU7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbTogRWxlbWVudFJlZiwgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyKSB7fVxyXG5cclxuICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCkge1xyXG4gICAgdGhpcy5yZXNpemUoKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBuZ0RvQ2hlY2soKSB7XHJcbiAgICB0aGlzLnJlc2l6ZSgpO1xyXG4gIH1cclxuXHJcbiAgQEhvc3RMaXN0ZW5lcignaW5wdXQnKVxyXG4gIHByaXZhdGUgcmVzaXplKCkge1xyXG4gICAgaWYgKCF0aGlzLmF1dG9zaXplKSB7XHJcbiAgICAgIHRoaXMub3ZlcmZsb3cgPSAnYXV0bydcclxuICAgICAgcmV0dXJuXHJcbiAgICB9XHJcblxyXG4gICAgY29uc3QgdGV4dGFyZWEgPSB0aGlzLmVsZW0ubmF0aXZlRWxlbWVudCBhcyBIVE1MVGV4dEFyZWFFbGVtZW50O1xyXG4gICAgLy8gQ2FsY3VsYXRlIGJvcmRlciBoZWlnaHQgd2hpY2ggaXMgbm90IGluY2x1ZGVkIGluIHNjcm9sbEhlaWdodFxyXG4gICAgY29uc3QgYm9yZGVySGVpZ2h0ID0gdGV4dGFyZWEub2Zmc2V0SGVpZ2h0IC0gdGV4dGFyZWEuY2xpZW50SGVpZ2h0O1xyXG4gICAgLy8gUmVzZXQgdGV4dGFyZWEgaGVpZ2h0IHRvIGF1dG8gdGhhdCBjb3JyZWN0bHkgY2FsY3VsYXRlIHRoZSBuZXcgaGVpZ2h0XHJcbiAgICB0aGlzLnNldEhlaWdodCgnYXV0bycpO1xyXG4gICAgLy8gU2V0IG5ldyBoZWlnaHRcclxuICAgIHRoaXMuc2V0SGVpZ2h0KGAke3RleHRhcmVhLnNjcm9sbEhlaWdodCArIGJvcmRlckhlaWdodH1weGApO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBzZXRIZWlnaHQodmFsdWU6IHN0cmluZykge1xyXG4gICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZSh0aGlzLmVsZW0ubmF0aXZlRWxlbWVudCwgJ2hlaWdodCcsIHZhbHVlKTtcclxuICB9XHJcbn1cclxuIl19
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}"]}
@@ -340,6 +340,7 @@ class AlertComponent {
340
340
  return `${AlertIconClasses[this.color]}`;
341
341
  }
342
342
  onCloseClick() {
343
+ console.log(1);
343
344
  this.close.emit(null);
344
345
  }
345
346
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
@@ -5948,18 +5949,65 @@ var InputTextareaSizesEnum;
5948
5949
  class AutosizeDirective {
5949
5950
  elem;
5950
5951
  renderer;
5952
+ ngZone;
5951
5953
  overflow = 'hidden';
5952
5954
  rows = 1;
5953
- autosize = true;
5954
- constructor(elem, renderer) {
5955
+ set autosize(value) {
5956
+ this._autosize = value;
5957
+ if (!value) {
5958
+ this.overflow = 'auto';
5959
+ this.setHeight('auto');
5960
+ }
5961
+ }
5962
+ get autosize() {
5963
+ return this._autosize;
5964
+ }
5965
+ _autosize = true;
5966
+ observer = null;
5967
+ resizeTimeout;
5968
+ lastHeight = 0;
5969
+ constructor(elem, renderer, ngZone) {
5955
5970
  this.elem = elem;
5956
5971
  this.renderer = renderer;
5972
+ this.ngZone = ngZone;
5957
5973
  }
5958
5974
  ngAfterViewInit() {
5959
- this.resize();
5975
+ this.setupAutoResize();
5976
+ // Первоначальный расчет
5977
+ setTimeout(() => this.resize(), 0);
5978
+ }
5979
+ ngOnDestroy() {
5980
+ this.cleanup();
5981
+ }
5982
+ setupAutoResize() {
5983
+ if (!this.autosize)
5984
+ return;
5985
+ const textarea = this.elem.nativeElement;
5986
+ // Используем MutationObserver вместо ngDoCheck
5987
+ this.ngZone.runOutsideAngular(() => {
5988
+ this.observer = new MutationObserver(() => {
5989
+ this.scheduleResize();
5990
+ });
5991
+ this.observer.observe(textarea, {
5992
+ characterData: true,
5993
+ childList: true,
5994
+ subtree: true
5995
+ });
5996
+ });
5997
+ // Также следим за resize окна
5998
+ this.renderer.listen('window', 'resize', () => this.scheduleResize());
5999
+ }
6000
+ scheduleResize() {
6001
+ if (!this.autosize)
6002
+ return;
6003
+ // Debounce для оптимизации
6004
+ clearTimeout(this.resizeTimeout);
6005
+ this.resizeTimeout = setTimeout(() => {
6006
+ this.ngZone.run(() => this.resize());
6007
+ }, 50); // Задержка 50мс
5960
6008
  }
5961
- ngDoCheck() {
5962
- this.resize();
6009
+ onInput() {
6010
+ this.scheduleResize();
5963
6011
  }
5964
6012
  resize() {
5965
6013
  if (!this.autosize) {
@@ -5967,25 +6015,43 @@ class AutosizeDirective {
5967
6015
  return;
5968
6016
  }
5969
6017
  const textarea = this.elem.nativeElement;
5970
- // Calculate border height which is not included in scrollHeight
6018
+ // Временно отключаем transition для предотвращения скачков
6019
+ const originalTransition = textarea.style.transition;
6020
+ this.renderer.setStyle(textarea, 'transition', 'none');
6021
+ // Рассчитываем новую высоту
5971
6022
  const borderHeight = textarea.offsetHeight - textarea.clientHeight;
5972
- // Reset textarea height to auto that correctly calculate the new height
5973
6023
  this.setHeight('auto');
5974
- // Set new height
5975
- this.setHeight(`${textarea.scrollHeight + borderHeight}px`);
6024
+ const scrollHeight = textarea.scrollHeight;
6025
+ const newHeight = scrollHeight + borderHeight;
6026
+ // Изменяем высоту только если она действительно изменилась
6027
+ if (Math.abs(newHeight - this.lastHeight) > 2) { // Порог 2px
6028
+ this.setHeight(`${newHeight}px`);
6029
+ this.lastHeight = newHeight;
6030
+ }
6031
+ // Восстанавливаем transition
6032
+ setTimeout(() => {
6033
+ this.renderer.setStyle(textarea, 'transition', originalTransition);
6034
+ }, 0);
5976
6035
  }
5977
6036
  setHeight(value) {
5978
6037
  this.renderer.setStyle(this.elem.nativeElement, 'height', value);
5979
6038
  }
5980
- 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 });
5981
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: AutosizeDirective, selector: "[mrxAutosize]", inputs: { rows: "rows", autosize: "autosize" }, host: { listeners: { "input": "resize()" }, properties: { "style.overflow": "this.overflow", "rows": "this.rows" } }, ngImport: i0 });
6039
+ cleanup() {
6040
+ if (this.observer) {
6041
+ this.observer.disconnect();
6042
+ this.observer = null;
6043
+ }
6044
+ clearTimeout(this.resizeTimeout);
6045
+ }
6046
+ 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 });
6047
+ 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 });
5982
6048
  }
5983
6049
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AutosizeDirective, decorators: [{
5984
6050
  type: Directive,
5985
6051
  args: [{
5986
6052
  selector: '[mrxAutosize]'
5987
6053
  }]
5988
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { overflow: [{
6054
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.NgZone }], propDecorators: { overflow: [{
5989
6055
  type: HostBinding,
5990
6056
  args: ['style.overflow']
5991
6057
  }], rows: [{
@@ -5995,7 +6061,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
5995
6061
  args: ['rows']
5996
6062
  }], autosize: [{
5997
6063
  type: Input
5998
- }], resize: [{
6064
+ }], onInput: [{
5999
6065
  type: HostListener,
6000
6066
  args: ['input']
6001
6067
  }] } });