Handle router events with progress service

This commit is contained in:
piotrpekala7
2020-02-14 11:55:00 +01:00
parent e11281ddf6
commit 20a86eb6bf
2 changed files with 22 additions and 2 deletions

View File

@ -149,7 +149,7 @@ const routes: Routes = [
]; ];
@NgModule({ @NgModule({
imports: [RouterModule.forRoot(routes)], imports: [RouterModule.forRoot(routes, { enableTracing: true })],
exports: [RouterModule] exports: [RouterModule]
}) })
export class AppRoutingModule {} export class AppRoutingModule {}

View File

@ -4,6 +4,8 @@ import { DomSanitizer } from '@angular/platform-browser';
import { ElectronService } from 'ngx-electron'; import { ElectronService } from 'ngx-electron';
import { SettingsService } from './services/settings.service'; import { SettingsService } from './services/settings.service';
import { ThemeService } from './services/theme.service'; import { ThemeService } from './services/theme.service';
import { Router, NavigationStart, NavigationEnd, NavigationCancel, NavigationError } from '@angular/router';
import { ProgressService } from './common/progress/progress.service';
@Component({ @Component({
selector: 'app-root', selector: 'app-root',
@ -16,10 +18,16 @@ export class AppComponent implements OnInit {
sanitizer: DomSanitizer, sanitizer: DomSanitizer,
private settingsService: SettingsService, private settingsService: SettingsService,
private electronService: ElectronService, private electronService: ElectronService,
private themeService: ThemeService private themeService: ThemeService,
private router: Router,
private progressService: ProgressService
) { ) {
iconReg.addSvgIcon('gns3', sanitizer.bypassSecurityTrustResourceUrl('./assets/gns3_icon.svg')); iconReg.addSvgIcon('gns3', sanitizer.bypassSecurityTrustResourceUrl('./assets/gns3_icon.svg'));
iconReg.addSvgIcon('gns3black', sanitizer.bypassSecurityTrustResourceUrl('./assets/gns3_icon_black.svg')); iconReg.addSvgIcon('gns3black', sanitizer.bypassSecurityTrustResourceUrl('./assets/gns3_icon_black.svg'));
router.events.subscribe((value) => {
this.checkEvent(value);
});
} }
ngOnInit(): void { ngOnInit(): void {
@ -35,4 +43,16 @@ export class AppComponent implements OnInit {
this.themeService.setDarkMode(true); this.themeService.setDarkMode(true);
} }
} }
checkEvent(routerEvent) : void {
if (routerEvent instanceof NavigationStart) {
this.progressService.activate();
}
else if (routerEvent instanceof NavigationEnd ||
routerEvent instanceof NavigationCancel ||
routerEvent instanceof NavigationError) {
this.progressService.deactivate();
}
}
} }