mirror of
https://github.com/richard-loafle/fuse-angular.git
synced 2025-01-10 12:35:07 +00:00
(FuseNavBar) default folded option added, responsive, right/left sidenav issues fixed.
This commit is contained in:
parent
117f5a85b2
commit
da97ab7e4b
|
@ -10,7 +10,7 @@
|
||||||
|
|
||||||
<div id="wrapper">
|
<div id="wrapper">
|
||||||
|
|
||||||
<fuse-navbar class="md-primary-700-bg" *ngIf="layoutSettings.navigation === 'left'"></fuse-navbar>
|
<fuse-navbar [folded]="true" class="md-primary-700-bg left-navbar" *ngIf="layoutSettings.navigation === 'left'"></fuse-navbar>
|
||||||
|
|
||||||
<div class="content-wrapper">
|
<div class="content-wrapper">
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<fuse-navbar class="md-primary-bg" *ngIf="layoutSettings.navigation === 'right'"></fuse-navbar>
|
<fuse-navbar [folded]="true" class="md-primary-700-bg right-navbar" *ngIf="layoutSettings.navigation === 'right'"></fuse-navbar>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
|
@ -10,18 +10,20 @@ export class FuseNavbarToggleDirective
|
||||||
@Input() fuseNavbar: string;
|
@Input() fuseNavbar: string;
|
||||||
navbar: FuseNavbarComponent;
|
navbar: FuseNavbarComponent;
|
||||||
|
|
||||||
constructor(navbar: FuseNavbarService)
|
constructor(private navbarService: FuseNavbarService)
|
||||||
{
|
{
|
||||||
this.navbar = navbar.getNavBar();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@HostListener('click')
|
@HostListener('click')
|
||||||
onClick()
|
onClick()
|
||||||
{
|
{
|
||||||
|
this.navbar = this.navbarService.getNavBar();
|
||||||
|
|
||||||
if ( !this.navbar[this.fuseNavbar] )
|
if ( !this.navbar[this.fuseNavbar] )
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.navbar[this.fuseNavbar]();
|
this.navbar[this.fuseNavbar]();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,14 @@ body {
|
||||||
&.fuse-nav-bar-folded {
|
&.fuse-nav-bar-folded {
|
||||||
|
|
||||||
.content-wrapper {
|
.content-wrapper {
|
||||||
padding-left: 64px !important;
|
|
||||||
|
&:last-child {
|
||||||
|
padding-left: 64px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:first-child {
|
||||||
|
padding-right: 64px !important;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -27,6 +34,13 @@ fuse-navbar {
|
||||||
&.folded {
|
&.folded {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
|
|
||||||
|
&.left-navbar {
|
||||||
|
left: 0;
|
||||||
|
}
|
||||||
|
&.right-navbar {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
&:not(.folded-open) {
|
&:not(.folded-open) {
|
||||||
width: 64px;
|
width: 64px;
|
||||||
min-width: 64px;
|
min-width: 64px;
|
||||||
|
@ -42,20 +56,35 @@ fuse-navbar {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&.open {
|
|
||||||
transform: translateX(0) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
&.close {
|
&.close {
|
||||||
transform: translateX(-100%) !important;
|
&.left-navbar {
|
||||||
|
transform: translateX(-100%) !important;
|
||||||
|
}
|
||||||
|
&.right-navbar {
|
||||||
|
transform: translateX(100%) !important;
|
||||||
|
}
|
||||||
|
box-shadow: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@include media-breakpoint('xs') {
|
@include media-breakpoint('xs') {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: 0;
|
top: 0;
|
||||||
left: 0;
|
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
transform: translateX(-100%);
|
&.left-navbar {
|
||||||
|
left: 0;
|
||||||
|
}
|
||||||
|
&.right-navbar {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:not(.initialized) {
|
||||||
|
&.left-navbar {
|
||||||
|
transform: translateX(-100%);
|
||||||
|
}
|
||||||
|
&.right-navbar {
|
||||||
|
transform: translateX(100%);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.navbar-header {
|
.navbar-header {
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
import { Component, HostBinding, HostListener, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';
|
import { Component, HostBinding, HostListener, Input, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';
|
||||||
import { AppComponent } from '../../app.component';
|
import { AppComponent } from '../../app.component';
|
||||||
import { Subscription } from 'rxjs/Subscription';
|
import { Subscription } from 'rxjs/Subscription';
|
||||||
import { FuseMatchMedia } from '../../core/services/match-media.service';
|
import { FuseMatchMedia } from '../../core/services/match-media.service';
|
||||||
import { FuseNavbarService } from './navbar.service';
|
import { FuseNavbarService } from './navbar.service';
|
||||||
|
import { ObservableMedia } from '@angular/flex-layout';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector : 'fuse-navbar',
|
selector : 'fuse-navbar',
|
||||||
|
@ -13,39 +14,70 @@ import { FuseNavbarService } from './navbar.service';
|
||||||
export class FuseNavbarComponent implements OnInit, OnDestroy
|
export class FuseNavbarComponent implements OnInit, OnDestroy
|
||||||
{
|
{
|
||||||
@HostBinding('class.close') isClosed: boolean;
|
@HostBinding('class.close') isClosed: boolean;
|
||||||
@HostBinding('class.open') isOpened: boolean = !this.isClosed;
|
|
||||||
|
|
||||||
@HostBinding('class.folded') isFoldedActive: boolean;
|
@HostBinding('class.folded') isFoldedActive: boolean;
|
||||||
@HostBinding('class.folded-open') isFoldedOpen: boolean;
|
@HostBinding('class.folded-open') isFoldedOpen: boolean;
|
||||||
|
@HostBinding('class.initialized') initialized: boolean;
|
||||||
|
@Input('folded') foldedByDefault = false;
|
||||||
|
|
||||||
matchMediaWatcher: Subscription;
|
matchMediaWatcher: Subscription;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
private bodyEl: AppComponent,
|
private bodyEl: AppComponent,
|
||||||
private fuseMatchMedia: FuseMatchMedia,
|
private fuseMatchMedia: FuseMatchMedia,
|
||||||
private navBarService: FuseNavbarService
|
private navBarService: FuseNavbarService,
|
||||||
|
public media: ObservableMedia
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
navBarService.setNavBar(this);
|
navBarService.setNavBar(this);
|
||||||
this.isClosed = false;
|
|
||||||
this.isFoldedActive = false;
|
|
||||||
this.isFoldedOpen = false;
|
|
||||||
this.updateCssClasses();
|
|
||||||
|
|
||||||
this.matchMediaWatcher =
|
this.matchMediaWatcher =
|
||||||
this.fuseMatchMedia.onMediaChange
|
this.fuseMatchMedia.onMediaChange
|
||||||
.subscribe((mediaStep) => {
|
.subscribe((mediaStep) => {
|
||||||
if ( mediaStep === 'xs' )
|
setTimeout(() => {
|
||||||
{
|
|
||||||
this.closeBar();
|
if ( mediaStep === 'xs' )
|
||||||
}
|
{
|
||||||
else
|
this.closeBar();
|
||||||
{
|
this.deActivateFolded();
|
||||||
this.openBar();
|
}
|
||||||
}
|
else
|
||||||
|
{
|
||||||
|
this.openBar();
|
||||||
|
}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ngOnInit()
|
||||||
|
{
|
||||||
|
this.isClosed = false;
|
||||||
|
this.isFoldedActive = this.foldedByDefault;
|
||||||
|
this.isFoldedOpen = false;
|
||||||
|
this.initialized = false;
|
||||||
|
this.updateCssClasses();
|
||||||
|
|
||||||
|
setTimeout(() => {
|
||||||
|
this.initialized = true;
|
||||||
|
});
|
||||||
|
|
||||||
|
if ( this.media.isActive('xs') )
|
||||||
|
{
|
||||||
|
this.closeBar();
|
||||||
|
this.deActivateFolded();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( !this.foldedByDefault )
|
||||||
|
{
|
||||||
|
this.deActivateFolded();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this.activateFolded();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
openBar()
|
openBar()
|
||||||
{
|
{
|
||||||
this.isClosed = false;
|
this.isClosed = false;
|
||||||
|
@ -74,14 +106,25 @@ export class FuseNavbarComponent implements OnInit, OnDestroy
|
||||||
{
|
{
|
||||||
if ( !this.isFoldedActive )
|
if ( !this.isFoldedActive )
|
||||||
{
|
{
|
||||||
this.isFoldedActive = true;
|
this.activateFolded();
|
||||||
this.bodyEl.addClass('fuse-nav-bar-folded');
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this.isFoldedActive = false;
|
this.deActivateFolded();
|
||||||
this.bodyEl.removeClass('fuse-nav-bar-folded');
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
activateFolded()
|
||||||
|
{
|
||||||
|
this.isFoldedActive = true;
|
||||||
|
this.bodyEl.addClass('fuse-nav-bar-folded');
|
||||||
|
this.isFoldedOpen = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
deActivateFolded()
|
||||||
|
{
|
||||||
|
this.isFoldedActive = false;
|
||||||
|
this.bodyEl.removeClass('fuse-nav-bar-folded');
|
||||||
this.isFoldedOpen = false;
|
this.isFoldedOpen = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -111,11 +154,6 @@ export class FuseNavbarComponent implements OnInit, OnDestroy
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ngOnInit()
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
ngOnDestroy()
|
ngOnDestroy()
|
||||||
{
|
{
|
||||||
this.matchMediaWatcher.unsubscribe();
|
this.matchMediaWatcher.unsubscribe();
|
||||||
|
|
Loading…
Reference in New Issue
Block a user