- Scrolling is not smooth on iOS devices +
- (Horizontal Layout) Navbar covers the entire screen
diff --git a/src/@fuse/scss/partials/_global.scss b/src/@fuse/scss/partials/_global.scss index c54af974..9a100ea6 100644 --- a/src/@fuse/scss/partials/_global.scss +++ b/src/@fuse/scss/partials/_global.scss @@ -10,4 +10,15 @@ body { padding: 0; overflow: hidden; background: #F5F5F5; +} + +body { + + // Boxed + &.boxed { + max-width: 1200px; + margin: 0 auto; + + @include mat-elevation(8); + } } \ No newline at end of file diff --git a/src/app/app.component.ts b/src/app/app.component.ts index d70f0da7..cfae4916 100644 --- a/src/app/app.component.ts +++ b/src/app/app.component.ts @@ -75,7 +75,7 @@ export class AppComponent implements OnInit, OnDestroy // Add is-mobile class to the body if the platform is mobile if ( this._platform.ANDROID || this._platform.IOS ) { - this.document.body.className += ' is-mobile'; + this.document.body.classList.add('is-mobile'); } // Set the private defaults @@ -96,6 +96,15 @@ export class AppComponent implements OnInit, OnDestroy .pipe(takeUntil(this._unsubscribeAll)) .subscribe((config) => { this.fuseConfig = config; + + if ( this.fuseConfig.layout.width === 'boxed' ) + { + this.document.body.classList.add('boxed'); + } + else + { + this.document.body.classList.remove('boxed'); + } }); } diff --git a/src/app/layout/components/navbar/horizontal/style-1/style-1.component.scss b/src/app/layout/components/navbar/horizontal/style-1/style-1.component.scss index 9a5630e2..3cc1a98d 100644 --- a/src/app/layout/components/navbar/horizontal/style-1/style-1.component.scss +++ b/src/app/layout/components/navbar/horizontal/style-1/style-1.component.scss @@ -1,3 +1,16 @@ navbar-horizontal-style-1 { } + +navbar { + + &.horizontal-style-1 { + display: flex; + flex-direction: column; + flex: 1 1 auto; + width: 100%; + height: 56px; + max-height: 56px; + min-height: 56px; + } +} \ No newline at end of file diff --git a/src/app/layout/components/navbar/navbar.component.scss b/src/app/layout/components/navbar/navbar.component.scss index e14eee3b..93609b0b 100644 --- a/src/app/layout/components/navbar/navbar.component.scss +++ b/src/app/layout/components/navbar/navbar.component.scss @@ -1,7 +1,3 @@ navbar { - display: flex; - flex-direction: column; - flex: 1 1 auto; - width: 100%; - height: 100%; + } diff --git a/src/app/layout/components/navbar/navbar.component.ts b/src/app/layout/components/navbar/navbar.component.ts index c9544269..069ab5fb 100644 --- a/src/app/layout/components/navbar/navbar.component.ts +++ b/src/app/layout/components/navbar/navbar.component.ts @@ -1,4 +1,4 @@ -import { Component, Input, ViewEncapsulation } from '@angular/core'; +import { Component, ElementRef, Input, Renderer2, ViewEncapsulation } from '@angular/core'; @Component({ selector : 'navbar', @@ -8,16 +8,46 @@ import { Component, Input, ViewEncapsulation } from '@angular/core'; }) export class NavbarComponent { - // Variant - @Input() - variant; + // Private + _variant: string; /** * Constructor + * + * @param {ElementRef} _elementRef + * @param {Renderer2} _renderer */ - constructor() + constructor( + private _elementRef: ElementRef, + private _renderer: Renderer2 + ) { - // Set the defaults - this.variant = 'vertical-style-1'; + // Set the private defaults + this._variant = 'vertical-style-1'; + } + + // ----------------------------------------------------------------------------------------------------- + // @ Accessors + // ----------------------------------------------------------------------------------------------------- + + /** + * Variant + */ + get variant(): string + { + return this._variant; + } + + @Input() + set variant(value: string) + { + // Remove the old class name + this._renderer.removeClass(this._elementRef.nativeElement, this.variant); + + // Store the variant value + this._variant = value; + + // Add the new class name + this._renderer.addClass(this._elementRef.nativeElement, value); } } diff --git a/src/app/layout/components/navbar/vertical/style-1/style-1.component.scss b/src/app/layout/components/navbar/vertical/style-1/style-1.component.scss index 136fdcc3..d8c24ee3 100644 --- a/src/app/layout/components/navbar/vertical/style-1/style-1.component.scss +++ b/src/app/layout/components/navbar/vertical/style-1/style-1.component.scss @@ -68,6 +68,24 @@ fuse-sidebar { navbar { + &.vertical-style-1 { + display: flex; + flex-direction: column; + flex: 1 1 auto; + width: 100%; + height: 100%; + + &.right-navbar { + + .toggle-sidebar-opened { + + mat-icon { + transform: rotate(180deg); + } + } + } + } + navbar-vertical-style-1 { display: flex; flex-direction: column; @@ -156,14 +174,4 @@ navbar { } } } - - &.right-navbar { - - .toggle-sidebar-opened { - - mat-icon { - transform: rotate(180deg); - } - } - } } \ No newline at end of file diff --git a/src/app/layout/components/navbar/vertical/style-2/style-2.component.scss b/src/app/layout/components/navbar/vertical/style-2/style-2.component.scss index 7637b741..198f1430 100644 --- a/src/app/layout/components/navbar/vertical/style-2/style-2.component.scss +++ b/src/app/layout/components/navbar/vertical/style-2/style-2.component.scss @@ -30,6 +30,24 @@ fuse-sidebar { navbar { + &.vertical-style-2 { + display: flex; + flex-direction: column; + flex: 1 1 auto; + width: 100%; + height: 100%; + + &.right-navbar { + + .toggle-sidebar-opened { + + mat-icon { + transform: rotate(180deg); + } + } + } + } + navbar-vertical-style-2 { display: flex; flex-direction: column; @@ -72,14 +90,4 @@ navbar { } } - - &.right-navbar { - - .toggle-sidebar-opened { - - mat-icon { - transform: rotate(180deg); - } - } - } } diff --git a/src/app/layout/horizontal/layout-1/layout-1.component.html b/src/app/layout/horizontal/layout-1/layout-1.component.html index e06ee6be..a4bac971 100644 --- a/src/app/layout/horizontal/layout-1/layout-1.component.html +++ b/src/app/layout/horizontal/layout-1/layout-1.component.html @@ -12,7 +12,7 @@ -