feature(theme-shared): add route subscription to loader-bar.component

pull/1566/head
mehmet-erim 6 years ago
parent 36e819e5d5
commit 1b852f5fb7

@ -1,7 +1,9 @@
import { Component, OnInit, Input } from '@angular/core';
import { Component, OnInit, Input, OnDestroy } from '@angular/core';
import { Actions, ofActionSuccessful } from '@ngxs/store';
import { LoaderStart, LoaderStop } from '@abp/ng.core';
import { filter } from 'rxjs/operators';
import { Router, NavigationStart, NavigationEnd } from '@angular/router';
import { takeUntilDestroy } from '@ngx-validate/core';
@Component({
selector: 'abp-loader-bar',
@ -12,7 +14,7 @@ import { filter } from 'rxjs/operators';
`,
styleUrls: ['./loader-bar.component.scss'],
})
export class LoaderBarComponent {
export class LoaderBarComponent implements OnDestroy {
@Input()
containerClass: string = 'abp-loader-bar';
@ -29,21 +31,31 @@ export class LoaderBarComponent {
interval: any;
constructor(private actions: Actions) {
constructor(private actions: Actions, private router: Router) {
actions
.pipe(
ofActionSuccessful(LoaderStart, LoaderStop),
filter(this.filter),
takeUntilDestroy(this),
)
.subscribe(action => {
if (action instanceof LoaderStart) {
this.startLoading();
} else {
this.stopLoading();
}
if (action instanceof LoaderStart) this.startLoading();
else this.stopLoading();
});
router.events
.pipe(
filter(event => event instanceof NavigationStart || event instanceof NavigationEnd),
takeUntilDestroy(this),
)
.subscribe(event => {
if (event instanceof NavigationStart) this.startLoading();
else this.stopLoading();
});
}
ngOnDestroy() {}
startLoading() {
this.isLoading = true;
const interval = setInterval(() => {

Loading…
Cancel
Save