From 8331e5260cc6552e5667d8b1378399b639536e19 Mon Sep 17 00:00:00 2001 From: shiv9604 Date: Wed, 11 Dec 2024 01:57:32 +0530 Subject: [PATCH 1/2] fix(core): emit tuiDropdownOpenChange on distinct values --- .../dropdown/dropdown-open-legacy.directive.ts | 14 +++++++++++--- .../legacy-dropdown-open-monitor.ts | 2 +- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts b/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts index ded45fa8ffd5..126dfff817f3 100644 --- a/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts +++ b/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts @@ -1,5 +1,5 @@ import {Directive, Input, Output} from '@angular/core'; -import {BehaviorSubject} from 'rxjs'; +import {distinctUntilChanged, Subject} from 'rxjs'; /** * @deprecated TODO: remove in v.5 when legacy controls are dropped @@ -10,11 +10,19 @@ import {BehaviorSubject} from 'rxjs'; '[tuiDropdownOpen]:not([tuiDropdown]),[tuiDropdownOpenChange]:not([tuiDropdown])', }) export class TuiDropdownOpenLegacy { + private readonly openStateSub = new Subject(); + @Output() - public readonly tuiDropdownOpenChange = new BehaviorSubject(false); + public readonly tuiDropdownOpenChange = this.openStateSub + .asObservable() + .pipe(distinctUntilChanged()); @Input() public set tuiDropdownOpen(open: boolean) { - this.tuiDropdownOpenChange.next(open); + this.emitOpenChange(open); + } + + public emitOpenChange(open: boolean): void { + this.openStateSub.next(open); } } diff --git a/projects/legacy/directives/legacy-dropdown-open-monitor/legacy-dropdown-open-monitor.ts b/projects/legacy/directives/legacy-dropdown-open-monitor/legacy-dropdown-open-monitor.ts index 9fd6cb8fcf88..e0d027a48492 100644 --- a/projects/legacy/directives/legacy-dropdown-open-monitor/legacy-dropdown-open-monitor.ts +++ b/projects/legacy/directives/legacy-dropdown-open-monitor/legacy-dropdown-open-monitor.ts @@ -34,6 +34,6 @@ export class TuiLegacyDropdownOpenMonitorDirective implements AfterViewInit { this.host.driver .pipe(distinctUntilChanged(), takeUntilDestroyed(this.destroyRef)) - .subscribe((open) => this.external?.tuiDropdownOpenChange.next(open)); + .subscribe((open) => this.external?.emitOpenChange(open)); } } From c07231c216e2a5bb3050f05258ee9e9fce3dd576 Mon Sep 17 00:00:00 2001 From: shiv9604 Date: Thu, 12 Dec 2024 20:22:55 +0530 Subject: [PATCH 2/2] fix(core): resolve pr comment --- .../directives/dropdown/dropdown-open-legacy.directive.ts | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts b/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts index 126dfff817f3..1c1c4a98dc16 100644 --- a/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts +++ b/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts @@ -13,9 +13,8 @@ export class TuiDropdownOpenLegacy { private readonly openStateSub = new Subject(); @Output() - public readonly tuiDropdownOpenChange = this.openStateSub - .asObservable() - .pipe(distinctUntilChanged()); + public readonly tuiDropdownOpenChange = + this.openStateSub.pipe(distinctUntilChanged()); @Input() public set tuiDropdownOpen(open: boolean) {