From 93fb577eebdc3c6b9e4f6fe08a022a66c6ddc031 Mon Sep 17 00:00:00 2001 From: Maksim Ivanov Date: Thu, 19 Sep 2024 16:06:19 +0300 Subject: [PATCH] fix(kit): memory leak in line-clamp (#9014) --- .../line-clamp/line-clamp.component.ts | 66 ++++++++----------- .../line-clamp/line-clamp.template.html | 7 +- 2 files changed, 31 insertions(+), 42 deletions(-) diff --git a/projects/kit/components/line-clamp/line-clamp.component.ts b/projects/kit/components/line-clamp/line-clamp.component.ts index 2ea2201ae854..7ce803ab2989 100644 --- a/projects/kit/components/line-clamp/line-clamp.component.ts +++ b/projects/kit/components/line-clamp/line-clamp.component.ts @@ -9,15 +9,13 @@ import { Input, NgZone, Output, - Renderer2, signal, ViewChild, } from '@angular/core'; +import {takeUntilDestroyed, toSignal} from '@angular/core/rxjs-interop'; import {WaResizeObserver} from '@ng-web-apis/resize-observer'; -import {TuiLet} from '@taiga-ui/cdk/directives/let'; import {tuiTypedFromEvent, tuiZonefree} from '@taiga-ui/cdk/observables'; import {tuiInjectElement, tuiIsCurrentTarget} from '@taiga-ui/cdk/utils/dom'; -import {tuiPx} from '@taiga-ui/cdk/utils/miscellaneous'; import { TUI_HINT_COMPONENT, TuiHint, @@ -51,7 +49,6 @@ import {TuiLineClampPositionDirective} from './line-clamp-position.directive'; PolymorpheusOutlet, PolymorpheusTemplate, TuiHint, - TuiLet, TuiLineClampPositionDirective, WaResizeObserver, ], @@ -65,8 +62,12 @@ import {TuiLineClampPositionDirective} from './line-clamp-position.directive'; }, ], host: { - '(transitionend)': 'updateView()', + '[style.height.px]': 'height()', + '[style.max-height.px]': 'maxHeight()', '[class._initialized]': 'initialized()', + '(transitionend)': 'updateView()', + '(mouseenter)': 'updateView()', + '(resize)': 'updateView()', }, }) export class TuiLineClamp implements DoCheck, AfterViewInit { @@ -75,24 +76,33 @@ export class TuiLineClamp implements DoCheck, AfterViewInit { private readonly options = inject(TUI_LINE_CLAMP_OPTIONS); private readonly el = tuiInjectElement(); - private readonly renderer = inject(Renderer2); private readonly cd = inject(ChangeDetectorRef); private readonly zone: NgZone = inject(NgZone); private readonly linesLimit$ = new BehaviorSubject(1); private readonly isOverflown$ = new Subject(); protected initialized = signal(false); - - protected lineClamp$ = this.linesLimit$.pipe( - startWith(1), - pairwise(), - switchMap(([prev, next]) => - next >= prev - ? of(next) - : tuiTypedFromEvent(this.el, 'transitionend').pipe( - filter(tuiIsCurrentTarget), - map(() => next), - ), + protected maxHeight = signal(0); + protected height = signal(0); + + protected readonly $ = timer(0) + .pipe(tuiZonefree(this.zone), takeUntilDestroyed()) + .subscribe(() => this.initialized.set(true)); + + protected lineClamp = toSignal( + this.linesLimit$.pipe( + startWith(1), + pairwise(), + switchMap(([prev, next]) => + next >= prev + ? of(next) + : tuiTypedFromEvent(this.el, 'transitionend').pipe( + filter(tuiIsCurrentTarget), + map(() => next), + ), + ), + takeUntilDestroyed(), ), + {initialValue: 0}, ); @Input() @@ -105,10 +115,6 @@ export class TuiLineClamp implements DoCheck, AfterViewInit { public readonly overflownChange: Observable = this.isOverflown$.pipe(distinctUntilChanged()); - constructor() { - this.skipInitialTransition(); - } - @Input() public set linesLimit(linesLimit: number) { this.linesLimit$.next(linesLimit); @@ -143,27 +149,13 @@ export class TuiLineClamp implements DoCheck, AfterViewInit { this.cd.detectChanges(); } - private skipInitialTransition(): void { - timer(0) - .pipe(tuiZonefree(this.zone)) - .subscribe(() => this.initialized.set(true)); - } - private update(): void { if (this.outlet) { - this.renderer.setStyle( - this.el, - 'height', - tuiPx(this.outlet.nativeElement.scrollHeight + 4), - ); + this.height.set(this.outlet.nativeElement.scrollHeight + 4); } if (this.initialized()) { - this.renderer.setStyle( - this.el, - 'max-height', - tuiPx(this.lineHeight * this.linesLimit$.value), - ); + this.maxHeight.set(this.lineHeight * this.linesLimit$.value); } } } diff --git a/projects/kit/components/line-clamp/line-clamp.template.html b/projects/kit/components/line-clamp/line-clamp.template.html index 33e62b79aa83..ad152341e4b1 100644 --- a/projects/kit/components/line-clamp/line-clamp.template.html +++ b/projects/kit/components/line-clamp/line-clamp.template.html @@ -1,12 +1,9 @@
{{ text }}