mirror of
https://github.com/richard-loafle/fuse-angular.git
synced 2025-01-10 12:35:07 +00:00
Moved core into @fuse
+ New fuse sidebar component + Moved the navbar to the sidebar
This commit is contained in:
parent
e55a385858
commit
51bd636ba6
544
package-lock.json
generated
544
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
34
package.json
34
package.json
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "fuse2",
|
"name": "fuse2",
|
||||||
"version": "1.3.6",
|
"version": "1.3.7",
|
||||||
"license": "https://themeforest.net/licenses/terms/regular",
|
"license": "https://themeforest.net/licenses/terms/regular",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"ng": "ng",
|
"ng": "ng",
|
||||||
|
@ -19,19 +19,19 @@
|
||||||
"private": true,
|
"private": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@agm/core": "1.0.0-beta.2",
|
"@agm/core": "1.0.0-beta.2",
|
||||||
"@angular/animations": "5.2.3",
|
"@angular/animations": "5.2.4",
|
||||||
"@angular/cdk": "5.1.1",
|
"@angular/cdk": "5.2.0",
|
||||||
"@angular/common": "5.2.3",
|
"@angular/common": "5.2.4",
|
||||||
"@angular/compiler": "5.2.3",
|
"@angular/compiler": "5.2.4",
|
||||||
"@angular/core": "5.2.3",
|
"@angular/core": "5.2.4",
|
||||||
"@angular/flex-layout": "2.0.0-beta.12",
|
"@angular/flex-layout": "2.0.0-beta.12",
|
||||||
"@angular/forms": "5.2.3",
|
"@angular/forms": "5.2.4",
|
||||||
"@angular/http": "5.2.3",
|
"@angular/http": "5.2.4",
|
||||||
"@angular/material": "5.1.1",
|
"@angular/material": "5.2.0",
|
||||||
"@angular/material-moment-adapter": "5.1.1",
|
"@angular/material-moment-adapter": "5.2.0",
|
||||||
"@angular/platform-browser": "5.2.3",
|
"@angular/platform-browser": "5.2.4",
|
||||||
"@angular/platform-browser-dynamic": "5.2.3",
|
"@angular/platform-browser-dynamic": "5.2.4",
|
||||||
"@angular/router": "5.2.3",
|
"@angular/router": "5.2.4",
|
||||||
"@ngrx/effects": "5.0.0",
|
"@ngrx/effects": "5.0.0",
|
||||||
"@ngrx/router-store": "5.0.0",
|
"@ngrx/router-store": "5.0.0",
|
||||||
"@ngrx/store": "5.0.0",
|
"@ngrx/store": "5.0.0",
|
||||||
|
@ -61,13 +61,13 @@
|
||||||
"zone.js": "0.8.20"
|
"zone.js": "0.8.20"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@angular/cli": "1.6.7",
|
"@angular/cli": "1.6.8",
|
||||||
"@angular/compiler-cli": "5.2.3",
|
"@angular/compiler-cli": "5.2.4",
|
||||||
"@angular/language-service": "5.2.3",
|
"@angular/language-service": "5.2.4",
|
||||||
"@angularclass/hmr": "2.1.3",
|
"@angularclass/hmr": "2.1.3",
|
||||||
"@types/jasmine": "2.8.6",
|
"@types/jasmine": "2.8.6",
|
||||||
"@types/jasminewd2": "2.0.3",
|
"@types/jasminewd2": "2.0.3",
|
||||||
"@types/node": "6.0.96",
|
"@types/node": "6.0.98",
|
||||||
"codelyzer": "4.1.0",
|
"codelyzer": "4.1.0",
|
||||||
"jasmine-core": "2.8.0",
|
"jasmine-core": "2.8.0",
|
||||||
"jasmine-spec-reporter": "4.2.1",
|
"jasmine-spec-reporter": "4.2.1",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import { Component, EventEmitter, Input, OnChanges, OnInit, Output, ViewEncapsulation } from '@angular/core';
|
import { Component, EventEmitter, Input, OnChanges, OnInit, Output, ViewEncapsulation } from '@angular/core';
|
||||||
import { MatColors } from '../../matColors';
|
import { MatColors } from '../../matColors';
|
||||||
import { fuseAnimations } from '../../animations';
|
import { fuseAnimations } from '../../animations/index';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector : 'fuse-material-color-picker',
|
selector : 'fuse-material-color-picker',
|
|
@ -1,5 +1,5 @@
|
||||||
import { Component, HostBinding, HostListener, Input, OnDestroy } from '@angular/core';
|
import { Component, HostBinding, HostListener, Input, OnDestroy } from '@angular/core';
|
||||||
import { fuseAnimations } from '../../../../animations';
|
import { fuseAnimations } from '../../../../animations/index';
|
||||||
import { FuseConfigService } from '../../../../services/config.service';
|
import { FuseConfigService } from '../../../../services/config.service';
|
||||||
import { Subscription } from 'rxjs/Subscription';
|
import { Subscription } from 'rxjs/Subscription';
|
||||||
|
|
||||||
|
@ -11,7 +11,7 @@ import { Subscription } from 'rxjs/Subscription';
|
||||||
})
|
})
|
||||||
export class FuseNavHorizontalCollapseComponent implements OnDestroy
|
export class FuseNavHorizontalCollapseComponent implements OnDestroy
|
||||||
{
|
{
|
||||||
onSettingsChanged: Subscription;
|
onConfigChanged: Subscription;
|
||||||
fuseSettings: any;
|
fuseSettings: any;
|
||||||
isOpen = false;
|
isOpen = false;
|
||||||
|
|
||||||
|
@ -34,8 +34,8 @@ export class FuseNavHorizontalCollapseComponent implements OnDestroy
|
||||||
private fuseConfig: FuseConfigService
|
private fuseConfig: FuseConfigService
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
this.onSettingsChanged =
|
this.onConfigChanged =
|
||||||
this.fuseConfig.onSettingsChanged
|
this.fuseConfig.onConfigChanged
|
||||||
.subscribe(
|
.subscribe(
|
||||||
(newSettings) => {
|
(newSettings) => {
|
||||||
this.fuseSettings = newSettings;
|
this.fuseSettings = newSettings;
|
||||||
|
@ -45,6 +45,6 @@ export class FuseNavHorizontalCollapseComponent implements OnDestroy
|
||||||
|
|
||||||
ngOnDestroy()
|
ngOnDestroy()
|
||||||
{
|
{
|
||||||
this.onSettingsChanged.unsubscribe();
|
this.onConfigChanged.unsubscribe();
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
@import 'src/app/core/scss/fuse';
|
@import 'src/@fuse/scss/fuse';
|
||||||
|
|
||||||
#main-navigation {
|
#main-navigation {
|
||||||
margin: 0;
|
margin: 0;
|
|
@ -1,6 +1,6 @@
|
||||||
:host {
|
:host {
|
||||||
|
|
||||||
.folded:not(.folded-open) & {
|
.folded:not(.unfolded) & {
|
||||||
|
|
||||||
.nav-link {
|
.nav-link {
|
||||||
|
|
||||||
|
@ -19,6 +19,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.nav-link {
|
.nav-link {
|
||||||
|
|
||||||
.collapse-arrow {
|
.collapse-arrow {
|
||||||
transition: transform .3s ease-in-out, opacity .25s ease-in-out .1s;
|
transition: transform .3s ease-in-out, opacity .25s ease-in-out .1s;
|
||||||
transform: rotate(0);
|
transform: rotate(0);
|
|
@ -1,7 +1,7 @@
|
||||||
import { Component, HostBinding, Input, OnInit } from '@angular/core';
|
import { Component, HostBinding, Input, OnInit } from '@angular/core';
|
||||||
import { FuseNavigationService } from '../../navigation.service';
|
import { FuseNavigationService } from '../../navigation.service';
|
||||||
import { NavigationEnd, Router } from '@angular/router';
|
import { NavigationEnd, Router } from '@angular/router';
|
||||||
import { fuseAnimations } from '../../../../animations';
|
import { fuseAnimations } from '../../../../animations/index';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector : 'fuse-nav-vertical-collapse',
|
selector : 'fuse-nav-vertical-collapse',
|
|
@ -1,6 +1,6 @@
|
||||||
:host {
|
:host {
|
||||||
|
|
||||||
.folded:not(.folded-open) & {
|
.folded:not(.unfolded) & {
|
||||||
|
|
||||||
> .group-title {
|
> .group-title {
|
||||||
align-items: center;
|
align-items: center;
|
|
@ -1,6 +1,6 @@
|
||||||
:host {
|
:host {
|
||||||
|
|
||||||
.folded:not(.folded-open) & {
|
.folded:not(.unfolded) & {
|
||||||
|
|
||||||
.nav-link {
|
.nav-link {
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
@import "src/app/core/scss/fuse";
|
@import "src/@fuse/scss/fuse";
|
||||||
|
|
||||||
:host {
|
:host {
|
||||||
|
|
|
@ -12,15 +12,15 @@ export class FuseSearchBarComponent implements OnInit
|
||||||
collapsed: boolean;
|
collapsed: boolean;
|
||||||
toolbarColor: string;
|
toolbarColor: string;
|
||||||
@Output() onInput: EventEmitter<any> = new EventEmitter();
|
@Output() onInput: EventEmitter<any> = new EventEmitter();
|
||||||
onSettingsChanged: Subscription;
|
onConfigChanged: Subscription;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
private fuseConfig: FuseConfigService
|
private fuseConfig: FuseConfigService
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
this.collapsed = true;
|
this.collapsed = true;
|
||||||
this.onSettingsChanged =
|
this.onConfigChanged =
|
||||||
this.fuseConfig.onSettingsChanged
|
this.fuseConfig.onConfigChanged
|
||||||
.subscribe(
|
.subscribe(
|
||||||
(newSettings) => {
|
(newSettings) => {
|
||||||
this.toolbarColor = newSettings.colorClasses.toolbar;
|
this.toolbarColor = newSettings.colorClasses.toolbar;
|
|
@ -1,4 +1,4 @@
|
||||||
@import 'src/app/core/scss/fuse';
|
@import 'src/@fuse/scss/fuse';
|
||||||
|
|
||||||
:host {
|
:host {
|
||||||
|
|
|
@ -20,7 +20,7 @@ export class FuseShortcutsComponent implements OnInit, OnDestroy
|
||||||
mobileShortcutsPanelActive = false;
|
mobileShortcutsPanelActive = false;
|
||||||
toolbarColor: string;
|
toolbarColor: string;
|
||||||
matchMediaSubscription: Subscription;
|
matchMediaSubscription: Subscription;
|
||||||
onSettingsChanged: Subscription;
|
onConfigChanged: Subscription;
|
||||||
|
|
||||||
@ViewChild('searchInput') searchInputField;
|
@ViewChild('searchInput') searchInputField;
|
||||||
@ViewChild('shortcuts') shortcutsEl: ElementRef;
|
@ViewChild('shortcuts') shortcutsEl: ElementRef;
|
||||||
|
@ -36,8 +36,8 @@ export class FuseShortcutsComponent implements OnInit, OnDestroy
|
||||||
{
|
{
|
||||||
this.filteredNavigationItems = this.navigationItems = this.fuseNavigationService.getFlatNavigation();
|
this.filteredNavigationItems = this.navigationItems = this.fuseNavigationService.getFlatNavigation();
|
||||||
|
|
||||||
this.onSettingsChanged =
|
this.onConfigChanged =
|
||||||
this.fuseConfig.onSettingsChanged
|
this.fuseConfig.onConfigChanged
|
||||||
.subscribe(
|
.subscribe(
|
||||||
(newSettings) => {
|
(newSettings) => {
|
||||||
this.toolbarColor = newSettings.colorClasses.toolbar;
|
this.toolbarColor = newSettings.colorClasses.toolbar;
|
1
src/@fuse/components/sidebar/sidebar.component.html
Normal file
1
src/@fuse/components/sidebar/sidebar.component.html
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<ng-content></ng-content>
|
59
src/@fuse/components/sidebar/sidebar.component.scss
Normal file
59
src/@fuse/components/sidebar/sidebar.component.scss
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
fuse-sidebar {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
flex: 1 0 auto;
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
bottom: 0;
|
||||||
|
overflow: hidden;
|
||||||
|
width: 280px;
|
||||||
|
min-width: 280px;
|
||||||
|
max-width: 280px;
|
||||||
|
z-index: 1000;
|
||||||
|
transition-property: transform, width, min-width, max-width;
|
||||||
|
transition-duration: 150ms;
|
||||||
|
transition-timing-function: ease-in-out;
|
||||||
|
box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.35);
|
||||||
|
|
||||||
|
&.left-aligned {
|
||||||
|
left: 0;
|
||||||
|
transform: translateX(-100%);
|
||||||
|
}
|
||||||
|
|
||||||
|
&.right-aligned {
|
||||||
|
right: 0;
|
||||||
|
transform: translateX(100%);
|
||||||
|
}
|
||||||
|
|
||||||
|
&.open {
|
||||||
|
transform: translateX(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
&.locked-open {
|
||||||
|
position: relative !important;
|
||||||
|
transform: translateX(0) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.folded {
|
||||||
|
position: absolute !important;
|
||||||
|
top: 0;
|
||||||
|
bottom: 0;
|
||||||
|
|
||||||
|
&:not(.unfolded) {
|
||||||
|
width: 64px;
|
||||||
|
min-width: 64px;
|
||||||
|
max-width: 64px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.fuse-sidebar-overlay {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
right: 0;
|
||||||
|
z-index: 3;
|
||||||
|
background-color: rgba(0, 0, 0, 0.6);
|
||||||
|
opacity: 0;
|
||||||
|
}
|
368
src/@fuse/components/sidebar/sidebar.component.ts
Normal file
368
src/@fuse/components/sidebar/sidebar.component.ts
Normal file
|
@ -0,0 +1,368 @@
|
||||||
|
import { Component, ElementRef, HostBinding, HostListener, Inject, Input, OnDestroy, OnInit, Renderer2, ViewEncapsulation } from '@angular/core';
|
||||||
|
import { animate, AnimationBuilder, AnimationPlayer, style } from '@angular/animations';
|
||||||
|
import { ObservableMedia } from '@angular/flex-layout';
|
||||||
|
import { Subscription } from 'rxjs/Subscription';
|
||||||
|
|
||||||
|
import { FuseSidebarService } from './sidebar.service';
|
||||||
|
import { FuseMatchMedia } from '@fuse/services/match-media.service';
|
||||||
|
import { DOCUMENT } from '@angular/common';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector : 'fuse-sidebar',
|
||||||
|
templateUrl : './sidebar.component.html',
|
||||||
|
styleUrls : ['./sidebar.component.scss'],
|
||||||
|
encapsulation: ViewEncapsulation.None
|
||||||
|
})
|
||||||
|
export class FuseSidebarComponent implements OnInit, OnDestroy
|
||||||
|
{
|
||||||
|
// Name
|
||||||
|
@Input()
|
||||||
|
name: string;
|
||||||
|
|
||||||
|
// Align
|
||||||
|
@Input()
|
||||||
|
align: string;
|
||||||
|
|
||||||
|
// Open
|
||||||
|
@HostBinding('class.open')
|
||||||
|
opened: boolean;
|
||||||
|
|
||||||
|
// Locked Open
|
||||||
|
@Input()
|
||||||
|
lockedOpen: string;
|
||||||
|
|
||||||
|
// isLockedOpen
|
||||||
|
@HostBinding('class.locked-open')
|
||||||
|
isLockedOpen: boolean;
|
||||||
|
|
||||||
|
// Folded
|
||||||
|
@HostBinding('class.folded')
|
||||||
|
@Input()
|
||||||
|
folded: boolean;
|
||||||
|
|
||||||
|
// Folded unfolded
|
||||||
|
@HostBinding('class.unfolded')
|
||||||
|
unfolded: boolean;
|
||||||
|
|
||||||
|
// Private
|
||||||
|
private _wasActive: boolean;
|
||||||
|
private _backdrop: HTMLElement | null = null;
|
||||||
|
private _player: AnimationPlayer;
|
||||||
|
private _matchMediaWatcher: Subscription;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* @param renderer
|
||||||
|
* @param elementRef
|
||||||
|
* @param animationBuilder
|
||||||
|
* @param sidebarService
|
||||||
|
* @param matchMedia
|
||||||
|
* @param media
|
||||||
|
* @param document
|
||||||
|
*/
|
||||||
|
constructor(
|
||||||
|
private renderer: Renderer2,
|
||||||
|
private elementRef: ElementRef,
|
||||||
|
private animationBuilder: AnimationBuilder,
|
||||||
|
private sidebarService: FuseSidebarService,
|
||||||
|
private matchMedia: FuseMatchMedia,
|
||||||
|
private media: ObservableMedia,
|
||||||
|
@Inject(DOCUMENT) private document: any
|
||||||
|
)
|
||||||
|
{
|
||||||
|
// Set the defaults
|
||||||
|
this.opened = false;
|
||||||
|
this.folded = false;
|
||||||
|
this.align = 'left';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* On init
|
||||||
|
*/
|
||||||
|
ngOnInit(): void
|
||||||
|
{
|
||||||
|
// Register the sidebar
|
||||||
|
this.sidebarService.register(this.name, this);
|
||||||
|
|
||||||
|
// Setup alignment
|
||||||
|
this._setupAlignment();
|
||||||
|
|
||||||
|
// Setup lockedOpen
|
||||||
|
this._setupLockedOpen();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* On destroy
|
||||||
|
*/
|
||||||
|
ngOnDestroy(): void
|
||||||
|
{
|
||||||
|
// Unregister the sidebar
|
||||||
|
this.sidebarService.unregister(this.name);
|
||||||
|
|
||||||
|
// Unregister the media watcher
|
||||||
|
this._matchMediaWatcher.unsubscribe();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setup the alignment
|
||||||
|
*
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
private _setupAlignment(): void
|
||||||
|
{
|
||||||
|
if ( this.align === 'left' )
|
||||||
|
{
|
||||||
|
this.renderer.addClass(this.elementRef.nativeElement, 'left-aligned');
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this.renderer.addClass(this.elementRef.nativeElement, 'right-aligned');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setup the lockedOpen handler
|
||||||
|
*
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
private _setupLockedOpen(): void
|
||||||
|
{
|
||||||
|
// Return if the lockedOpen wasn't set
|
||||||
|
if ( !this.lockedOpen )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set the wasActive for the first time
|
||||||
|
this._wasActive = false;
|
||||||
|
|
||||||
|
// Act on every media change
|
||||||
|
this._matchMediaWatcher =
|
||||||
|
|
||||||
|
this.matchMedia.onMediaChange.subscribe(() => {
|
||||||
|
|
||||||
|
// Get the active status
|
||||||
|
const isActive = this.media.isActive(this.lockedOpen);
|
||||||
|
|
||||||
|
// If the both status are the same, don't act
|
||||||
|
if ( this._wasActive === isActive )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Store the new active status
|
||||||
|
this._wasActive = isActive;
|
||||||
|
|
||||||
|
// Activate the lockedOpen
|
||||||
|
if ( isActive )
|
||||||
|
{
|
||||||
|
// Set the lockedOpen status
|
||||||
|
this.isLockedOpen = true;
|
||||||
|
}
|
||||||
|
// De-Activate the lockedOpen
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Set the lockedOpen status
|
||||||
|
this.isLockedOpen = false;
|
||||||
|
|
||||||
|
// Unfold the sidebar in case if it was folded
|
||||||
|
this.unfold();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Open the sidebar
|
||||||
|
*/
|
||||||
|
open(): void
|
||||||
|
{
|
||||||
|
if ( this.opened || this.isLockedOpen )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Show the backdrop
|
||||||
|
this.showBackdrop();
|
||||||
|
|
||||||
|
// Set the opened status
|
||||||
|
this.opened = true;
|
||||||
|
|
||||||
|
// Add a css class to the body
|
||||||
|
this.renderer.addClass(this.document.body, 'fuse-sidebar-opened');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Close the sidebar
|
||||||
|
*/
|
||||||
|
close(): void
|
||||||
|
{
|
||||||
|
if ( !this.opened )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hide the backdrop
|
||||||
|
this.hideBackdrop();
|
||||||
|
|
||||||
|
// Set the opened status
|
||||||
|
this.opened = false;
|
||||||
|
|
||||||
|
// Remove the css class from the body
|
||||||
|
this.renderer.removeClass(this.document.body, 'fuse-sidebar-opened');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Toggle open/close the sidebar
|
||||||
|
*/
|
||||||
|
toggleOpen(): void
|
||||||
|
{
|
||||||
|
if ( this.opened )
|
||||||
|
{
|
||||||
|
this.close();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this.open();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mouseenter
|
||||||
|
*/
|
||||||
|
@HostListener('mouseenter')
|
||||||
|
onMouseEnter(): void
|
||||||
|
{
|
||||||
|
// Only work if the sidebar is folded
|
||||||
|
if ( !this.folded )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unfold the sidebar temporarily
|
||||||
|
this.unfolded = true;
|
||||||
|
|
||||||
|
// Add a css class to the body
|
||||||
|
this.renderer.addClass(this.document.body, 'fuse-sidebar-folded-unfolded');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mouseleave
|
||||||
|
*/
|
||||||
|
@HostListener('mouseleave')
|
||||||
|
onMouseLeave(): void
|
||||||
|
{
|
||||||
|
// Only work if the sidebar is folded
|
||||||
|
if ( !this.folded )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fold the sidebar back
|
||||||
|
this.unfolded = false;
|
||||||
|
|
||||||
|
// Remove the css class from the body
|
||||||
|
this.renderer.removeClass(this.document.body, 'fuse-sidebar-folded-unfolded');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fold the sidebar permanently
|
||||||
|
*/
|
||||||
|
fold(): void
|
||||||
|
{
|
||||||
|
this.folded = true;
|
||||||
|
|
||||||
|
// Add a css class to the body
|
||||||
|
this.renderer.addClass(this.document.body, 'fuse-sidebar-folded');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unfold the sidebar permanently
|
||||||
|
*/
|
||||||
|
unfold(): void
|
||||||
|
{
|
||||||
|
this.folded = false;
|
||||||
|
|
||||||
|
// Remove the css class from the body
|
||||||
|
this.renderer.removeClass(this.document.body, 'fuse-sidebar-folded');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Toggle the sidebar fold/unfold permanently
|
||||||
|
*/
|
||||||
|
toggleFold(): void
|
||||||
|
{
|
||||||
|
if ( this.folded )
|
||||||
|
{
|
||||||
|
this.unfold();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this.fold();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Show the backdrop
|
||||||
|
*/
|
||||||
|
showBackdrop(): void
|
||||||
|
{
|
||||||
|
// Create the backdrop element
|
||||||
|
this._backdrop = this.renderer.createElement('div');
|
||||||
|
|
||||||
|
// Add a class to the backdrop element
|
||||||
|
this._backdrop.classList.add('fuse-sidebar-overlay');
|
||||||
|
|
||||||
|
// Append the backdrop to the parent of the sidebar
|
||||||
|
this.renderer.appendChild(this.elementRef.nativeElement.parentElement, this._backdrop);
|
||||||
|
|
||||||
|
// Create the enter animation and attach it to the player
|
||||||
|
this._player =
|
||||||
|
this.animationBuilder
|
||||||
|
.build([
|
||||||
|
animate('300ms ease', style({opacity: 1}))
|
||||||
|
]).create(this._backdrop);
|
||||||
|
|
||||||
|
// Play the animation
|
||||||
|
this._player.play();
|
||||||
|
|
||||||
|
// Add an event listener to the overlay
|
||||||
|
this._backdrop.addEventListener('click', () => {
|
||||||
|
this.close();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hide the backdrop
|
||||||
|
*/
|
||||||
|
hideBackdrop(): void
|
||||||
|
{
|
||||||
|
if ( !this._backdrop )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the leave animation and attach it to the player
|
||||||
|
this._player =
|
||||||
|
this.animationBuilder
|
||||||
|
.build([
|
||||||
|
animate('300ms ease', style({opacity: 0}))
|
||||||
|
]).create(this._backdrop);
|
||||||
|
|
||||||
|
// Play the animation
|
||||||
|
this._player.play();
|
||||||
|
|
||||||
|
// Once the animation is done...
|
||||||
|
this._player.onDone(() => {
|
||||||
|
|
||||||
|
// If the backdrop still exists...
|
||||||
|
if ( this._backdrop )
|
||||||
|
{
|
||||||
|
// Remove the backdrop
|
||||||
|
this._backdrop.parentNode.removeChild(this._backdrop);
|
||||||
|
this._backdrop = null;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
19
src/@fuse/components/sidebar/sidebar.module.ts
Normal file
19
src/@fuse/components/sidebar/sidebar.module.ts
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
import { NgModule } from '@angular/core';
|
||||||
|
|
||||||
|
import { FuseSidebarComponent } from './sidebar.component';
|
||||||
|
import { FuseSidebarService } from './sidebar.service';
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
declarations: [
|
||||||
|
FuseSidebarComponent
|
||||||
|
],
|
||||||
|
exports : [
|
||||||
|
FuseSidebarComponent
|
||||||
|
],
|
||||||
|
providers : [
|
||||||
|
FuseSidebarService
|
||||||
|
]
|
||||||
|
})
|
||||||
|
export class FuseSidebarModule
|
||||||
|
{
|
||||||
|
}
|
74
src/@fuse/components/sidebar/sidebar.service.ts
Normal file
74
src/@fuse/components/sidebar/sidebar.service.ts
Normal file
|
@ -0,0 +1,74 @@
|
||||||
|
import { Injectable } from '@angular/core';
|
||||||
|
|
||||||
|
import { FuseSidebarComponent } from './sidebar.component';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class FuseSidebarService
|
||||||
|
{
|
||||||
|
// Private
|
||||||
|
private _registry: { [key: string]: FuseSidebarComponent } = {};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*/
|
||||||
|
constructor()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add the sidebar to the registry
|
||||||
|
*
|
||||||
|
* @param key
|
||||||
|
* @param sidebar
|
||||||
|
*/
|
||||||
|
register(key, sidebar): void
|
||||||
|
{
|
||||||
|
// Check if the key already being used
|
||||||
|
if ( this._registry[key] )
|
||||||
|
{
|
||||||
|
console.error(`The sidebar with the key '${key}' already exists. Either unregister it first or use a unique key.`);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add to the registry
|
||||||
|
this._registry[key] = sidebar;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the sidebar from the registry
|
||||||
|
*
|
||||||
|
* @param key
|
||||||
|
*/
|
||||||
|
unregister(key): void
|
||||||
|
{
|
||||||
|
// Check if the sidebar exists
|
||||||
|
if ( !this._registry[key] )
|
||||||
|
{
|
||||||
|
console.error(`The sidebar with the key '${key}' doesn't exist in the registry.`);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unregister the sidebar
|
||||||
|
delete this._registry[key];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the sidebar with the given key
|
||||||
|
*
|
||||||
|
* @param key
|
||||||
|
*/
|
||||||
|
getSidebar(key): any
|
||||||
|
{
|
||||||
|
// Check if the sidebar exists
|
||||||
|
if ( !this._registry[key] )
|
||||||
|
{
|
||||||
|
console.error(`The sidebar with the key '${key}' doesn't exist in the registry.`);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return the sidebar
|
||||||
|
return this._registry[key];
|
||||||
|
}
|
||||||
|
}
|
|
@ -13,7 +13,7 @@
|
||||||
<div class="theme-options-panel-inner" fxLayout="column" fxLayoutAlign="start start">
|
<div class="theme-options-panel-inner" fxLayout="column" fxLayoutAlign="start start">
|
||||||
|
|
||||||
<h3>Navigation:</h3>
|
<h3>Navigation:</h3>
|
||||||
<mat-radio-group [(ngModel)]="fuseSettings.layout.navigation" (ngModelChange)="onSettingsChange()"
|
<mat-radio-group [(ngModel)]="config.layout.navigation" (ngModelChange)="onSettingsChange()"
|
||||||
fxLayout="column" fxLayout.gt-xs="row" fxLayoutAlign="start start" fxLayoutWrap>
|
fxLayout="column" fxLayout.gt-xs="row" fxLayoutAlign="start start" fxLayoutWrap>
|
||||||
<mat-radio-button class="mr-8 mb-8" value="top">Top</mat-radio-button>
|
<mat-radio-button class="mr-8 mb-8" value="top">Top</mat-radio-button>
|
||||||
<mat-radio-button class="mr-8 mb-8" value="left">Left</mat-radio-button>
|
<mat-radio-button class="mr-8 mb-8" value="left">Left</mat-radio-button>
|
||||||
|
@ -22,13 +22,13 @@
|
||||||
</mat-radio-group>
|
</mat-radio-group>
|
||||||
|
|
||||||
<h3>Navigation Fold (for vertical navigation):</h3>
|
<h3>Navigation Fold (for vertical navigation):</h3>
|
||||||
<mat-slide-toggle [(ngModel)]="fuseSettings.layout.navigationFolded"
|
<mat-slide-toggle [(ngModel)]="config.layout.navigationFolded"
|
||||||
(change)="onSettingsChange()">
|
(change)="onSettingsChange()">
|
||||||
Folded
|
Folded
|
||||||
</mat-slide-toggle>
|
</mat-slide-toggle>
|
||||||
|
|
||||||
<h3 class="mt-24">Toolbar:</h3>
|
<h3 class="mt-24">Toolbar:</h3>
|
||||||
<mat-radio-group [(ngModel)]="fuseSettings.layout.toolbar" (ngModelChange)="onSettingsChange()"
|
<mat-radio-group [(ngModel)]="config.layout.toolbar" (ngModelChange)="onSettingsChange()"
|
||||||
fxLayout="column" fxLayout.gt-xs="row" fxLayoutAlign="start start" fxLayoutWrap>
|
fxLayout="column" fxLayout.gt-xs="row" fxLayoutAlign="start start" fxLayoutWrap>
|
||||||
<mat-radio-button class="mr-8 mb-8" value="below">Below</mat-radio-button>
|
<mat-radio-button class="mr-8 mb-8" value="below">Below</mat-radio-button>
|
||||||
<mat-radio-button class="mr-8 mb-8" value="above">Above</mat-radio-button>
|
<mat-radio-button class="mr-8 mb-8" value="above">Above</mat-radio-button>
|
||||||
|
@ -36,7 +36,7 @@
|
||||||
</mat-radio-group>
|
</mat-radio-group>
|
||||||
|
|
||||||
<h3 class="mt-24">Footer:</h3>
|
<h3 class="mt-24">Footer:</h3>
|
||||||
<mat-radio-group [(ngModel)]="fuseSettings.layout.footer" (ngModelChange)="onSettingsChange()"
|
<mat-radio-group [(ngModel)]="config.layout.footer" (ngModelChange)="onSettingsChange()"
|
||||||
fxLayout="column" fxLayout.gt-xs="row" fxLayoutAlign="start start" fxLayoutWrap>
|
fxLayout="column" fxLayout.gt-xs="row" fxLayoutAlign="start start" fxLayoutWrap>
|
||||||
<mat-radio-button class="mr-8 mb-8" value="below">Below</mat-radio-button>
|
<mat-radio-button class="mr-8 mb-8" value="below">Below</mat-radio-button>
|
||||||
<mat-radio-button class="mr-8 mb-8" value="above">Above</mat-radio-button>
|
<mat-radio-button class="mr-8 mb-8" value="above">Above</mat-radio-button>
|
||||||
|
@ -44,7 +44,7 @@
|
||||||
</mat-radio-group>
|
</mat-radio-group>
|
||||||
|
|
||||||
<h3 class="mt-24">Layout Mode:</h3>
|
<h3 class="mt-24">Layout Mode:</h3>
|
||||||
<mat-radio-group [(ngModel)]="fuseSettings.layout.mode" (ngModelChange)="onSettingsChange()"
|
<mat-radio-group [(ngModel)]="config.layout.mode" (ngModelChange)="onSettingsChange()"
|
||||||
fxLayout="column" fxLayout.gt-xs="row" fxLayoutAlign="start start" fxLayoutWrap>
|
fxLayout="column" fxLayout.gt-xs="row" fxLayoutAlign="start start" fxLayoutWrap>
|
||||||
<mat-radio-button class="mr-8 mb-8" value="boxed">Boxed</mat-radio-button>
|
<mat-radio-button class="mr-8 mb-8" value="boxed">Boxed</mat-radio-button>
|
||||||
<mat-radio-button class="mr-8 mb-8" value="fullwidth">Fullwidth</mat-radio-button>
|
<mat-radio-button class="mr-8 mb-8" value="fullwidth">Fullwidth</mat-radio-button>
|
||||||
|
@ -57,19 +57,19 @@
|
||||||
|
|
||||||
<div fxFlex fxLayout="row" fxLayoutAlign="space-between center">
|
<div fxFlex fxLayout="row" fxLayoutAlign="space-between center">
|
||||||
<h4 class="mr-8">Toolbar Color</h4>
|
<h4 class="mr-8">Toolbar Color</h4>
|
||||||
<fuse-material-color-picker [(selectedClass)]="fuseSettings.colorClasses.toolbar"
|
<fuse-material-color-picker [(selectedClass)]="config.colorClasses.toolbar"
|
||||||
(onValueChange)="onSettingsChange()"></fuse-material-color-picker>
|
(onValueChange)="onSettingsChange()"></fuse-material-color-picker>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div fxFlex fxLayout="row" fxLayoutAlign="space-between center">
|
<div fxFlex fxLayout="row" fxLayoutAlign="space-between center">
|
||||||
<h4 class="mr-8">Navigation Bar Color</h4>
|
<h4 class="mr-8">Navigation Bar Color</h4>
|
||||||
<fuse-material-color-picker [(selectedClass)]="fuseSettings.colorClasses.navbar"
|
<fuse-material-color-picker [(selectedClass)]="config.colorClasses.navbar"
|
||||||
(onValueChange)="onSettingsChange()"></fuse-material-color-picker>
|
(onValueChange)="onSettingsChange()"></fuse-material-color-picker>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div fxFlex fxLayout="row" fxLayoutAlign="space-between center">
|
<div fxFlex fxLayout="row" fxLayoutAlign="space-between center">
|
||||||
<h4 class="mr-8">Footer Color</h4>
|
<h4 class="mr-8">Footer Color</h4>
|
||||||
<fuse-material-color-picker [(selectedClass)]="fuseSettings.colorClasses.footer"
|
<fuse-material-color-picker [(selectedClass)]="config.colorClasses.footer"
|
||||||
(onValueChange)="onSettingsChange()"></fuse-material-color-picker>
|
(onValueChange)="onSettingsChange()"></fuse-material-color-picker>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -79,7 +79,7 @@
|
||||||
|
|
||||||
<h3>Router Animation:</h3>
|
<h3>Router Animation:</h3>
|
||||||
<mat-form-field class="w-100-p">
|
<mat-form-field class="w-100-p">
|
||||||
<mat-select class="p-0" [(ngModel)]="fuseSettings.routerAnimation">
|
<mat-select class="p-0" [(ngModel)]="config.routerAnimation">
|
||||||
<mat-option value="none">
|
<mat-option value="none">
|
||||||
None
|
None
|
||||||
</mat-option>
|
</mat-option>
|
|
@ -1,4 +1,4 @@
|
||||||
@import "src/app/core/scss/fuse";
|
@import "src/@fuse/scss/fuse";
|
||||||
|
|
||||||
@keyframes rotating {
|
@keyframes rotating {
|
||||||
from {
|
from {
|
|
@ -2,7 +2,7 @@ import { Component, ElementRef, HostBinding, OnDestroy, OnInit, Renderer2, ViewC
|
||||||
import { style, animate, AnimationBuilder, AnimationPlayer } from '@angular/animations';
|
import { style, animate, AnimationBuilder, AnimationPlayer } from '@angular/animations';
|
||||||
import { Subscription } from 'rxjs/Subscription';
|
import { Subscription } from 'rxjs/Subscription';
|
||||||
import { FuseConfigService } from '../../services/config.service';
|
import { FuseConfigService } from '../../services/config.service';
|
||||||
import { fuseAnimations } from '../../animations';
|
import { fuseAnimations } from '../../animations/index';
|
||||||
import { FuseNavigationService } from '../navigation/navigation.service';
|
import { FuseNavigationService } from '../navigation/navigation.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -18,9 +18,9 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy
|
||||||
@ViewChild('overlay') overlay: ElementRef;
|
@ViewChild('overlay') overlay: ElementRef;
|
||||||
|
|
||||||
public player: AnimationPlayer;
|
public player: AnimationPlayer;
|
||||||
fuseSettings: any;
|
config: any;
|
||||||
|
|
||||||
onSettingsChanged: Subscription;
|
onConfigChanged: Subscription;
|
||||||
|
|
||||||
@HostBinding('class.bar-closed') barClosed: boolean;
|
@HostBinding('class.bar-closed') barClosed: boolean;
|
||||||
|
|
||||||
|
@ -33,11 +33,11 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy
|
||||||
{
|
{
|
||||||
this.barClosed = true;
|
this.barClosed = true;
|
||||||
|
|
||||||
this.onSettingsChanged =
|
this.onConfigChanged =
|
||||||
this.fuseConfig.onSettingsChanged
|
this.fuseConfig.onConfigChanged
|
||||||
.subscribe(
|
.subscribe(
|
||||||
(newSettings) => {
|
(newConfig) => {
|
||||||
this.fuseSettings = newSettings;
|
this.config = newConfig;
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -72,7 +72,7 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy
|
||||||
|
|
||||||
onSettingsChange()
|
onSettingsChange()
|
||||||
{
|
{
|
||||||
this.fuseConfig.setSettings(this.fuseSettings);
|
this.fuseConfig.setConfig(this.config);
|
||||||
}
|
}
|
||||||
|
|
||||||
closeBar()
|
closeBar()
|
||||||
|
@ -107,6 +107,6 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy
|
||||||
|
|
||||||
ngOnDestroy()
|
ngOnDestroy()
|
||||||
{
|
{
|
||||||
this.onSettingsChanged.unsubscribe();
|
this.onConfigChanged.unsubscribe();
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -9,7 +9,7 @@ import PerfectScrollbar from 'perfect-scrollbar';
|
||||||
})
|
})
|
||||||
export class FusePerfectScrollbarDirective implements AfterViewInit, OnDestroy
|
export class FusePerfectScrollbarDirective implements AfterViewInit, OnDestroy
|
||||||
{
|
{
|
||||||
onSettingsChanged: Subscription;
|
onConfigChanged: Subscription;
|
||||||
isDisableCustomScrollbars = false;
|
isDisableCustomScrollbars = false;
|
||||||
isMobile = false;
|
isMobile = false;
|
||||||
isInitialized = true;
|
isInitialized = true;
|
||||||
|
@ -21,8 +21,8 @@ export class FusePerfectScrollbarDirective implements AfterViewInit, OnDestroy
|
||||||
private platform: Platform
|
private platform: Platform
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
this.onSettingsChanged =
|
this.onConfigChanged =
|
||||||
this.fuseConfig.onSettingsChanged
|
this.fuseConfig.onConfigChanged
|
||||||
.subscribe(
|
.subscribe(
|
||||||
(settings) => {
|
(settings) => {
|
||||||
this.isDisableCustomScrollbars = !settings.customScrollbars;
|
this.isDisableCustomScrollbars = !settings.customScrollbars;
|
||||||
|
@ -56,7 +56,7 @@ export class FusePerfectScrollbarDirective implements AfterViewInit, OnDestroy
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.onSettingsChanged.unsubscribe();
|
this.onConfigChanged.unsubscribe();
|
||||||
|
|
||||||
// Destroy the perfect-scrollbar
|
// Destroy the perfect-scrollbar
|
||||||
this.ps.destroy();
|
this.ps.destroy();
|
37
src/@fuse/fuse.module.ts
Normal file
37
src/@fuse/fuse.module.ts
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
import { ModuleWithProviders, NgModule, Optional, SkipSelf } from '@angular/core';
|
||||||
|
|
||||||
|
import { FUSE_CONFIG, FuseConfigService } from '@fuse/services/config.service';
|
||||||
|
import { FuseNavigationService } from '@fuse/components/navigation/navigation.service';
|
||||||
|
import { FuseSplashScreenService } from '@fuse/services/splash-screen.service';
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
declarations: [],
|
||||||
|
providers : [
|
||||||
|
FuseConfigService,
|
||||||
|
FuseNavigationService,
|
||||||
|
FuseSplashScreenService
|
||||||
|
]
|
||||||
|
})
|
||||||
|
export class FuseModule
|
||||||
|
{
|
||||||
|
constructor(@Optional() @SkipSelf() parentModule: FuseModule)
|
||||||
|
{
|
||||||
|
if ( parentModule )
|
||||||
|
{
|
||||||
|
throw new Error('FuseModule is already loaded. Import it in the AppModule only!');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static forRoot(config): ModuleWithProviders
|
||||||
|
{
|
||||||
|
return {
|
||||||
|
ngModule : FuseModule,
|
||||||
|
providers: [
|
||||||
|
{
|
||||||
|
provide : FUSE_CONFIG,
|
||||||
|
useValue: config
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
|
@ -14,7 +14,6 @@ import { FusePipesModule } from '../pipes/pipes.module';
|
||||||
import { FuseConfirmDialogComponent } from '../components/confirm-dialog/confirm-dialog.component';
|
import { FuseConfirmDialogComponent } from '../components/confirm-dialog/confirm-dialog.component';
|
||||||
import { FuseCountdownComponent } from '../components/countdown/countdown.component';
|
import { FuseCountdownComponent } from '../components/countdown/countdown.component';
|
||||||
import { FuseMatchMedia } from '../services/match-media.service';
|
import { FuseMatchMedia } from '../services/match-media.service';
|
||||||
import { FuseNavbarVerticalService } from '../../main/navbar/vertical/navbar-vertical.service';
|
|
||||||
import { FuseHighlightComponent } from '../components/highlight/highlight.component';
|
import { FuseHighlightComponent } from '../components/highlight/highlight.component';
|
||||||
import { FusePerfectScrollbarDirective } from '../directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive';
|
import { FusePerfectScrollbarDirective } from '../directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive';
|
||||||
import { FuseIfOnDomDirective } from '../directives/fuse-if-on-dom/fuse-if-on-dom.directive';
|
import { FuseIfOnDomDirective } from '../directives/fuse-if-on-dom/fuse-if-on-dom.directive';
|
||||||
|
@ -73,7 +72,6 @@ import { ChartsModule } from 'ng2-charts';
|
||||||
providers : [
|
providers : [
|
||||||
CookieService,
|
CookieService,
|
||||||
FuseMatchMedia,
|
FuseMatchMedia,
|
||||||
FuseNavbarVerticalService,
|
|
||||||
FuseMatSidenavHelperService,
|
FuseMatSidenavHelperService,
|
||||||
FuseTranslationLoaderService
|
FuseTranslationLoaderService
|
||||||
]
|
]
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user