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.
- package/esm2022/lib/components/alert/alert.component.mjs +2 -1
- package/esm2022/lib/directives/autosize/autosize.directive.mjs +79 -14
- package/fesm2022/myrta-ui.mjs +79 -13
- package/fesm2022/myrta-ui.mjs.map +1 -1
- package/lib/directives/autosize/autosize.directive.d.ts +15 -5
- package/package.json +1 -1
|
@@ -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,
|
|
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
|
|
9
|
-
|
|
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.
|
|
29
|
+
this.setupAutoResize();
|
|
30
|
+
// Первоначальный расчет
|
|
31
|
+
setTimeout(() => this.resize(), 0);
|
|
15
32
|
}
|
|
16
|
-
|
|
17
|
-
this.
|
|
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
|
-
//
|
|
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
|
-
|
|
30
|
-
|
|
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
|
-
|
|
36
|
-
|
|
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
|
-
}],
|
|
118
|
+
}], onInput: [{
|
|
54
119
|
type: HostListener,
|
|
55
120
|
args: ['input']
|
|
56
121
|
}] } });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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}"]}
|
package/fesm2022/myrta-ui.mjs
CHANGED
|
@@ -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
|
|
5954
|
-
|
|
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.
|
|
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
|
-
|
|
5962
|
-
this.
|
|
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
|
-
//
|
|
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
|
-
|
|
5975
|
-
|
|
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
|
-
|
|
5981
|
-
|
|
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
|
-
}],
|
|
6064
|
+
}], onInput: [{
|
|
5999
6065
|
type: HostListener,
|
|
6000
6066
|
args: ['input']
|
|
6001
6067
|
}] } });
|