From ed4a3cb8d72af96e221a63cb96eb5585801cf13b Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Wed, 4 Apr 2018 14:20:45 +0300 Subject: [PATCH] Move the layout settings reset to the 'NavigationEnd' to make things smoother on lazily loaded components --- src/@fuse/services/config.service.ts | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/src/@fuse/services/config.service.ts b/src/@fuse/services/config.service.ts index 2c4cbde4..6da22643 100644 --- a/src/@fuse/services/config.service.ts +++ b/src/@fuse/services/config.service.ts @@ -1,5 +1,5 @@ import { Inject, Injectable, InjectionToken, Optional } from '@angular/core'; -import { NavigationStart, Router } from '@angular/router'; +import { NavigationEnd, NavigationStart, Router } from '@angular/router'; import { BehaviorSubject } from 'rxjs/BehaviorSubject'; import { Platform } from '@angular/cdk/platform'; @@ -29,6 +29,7 @@ export class FuseConfigService { config: any; defaultConfig: any; + isSetConfigRan = false; onConfigChanged: BehaviorSubject; @@ -70,8 +71,19 @@ export class FuseConfigService // layout on every navigation start router.events.subscribe( (event) => { + if ( event instanceof NavigationStart ) { + this.isSetConfigRan = false; + } + + if ( event instanceof NavigationEnd ) + { + if ( this.isSetConfigRan ) + { + return; + } + this.setConfig({ layout: this.defaultConfig.layout } @@ -91,14 +103,17 @@ export class FuseConfigService */ setConfig(config): void { + // Set the SetConfigRan true + this.isSetConfigRan = true; + // Set the config from the given object // Ugly, but works for now... this.config = { ...this.config, ...config, - layout : { + layout : { ...this.config.layout, - ...config.layout, + ...config.layout }, colorClasses: { ...this.config.colorClasses,