Skip to content

Commit

Permalink
refactor(cdk): improve performance for resize service
Browse files Browse the repository at this point in the history
  • Loading branch information
splincode committed Dec 5, 2022
1 parent c79a788 commit 4a80a8d
Showing 1 changed file with 15 additions and 16 deletions.
31 changes: 15 additions & 16 deletions projects/cdk/services/resize.service.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import {ElementRef, Inject, Injectable, NgZone, Self} from '@angular/core';
import {ANIMATION_FRAME} from '@ng-web-apis/common';
import {
RESIZE_OBSERVER_SUPPORT,
RESIZE_OPTION_BOX,
Expand All @@ -12,8 +11,7 @@ import {
catchError,
debounceTime,
distinctUntilChanged,
map,
mapTo,
share,
takeUntil,
throttleTime,
} from 'rxjs/operators';
Expand All @@ -28,25 +26,26 @@ export class TuiResizeService extends ResizeObserverService {
@Self() @Inject(TuiDestroyService) destroy$: Observable<void>,
@Inject(RESIZE_OBSERVER_SUPPORT) support: boolean,
@Inject(RESIZE_OPTION_BOX) box: ResizeObserverBoxOptions,
@Inject(ANIMATION_FRAME) animationFrame$: Observable<number>,
) {
super(elementRef, ngZone, support, box);

return this.pipe(
catchError(() =>
animationFrame$.pipe(
throttleTime(POLLING_TIME),
map(
() =>
`${elementRef.nativeElement.clientWidth} ${elementRef.nativeElement.clientHeight}`,
),
distinctUntilChanged(),
mapTo(EMPTY_ARRAY),
),
),
debounceTime(0),
tuiZonefree(ngZone),
debounceTime(0),
throttleTime(POLLING_TIME),
distinctUntilChanged(
(
[x]: readonly ResizeObserverEntry[],
[y]: readonly ResizeObserverEntry[],
) => sizeOfEntry(x.target) !== sizeOfEntry(y.target),
),
catchError(() => EMPTY_ARRAY),
share(),
takeUntil(destroy$),
);
}
}

function sizeOfEntry(element: Element): string {
return `${element.clientWidth} ${element.clientHeight}`;
}

0 comments on commit 4a80a8d

Please sign in to comment.