Nav Collapse arrow icon and animation added

This commit is contained in:
mustafahlvc 2017-07-10 05:59:30 +03:00
parent b7ef64154d
commit 829f570913
6 changed files with 51 additions and 12 deletions

View File

@ -0,0 +1,11 @@
import {trigger, state, transition, animate, style} from '@angular/animations';
export class Animations
{
public static slideInOut = trigger('slideInOut', [
state('0', style({height: '0px', display: 'none'})),
state('1', style({height: '*', display: 'block'})),
transition('1 => 0', animate('300ms ease-out')),
transition('0 => 1', animate('300ms ease-in'))
]);
}

View File

@ -1,8 +1,9 @@
<a class="nav-link" md-ripple (click)="toggleOpen($event)"> <a class="nav-link" md-ripple (click)="toggleOpen($event)">
<md-icon *ngIf="item.icon">{{item.icon}}</md-icon> <md-icon class="nav-link-icon" *ngIf="item.icon">{{item.icon}}</md-icon>
<span>{{item.title}}</span> <span>{{item.title}}</span>
<md-icon class="collapse-arrow">keyboard_arrow_right</md-icon>
</a> </a>
<div class="children"> <div class="children" [@slideInOut]="isOpen">
<ng-container *ngFor="let item of item.children"> <ng-container *ngFor="let item of item.children">
<fuse-nav-item *ngIf="item.type=='nav-item'" [item]="item"></fuse-nav-item> <fuse-nav-item *ngIf="item.type=='nav-item'" [item]="item"></fuse-nav-item>
<fuse-nav-collapse *ngIf="item.type=='nav-collapse'" [item]="item"></fuse-nav-collapse> <fuse-nav-collapse *ngIf="item.type=='nav-collapse'" [item]="item"></fuse-nav-collapse>

View File

@ -1,12 +1,26 @@
:host { :host {
.nav-link {
.collapse-arrow {
transition: transform .3s ease-in-out, opacity .25s ease-in-out .1s;
transform: rotate(0);
}
}
> .children { > .children {
display: none; overflow: hidden;
} }
&.open { &.open {
.nav-link {
.collapse-arrow {
transform: rotate(90deg);
}
}
> .children { > .children {
display: block; }
}
} }
} }

View File

@ -1,17 +1,19 @@
import {Component, HostBinding, Input, OnInit} from '@angular/core'; import {Component, HostBinding, Input, OnInit} from '@angular/core';
import {NavigationService} from '../navigation.service'; import {NavigationService} from '../navigation.service';
import {NavigationEnd, Router} from '@angular/router'; import {NavigationEnd, Router} from '@angular/router';
import {Animations} from '../../core/animations';
@Component({ @Component({
selector : 'fuse-nav-collapse', selector : 'fuse-nav-collapse',
templateUrl: './nav-collapse.component.html', templateUrl: './nav-collapse.component.html',
styleUrls : ['./nav-collapse.component.scss'], styleUrls : ['./nav-collapse.component.scss'],
animations : [Animations.slideInOut]
}) })
export class NavCollapseComponent implements OnInit export class NavCollapseComponent implements OnInit
{ {
@Input() item: any; @Input() item: any;
@HostBinding('class') classes = 'nav-collapse nav-item'; @HostBinding('class') classes = 'nav-collapse nav-item';
@HostBinding('class.open') private isOpen = false; @HostBinding('class.open') public isOpen = false;
constructor(private navigationService: NavigationService, private router: Router) constructor(private navigationService: NavigationService, private router: Router)
{ {
@ -75,9 +77,7 @@ export class NavCollapseComponent implements OnInit
{ {
ev.preventDefault(); ev.preventDefault();
this.isOpen = !this.isOpen; this.isOpen = !this.isOpen;
// this.navigationService.onNavItemClicked.emit(this.item);
this.navigationService.onNavCollapseToggled.emit(this.item); this.navigationService.onNavCollapseToggled.emit(this.item);
console.log('toggleOpen');
} }
/** /**
@ -133,6 +133,11 @@ export class NavCollapseComponent implements OnInit
return false; return false;
} }
public isCollapsed(): boolean
{
return this.isOpen;
}
ngOnInit() ngOnInit()
{ {
} }

View File

@ -1,5 +1,5 @@
<a class="nav-link" md-ripple <a class="nav-link" md-ripple
[routerLink]="[item.url]" routerLinkActive="active"> [routerLink]="[item.url]" routerLinkActive="active">
<md-icon *ngIf="item.icon">{{item.icon}}</md-icon> <md-icon class="nav-link-icon" *ngIf="item.icon">{{item.icon}}</md-icon>
<span>{{item.title}}</span> <span>{{item.title}}</span>
</a> </a>

View File

@ -27,6 +27,10 @@
color: map_get($foreground, text); color: map_get($foreground, text);
cursor: pointer; cursor: pointer;
> span {
flex: 1;
}
&:hover { &:hover {
background-color: map-get($background, hover); background-color: map-get($background, hover);
} }
@ -42,18 +46,22 @@
background-color: mat-color($accent, default-contrast, 0.1); background-color: mat-color($accent, default-contrast, 0.1);
} }
&, .mat-icon { &, .nav-link-icon {
color: mat-color($accent, default-contrast); color: mat-color($accent, default-contrast);
} }
} }
.mat-icon { .nav-link-icon {
margin-right: 16px;
}
.nav-link-icon,
.collapse-arrow {
font-size: 16px; font-size: 16px;
width: 16px; width: 16px;
height: 16px; height: 16px;
line-height: 16px; line-height: 16px;
color: map_get($mat-light-theme-foreground, icon);; color: map_get($mat-light-theme-foreground, icon);;
margin-right: 16px;
} }
} }