This commit is contained in:
Sercan Yemen 2017-07-12 17:34:32 +03:00
parent a8844e8b46
commit 6f159f54c8
23 changed files with 433 additions and 163 deletions

View File

@ -1 +1,12 @@
<fuse-layout></fuse-layout> <md-sidenav-container>
<fuse-layout></fuse-layout>
<!-- QUICK PANEL -->
<md-sidenav id="quick-panel" #quickPanel [fuseMdSidenavHelper]="quickPanel" align="end">
quick-panel
</md-sidenav>
<!-- / QUICK PANEL -->
</md-sidenav-container>

View File

@ -1,25 +1,28 @@
import {BrowserModule} from '@angular/platform-browser'; import { BrowserModule } from '@angular/platform-browser';
import {NgModule} from '@angular/core'; import { NgModule } from '@angular/core';
import 'hammerjs'; import 'hammerjs';
import {BrowserAnimationsModule} from '@angular/platform-browser/animations'; import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import {AppComponent} from './app.component'; import { AppComponent } from './app.component';
import {RouterModule, Routes} from '@angular/router'; import { RouterModule, Routes } from '@angular/router';
import {LayoutComponent} from './core/components/layout/layout.component'; import { LayoutComponent } from './core/components/layout/layout.component';
import {MailModule} from './main/apps/mail/mail.module'; import { MailModule } from './main/apps/mail/mail.module';
import {ChatModule} from './main/apps/chat/chat.module'; import { ChatModule } from './main/apps/chat/chat.module';
import {ProjectModule} from './main/apps/dashboards/project/project.module'; import { ProjectModule } from './main/apps/dashboards/project/project.module';
import {CardedFullWidthModule} from './main/ui/page-layouts/carded/fullwidth/fullwidth.module'; import { CardedFullWidthModule } from './main/ui/page-layouts/carded/fullwidth/fullwidth.module';
import {LayoutService} from './core/services/layout.service'; import { LayoutService } from './core/services/layout.service';
import {NavbarComponent} from './core/components/layout/navbar/navbar.component'; import { NavbarComponent } from './core/components/layout/navbar/navbar.component';
import {ToolbarComponent} from './core/components/layout/toolbar/toolbar.component'; import { ToolbarComponent } from './core/components/layout/toolbar/toolbar.component';
import {NavigationModule} from './core/components/navigation/navigation.module'; import { NavigationModule } from './core/components/navigation/navigation.module';
import {NavigationService} from './core/components/navigation/navigation.service'; import { NavigationService } from './core/components/navigation/navigation.service';
import {SidenavComponent} from './core/components/sidenav/sidenav.component'; import { SidenavComponent } from './core/components/sidenav/sidenav.component';
import {FuseMatchMedia} from './core/services/match-media.service'; import { FuseMatchMedia } from './core/services/match-media.service';
import {NavbarToggleDirective} from './core/components/layout/navbar/navbar-toggle.directive'; import { NavbarToggleDirective } from './core/components/layout/navbar/navbar-toggle.directive';
import {NavbarService} from './core/components/layout/navbar/navbar.service'; import { NavbarService } from './core/components/layout/navbar/navbar.service';
import { ContentComponent } from './core/components/layout/content/content.component'; import { ContentComponent } from './core/components/layout/content/content.component';
import { SharedModule } from './core/modules/shared.module'; import { SharedModule } from './core/modules/shared.module';
import { FooterComponent } from './core/components/layout/footer/footer.component';
import { FuseMdSidenavHelperDirective, FuseMdSidenavTogglerDirective } from './core/directives/md-sidenav-helper/md-sidenav-helper.directive';
import { FuseMdSidenavHelperService } from './core/directives/md-sidenav-helper/md-sidenav-helper.service';
const appRoutes: Routes = [ const appRoutes: Routes = [
{ {
@ -36,7 +39,10 @@ const appRoutes: Routes = [
NavbarComponent, NavbarComponent,
SidenavComponent, SidenavComponent,
NavbarToggleDirective, NavbarToggleDirective,
ContentComponent FuseMdSidenavHelperDirective,
FuseMdSidenavTogglerDirective,
ContentComponent,
FooterComponent
], ],
imports : [ imports : [
SharedModule, SharedModule,
@ -49,7 +55,13 @@ const appRoutes: Routes = [
ProjectModule, ProjectModule,
CardedFullWidthModule CardedFullWidthModule
], ],
providers : [NavigationService, LayoutService, FuseMatchMedia, NavbarService], providers : [
NavigationService,
LayoutService,
FuseMatchMedia,
NavbarService,
FuseMdSidenavHelperService
],
bootstrap : [AppComponent] bootstrap : [AppComponent]
}) })
export class AppModule export class AppModule

View File

@ -0,0 +1,5 @@
<md-toolbar>
<span>Footer</span>
</md-toolbar>

View File

@ -0,0 +1,7 @@
:host {
&.above {
position: relative;
z-index: 99;
}
}

View File

@ -0,0 +1,15 @@
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'fuse-footer',
templateUrl: './footer.component.html',
styleUrls: ['./footer.component.scss']
})
export class FooterComponent implements OnInit {
constructor() { }
ngOnInit() {
}
}

View File

@ -1,11 +1,35 @@
<!-- TOOLBAR: Above --> <!-- TOOLBAR: Above -->
<ng-container *ngIf="layoutSettings.toolbar === 'above'"> <ng-container *ngIf="layoutSettings.toolbar === 'above'">
<fuse-toolbar></fuse-toolbar> <fuse-toolbar class="above"></fuse-toolbar>
</ng-container> </ng-container>
<!-- / TOOLBAR: Above --> <!-- / TOOLBAR: Above -->
<div id="wrapper"> <div id="wrapper">
<!-- NAVIGATION: None -->
<ng-container *ngIf="layoutSettings.navigation === 'none'">
<div class="content-wrapper">
<!-- TOOLBAR: Below -->
<ng-container *ngIf="layoutSettings.toolbar === 'below'">
<fuse-toolbar class="below"></fuse-toolbar>
</ng-container>
<!-- / TOOLBAR: Below -->
<fuse-content></fuse-content>
<!-- FOOTER: Below -->
<ng-container *ngIf="layoutSettings.footer === 'below'">
<fuse-footer class="below"></fuse-footer>
</ng-container>
<!-- / FOOTER: Below -->
</div>
</ng-container>
<!-- / NAVIGATION: None -->
<!-- NAVIGATION: Left --> <!-- NAVIGATION: Left -->
<ng-container *ngIf="layoutSettings.navigation === 'left'"> <ng-container *ngIf="layoutSettings.navigation === 'left'">
@ -13,15 +37,55 @@
<div class="content-wrapper"> <div class="content-wrapper">
<!-- TOOLBAR: Below -->
<ng-container *ngIf="layoutSettings.toolbar === 'below'"> <ng-container *ngIf="layoutSettings.toolbar === 'below'">
<fuse-toolbar></fuse-toolbar> <fuse-toolbar class="below"></fuse-toolbar>
</ng-container> </ng-container>
<!-- / TOOLBAR: Below -->
<fuse-content></fuse-content> <fuse-content></fuse-content>
<!-- FOOTER: Below -->
<ng-container *ngIf="layoutSettings.footer === 'below'">
<fuse-footer class="below"></fuse-footer>
</ng-container>
<!-- / FOOTER: Below -->
</div> </div>
</ng-container> </ng-container>
<!-- / NAVIGATION: Left --> <!-- / NAVIGATION: Left -->
<!-- NAVIGATION: Right -->
<ng-container *ngIf="layoutSettings.navigation === 'right'">
<div class="content-wrapper">
<!-- TOOLBAR: Below -->
<ng-container *ngIf="layoutSettings.toolbar === 'below'">
<fuse-toolbar class="below"></fuse-toolbar>
</ng-container>
<!-- / TOOLBAR: Below -->
<fuse-content></fuse-content>
<!-- FOOTER: Below -->
<ng-container *ngIf="layoutSettings.footer === 'below'">
<fuse-footer class="below"></fuse-footer>
</ng-container>
<!-- / FOOTER: Below -->
</div>
<fuse-navbar></fuse-navbar>
</ng-container>
<!-- / NAVIGATION: Right -->
</div> </div>
<!-- FOOTER: Above -->
<ng-container *ngIf="layoutSettings.footer === 'above'">
<fuse-footer class="above"></fuse-footer>
</ng-container>
<!-- FOOTER: Above -->

View File

@ -6,13 +6,16 @@
#wrapper { #wrapper {
display: flex; display: flex;
flex: 1;
.content-wrapper { .content-wrapper {
display: flex; display: flex;
flex-direction: column;
flex: 1; flex: 1;
fuse-content { fuse-content {
display: flex; display: flex;
flex-direction: row;
width: 100%; width: 100%;
height: 100%; height: 100%;
overflow-x: hidden; overflow-x: hidden;

View File

@ -8,7 +8,7 @@ import { LayoutService } from '../../services/layout.service';
}) })
export class LayoutComponent implements OnInit export class LayoutComponent implements OnInit
{ {
layoutSettings: { toolbar: any, navigation: any }; layoutSettings: { navigation: string, toolbar: string, footer: string };
constructor(private layoutService: LayoutService) constructor(private layoutService: LayoutService)
{ {

View File

@ -1,4 +1,4 @@
import {Directive, HostListener, Input} from '@angular/core'; import { Directive, HostListener, Input } from '@angular/core';
import {NavbarService} from './navbar.service'; import {NavbarService} from './navbar.service';
import {NavbarComponent} from './navbar.component'; import {NavbarComponent} from './navbar.component';
@ -16,7 +16,7 @@ export class NavbarToggleDirective
} }
@HostListener('click') @HostListener('click')
onMouseEnter() onClick()
{ {
if ( !this.navbar[this.fuseNavbar] ) if ( !this.navbar[this.fuseNavbar] )
{ {

View File

@ -3,6 +3,8 @@
:host { :host {
display: block; display: block;
width: 256px; width: 256px;
min-width: 256px;
max-width: 256px;
height: 100%; height: 100%;
background-color: #FFFFFF; background-color: #FFFFFF;
overflow-y: auto; overflow-y: auto;
@ -16,9 +18,9 @@
position: absolute; position: absolute;
&:not(.folded-open) { &:not(.folded-open) {
width: 64px !important; width: 64px;
min-width: 64px !important; min-width: 64px;
max-width: 64px !important; max-width: 64px;
} }
&.folded-open { &.folded-open {

View File

@ -1,9 +1,8 @@
import {AfterViewInit, Component, ElementRef, HostBinding, HostListener, OnDestroy, OnInit} from '@angular/core'; import { Component, HostBinding, HostListener, OnDestroy, OnInit } from '@angular/core';
import {AppComponent} from '../../../../app.component'; import { AppComponent } from '../../../../app.component';
import {Subscription} from 'rxjs/Subscription'; import { Subscription } from 'rxjs/Subscription';
import {MatchMedia, MediaChange, MediaMonitor, ObservableMedia} from '@angular/flex-layout'; import { FuseMatchMedia } from '../../../services/match-media.service';
import {FuseMatchMedia} from '../../../services/match-media.service'; import { NavbarService } from './navbar.service';
import {NavbarService} from './navbar.service';
@Component({ @Component({
selector : 'fuse-navbar', selector : 'fuse-navbar',
@ -20,11 +19,11 @@ export class NavbarComponent implements OnInit, OnDestroy
matchMediaWatcher: Subscription; matchMediaWatcher: Subscription;
constructor(private elementRef: ElementRef, constructor(
private bodyEl: AppComponent, private bodyEl: AppComponent,
private observableMedia: ObservableMedia,
private fuseMatchMedia: FuseMatchMedia, private fuseMatchMedia: FuseMatchMedia,
private navBarService: NavbarService) private navBarService: NavbarService
)
{ {
navBarService.setNavBar(this); navBarService.setNavBar(this);
this.isClosed = false; this.isClosed = false;
@ -34,7 +33,6 @@ export class NavbarComponent implements OnInit, OnDestroy
this.matchMediaWatcher = this.fuseMatchMedia.onMediaChange.subscribe((mediaStep) => this.matchMediaWatcher = this.fuseMatchMedia.onMediaChange.subscribe((mediaStep) =>
{ {
console.warn('Media step changed:', mediaStep);
if ( mediaStep === 'xs' ) if ( mediaStep === 'xs' )
{ {
this.closeBar(); this.closeBar();
@ -48,14 +46,12 @@ export class NavbarComponent implements OnInit, OnDestroy
openBar() openBar()
{ {
console.info('opened');
this.isClosed = false; this.isClosed = false;
this.updateCssClasses(); this.updateCssClasses();
} }
closeBar() closeBar()
{ {
console.info('closed');
this.isClosed = true; this.isClosed = true;
this.updateCssClasses(); this.updateCssClasses();
} }

View File

@ -6,4 +6,8 @@
<span>Toolbar</span> <span>Toolbar</span>
<button md-button class="toggle-button-navbar mat-icon-button" fuseMdSidenavToggler="quick-panel">
<md-icon>menu</md-icon>
</button>
</md-toolbar> </md-toolbar>

View File

@ -1,25 +0,0 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { NavCollapseComponent } from './nav-collapse.component';
describe('NavCollapseComponent', () => {
let component: NavCollapseComponent;
let fixture: ComponentFixture<NavCollapseComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ NavCollapseComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(NavCollapseComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should be created', () => {
expect(component).toBeTruthy();
});
});

View File

@ -1,25 +0,0 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { NavItemComponent } from './nav-item.component';
describe('NavItemComponent', () => {
let component: NavItemComponent;
let fixture: ComponentFixture<NavItemComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ NavItemComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(NavItemComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should be created', () => {
expect(component).toBeTruthy();
});
});

View File

@ -0,0 +1,44 @@
import { Directive, Input, OnInit, HostListener, ElementRef } from '@angular/core';
import { MdSidenav } from '@angular/material';
import { FuseMdSidenavHelperService } from 'app/core/directives/md-sidenav-helper/md-sidenav-helper.service';
@Directive({
selector: '[fuseMdSidenavHelper]'
})
export class FuseMdSidenavHelperDirective implements OnInit
{
@Input('fuseMdSidenavHelper') mdSidenavInstance: MdSidenav;
constructor(
private fuseMdSidenavService: FuseMdSidenavHelperService,
private elRef: ElementRef
)
{
}
ngOnInit()
{
this.fuseMdSidenavService.setSidenav(this.elRef.nativeElement.id, this.mdSidenavInstance);
}
}
@Directive({
selector: '[fuseMdSidenavToggler]'
})
export class FuseMdSidenavTogglerDirective
{
@Input('fuseMdSidenavToggler') id;
instance: MdSidenav;
constructor(private fuseMdSidenavService: FuseMdSidenavHelperService)
{
}
@HostListener('click')
onClick()
{
this.instance = this.fuseMdSidenavService.getSidenav(this.id);
this.instance.toggle();
}
}

View File

@ -0,0 +1,23 @@
import { Injectable } from '@angular/core';
import { MdSidenav } from '@angular/material';
@Injectable()
export class FuseMdSidenavHelperService
{
sidenavInstances: MdSidenav[];
constructor()
{
this.sidenavInstances = [];
}
setSidenav(id, instance)
{
this.sidenavInstances[id] = instance;
}
getSidenav(id)
{
return this.sidenavInstances[id];
}
}

View File

@ -4,10 +4,10 @@ import { NavigationStart, Router } from '@angular/router';
@Injectable() @Injectable()
export class LayoutService export class LayoutService
{ {
defaultSettings: { toolbar: string, navigation: string }; defaultSettings: { navigation: string, toolbar: string, footer: string };
settings: { toolbar: string, navigation: string }; settings: { navigation: string, toolbar: string, footer: string };
onSettingsChanged = new EventEmitter<{ toolbar: string, navigation: string }>(); onSettingsChanged = new EventEmitter<{ navigation: string, toolbar: string, footer: string }>();
/** /**
* @param router * @param router
@ -16,8 +16,9 @@ export class LayoutService
{ {
// Set the default settings // Set the default settings
this.defaultSettings = { this.defaultSettings = {
navigation: 'left', // 'right', 'left', 'top', false navigation: 'left', // 'right', 'left', 'top', none
toolbar : 'above' // 'above', 'below', false toolbar : 'above', // 'above', 'below', none
footer : 'above' // 'above', 'below', none
}; };
// Assign default settings at the init // Assign default settings at the init
@ -38,7 +39,7 @@ export class LayoutService
/** /**
* Get Settings * Get Settings
* @returns {{navigation: any, toolbar: any}} * @returns {{navigation: string, toolbar: string, footer: string}}
*/ */
getSettings() getSettings()
{ {

View File

@ -1,20 +1,15 @@
import { MediaChange, MediaMonitor, ObservableMedia } from '@angular/flex-layout'; import { MediaChange, ObservableMedia } from '@angular/flex-layout';
import { Observable } from 'rxjs/Observable'; import { Observable } from 'rxjs/Observable';
import { Observer } from 'rxjs/Observer'; import { Observer } from 'rxjs/Observer';
import { EventEmitter, Injectable } from '@angular/core'; import { Injectable } from '@angular/core';
import 'rxjs/add/operator/filter';
import { Subscription } from 'rxjs/Subscription';
@Injectable() @Injectable()
export class FuseMatchMedia export class FuseMatchMedia
{ {
activeMediaQuery: string; activeMediaQuery: string;
onMediaChange: Observable<string>; onMediaChange: Observable<string>;
// onMediaChange = new EventEmitter<string>();
watcher: Subscription;
constructor(private observableMedia: ObservableMedia, constructor(private observableMedia: ObservableMedia)
private mediaMonitor: MediaMonitor)
{ {
this.activeMediaQuery = ''; this.activeMediaQuery = '';
@ -22,56 +17,12 @@ export class FuseMatchMedia
{ {
this.observableMedia.subscribe((change: MediaChange) => this.observableMedia.subscribe((change: MediaChange) =>
{ {
if ( this.activeMediaQuery !== change.mqAlias ) if ( this.activeMediaQuery !== change.mqAlias )
{ {
this.activeMediaQuery = change.mqAlias; this.activeMediaQuery = change.mqAlias;
observer.next(this.activeMediaQuery); observer.next(this.activeMediaQuery);
console.warn('From observableMedia:', change.mqAlias);
} }
}); });
}); });
/*
this.mediaMonitor.observe('xs').subscribe((change: MediaChange) =>
{
console.warn('From mediaMonitor:', change);
if ( this.activeMediaQuery !== change.mqAlias )
{
// this.activeMediaQuery = change.mqAlias;
// this.onMediaChange.emit(this.activeMediaQuery);
}
});*/
/* this.observableMedia.subscribe((change: MediaChange) =>
{
console.warn('From observableMedia:', change.mqAlias);
if ( this.activeMediaQuery !== change.mqAlias )
{
this.activeMediaQuery = change.mqAlias;
this.onMediaChange.emit(this.activeMediaQuery);
}
});*/
/*this.observableMedia.asObservable()
.filter((change: MediaChange) => change.mqAlias === 'xs')
.subscribe(() =>
{
console.warn('From observableMedia:', this.activeMediaQuery);
this.onMediaChange.emit(this.activeMediaQuery);
});*/
/* this.watcher = this.observableMedia.subscribe((change: MediaChange) =>
{
this.activeMediaQuery = change ? `'${change.mqAlias}' = (${change.mediaQuery})` : '';
console.warn('From Watcher:', change.mqAlias);
});*/
} }
} }

View File

@ -1,3 +1,180 @@
<p> <p>
project works! project works!
</p> </p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>
<p>
project works!
</p>
<br><br>

View File

@ -1,4 +1,3 @@
:host { :host {
display: flex; padding: 32px;
flex: 1;
} }

View File

@ -1,4 +1,5 @@
import {Component, OnInit} from '@angular/core'; import { Component, OnInit } from '@angular/core';
import { LayoutService } from '../../../../core/services/layout.service';
@Component({ @Component({
selector : 'fuse-project', selector : 'fuse-project',
@ -7,9 +8,13 @@ import {Component, OnInit} from '@angular/core';
}) })
export class ProjectComponent implements OnInit export class ProjectComponent implements OnInit
{ {
constructor(private layoutService: LayoutService)
constructor()
{ {
this.layoutService.setSettings({
navigation: 'left',
toolbar : 'above',
footer : 'above'
});
} }
ngOnInit() ngOnInit()

View File

@ -1,5 +1,5 @@
import {Component, OnInit} from '@angular/core'; import { Component, OnInit } from '@angular/core';
import {LayoutService} from '../../../core/services/layout.service'; import { LayoutService } from '../../../core/services/layout.service';
@Component({ @Component({
selector : 'fuse-mail', selector : 'fuse-mail',
@ -12,8 +12,9 @@ export class MailComponent implements OnInit
constructor(private layoutService: LayoutService) constructor(private layoutService: LayoutService)
{ {
this.layoutService.setSettings({ this.layoutService.setSettings({
navigation: 'left',
toolbar : 'below', toolbar : 'below',
navigation: 'left' footer : 'below'
}); });
} }

View File

@ -117,8 +117,8 @@
"use-input-property-decorator": true, "use-input-property-decorator": true,
"use-output-property-decorator": true, "use-output-property-decorator": true,
"use-host-property-decorator": true, "use-host-property-decorator": true,
"no-input-rename": true, "no-input-rename": false,
"no-output-rename": true, "no-output-rename": false,
"use-life-cycle-interface": true, "use-life-cycle-interface": true,
"use-pipe-transform-interface": true, "use-pipe-transform-interface": true,
"component-class-suffix": true, "component-class-suffix": true,