mirror of
https://github.com/bitwarden/browser.git
synced 2024-12-22 16:29:09 +01:00
[EC-879] fix: close dialogs on vault lock (#4349)
This commit is contained in:
parent
bf67493663
commit
d922976f8e
@ -1,9 +1,30 @@
|
|||||||
import { Dialog, DialogConfig, DialogRef } from "@angular/cdk/dialog";
|
import {
|
||||||
import { ComponentType } from "@angular/cdk/overlay";
|
DEFAULT_DIALOG_CONFIG,
|
||||||
import { Injectable, TemplateRef } from "@angular/core";
|
Dialog,
|
||||||
|
DialogConfig,
|
||||||
|
DialogRef,
|
||||||
|
DIALOG_SCROLL_STRATEGY,
|
||||||
|
} from "@angular/cdk/dialog";
|
||||||
|
import { ComponentType, Overlay, OverlayContainer } from "@angular/cdk/overlay";
|
||||||
|
import {
|
||||||
|
Inject,
|
||||||
|
Injectable,
|
||||||
|
Injector,
|
||||||
|
OnDestroy,
|
||||||
|
Optional,
|
||||||
|
SkipSelf,
|
||||||
|
TemplateRef,
|
||||||
|
} from "@angular/core";
|
||||||
|
import { NavigationEnd, Router } from "@angular/router";
|
||||||
|
import { filter, Subject, switchMap, takeUntil } from "rxjs";
|
||||||
|
|
||||||
|
import { AuthService } from "@bitwarden/common/abstractions/auth.service";
|
||||||
|
import { AuthenticationStatus } from "@bitwarden/common/enums/authenticationStatus";
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class DialogService extends Dialog {
|
export class DialogService extends Dialog implements OnDestroy {
|
||||||
|
private _destroy$ = new Subject<void>();
|
||||||
|
|
||||||
override open<R = unknown, D = unknown, C = unknown>(
|
override open<R = unknown, D = unknown, C = unknown>(
|
||||||
componentOrTemplateRef: ComponentType<C> | TemplateRef<C>,
|
componentOrTemplateRef: ComponentType<C> | TemplateRef<C>,
|
||||||
config?: DialogConfig<D, DialogRef<R, C>>
|
config?: DialogConfig<D, DialogRef<R, C>>
|
||||||
@ -15,4 +36,38 @@ export class DialogService extends Dialog {
|
|||||||
|
|
||||||
return super.open(componentOrTemplateRef, config);
|
return super.open(componentOrTemplateRef, config);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
/** Parent class constructor */
|
||||||
|
_overlay: Overlay,
|
||||||
|
_injector: Injector,
|
||||||
|
@Optional() @Inject(DEFAULT_DIALOG_CONFIG) _defaultOptions: DialogConfig,
|
||||||
|
@Optional() @SkipSelf() _parentDialog: Dialog,
|
||||||
|
_overlayContainer: OverlayContainer,
|
||||||
|
@Inject(DIALOG_SCROLL_STRATEGY) scrollStrategy: any,
|
||||||
|
|
||||||
|
/** Not in parent class */
|
||||||
|
@Optional() router: Router,
|
||||||
|
@Optional() authService: AuthService
|
||||||
|
) {
|
||||||
|
super(_overlay, _injector, _defaultOptions, _parentDialog, _overlayContainer, scrollStrategy);
|
||||||
|
|
||||||
|
/** Close all open dialogs if the vault locks */
|
||||||
|
if (router && authService) {
|
||||||
|
router.events
|
||||||
|
.pipe(
|
||||||
|
filter((event) => event instanceof NavigationEnd),
|
||||||
|
switchMap(() => authService.getAuthStatus()),
|
||||||
|
filter((v) => v !== AuthenticationStatus.Unlocked),
|
||||||
|
takeUntil(this._destroy$)
|
||||||
|
)
|
||||||
|
.subscribe(() => this.closeAll());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
override ngOnDestroy(): void {
|
||||||
|
this._destroy$.next();
|
||||||
|
this._destroy$.complete();
|
||||||
|
super.ngOnDestroy();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user