mirror of
https://github.com/richard-loafle/fuse-angular.git
synced 2025-01-10 12:35:07 +00:00
Nav Collapse arrow icon and animation added
This commit is contained in:
parent
b7ef64154d
commit
829f570913
11
src/app/core/animations.ts
Normal file
11
src/app/core/animations.ts
Normal 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'))
|
||||||
|
]);
|
||||||
|
}
|
|
@ -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>
|
||||||
|
|
|
@ -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 {
|
||||||
> .children {
|
|
||||||
display: block;
|
.nav-link {
|
||||||
|
.collapse-arrow {
|
||||||
|
transform: rotate(90deg);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
> .children {
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user