blob: 0edde9246650f7465d7139969dbac8ff2f0959e6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
import { Component, OnInit, OnDestroy, ViewChild } from '@angular/core';
import { UserService } from '../user-service/user.service';
import { RouterOutlet, Router, ActivationStart } from '@angular/router';
@Component({
selector: 'app-user-dialog',
templateUrl: './user-dialog.component.html',
styleUrls: ['./user-dialog.component.css']
})
export class UserDialogComponent implements OnInit, OnDestroy {
constructor(private userService: UserService, private router: Router) { }
@ViewChild(RouterOutlet) outlet: RouterOutlet;
isLoading = true;
ngOnInit() {
// this is a workaround for a bug. see https://github.com/angular/angular/issues/20694
this.router.events.subscribe(e => {
if (e instanceof ActivationStart && e.snapshot.outlet === 'user') {
this.outlet.deactivate();
}
});
this.userService.validateUserLoginState().subscribe(result => {
this.isLoading = false;
if (result.state === 'success') {
this.userService.userRouteNavigate(['success', { reason: 'already' }]);
} else {
this.userService.userRouteNavigate(['login', { reason: result.state }]);
}
});
}
ngOnDestroy() {
this.userService.userRouteNavigate(null);
}
}
|