From 832a08208a7c0a93154abf69e181bd663f590b62 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Tue, 15 May 2018 13:52:01 +0300 Subject: [PATCH 01/80] (Toolbar) Set the selected the language from the translation service --- src/app/main/toolbar/toolbar.component.html | 6 ++--- src/app/main/toolbar/toolbar.component.ts | 30 ++++++++++++--------- 2 files changed, 20 insertions(+), 16 deletions(-) diff --git a/src/app/main/toolbar/toolbar.component.html b/src/app/main/toolbar/toolbar.component.html index 8c75a0d4..e39c26f2 100644 --- a/src/app/main/toolbar/toolbar.component.html +++ b/src/app/main/toolbar/toolbar.component.html @@ -73,11 +73,11 @@ - + + diff --git a/src/app/layout/toolbar/toolbar.component.scss b/src/app/layout/blocks/toolbar/toolbar.component.scss similarity index 96% rename from src/app/layout/toolbar/toolbar.component.scss rename to src/app/layout/blocks/toolbar/toolbar.component.scss index 25abc217..ea7692af 100644 --- a/src/app/layout/toolbar/toolbar.component.scss +++ b/src/app/layout/blocks/toolbar/toolbar.component.scss @@ -1,4 +1,4 @@ -@import '../../../@fuse/scss/fuse'; +@import "src/@fuse/scss/fuse"; :host { position: relative; diff --git a/src/app/layout/blocks/toolbar/toolbar.component.ts b/src/app/layout/blocks/toolbar/toolbar.component.ts new file mode 100644 index 00000000..34ab33fc --- /dev/null +++ b/src/app/layout/blocks/toolbar/toolbar.component.ts @@ -0,0 +1,182 @@ +import { Component, OnDestroy, OnInit } from '@angular/core'; +import { NavigationEnd, NavigationStart, Router } from '@angular/router'; +import { Subject } from 'rxjs'; +import { filter, takeUntil } from 'rxjs/operators'; +import { TranslateService } from '@ngx-translate/core'; +import * as _ from 'lodash'; + +import { FuseConfigService } from '@fuse/services/config.service'; +import { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service'; + +import { navigation } from 'app/navigation/navigation'; + +@Component({ + selector : 'toolbar', + templateUrl: './toolbar.component.html', + styleUrls : ['./toolbar.component.scss'] +}) + +export class ToolbarComponent implements OnInit, OnDestroy +{ + horizontalNav: boolean; + languages: any; + noNav: boolean; + navigation: any; + selectedLanguage: any; + showLoadingBar: boolean; + userStatusOptions: any[]; + + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + * @param {FuseSidebarService} _fuseSidebarService + * @param {Router} _router + * @param {TranslateService} _translateService + */ + constructor( + private _fuseConfigService: FuseConfigService, + private _fuseSidebarService: FuseSidebarService, + private _router: Router, + private _translateService: TranslateService + ) + { + // Set the defaults + this.userStatusOptions = [ + { + 'title': 'Online', + 'icon' : 'icon-checkbox-marked-circle', + 'color': '#4CAF50' + }, + { + 'title': 'Away', + 'icon' : 'icon-clock', + 'color': '#FFC107' + }, + { + 'title': 'Do not Disturb', + 'icon' : 'icon-minus-circle', + 'color': '#F44336' + }, + { + 'title': 'Invisible', + 'icon' : 'icon-checkbox-blank-circle-outline', + 'color': '#BDBDBD' + }, + { + 'title': 'Offline', + 'icon' : 'icon-checkbox-blank-circle-outline', + 'color': '#616161' + } + ]; + + this.languages = [ + { + id : 'en', + title: 'English', + flag : 'us' + }, + { + id : 'tr', + title: 'Turkish', + flag : 'tr' + } + ]; + + this.navigation = navigation; + + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + // Subscribe to the router events to show/hide the loading bar + this._router.events + .pipe( + filter((event) => event instanceof NavigationStart), + takeUntil(this._unsubscribeAll) + ) + .subscribe((event) => { + this.showLoadingBar = true; + }); + + this._router.events + .pipe( + filter((event) => event instanceof NavigationEnd) + ) + .subscribe((event) => { + this.showLoadingBar = false; + }); + + // Subscribe to the config changes + this._fuseConfigService.config + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe((settings) => { + this.horizontalNav = settings.layout.navigation.position === 'top'; + this.noNav = settings.layout.navigation.position === 'none'; + }); + + // Set the selected language from default languages + this.selectedLanguage = _.find(this.languages, {'id': this._translateService.currentLang}); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Toggle sidebar opened + * + * @param key + */ + toggleSidebarOpened(key): void + { + this._fuseSidebarService.getSidebar(key).toggleOpen(); + } + + /** + * Search + * + * @param value + */ + search(value): void + { + // Do your search here... + console.log(value); + } + + /** + * Set the language + * + * @param langId + */ + setLanguage(langId): void + { + // Set the selected language for toolbar + this.selectedLanguage = _.find(this.languages, {'id': langId}); + + // Use the selected language for translations + this._translateService.use(langId); + } +} diff --git a/src/app/layout/toolbar/toolbar.module.ts b/src/app/layout/blocks/toolbar/toolbar.module.ts similarity index 80% rename from src/app/layout/toolbar/toolbar.module.ts rename to src/app/layout/blocks/toolbar/toolbar.module.ts index 57272437..4217e99a 100644 --- a/src/app/layout/toolbar/toolbar.module.ts +++ b/src/app/layout/blocks/toolbar/toolbar.module.ts @@ -2,18 +2,17 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; import { MatButtonModule, MatIconModule, MatMenuModule, MatProgressBarModule, MatToolbarModule } from '@angular/material'; +import { FuseSearchBarModule, FuseShortcutsModule } from '@fuse/components'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseToolbarComponent } from 'app/layout/toolbar/toolbar.component'; -import { FuseSearchBarModule, FuseShortcutsModule } from '@fuse/components'; +import { ToolbarComponent } from 'app/layout/blocks/toolbar/toolbar.component'; @NgModule({ declarations: [ - FuseToolbarComponent + ToolbarComponent ], imports : [ RouterModule, - MatButtonModule, MatIconModule, MatMenuModule, @@ -25,9 +24,9 @@ import { FuseSearchBarModule, FuseShortcutsModule } from '@fuse/components'; FuseShortcutsModule ], exports : [ - FuseToolbarComponent + ToolbarComponent ] }) -export class FuseToolbarModule +export class ToolbarModule { } diff --git a/src/app/layout/content/content.component.ts b/src/app/layout/content/content.component.ts deleted file mode 100644 index 1f2aedee..00000000 --- a/src/app/layout/content/content.component.ts +++ /dev/null @@ -1,70 +0,0 @@ -import { Component, HostBinding, OnDestroy } from '@angular/core'; -import { ActivatedRoute, NavigationEnd, Router } from '@angular/router'; - -import { Subscription } from 'rxjs'; -import { filter, map } from 'rxjs/operators'; - -import { fuseAnimations } from '@fuse/animations/index'; -import { FuseConfigService } from '@fuse/services/config.service'; - -@Component({ - selector : 'fuse-content', - templateUrl: './content.component.html', - styleUrls : ['./content.component.scss'], - animations : fuseAnimations -}) -export class FuseContentComponent implements OnDestroy -{ - onConfigChanged: Subscription; - fuseSettings: any; - - @HostBinding('@routerTransitionUp') routeAnimationUp = false; - @HostBinding('@routerTransitionDown') routeAnimationDown = false; - @HostBinding('@routerTransitionRight') routeAnimationRight = false; - @HostBinding('@routerTransitionLeft') routeAnimationLeft = false; - @HostBinding('@routerTransitionFade') routeAnimationFade = false; - - constructor( - private router: Router, - private activatedRoute: ActivatedRoute, - private fuseConfig: FuseConfigService - ) - { - this.router.events.pipe( - filter((event) => event instanceof NavigationEnd), - map(() => this.activatedRoute) - ).subscribe((event) => { - switch ( this.fuseSettings.routerAnimation ) - { - case 'fadeIn': - this.routeAnimationFade = !this.routeAnimationFade; - break; - case 'slideUp': - this.routeAnimationUp = !this.routeAnimationUp; - break; - case 'slideDown': - this.routeAnimationDown = !this.routeAnimationDown; - break; - case 'slideRight': - this.routeAnimationRight = !this.routeAnimationRight; - break; - case 'slideLeft': - this.routeAnimationLeft = !this.routeAnimationLeft; - break; - } - }); - - this.onConfigChanged = - this.fuseConfig.onConfigChanged - .subscribe( - (newSettings) => { - this.fuseSettings = newSettings; - } - ); - } - - ngOnDestroy() - { - this.onConfigChanged.unsubscribe(); - } -} diff --git a/src/app/layout/layout.module.ts b/src/app/layout/layout.module.ts new file mode 100644 index 00000000..0d168275 --- /dev/null +++ b/src/app/layout/layout.module.ts @@ -0,0 +1,15 @@ +import { NgModule } from '@angular/core'; + +import { VerticalNavBasicLayoutModule } from 'app/layout/vertical/basic/basic.module'; + +@NgModule({ + imports: [ + VerticalNavBasicLayoutModule + ], + exports: [ + VerticalNavBasicLayoutModule + ] +}) +export class LayoutModule +{ +} diff --git a/src/app/layout/navbar/navbar.component.ts b/src/app/layout/navbar/navbar.component.ts deleted file mode 100644 index 340ba35d..00000000 --- a/src/app/layout/navbar/navbar.component.ts +++ /dev/null @@ -1,95 +0,0 @@ -import { Component, Input, OnDestroy, OnInit, ViewChild, ViewEncapsulation } from '@angular/core'; -import { NavigationEnd, Router } from '@angular/router'; - -import { Subscription } from 'rxjs'; - -import { FusePerfectScrollbarDirective } from '@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive'; -import { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service'; - -import { navigation } from 'app/navigation/navigation'; -import { FuseNavigationService } from '@fuse/components/navigation/navigation.service'; -import { FuseSidebarComponent } from '@fuse/components/sidebar/sidebar.component'; - -@Component({ - selector : 'fuse-navbar', - templateUrl : './navbar.component.html', - styleUrls : ['./navbar.component.scss'], - encapsulation: ViewEncapsulation.None -}) -export class FuseNavbarComponent implements OnInit, OnDestroy -{ - private fusePerfectScrollbar: FusePerfectScrollbarDirective; - - @ViewChild(FusePerfectScrollbarDirective) set directive(theDirective: FusePerfectScrollbarDirective) - { - if ( !theDirective ) - { - return; - } - - this.fusePerfectScrollbar = theDirective; - - this.navigationServiceWatcher = - this.navigationService.onItemCollapseToggled.subscribe(() => { - this.fusePerfectScrollbarUpdateTimeout = setTimeout(() => { - this.fusePerfectScrollbar.update(); - }, 310); - }); - } - - @Input() layout; - navigation: any; - navigationServiceWatcher: Subscription; - fusePerfectScrollbarUpdateTimeout; - - constructor( - private sidebarService: FuseSidebarService, - private navigationService: FuseNavigationService, - private router: Router - ) - { - // Navigation data - this.navigation = navigation; - - // Default layout - this.layout = 'vertical'; - } - - ngOnInit() - { - this.router.events.subscribe( - (event) => { - if ( event instanceof NavigationEnd ) - { - if ( this.sidebarService.getSidebar('navbar') ) - { - this.sidebarService.getSidebar('navbar').close(); - } - } - } - ); - } - - ngOnDestroy() - { - if ( this.fusePerfectScrollbarUpdateTimeout ) - { - clearTimeout(this.fusePerfectScrollbarUpdateTimeout); - } - - if ( this.navigationServiceWatcher ) - { - this.navigationServiceWatcher.unsubscribe(); - } - } - - toggleSidebarOpened() - { - this.sidebarService.getSidebar('navbar').toggleOpen(); - } - - toggleSidebarFolded() - { - this.sidebarService.getSidebar('navbar').toggleFold(); - } -} diff --git a/src/app/layout/quick-panel/quick-panel.component.ts b/src/app/layout/quick-panel/quick-panel.component.ts deleted file mode 100644 index 6163e058..00000000 --- a/src/app/layout/quick-panel/quick-panel.component.ts +++ /dev/null @@ -1,41 +0,0 @@ -import { Component, OnInit, ViewEncapsulation } from '@angular/core'; -import { HttpClient } from '@angular/common/http'; - -@Component({ - selector : 'fuse-quick-panel', - templateUrl : './quick-panel.component.html', - styleUrls : ['./quick-panel.component.scss'], - encapsulation: ViewEncapsulation.None -}) -export class FuseQuickPanelComponent implements OnInit -{ - date: Date; - settings: any; - notes: any[]; - events: any[]; - - constructor(private http: HttpClient) - { - this.date = new Date(); - this.settings = { - notify: true, - cloud : false, - retro : true - }; - } - - ngOnInit() - { - this.http.get('api/quick-panel-notes') - .subscribe((response: any) => { - this.notes = response; - }); - - this.http.get('api/quick-panel-events') - .subscribe((response: any) => { - this.events = response; - }); - - } - -} diff --git a/src/app/layout/toolbar/toolbar.component.ts b/src/app/layout/toolbar/toolbar.component.ts deleted file mode 100644 index f5cab4b4..00000000 --- a/src/app/layout/toolbar/toolbar.component.ts +++ /dev/null @@ -1,119 +0,0 @@ -import { Component, OnInit } from '@angular/core'; -import { NavigationEnd, NavigationStart, Router } from '@angular/router'; -import { TranslateService } from '@ngx-translate/core'; -import * as _ from 'lodash'; - -import { FuseConfigService } from '@fuse/services/config.service'; -import { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service'; - -import { navigation } from 'app/navigation/navigation'; - -@Component({ - selector : 'fuse-toolbar', - templateUrl: './toolbar.component.html', - styleUrls : ['./toolbar.component.scss'] -}) - -export class FuseToolbarComponent implements OnInit -{ - userStatusOptions: any[]; - languages: any; - selectedLanguage: any; - showLoadingBar: boolean; - horizontalNav: boolean; - noNav: boolean; - navigation: any; - - constructor( - private router: Router, - private fuseConfig: FuseConfigService, - private sidebarService: FuseSidebarService, - private translate: TranslateService - ) - { - this.userStatusOptions = [ - { - 'title': 'Online', - 'icon' : 'icon-checkbox-marked-circle', - 'color': '#4CAF50' - }, - { - 'title': 'Away', - 'icon' : 'icon-clock', - 'color': '#FFC107' - }, - { - 'title': 'Do not Disturb', - 'icon' : 'icon-minus-circle', - 'color': '#F44336' - }, - { - 'title': 'Invisible', - 'icon' : 'icon-checkbox-blank-circle-outline', - 'color': '#BDBDBD' - }, - { - 'title': 'Offline', - 'icon' : 'icon-checkbox-blank-circle-outline', - 'color': '#616161' - } - ]; - - this.languages = [ - { - id : 'en', - title: 'English', - flag : 'us' - }, - { - id : 'tr', - title: 'Turkish', - flag : 'tr' - } - ]; - - router.events.subscribe( - (event) => { - if ( event instanceof NavigationStart ) - { - this.showLoadingBar = true; - } - if ( event instanceof NavigationEnd ) - { - this.showLoadingBar = false; - } - }); - - this.fuseConfig.onConfigChanged.subscribe((settings) => { - this.horizontalNav = settings.layout.navigation === 'top'; - this.noNav = settings.layout.navigation === 'none'; - }); - - this.navigation = navigation; - } - - ngOnInit() - { - this.selectedLanguage = _.find(this.languages, {'id': this.translate.currentLang}); - } - - toggleSidebarOpened(key) - { - this.sidebarService.getSidebar(key).toggleOpen(); - } - - search(value) - { - // Do your search here... - console.log(value); - } - - setLanguage(langId) - { - // Set the selected language for toolbar - this.selectedLanguage = _.find(this.languages, {'id': langId}); - - // Use the selected language for translations - this.translate.use(langId); - } -} diff --git a/src/app/layout/vertical/basic/basic.component.html b/src/app/layout/vertical/basic/basic.component.html new file mode 100644 index 00000000..a12d2561 --- /dev/null +++ b/src/app/layout/vertical/basic/basic.component.html @@ -0,0 +1,77 @@ + + +
+ + + + + + + + + + + + +
+ + + + + + + +
+ + + + + + + + + + + +
+
+ + +
+ + + + + + + +
+ + + +
+
+ + +
+ + + + + + + +
+ + \ No newline at end of file diff --git a/src/@fuse/components/layouts/vertical-nav/basic/basic.component.scss b/src/app/layout/vertical/basic/basic.component.scss similarity index 94% rename from src/@fuse/components/layouts/vertical-nav/basic/basic.component.scss rename to src/app/layout/vertical/basic/basic.component.scss index 793e79b4..3220c433 100644 --- a/src/@fuse/components/layouts/vertical-nav/basic/basic.component.scss +++ b/src/app/layout/vertical/basic/basic.component.scss @@ -1,6 +1,6 @@ @import "src/@fuse/scss/fuse"; -fuse-vertical-nav-basic-layout { +vertical-nav-basic-layout { display: flex; flex-direction: column; width: 100%; @@ -21,7 +21,7 @@ fuse-vertical-nav-basic-layout { height: auto !important; } - #fuse-main-content { + #main-content { display: flex; flex: 1; flex-direction: column; @@ -39,7 +39,7 @@ fuse-vertical-nav-basic-layout { flex: 1; overflow: hidden; - fuse-content { + content { position: relative; display: flex; flex: 1; diff --git a/src/app/layout/vertical/basic/basic.component.ts b/src/app/layout/vertical/basic/basic.component.ts new file mode 100644 index 00000000..ad498b0e --- /dev/null +++ b/src/app/layout/vertical/basic/basic.component.ts @@ -0,0 +1,64 @@ +import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; + +import { FuseConfigService } from '@fuse/services/config.service'; +import { navigation } from 'app/navigation/navigation'; + +@Component({ + selector : 'vertical-nav-basic-layout', + templateUrl : './basic.component.html', + styleUrls : ['./basic.component.scss'], + encapsulation: ViewEncapsulation.None +}) +export class VerticalNavBasicLayoutComponent implements OnInit, OnDestroy +{ + fuseConfig: any; + navigation: any; + + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + */ + constructor( + private _fuseConfigService: FuseConfigService + ) + { + // Set the defaults + this.navigation = navigation; + + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + // Subscribe to config changes + this._fuseConfigService.config + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe((config) => { + this.fuseConfig = config; + }); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } +} diff --git a/src/app/layout/vertical/basic/basic.module.ts b/src/app/layout/vertical/basic/basic.module.ts new file mode 100644 index 00000000..1f7a8949 --- /dev/null +++ b/src/app/layout/vertical/basic/basic.module.ts @@ -0,0 +1,38 @@ +import { NgModule } from '@angular/core'; +import { MatSidenavModule } from '@angular/material'; + +import { FuseSidebarModule, FuseThemeOptionsModule } from '@fuse/components'; +import { FuseSharedModule } from '@fuse/shared.module'; + +import { ContentModule } from 'app/layout/blocks/content/content.module'; +import { FooterModule } from 'app/layout/blocks/footer/footer.module'; +import { NavbarModule } from 'app/layout/blocks/navbar/navbar.module'; +import { QuickPanelModule } from 'app/layout/blocks/quick-panel/quick-panel.module'; +import { ToolbarModule } from 'app/layout/blocks/toolbar/toolbar.module'; + +import { VerticalNavBasicLayoutComponent } from 'app/layout/vertical/basic/basic.component'; + +@NgModule({ + declarations: [ + VerticalNavBasicLayoutComponent + ], + imports : [ + MatSidenavModule, + + FuseSharedModule, + FuseSidebarModule, + FuseThemeOptionsModule, + + ContentModule, + FooterModule, + NavbarModule, + QuickPanelModule, + ToolbarModule + ], + exports : [ + VerticalNavBasicLayoutComponent + ] +}) +export class VerticalNavBasicLayoutModule +{ +} diff --git a/src/app/main/apps/academy/academy.module.ts b/src/app/main/apps/academy/academy.module.ts index e1935402..277cf520 100644 --- a/src/app/main/apps/academy/academy.module.ts +++ b/src/app/main/apps/academy/academy.module.ts @@ -5,22 +5,23 @@ import { MatButtonModule, MatFormFieldModule, MatIconModule, MatInputModule, Mat import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseAcademyCoursesComponent } from './courses/courses.component'; -import { FuseAcademyCourseComponent } from './course/course.component'; -import { AcademyCoursesService } from './courses.service'; -import { AcademyCourseService } from './course.service'; +import { AcademyCoursesComponent } from 'app/main/apps/academy/courses/courses.component'; +import { AcademyCourseComponent } from 'app/main/apps/academy/course/course.component'; +import { AcademyCoursesService } from 'app/main/apps/academy/courses.service'; +import { AcademyCourseService } from 'app/main/apps/academy/course.service'; + const routes = [ { path : 'courses', - component: FuseAcademyCoursesComponent, + component: AcademyCoursesComponent, resolve : { academy: AcademyCoursesService } }, { path : 'courses/:courseId/:courseSlug', - component: FuseAcademyCourseComponent, + component: AcademyCourseComponent, resolve : { academy: AcademyCourseService } @@ -33,8 +34,8 @@ const routes = [ @NgModule({ declarations: [ - FuseAcademyCoursesComponent, - FuseAcademyCourseComponent + AcademyCoursesComponent, + AcademyCourseComponent ], imports : [ RouterModule.forChild(routes), @@ -53,6 +54,6 @@ const routes = [ AcademyCourseService ] }) -export class FuseAcademyModule +export class AcademyModule { } diff --git a/src/app/main/apps/academy/course.service.ts b/src/app/main/apps/academy/course.service.ts index 1d007e82..024a65cd 100644 --- a/src/app/main/apps/academy/course.service.ts +++ b/src/app/main/apps/academy/course.service.ts @@ -8,12 +8,23 @@ export class AcademyCourseService implements Resolve { onCourseChanged: BehaviorSubject = new BehaviorSubject({}); - constructor(private http: HttpClient) + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ + constructor( + private _httpClient: HttpClient + ) { } + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + /** - * The Academy App Main Resolver + * Resolver * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state @@ -34,10 +45,17 @@ export class AcademyCourseService implements Resolve }); } + /** + * Get course + * + * @param courseId + * @param courseSlug + * @returns {Promise} + */ getCourse(courseId, courseSlug): Promise { return new Promise((resolve, reject) => { - this.http.get('api/academy-course/' + courseId + '/' + courseSlug) + this._httpClient.get('api/academy-course/' + courseId + '/' + courseSlug) .subscribe((response: any) => { this.onCourseChanged.next(response); resolve(response); diff --git a/src/app/main/apps/academy/course/course.component.ts b/src/app/main/apps/academy/course/course.component.ts index ab249eae..a3970fa5 100644 --- a/src/app/main/apps/academy/course/course.component.ts +++ b/src/app/main/apps/academy/course/course.component.ts @@ -1,71 +1,114 @@ import { AfterViewInit, ChangeDetectorRef, Component, OnDestroy, OnInit, QueryList, ViewChildren, ViewEncapsulation } from '@angular/core'; -import { Subscription } from 'rxjs'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FusePerfectScrollbarDirective } from '@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive'; import { fuseAnimations } from '@fuse/animations'; -import { AcademyCourseService } from '../course.service'; +import { AcademyCourseService } from 'app/main/apps/academy/course.service'; @Component({ - selector : 'fuse-academy-course', + selector : 'academy-course', templateUrl : './course.component.html', styleUrls : ['./course.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseAcademyCourseComponent implements OnInit, OnDestroy, AfterViewInit +export class AcademyCourseComponent implements OnInit, OnDestroy, AfterViewInit { + animationDirection: 'left' | 'right' | 'none'; course: any; - courseSubscription: Subscription; - currentStep = 0; - courseStepContent; - animationDirection: 'left' | 'right' | 'none' = 'none'; - @ViewChildren(FusePerfectScrollbarDirective) fuseScrollbarDirectives: QueryList; + courseStepContent: any; + currentStep: number; + @ViewChildren(FusePerfectScrollbarDirective) + fuseScrollbarDirectives: QueryList; + + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {AcademyCourseService} _academyCourseService + * @param {ChangeDetectorRef} _changeDetectorRef + */ constructor( - private courseService: AcademyCourseService, - private changeDetectorRef: ChangeDetectorRef + private _academyCourseService: AcademyCourseService, + private _changeDetectorRef: ChangeDetectorRef ) { + // Set the defaults + this.animationDirection = 'none'; + this.currentStep = 0; + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { // Subscribe to courses - this.courseSubscription = - this.courseService.onCourseChanged - .subscribe(course => { - this.course = course; - }); + this._academyCourseService.onCourseChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(course => { + this.course = course; + }); } - ngAfterViewInit() + /** + * After view init + */ + ngAfterViewInit(): void { this.courseStepContent = this.fuseScrollbarDirectives.find((fuseScrollbarDirective) => { - return fuseScrollbarDirective.element.nativeElement.id === 'course-step-content'; + return fuseScrollbarDirective.elementRef.nativeElement.id === 'course-step-content'; }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.courseSubscription.unsubscribe(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - gotoStep(step) + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Go to step + * + * @param step + */ + gotoStep(step): void { // Decide the animation direction this.animationDirection = this.currentStep < step ? 'left' : 'right'; // Run change detection so the change // in the animation direction registered - this.changeDetectorRef.detectChanges(); + this._changeDetectorRef.detectChanges(); // Set the current step this.currentStep = step; } - gotoNextStep() + /** + * Go to next step + */ + gotoNextStep(): void { if ( this.currentStep === this.course.totalSteps - 1 ) { @@ -77,13 +120,16 @@ export class FuseAcademyCourseComponent implements OnInit, OnDestroy, AfterViewI // Run change detection so the change // in the animation direction registered - this.changeDetectorRef.detectChanges(); + this._changeDetectorRef.detectChanges(); // Increase the current step this.currentStep++; } - gotoPreviousStep() + /** + * Go to previous step + */ + gotoPreviousStep(): void { if ( this.currentStep === 0 ) { @@ -95,7 +141,7 @@ export class FuseAcademyCourseComponent implements OnInit, OnDestroy, AfterViewI // Run change detection so the change // in the animation direction registered - this.changeDetectorRef.detectChanges(); + this._changeDetectorRef.detectChanges(); // Decrease the current step this.currentStep--; diff --git a/src/app/main/apps/academy/courses.service.ts b/src/app/main/apps/academy/courses.service.ts index 59356eca..5f8776cb 100644 --- a/src/app/main/apps/academy/courses.service.ts +++ b/src/app/main/apps/academy/courses.service.ts @@ -9,12 +9,23 @@ export class AcademyCoursesService implements Resolve onCategoriesChanged: BehaviorSubject = new BehaviorSubject({}); onCoursesChanged: BehaviorSubject = new BehaviorSubject({}); - constructor(private http: HttpClient) + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ + constructor( + private _httpClient: HttpClient + ) { } + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + /** - * The Academy App Main Resolver + * Resolver * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state @@ -36,10 +47,15 @@ export class AcademyCoursesService implements Resolve }); } + /** + * Get categories + * + * @returns {Promise} + */ getCategories(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/academy-categories') + this._httpClient.get('api/academy-categories') .subscribe((response: any) => { this.onCategoriesChanged.next(response); resolve(response); @@ -47,10 +63,15 @@ export class AcademyCoursesService implements Resolve }); } + /** + * Get courses + * + * @returns {Promise} + */ getCourses(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/academy-courses') + this._httpClient.get('api/academy-courses') .subscribe((response: any) => { this.onCoursesChanged.next(response); resolve(response); diff --git a/src/app/main/apps/academy/courses/courses.component.ts b/src/app/main/apps/academy/courses/courses.component.ts index 58b82cfb..defd378d 100644 --- a/src/app/main/apps/academy/courses/courses.component.ts +++ b/src/app/main/apps/academy/courses/courses.component.ts @@ -1,59 +1,88 @@ import { Component, OnDestroy, OnInit } from '@angular/core'; -import { Subscription } from 'rxjs'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; -import { AcademyCoursesService } from '../courses.service'; +import { AcademyCoursesService } from 'app/main/apps/academy/courses.service'; @Component({ - selector : 'fuse-academy-courses', + selector : 'academy-courses', templateUrl: './courses.component.html', styleUrls : ['./courses.component.scss'], - animations : fuseAnimations + animations : fuseAnimations }) -export class FuseAcademyCoursesComponent implements OnInit, OnDestroy +export class AcademyCoursesComponent implements OnInit, OnDestroy { categories: any[]; courses: any[]; coursesFilteredByCategory: any[]; filteredCourses: any[]; + currentCategory: string; + searchTerm: string; - categoriesSubscription: Subscription; - coursesSubscription: Subscription; - - currentCategory = 'all'; - searchTerm = ''; + // Private + private _unsubscribeAll: Subject; + /** + * Constructor + * + * @param {AcademyCoursesService} _academyCoursesService + */ constructor( - private coursesService: AcademyCoursesService + private _academyCoursesService: AcademyCoursesService ) { + // Set the defaults + this.currentCategory = 'all'; + this.searchTerm = ''; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { // Subscribe to categories - this.categoriesSubscription = - this.coursesService.onCategoriesChanged - .subscribe(categories => { - this.categories = categories; - }); + this._academyCoursesService.onCategoriesChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(categories => { + this.categories = categories; + }); // Subscribe to courses - this.coursesSubscription = - this.coursesService.onCoursesChanged - .subscribe(courses => { - this.filteredCourses = this.coursesFilteredByCategory = this.courses = courses; - }); + this._academyCoursesService.onCoursesChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(courses => { + this.filteredCourses = this.coursesFilteredByCategory = this.courses = courses; + }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.categoriesSubscription.unsubscribe(); - this.coursesSubscription.unsubscribe(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - filterCoursesByCategory() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Filter courses by category + */ + filterCoursesByCategory(): void { // Filter if ( this.currentCategory === 'all' ) @@ -75,7 +104,10 @@ export class FuseAcademyCoursesComponent implements OnInit, OnDestroy this.filterCoursesByTerm(); } - filterCoursesByTerm() + /** + * Filter courses by term + */ + filterCoursesByTerm(): void { const searchTerm = this.searchTerm.toLowerCase(); diff --git a/src/app/main/apps/apps.module.ts b/src/app/main/apps/apps.module.ts index 63671052..98a60a34 100644 --- a/src/app/main/apps/apps.module.ts +++ b/src/app/main/apps/apps.module.ts @@ -1,18 +1,16 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; -import { FuseAngularMaterialModule } from '../components/angular-material/angular-material.module'; - import { FuseSharedModule } from '@fuse/shared.module'; const routes = [ { path : 'dashboards/analytics', - loadChildren: './dashboards/analytics/analytics.module#FuseAnalyticsDashboardModule' + loadChildren: './dashboards/analytics/analytics.module#AnalyticsDashboardModule' }, { path : 'dashboards/project', - loadChildren: './dashboards/project/project.module#FuseProjectDashboardModule' + loadChildren: './dashboards/project/project.module#ProjectDashboardModule' }, { path : 'mail', @@ -24,19 +22,19 @@ const routes = [ }, { path : 'chat', - loadChildren: './chat/chat.module#FuseChatModule' + loadChildren: './chat/chat.module#ChatModule' }, { path : 'calendar', - loadChildren: './calendar/calendar.module#FuseCalendarModule' + loadChildren: './calendar/calendar.module#CalendarModule' }, { path : 'e-commerce', - loadChildren: './e-commerce/e-commerce.module#FuseEcommerceModule' + loadChildren: './e-commerce/e-commerce.module#EcommerceModule' }, { path : 'academy', - loadChildren: './academy/academy.module#FuseAcademyModule' + loadChildren: './academy/academy.module#AcademyModule' }, { path : 'todo', @@ -44,11 +42,11 @@ const routes = [ }, { path : 'file-manager', - loadChildren: './file-manager/file-manager.module#FuseFileManagerModule' + loadChildren: './file-manager/file-manager.module#FileManagerModule' }, { path : 'contacts', - loadChildren: './contacts/contacts.module#FuseContactsModule' + loadChildren: './contacts/contacts.module#ContactsModule' }, { path : 'scrumboard', @@ -58,12 +56,10 @@ const routes = [ @NgModule({ imports : [ - FuseSharedModule, RouterModule.forChild(routes), - FuseAngularMaterialModule - ], - declarations: [] + FuseSharedModule + ] }) -export class FuseAppsModule +export class AppsModule { } diff --git a/src/app/main/apps/calendar/calendar.component.ts b/src/app/main/apps/calendar/calendar.component.ts index 998bab05..94074ddd 100644 --- a/src/app/main/apps/calendar/calendar.component.ts +++ b/src/app/main/apps/calendar/calendar.component.ts @@ -8,34 +8,35 @@ import { CalendarEvent, CalendarEventAction, CalendarEventTimesChangedEvent, Cal import { FuseConfirmDialogComponent } from '@fuse/components/confirm-dialog/confirm-dialog.component'; import { fuseAnimations } from '@fuse/animations'; -import { FuseCalendarEventFormDialogComponent } from './event-form/event-form.component'; -import { CalendarEventModel } from './event.model'; -import { CalendarService } from './calendar.service'; +import { CalendarService } from 'app/main/apps/calendar/calendar.service'; +import { CalendarEventModel } from 'app/main/apps/calendar/event.model'; +import { CalendarEventFormDialogComponent } from 'app/main/apps/calendar/event-form/event-form.component'; @Component({ - selector : 'fuse-calendar', + selector : 'calendar', templateUrl : './calendar.component.html', styleUrls : ['./calendar.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseCalendarComponent implements OnInit +export class CalendarComponent implements OnInit { + actions: CalendarEventAction[]; + activeDayIsOpen: boolean; + confirmDialogRef: MatDialogRef; + dialogRef: any; + events: CalendarEvent[]; + refresh: Subject = new Subject(); + selectedDay: any; view: string; viewDate: Date; - events: CalendarEvent[]; - public actions: CalendarEventAction[]; - activeDayIsOpen: boolean; - refresh: Subject = new Subject(); - dialogRef: any; - confirmDialogRef: MatDialogRef; - selectedDay: any; constructor( - public dialog: MatDialog, - public calendarService: CalendarService + private _matDialog: MatDialog, + private _calendarService: CalendarService ) { + // Set the defaults this.view = 'month'; this.viewDate = new Date(); this.activeDayIsOpen = true; @@ -62,29 +63,41 @@ export class FuseCalendarComponent implements OnInit this.setEvents(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { /** * Watch re-render-refresh for updating db */ this.refresh.subscribe(updateDB => { - // console.warn('REFRESH'); if ( updateDB ) { - // console.warn('UPDATE DB'); - this.calendarService.updateEvents(this.events); + this._calendarService.updateEvents(this.events); } }); - this.calendarService.onEventsUpdated.subscribe(events => { + this._calendarService.onEventsUpdated.subscribe(events => { this.setEvents(); this.refresh.next(); }); } - setEvents() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Set events + */ + setEvents(): void { - this.events = this.calendarService.events.map(item => { + this.events = this._calendarService.events.map(item => { item.actions = this.actions; return new CalendarEventModel(item); }); @@ -92,10 +105,11 @@ export class FuseCalendarComponent implements OnInit /** * Before View Renderer + * * @param {any} header * @param {any} body */ - beforeMonthViewRender({header, body}) + beforeMonthViewRender({header, body}): void { // console.info('beforeMonthViewRender'); /** @@ -118,6 +132,7 @@ export class FuseCalendarComponent implements OnInit /** * Day clicked + * * @param {MonthViewDay} day */ dayClicked(day: CalendarMonthViewDay): void @@ -144,6 +159,7 @@ export class FuseCalendarComponent implements OnInit /** * Event times changed * Event dropped or resized + * * @param {CalendarEvent} event * @param {Date} newStart * @param {Date} newEnd @@ -158,11 +174,12 @@ export class FuseCalendarComponent implements OnInit /** * Delete Event + * * @param event */ - deleteEvent(event) + deleteEvent(event): void { - this.confirmDialogRef = this.dialog.open(FuseConfirmDialogComponent, { + this.confirmDialogRef = this._matDialog.open(FuseConfirmDialogComponent, { disableClose: false }); @@ -182,14 +199,15 @@ export class FuseCalendarComponent implements OnInit /** * Edit Event + * * @param {string} action * @param {CalendarEvent} event */ - editEvent(action: string, event: CalendarEvent) + editEvent(action: string, event: CalendarEvent): void { const eventIndex = this.events.indexOf(event); - this.dialogRef = this.dialog.open(FuseCalendarEventFormDialogComponent, { + this.dialogRef = this._matDialog.open(CalendarEventFormDialogComponent, { panelClass: 'event-form-dialog', data : { event : event, @@ -233,7 +251,7 @@ export class FuseCalendarComponent implements OnInit */ addEvent(): void { - this.dialogRef = this.dialog.open(FuseCalendarEventFormDialogComponent, { + this.dialogRef = this._matDialog.open(CalendarEventFormDialogComponent, { panelClass: 'event-form-dialog', data : { action: 'new', diff --git a/src/app/main/apps/calendar/calendar.module.ts b/src/app/main/apps/calendar/calendar.module.ts index 769f78d5..e72231d6 100644 --- a/src/app/main/apps/calendar/calendar.module.ts +++ b/src/app/main/apps/calendar/calendar.module.ts @@ -1,22 +1,20 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; - import { MatButtonModule, MatDatepickerModule, MatFormFieldModule, MatIconModule, MatInputModule, MatSlideToggleModule, MatToolbarModule } from '@angular/material'; - -import { CalendarModule } from 'angular-calendar'; import { ColorPickerModule } from 'ngx-color-picker'; +import { CalendarModule as AngularCalendarModule } from 'angular-calendar'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseConfirmDialogModule } from '@fuse/components'; -import { CalendarService } from './calendar.service'; -import { FuseCalendarComponent } from './calendar.component'; -import { FuseCalendarEventFormDialogComponent } from './event-form/event-form.component'; +import { CalendarComponent } from 'app/main/apps/calendar/calendar.component'; +import { CalendarService } from 'app/main/apps/calendar/calendar.service'; +import { CalendarEventFormDialogComponent } from 'app/main/apps/calendar/event-form/event-form.component'; const routes: Routes = [ { path : '**', - component: FuseCalendarComponent, + component: CalendarComponent, children : [], resolve : { chat: CalendarService @@ -26,8 +24,8 @@ const routes: Routes = [ @NgModule({ declarations : [ - FuseCalendarComponent, - FuseCalendarEventFormDialogComponent + CalendarComponent, + CalendarEventFormDialogComponent ], imports : [ RouterModule.forChild(routes), @@ -40,7 +38,7 @@ const routes: Routes = [ MatSlideToggleModule, MatToolbarModule, - CalendarModule.forRoot(), + AngularCalendarModule.forRoot(), ColorPickerModule, FuseSharedModule, @@ -49,8 +47,10 @@ const routes: Routes = [ providers : [ CalendarService ], - entryComponents: [FuseCalendarEventFormDialogComponent] + entryComponents: [ + CalendarEventFormDialogComponent + ] }) -export class FuseCalendarModule +export class CalendarModule { } diff --git a/src/app/main/apps/calendar/calendar.service.ts b/src/app/main/apps/calendar/calendar.service.ts index bdd8e4d4..3d0554c3 100644 --- a/src/app/main/apps/calendar/calendar.service.ts +++ b/src/app/main/apps/calendar/calendar.service.ts @@ -9,11 +9,29 @@ export class CalendarService implements Resolve events: any; onEventsUpdated = new Subject(); - constructor(private http: HttpClient) + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ + constructor( + private _httpClient: HttpClient + ) { } + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Resolver + * + * @param {ActivatedRouteSnapshot} route + * @param {RouterStateSnapshot} state + * @returns {Observable | Promise | any} + */ resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable | Promise | any { return new Promise((resolve, reject) => { @@ -28,11 +46,16 @@ export class CalendarService implements Resolve }); } - getEvents() + /** + * Get events + * + * @returns {Promise} + */ + getEvents(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/calendar/events') + this._httpClient.get('api/calendar/events') .subscribe((response: any) => { this.events = response.data; this.onEventsUpdated.next(this.events); @@ -41,10 +64,16 @@ export class CalendarService implements Resolve }); } - updateEvents(events) + /** + * Update events + * + * @param events + * @returns {Promise} + */ + updateEvents(events): Promise { return new Promise((resolve, reject) => { - this.http.post('api/calendar/events', { + this._httpClient.post('api/calendar/events', { id : 'events', data: [...events] }) diff --git a/src/app/main/apps/calendar/event-form/event-form.component.ts b/src/app/main/apps/calendar/event-form/event-form.component.ts index 0730e7b9..95c4c181 100644 --- a/src/app/main/apps/calendar/event-form/event-form.component.ts +++ b/src/app/main/apps/calendar/event-form/event-form.component.ts @@ -1,11 +1,11 @@ import { Component, Inject, ViewEncapsulation } from '@angular/core'; import { FormBuilder, FormControl, FormGroup } from '@angular/forms'; import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material'; +import { CalendarEvent } from 'angular-calendar'; import { MatColors } from '@fuse/mat-colors'; -import { CalendarEvent } from 'angular-calendar'; -import { CalendarEventModel } from '../event.model'; +import { CalendarEventModel } from 'app/main/apps/calendar/event.model'; @Component({ selector : 'fuse-calendar-event-form-dialog', @@ -14,22 +14,29 @@ import { CalendarEventModel } from '../event.model'; encapsulation: ViewEncapsulation.None }) -export class FuseCalendarEventFormDialogComponent +export class CalendarEventFormDialogComponent { - event: CalendarEvent; - dialogTitle: string; - eventForm: FormGroup; action: string; + event: CalendarEvent; + eventForm: FormGroup; + dialogTitle: string; presetColors = MatColors.presets; + /** + * Constructor + * + * @param {MatDialogRef} dialogRef + * @param _data + * @param {FormBuilder} _formBuilder + */ constructor( - public dialogRef: MatDialogRef, - @Inject(MAT_DIALOG_DATA) private data: any, - private formBuilder: FormBuilder + public dialogRef: MatDialogRef, + @Inject(MAT_DIALOG_DATA) private _data: any, + private _formBuilder: FormBuilder ) { - this.event = data.event; - this.action = data.action; + this.event = _data.event; + this.action = _data.action; if ( this.action === 'edit' ) { @@ -39,27 +46,36 @@ export class FuseCalendarEventFormDialogComponent { this.dialogTitle = 'New Event'; this.event = new CalendarEventModel({ - start: data.date, - end : data.date + start: _data.date, + end : _data.date }); } this.eventForm = this.createEventForm(); } - createEventForm() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Create the event form + * + * @returns {FormGroup} + */ + createEventForm(): FormGroup { return new FormGroup({ title : new FormControl(this.event.title), start : new FormControl(this.event.start), end : new FormControl(this.event.end), allDay: new FormControl(this.event.allDay), - color : this.formBuilder.group({ + color : this._formBuilder.group({ primary : new FormControl(this.event.color.primary), secondary: new FormControl(this.event.color.secondary) }), meta : - this.formBuilder.group({ + this._formBuilder.group({ location: new FormControl(this.event.meta.location), notes : new FormControl(this.event.meta.notes) }) diff --git a/src/app/main/apps/calendar/event.model.ts b/src/app/main/apps/calendar/event.model.ts index 6e121f2e..4fe605e6 100644 --- a/src/app/main/apps/calendar/event.model.ts +++ b/src/app/main/apps/calendar/event.model.ts @@ -23,6 +23,11 @@ export class CalendarEventModel notes: string }; + /** + * Constructor + * + * @param data + */ constructor(data?) { data = data || {}; diff --git a/src/app/main/apps/chat/chat-start/chat-start.component.ts b/src/app/main/apps/chat/chat-start/chat-start.component.ts index 2651c617..adc689ea 100644 --- a/src/app/main/apps/chat/chat-start/chat-start.component.ts +++ b/src/app/main/apps/chat/chat-start/chat-start.component.ts @@ -3,12 +3,12 @@ import { Component } from '@angular/core'; import { fuseAnimations } from '@fuse/animations'; @Component({ - selector : 'fuse-chat-start', + selector : 'chat-start', templateUrl: './chat-start.component.html', styleUrls : ['./chat-start.component.scss'], animations : fuseAnimations }) -export class FuseChatStartComponent +export class ChatStartComponent { constructor() { diff --git a/src/app/main/apps/chat/chat-view/chat-view.component.html b/src/app/main/apps/chat/chat-view/chat-view.component.html index 62e1e32b..747600d3 100644 --- a/src/app/main/apps/chat/chat-view/chat-view.component.html +++ b/src/app/main/apps/chat/chat-view/chat-view.component.html @@ -87,7 +87,7 @@ - diff --git a/src/app/main/apps/chat/chat-view/chat-view.component.scss b/src/app/main/apps/chat/chat-view/chat-view.component.scss index 362b701d..3d8efac0 100644 --- a/src/app/main/apps/chat/chat-view/chat-view.component.scss +++ b/src/app/main/apps/chat/chat-view/chat-view.component.scss @@ -99,7 +99,7 @@ } .chat-footer { - min-height: 64px; + min-height: 72px; max-height: 96px; background-color: #F3F4F5; color: rgba(0, 0, 0, 0.87); @@ -116,6 +116,7 @@ overflow: auto; max-height: 80px; transition: height 200ms ease; + &.grow { height: 80px; } diff --git a/src/app/main/apps/chat/chat-view/chat-view.component.ts b/src/app/main/apps/chat/chat-view/chat-view.component.ts index bf687945..4f40e8fe 100644 --- a/src/app/main/apps/chat/chat-view/chat-view.component.ts +++ b/src/app/main/apps/chat/chat-view/chat-view.component.ts @@ -1,16 +1,18 @@ -import { AfterViewInit, Component, OnInit, ViewChild, ViewChildren } from '@angular/core'; +import { AfterViewInit, Component, OnDestroy, OnInit, ViewChild, ViewChildren } from '@angular/core'; import { NgForm } from '@angular/forms'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FusePerfectScrollbarDirective } from '@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive'; -import { ChatService } from '../chat.service'; +import { ChatService } from 'app/main/apps/chat/chat.service'; @Component({ - selector : 'fuse-chat-view', + selector : 'chat-view', templateUrl: './chat-view.component.html', styleUrls : ['./chat-view.component.scss'] }) -export class FuseChatViewComponent implements OnInit, AfterViewInit +export class ChatViewComponent implements OnInit, OnDestroy, AfterViewInit { user: any; chat: any; @@ -18,18 +20,44 @@ export class FuseChatViewComponent implements OnInit, AfterViewInit contact: any; replyInput: any; selectedChat: any; - @ViewChild(FusePerfectScrollbarDirective) directiveScroll: FusePerfectScrollbarDirective; - @ViewChildren('replyInput') replyInputField; - @ViewChild('replyForm') replyForm: NgForm; - constructor(private chatService: ChatService) + @ViewChild(FusePerfectScrollbarDirective) + directiveScroll: FusePerfectScrollbarDirective; + + @ViewChildren('replyInput') + replyInputField; + + @ViewChild('replyForm') + replyForm: NgForm; + + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ChatService} _chatService + */ + constructor( + private _chatService: ChatService + ) { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.user = this.chatService.user; - this.chatService.onChatSelected + this.user = this._chatService.user; + this._chatService.onChatSelected + .pipe(takeUntil(this._unsubscribeAll)) .subscribe(chatData => { if ( chatData ) { @@ -41,18 +69,41 @@ export class FuseChatViewComponent implements OnInit, AfterViewInit }); } - ngAfterViewInit() + /** + * After view init + */ + ngAfterViewInit(): void { this.replyInput = this.replyInputField.first.nativeElement; this.readyToReply(); } - selectContact() + /** + * On destroy + */ + ngOnDestroy(): void { - this.chatService.selectContact(this.contact); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - readyToReply() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Select contact + */ + selectContact(): void + { + this._chatService.selectContact(this.contact); + } + + /** + * Ready to reply + */ + readyToReply(): void { setTimeout(() => { this.replyForm.reset(); @@ -62,14 +113,22 @@ export class FuseChatViewComponent implements OnInit, AfterViewInit } - focusReplyInput() + /** + * Focus to the reply input + */ + focusReplyInput(): void { setTimeout(() => { this.replyInput.focus(); }); } - scrollToBottom(speed?: number) + /** + * Scroll to the bottom + * + * @param {number} speed + */ + scrollToBottom(speed?: number): void { speed = speed || 400; if ( this.directiveScroll ) @@ -82,7 +141,10 @@ export class FuseChatViewComponent implements OnInit, AfterViewInit } } - reply(event) + /** + * Reply + */ + reply(): void { // Message const message = { @@ -95,9 +157,8 @@ export class FuseChatViewComponent implements OnInit, AfterViewInit this.dialog.push(message); // Update the server - this.chatService.updateDialog(this.selectedChat.chatId, this.dialog).then(response => { + this._chatService.updateDialog(this.selectedChat.chatId, this.dialog).then(response => { this.readyToReply(); }); - } } diff --git a/src/app/main/apps/chat/chat.component.html b/src/app/main/apps/chat/chat.component.html index 2a903f8f..6967d337 100644 --- a/src/app/main/apps/chat/chat.component.html +++ b/src/app/main/apps/chat/chat.component.html @@ -15,20 +15,20 @@ - + - + - + - + diff --git a/src/app/main/apps/chat/chat.component.ts b/src/app/main/apps/chat/chat.component.ts index 31005479..fba6d3cb 100644 --- a/src/app/main/apps/chat/chat.component.ts +++ b/src/app/main/apps/chat/chat.component.ts @@ -1,30 +1,61 @@ -import { Component, OnInit, ViewEncapsulation } from '@angular/core'; +import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; -import { ChatService } from './chat.service'; +import { ChatService } from 'app/main/apps/chat/chat.service'; @Component({ - selector : 'fuse-chat', + selector : 'chat', templateUrl : './chat.component.html', styleUrls : ['./chat.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseChatComponent implements OnInit +export class ChatComponent implements OnInit, OnDestroy { selectedChat: any; - constructor(private chatService: ChatService) + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ChatService} _chatService + */ + constructor( + private _chatService: ChatService + ) { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.chatService.onChatSelected + this._chatService.onChatSelected + .pipe(takeUntil(this._unsubscribeAll)) .subscribe(chatData => { this.selectedChat = chatData; }); } + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } } diff --git a/src/app/main/apps/chat/chat.module.ts b/src/app/main/apps/chat/chat.module.ts index 2b80c69b..a54b46e5 100644 --- a/src/app/main/apps/chat/chat.module.ts +++ b/src/app/main/apps/chat/chat.module.ts @@ -5,20 +5,20 @@ import { MatButtonModule, MatCardModule, MatFormFieldModule, MatIconModule, MatI import { FuseSharedModule } from '@fuse/shared.module'; -import { ChatService } from './chat.service'; -import { FuseChatComponent } from './chat.component'; -import { FuseChatViewComponent } from './chat-view/chat-view.component'; -import { FuseChatStartComponent } from './chat-start/chat-start.component'; -import { FuseChatChatsSidenavComponent } from './sidenavs/left/chats/chats.component'; -import { FuseChatUserSidenavComponent } from './sidenavs/left/user/user.component'; -import { FuseChatLeftSidenavComponent } from './sidenavs/left/left.component'; -import { FuseChatRightSidenavComponent } from './sidenavs/right/right.component'; -import { FuseChatContactSidenavComponent } from './sidenavs/right/contact/contact.component'; +import { ChatService } from 'app/main/apps/chat/chat.service'; +import { ChatComponent } from 'app/main/apps/chat/chat.component'; +import { ChatStartComponent } from 'app/main/apps/chat/chat-start/chat-start.component'; +import { ChatViewComponent } from 'app/main/apps/chat/chat-view/chat-view.component'; +import { ChatChatsSidenavComponent } from 'app/main/apps/chat/sidenavs/left/chats/chats.component'; +import { ChatUserSidenavComponent } from 'app/main/apps/chat/sidenavs/left/user/user.component'; +import { ChatLeftSidenavComponent } from 'app/main/apps/chat/sidenavs/left/left.component'; +import { ChatRightSidenavComponent } from 'app/main/apps/chat/sidenavs/right/right.component'; +import { ChatContactSidenavComponent } from 'app/main/apps/chat/sidenavs/right/contact/contact.component'; const routes: Routes = [ { path : '**', - component: FuseChatComponent, + component: ChatComponent, children : [], resolve : { chat: ChatService @@ -28,14 +28,14 @@ const routes: Routes = [ @NgModule({ declarations: [ - FuseChatComponent, - FuseChatViewComponent, - FuseChatStartComponent, - FuseChatChatsSidenavComponent, - FuseChatUserSidenavComponent, - FuseChatLeftSidenavComponent, - FuseChatRightSidenavComponent, - FuseChatContactSidenavComponent + ChatComponent, + ChatViewComponent, + ChatStartComponent, + ChatChatsSidenavComponent, + ChatUserSidenavComponent, + ChatLeftSidenavComponent, + ChatRightSidenavComponent, + ChatContactSidenavComponent ], imports : [ RouterModule.forChild(routes), @@ -57,6 +57,6 @@ const routes: Routes = [ ChatService ] }) -export class FuseChatModule +export class ChatModule { } diff --git a/src/app/main/apps/chat/sidenavs/left/chats/chats.component.ts b/src/app/main/apps/chat/sidenavs/left/chats/chats.component.ts index d2261bfd..98a8c3a6 100644 --- a/src/app/main/apps/chat/sidenavs/left/chats/chats.component.ts +++ b/src/app/main/apps/chat/sidenavs/left/chats/chats.component.ts @@ -1,72 +1,132 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { ObservableMedia } from '@angular/flex-layout'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; import { FuseMatSidenavHelperService } from '@fuse/directives/fuse-mat-sidenav/fuse-mat-sidenav.service'; -import { ChatService } from '../../../chat.service'; +import { ChatService } from 'app/main/apps/chat/chat.service'; @Component({ - selector : 'fuse-chat-chats-sidenav', + selector : 'chat-chats-sidenav', templateUrl: './chats.component.html', styleUrls : ['./chats.component.scss'], animations : fuseAnimations }) -export class FuseChatChatsSidenavComponent implements OnInit +export class ChatChatsSidenavComponent implements OnInit, OnDestroy { - user: any; chats: any[]; - contacts: any[]; chatSearch: any; - searchText = ''; + contacts: any[]; + searchText: string; + user: any; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ChatService} _chatService + * @param {FuseMatSidenavHelperService} _fuseMatSidenavHelperService + * @param {ObservableMedia} _observableMedia + */ constructor( - private chatService: ChatService, - private fuseMatSidenavService: FuseMatSidenavHelperService, - public media: ObservableMedia + private _chatService: ChatService, + private _fuseMatSidenavHelperService: FuseMatSidenavHelperService, + public _observableMedia: ObservableMedia ) { + // Set the defaults this.chatSearch = { name: '' }; + this.searchText = ''; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.user = this.chatService.user; - this.chats = this.chatService.chats; - this.contacts = this.chatService.contacts; + this.user = this._chatService.user; + this.chats = this._chatService.chats; + this.contacts = this._chatService.contacts; - this.chatService.onChatsUpdated.subscribe(updatedChats => { - this.chats = updatedChats; - }); + this._chatService.onChatsUpdated + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(updatedChats => { + this.chats = updatedChats; + }); - this.chatService.onUserUpdated.subscribe(updatedUser => { - this.user = updatedUser; - }); + this._chatService.onUserUpdated + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(updatedUser => { + this.user = updatedUser; + }); } - getChat(contact) + /** + * On destroy + */ + ngOnDestroy(): void { - this.chatService.getChat(contact); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } - if ( !this.media.isActive('gt-md') ) + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Get chat + * + * @param contact + */ + getChat(contact): void + { + this._chatService.getChat(contact); + + if ( !this._observableMedia.isActive('gt-md') ) { - this.fuseMatSidenavService.getSidenav('chat-left-sidenav').toggle(); + this._fuseMatSidenavHelperService.getSidenav('chat-left-sidenav').toggle(); } } - setUserStatus(status) + /** + * Set user status + * + * @param status + */ + setUserStatus(status): void { - this.chatService.setUserStatus(status); + this._chatService.setUserStatus(status); } - changeLeftSidenavView(view) + /** + * Change left sidenav view + * + * @param view + */ + changeLeftSidenavView(view): void { - this.chatService.onLeftSidenavViewChanged.next(view); + this._chatService.onLeftSidenavViewChanged.next(view); } - logout() + /** + * Logout + */ + logout(): void { console.log('logout triggered'); } diff --git a/src/app/main/apps/chat/sidenavs/left/left.component.html b/src/app/main/apps/chat/sidenavs/left/left.component.html index 5595a45f..3c23e7eb 100644 --- a/src/app/main/apps/chat/sidenavs/left/left.component.html +++ b/src/app/main/apps/chat/sidenavs/left/left.component.html @@ -1,11 +1,11 @@
- - + + - - + +
diff --git a/src/app/main/apps/chat/sidenavs/left/left.component.ts b/src/app/main/apps/chat/sidenavs/left/left.component.ts index 0854b6b3..a3f988a3 100644 --- a/src/app/main/apps/chat/sidenavs/left/left.component.ts +++ b/src/app/main/apps/chat/sidenavs/left/left.component.ts @@ -1,29 +1,63 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; -import { ChatService } from '../../chat.service'; +import { ChatService } from 'app/main/apps/chat/chat.service'; @Component({ - selector : 'fuse-chat-left-sidenav', + selector : 'chat-left-sidenav', templateUrl: './left.component.html', styleUrls : ['./left.component.scss'], animations : fuseAnimations }) -export class FuseChatLeftSidenavComponent implements OnInit +export class ChatLeftSidenavComponent implements OnInit, OnDestroy { view: string; - constructor(private chatService: ChatService) + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ChatService} _chatService + */ + constructor( + private _chatService: ChatService + ) { + // Set the defaults this.view = 'chats'; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.chatService.onLeftSidenavViewChanged.subscribe(view => { - this.view = view; - }); + this._chatService.onLeftSidenavViewChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(view => { + this.view = view; + }); } + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } } diff --git a/src/app/main/apps/chat/sidenavs/left/user/user.component.ts b/src/app/main/apps/chat/sidenavs/left/user/user.component.ts index 7250c2b8..8cbf54e1 100644 --- a/src/app/main/apps/chat/sidenavs/left/user/user.component.ts +++ b/src/app/main/apps/chat/sidenavs/left/user/user.component.ts @@ -1,48 +1,87 @@ import { Component, OnDestroy, OnInit } from '@angular/core'; import { FormControl, FormGroup } from '@angular/forms'; -import { debounceTime, distinctUntilChanged } from 'rxjs/operators'; +import { Subject } from 'rxjs'; +import { debounceTime, distinctUntilChanged, takeUntil } from 'rxjs/operators'; -import { ChatService } from '../../../chat.service'; +import { ChatService } from 'app/main/apps/chat/chat.service'; @Component({ - selector : 'fuse-chat-user-sidenav', + selector : 'chat-user-sidenav', templateUrl: './user.component.html', styleUrls : ['./user.component.scss'] }) -export class FuseChatUserSidenavComponent implements OnInit, OnDestroy +export class ChatUserSidenavComponent implements OnInit, OnDestroy { user: any; - onFormChange: any; userForm: FormGroup; - constructor(private chatService: ChatService) + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ChatService} _chatService + */ + constructor( + private _chatService: ChatService + ) { - this.user = this.chatService.user; + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + this.user = this._chatService.user; + this.userForm = new FormGroup({ mood : new FormControl(this.user.mood), status: new FormControl(this.user.status) }); + + this.userForm.valueChanges + .pipe( + takeUntil(this._unsubscribeAll), + debounceTime(500), + distinctUntilChanged() + ) + .subscribe(data => { + this.user.mood = data.mood; + this.user.status = data.status; + this._chatService.updateUserData(this.user); + }); } - ngOnInit() + /** + * On destroy + */ + ngOnDestroy(): void { - this.onFormChange = this.userForm.valueChanges.pipe( - debounceTime(500), - distinctUntilChanged() - ).subscribe(data => { - this.user.mood = data.mood; - this.user.status = data.status; - this.chatService.updateUserData(this.user); - }); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - changeLeftSidenavView(view) + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Change left sidenav view + * + * @param view + */ + changeLeftSidenavView(view): void { - this.chatService.onLeftSidenavViewChanged.next(view); + this._chatService.onLeftSidenavViewChanged.next(view); } - ngOnDestroy() - { - this.onFormChange.unsubscribe(); - } } diff --git a/src/app/main/apps/chat/sidenavs/right/contact/contact.component.ts b/src/app/main/apps/chat/sidenavs/right/contact/contact.component.ts index be6a10a2..85f25438 100644 --- a/src/app/main/apps/chat/sidenavs/right/contact/contact.component.ts +++ b/src/app/main/apps/chat/sidenavs/right/contact/contact.component.ts @@ -1,26 +1,57 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; -import { ChatService } from '../../../chat.service'; +import { ChatService } from 'app/main/apps/chat/chat.service'; @Component({ - selector : 'fuse-chat-contact-sidenav', + selector : 'chat-contact-sidenav', templateUrl: './contact.component.html', styleUrls : ['./contact.component.scss'] }) -export class FuseChatContactSidenavComponent implements OnInit +export class ChatContactSidenavComponent implements OnInit, OnDestroy { contact: any; - constructor(private chatService: ChatService) - { + // Private + private _unsubscribeAll: Subject; + /** + * Constructor + * + * @param {ChatService} _chatService + */ + constructor( + private _chatService: ChatService + ) + { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.chatService.onContactSelected.subscribe(contact => { + this._chatService.onContactSelected + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(contact => { this.contact = contact; }); } + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } } diff --git a/src/app/main/apps/chat/sidenavs/right/right.component.html b/src/app/main/apps/chat/sidenavs/right/right.component.html index 35e7b937..1b28582a 100644 --- a/src/app/main/apps/chat/sidenavs/right/right.component.html +++ b/src/app/main/apps/chat/sidenavs/right/right.component.html @@ -1,8 +1,8 @@
- - + +
diff --git a/src/app/main/apps/chat/sidenavs/right/right.component.ts b/src/app/main/apps/chat/sidenavs/right/right.component.ts index 7ed97497..cb08c0c6 100644 --- a/src/app/main/apps/chat/sidenavs/right/right.component.ts +++ b/src/app/main/apps/chat/sidenavs/right/right.component.ts @@ -1,29 +1,59 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; -import { ChatService } from '../../chat.service'; +import { ChatService } from 'app/main/apps/chat/chat.service'; @Component({ - selector : 'fuse-chat-right-sidenav', + selector : 'chat-right-sidenav', templateUrl: './right.component.html', styleUrls : ['./right.component.scss'], animations : fuseAnimations }) -export class FuseChatRightSidenavComponent implements OnInit +export class ChatRightSidenavComponent implements OnInit, OnDestroy { view: string; - constructor(private chatService: ChatService) + // Private + private _unsubscribeAll: Subject; + + constructor( + private _chatService: ChatService + ) { + // Set the defaults this.view = 'contact'; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.chatService.onRightSidenavViewChanged.subscribe(view => { - this.view = view; - }); + this._chatService.onRightSidenavViewChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(view => { + this.view = view; + }); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } } diff --git a/src/app/main/apps/contacts/contact-form/contact-form.component.ts b/src/app/main/apps/contacts/contact-form/contact-form.component.ts index 767024b5..81cb180e 100644 --- a/src/app/main/apps/contacts/contact-form/contact-form.component.ts +++ b/src/app/main/apps/contacts/contact-form/contact-form.component.ts @@ -2,37 +2,41 @@ import { Component, Inject, ViewEncapsulation } from '@angular/core'; import { FormBuilder, FormGroup } from '@angular/forms'; import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material'; -import { CalendarEvent } from 'angular-calendar'; - -import { Contact } from '../contact.model'; +import { Contact } from 'app/main/apps/contacts/contact.model'; @Component({ - selector : 'fuse-contacts-contact-form-dialog', + selector : 'contacts-contact-form-dialog', templateUrl : './contact-form.component.html', styleUrls : ['./contact-form.component.scss'], encapsulation: ViewEncapsulation.None }) -export class FuseContactsContactFormDialogComponent +export class ContactsContactFormDialogComponent { - event: CalendarEvent; - dialogTitle: string; - contactForm: FormGroup; action: string; contact: Contact; + contactForm: FormGroup; + dialogTitle: string; + /** + * Constructor + * + * @param {MatDialogRef} _dialogRef + * @param _data + * @param {FormBuilder} _formBuilder + */ constructor( - public dialogRef: MatDialogRef, - @Inject(MAT_DIALOG_DATA) private data: any, - private formBuilder: FormBuilder + private _dialogRef: MatDialogRef, + @Inject(MAT_DIALOG_DATA) private _data: any, + private _formBuilder: FormBuilder ) { - this.action = data.action; + this.action = _data.action; if ( this.action === 'edit' ) { this.dialogTitle = 'Edit Contact'; - this.contact = data.contact; + this.contact = _data.contact; } else { @@ -43,9 +47,18 @@ export class FuseContactsContactFormDialogComponent this.contactForm = this.createContactForm(); } - createContactForm() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Create contact form + * + * @returns {FormGroup} + */ + createContactForm(): FormGroup { - return this.formBuilder.group({ + return this._formBuilder.group({ id : [this.contact.id], name : [this.contact.name], lastName: [this.contact.lastName], diff --git a/src/app/main/apps/contacts/contact-list/contact-list.component.scss b/src/app/main/apps/contacts/contact-list/contact-list.component.scss index 14510b4a..a8b26b96 100644 --- a/src/app/main/apps/contacts/contact-list/contact-list.component.scss +++ b/src/app/main/apps/contacts/contact-list/contact-list.component.scss @@ -1,6 +1,6 @@ @import "src/@fuse/scss/fuse"; -fuse-contacts-contact-list { +contacts-contact-list { display: flex; flex: 1 1 auto; width: 100%; diff --git a/src/app/main/apps/contacts/contact-list/contact-list.component.ts b/src/app/main/apps/contacts/contact-list/contact-list.component.ts index b41d1693..2443be7a 100644 --- a/src/app/main/apps/contacts/contact-list/contact-list.component.ts +++ b/src/app/main/apps/contacts/contact-list/contact-list.component.ts @@ -2,24 +2,26 @@ import { Component, OnDestroy, OnInit, TemplateRef, ViewChild, ViewEncapsulation import { FormGroup } from '@angular/forms'; import { MatDialog, MatDialogRef } from '@angular/material'; import { DataSource } from '@angular/cdk/collections'; -import { Observable, Subscription } from 'rxjs'; +import { Observable, Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; import { FuseConfirmDialogComponent } from '@fuse/components/confirm-dialog/confirm-dialog.component'; -import { FuseContactsContactFormDialogComponent } from '../contact-form/contact-form.component'; -import { ContactsService } from '../contacts.service'; +import { ContactsService } from 'app/main/apps/contacts/contacts.service'; +import { ContactsContactFormDialogComponent } from 'app/main/apps/contacts/contact-form/contact-form.component'; @Component({ - selector : 'fuse-contacts-contact-list', + selector : 'contacts-contact-list', templateUrl : './contact-list.component.html', styleUrls : ['./contact-list.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseContactsContactListComponent implements OnInit, OnDestroy +export class ContactsContactListComponent implements OnInit, OnDestroy { - @ViewChild('dialogContent') dialogContent: TemplateRef; + @ViewChild('dialogContent') + dialogContent: TemplateRef; contacts: any; user: any; @@ -27,24 +29,41 @@ export class FuseContactsContactListComponent implements OnInit, OnDestroy displayedColumns = ['checkbox', 'avatar', 'name', 'email', 'phone', 'jobTitle', 'buttons']; selectedContacts: any[]; checkboxes: {}; - - onContactsChangedSubscription: Subscription; - onFilterChangedSubscription: Subscription; - onSelectedContactsChangedSubscription: Subscription; - onUserDataChangedSubscription: Subscription; - dialogRef: any; - confirmDialogRef: MatDialogRef; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ContactsService} _contactsService + * @param {MatDialog} _matDialog + */ constructor( - private contactsService: ContactsService, - public dialog: MatDialog + private _contactsService: ContactsService, + public _matDialog: MatDialog ) { - this.onContactsChangedSubscription = - this.contactsService.onContactsChanged.subscribe(contacts => { + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + this.dataSource = new FilesDataSource(this._contactsService); + + this._contactsService.onContactsChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(contacts => { this.contacts = contacts; this.checkboxes = {}; @@ -53,8 +72,9 @@ export class FuseContactsContactListComponent implements OnInit, OnDestroy }); }); - this.onSelectedContactsChangedSubscription = - this.contactsService.onSelectedContactsChanged.subscribe(selectedContacts => { + this._contactsService.onSelectedContactsChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(selectedContacts => { for ( const id in this.checkboxes ) { if ( !this.checkboxes.hasOwnProperty(id) ) @@ -67,33 +87,41 @@ export class FuseContactsContactListComponent implements OnInit, OnDestroy this.selectedContacts = selectedContacts; }); - this.onUserDataChangedSubscription = - this.contactsService.onUserDataChanged.subscribe(user => { + this._contactsService.onUserDataChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(user => { this.user = user; }); - this.onFilterChangedSubscription = - this.contactsService.onFilterChanged.subscribe(() => { - this.contactsService.deselectContacts(); + this._contactsService.onFilterChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this._contactsService.deselectContacts(); }); } - ngOnInit() + /** + * On destroy + */ + ngOnDestroy(): void { - this.dataSource = new FilesDataSource(this.contactsService); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - ngOnDestroy() - { - this.onContactsChangedSubscription.unsubscribe(); - this.onFilterChangedSubscription.unsubscribe(); - this.onSelectedContactsChangedSubscription.unsubscribe(); - this.onUserDataChangedSubscription.unsubscribe(); - } + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- - editContact(contact) + /** + * Edit contact + * + * @param contact + */ + editContact(contact): void { - this.dialogRef = this.dialog.open(FuseContactsContactFormDialogComponent, { + this.dialogRef = this._matDialog.open(ContactsContactFormDialogComponent, { panelClass: 'contact-form-dialog', data : { contact: contact, @@ -116,7 +144,7 @@ export class FuseContactsContactListComponent implements OnInit, OnDestroy */ case 'save': - this.contactsService.updateContact(formData.getRawValue()); + this._contactsService.updateContact(formData.getRawValue()); break; /** @@ -134,9 +162,9 @@ export class FuseContactsContactListComponent implements OnInit, OnDestroy /** * Delete Contact */ - deleteContact(contact) + deleteContact(contact): void { - this.confirmDialogRef = this.dialog.open(FuseConfirmDialogComponent, { + this.confirmDialogRef = this._matDialog.open(FuseConfirmDialogComponent, { disableClose: false }); @@ -145,19 +173,29 @@ export class FuseContactsContactListComponent implements OnInit, OnDestroy this.confirmDialogRef.afterClosed().subscribe(result => { if ( result ) { - this.contactsService.deleteContact(contact); + this._contactsService.deleteContact(contact); } this.confirmDialogRef = null; }); } - onSelectedChange(contactId) + /** + * On selected change + * + * @param contactId + */ + onSelectedChange(contactId): void { - this.contactsService.toggleSelectedContact(contactId); + this._contactsService.toggleSelectedContact(contactId); } - toggleStar(contactId) + /** + * Toggle star + * + * @param contactId + */ + toggleStar(contactId): void { if ( this.user.starred.includes(contactId) ) { @@ -168,24 +206,37 @@ export class FuseContactsContactListComponent implements OnInit, OnDestroy this.user.starred.push(contactId); } - this.contactsService.updateUserData(this.user); + this._contactsService.updateUserData(this.user); } } export class FilesDataSource extends DataSource { - constructor(private contactsService: ContactsService) + /** + * Constructor + * + * @param {ContactsService} _contactsService + */ + constructor( + private _contactsService: ContactsService + ) { super(); } - /** Connect function called by the table to retrieve one stream containing the data to render. */ + /** + * Connect function called by the table to retrieve one stream containing the data to render. + * @returns {Observable} + */ connect(): Observable { - return this.contactsService.onContactsChanged; + return this._contactsService.onContactsChanged; } - disconnect() + /** + * Disconnect + */ + disconnect(): void { } } diff --git a/src/app/main/apps/contacts/contact.model.ts b/src/app/main/apps/contacts/contact.model.ts index efc5e687..3a5df6c6 100644 --- a/src/app/main/apps/contacts/contact.model.ts +++ b/src/app/main/apps/contacts/contact.model.ts @@ -15,6 +15,11 @@ export class Contact birthday: string; notes: string; + /** + * Constructor + * + * @param contact + */ constructor(contact) { { diff --git a/src/app/main/apps/contacts/contacts.component.html b/src/app/main/apps/contacts/contacts.component.html index 56f9661c..8c7b73f4 100644 --- a/src/app/main/apps/contacts/contacts.component.html +++ b/src/app/main/apps/contacts/contacts.component.html @@ -36,7 +36,7 @@ - + @@ -45,7 +45,7 @@ - + @@ -56,7 +56,7 @@
- +
diff --git a/src/app/main/apps/contacts/contacts.component.ts b/src/app/main/apps/contacts/contacts.component.ts index da705aad..dea74ea6 100644 --- a/src/app/main/apps/contacts/contacts.component.ts +++ b/src/app/main/apps/contacts/contacts.component.ts @@ -1,40 +1,94 @@ import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { FormControl, FormGroup } from '@angular/forms'; import { MatDialog } from '@angular/material'; - -import { Subscription } from 'rxjs'; -import { debounceTime, distinctUntilChanged } from 'rxjs/operators'; +import { Subject } from 'rxjs'; +import { debounceTime, distinctUntilChanged, takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; -import { FuseContactsContactFormDialogComponent } from './contact-form/contact-form.component'; -import { ContactsService } from './contacts.service'; +import { ContactsService } from 'app/main/apps/contacts/contacts.service'; +import { ContactsContactFormDialogComponent } from 'app/main/apps/contacts/contact-form/contact-form.component'; @Component({ - selector : 'fuse-contacts', + selector : 'contacts', templateUrl : './contacts.component.html', styleUrls : ['./contacts.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseContactsComponent implements OnInit, OnDestroy +export class ContactsComponent implements OnInit, OnDestroy { + dialogRef: any; hasSelectedContacts: boolean; searchInput: FormControl; - dialogRef: any; - onSelectedContactsChangedSubscription: Subscription; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ContactsService} _contactsService + * @param {MatDialog} _matDialog + */ constructor( - private contactsService: ContactsService, - public dialog: MatDialog + private _contactsService: ContactsService, + public _matDialog: MatDialog ) { + // Set the defaults this.searchInput = new FormControl(''); + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - newContact() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.dialogRef = this.dialog.open(FuseContactsContactFormDialogComponent, { + this._contactsService.onSelectedContactsChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(selectedContacts => { + this.hasSelectedContacts = selectedContacts.length > 0; + }); + + this.searchInput.valueChanges + .pipe( + takeUntil(this._unsubscribeAll), + debounceTime(300), + distinctUntilChanged() + ) + .subscribe(searchText => { + this._contactsService.onSearchTextChanged.next(searchText); + }); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * New contact + */ + newContact(): void + { + this.dialogRef = this._matDialog.open(ContactsContactFormDialogComponent, { panelClass: 'contact-form-dialog', data : { action: 'new' @@ -48,32 +102,7 @@ export class FuseContactsComponent implements OnInit, OnDestroy return; } - this.contactsService.updateContact(response.getRawValue()); - + this._contactsService.updateContact(response.getRawValue()); }); - - } - - ngOnInit() - { - this.onSelectedContactsChangedSubscription = - this.contactsService.onSelectedContactsChanged - .subscribe(selectedContacts => { - this.hasSelectedContacts = selectedContacts.length > 0; - }); - - this.searchInput.valueChanges - .pipe( - debounceTime(300), - distinctUntilChanged() - ) - .subscribe(searchText => { - this.contactsService.onSearchTextChanged.next(searchText); - }); - } - - ngOnDestroy() - { - this.onSelectedContactsChangedSubscription.unsubscribe(); } } diff --git a/src/app/main/apps/contacts/contacts.module.ts b/src/app/main/apps/contacts/contacts.module.ts index fd3a1a5a..e1125816 100644 --- a/src/app/main/apps/contacts/contacts.module.ts +++ b/src/app/main/apps/contacts/contacts.module.ts @@ -7,17 +7,17 @@ import { MatButtonModule, MatCheckboxModule, MatDatepickerModule, MatFormFieldMo import { FuseSharedModule } from '@fuse/shared.module'; import { FuseConfirmDialogModule } from '@fuse/components'; -import { FuseContactsMainSidenavComponent } from './sidenavs/main/main.component'; -import { FuseContactsComponent } from './contacts.component'; -import { ContactsService } from './contacts.service'; -import { FuseContactsContactListComponent } from './contact-list/contact-list.component'; -import { FuseContactsSelectedBarComponent } from './selected-bar/selected-bar.component'; -import { FuseContactsContactFormDialogComponent } from './contact-form/contact-form.component'; +import { ContactsComponent } from 'app/main/apps/contacts/contacts.component'; +import { ContactsService } from 'app/main/apps/contacts/contacts.service'; +import { ContactsContactListComponent } from 'app/main/apps/contacts/contact-list/contact-list.component'; +import { ContactsSelectedBarComponent } from 'app/main/apps/contacts/selected-bar/selected-bar.component'; +import { ContactsMainSidenavComponent } from 'app/main/apps/contacts/sidenavs/main/main.component'; +import { ContactsContactFormDialogComponent } from 'app/main/apps/contacts/contact-form/contact-form.component'; const routes: Routes = [ { path : '**', - component: FuseContactsComponent, + component: ContactsComponent, resolve : { contacts: ContactsService } @@ -26,11 +26,11 @@ const routes: Routes = [ @NgModule({ declarations : [ - FuseContactsComponent, - FuseContactsContactListComponent, - FuseContactsSelectedBarComponent, - FuseContactsMainSidenavComponent, - FuseContactsContactFormDialogComponent + ContactsComponent, + ContactsContactListComponent, + ContactsSelectedBarComponent, + ContactsMainSidenavComponent, + ContactsContactFormDialogComponent ], imports : [ RouterModule.forChild(routes), @@ -54,8 +54,10 @@ const routes: Routes = [ providers : [ ContactsService ], - entryComponents: [FuseContactsContactFormDialogComponent] + entryComponents: [ + ContactsContactFormDialogComponent + ] }) -export class FuseContactsModule +export class ContactsModule { } diff --git a/src/app/main/apps/contacts/contacts.service.ts b/src/app/main/apps/contacts/contacts.service.ts index 66563638..35da8fbd 100644 --- a/src/app/main/apps/contacts/contacts.service.ts +++ b/src/app/main/apps/contacts/contacts.service.ts @@ -5,7 +5,7 @@ import { BehaviorSubject, Observable, Subject } from 'rxjs'; import { FuseUtils } from '@fuse/utils'; -import { Contact } from './contact.model'; +import { Contact } from 'app/main/apps/contacts/contact.model'; @Injectable() export class ContactsService implements Resolve @@ -23,12 +23,24 @@ export class ContactsService implements Resolve searchText: string; filterBy: string; - constructor(private http: HttpClient) + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ + constructor( + private _httpClient: HttpClient + ) { } + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + /** - * The Contacts App Main Resolver + * Resolver + * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state * @returns {Observable | Promise | any} @@ -61,10 +73,15 @@ export class ContactsService implements Resolve }); } + /** + * Get contacts + * + * @returns {Promise} + */ getContacts(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/contacts-contacts') + this._httpClient.get('api/contacts-contacts') .subscribe((response: any) => { this.contacts = response; @@ -99,10 +116,15 @@ export class ContactsService implements Resolve ); } + /** + * Get user data + * + * @returns {Promise} + */ getUserData(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/contacts-user/5725a6802d10e277a0f35724') + this._httpClient.get('api/contacts-user/5725a6802d10e277a0f35724') .subscribe((response: any) => { this.user = response; this.onUserDataChanged.next(this.user); @@ -114,9 +136,10 @@ export class ContactsService implements Resolve /** * Toggle selected contact by id + * * @param id */ - toggleSelectedContact(id) + toggleSelectedContact(id): void { // First, check if we already have that contact as selected... if ( this.selectedContacts.length > 0 ) @@ -145,7 +168,7 @@ export class ContactsService implements Resolve /** * Toggle select all */ - toggleSelectAll() + toggleSelectAll(): void { if ( this.selectedContacts.length > 0 ) { @@ -157,11 +180,17 @@ export class ContactsService implements Resolve } } - selectContacts(filterParameter?, filterValue?) + /** + * Select contacts + * + * @param filterParameter + * @param filterValue + */ + selectContacts(filterParameter?, filterValue?): void { this.selectedContacts = []; - // If there is no filter, select all todos + // If there is no filter, select all contacts if ( filterParameter === undefined || filterValue === undefined ) { this.selectedContacts = []; @@ -169,24 +198,22 @@ export class ContactsService implements Resolve this.selectedContacts.push(contact.id); }); } - else - { - /* this.selectedContacts.push(... - this.contacts.filter(todo => { - return todo[filterParameter] === filterValue; - }) - );*/ - } // Trigger the next event this.onSelectedContactsChanged.next(this.selectedContacts); } - updateContact(contact) + /** + * Update contact + * + * @param contact + * @returns {Promise} + */ + updateContact(contact): Promise { return new Promise((resolve, reject) => { - this.http.post('api/contacts-contacts/' + contact.id, {...contact}) + this._httpClient.post('api/contacts-contacts/' + contact.id, {...contact}) .subscribe(response => { this.getContacts(); resolve(response); @@ -194,10 +221,16 @@ export class ContactsService implements Resolve }); } - updateUserData(userData) + /** + * Update user data + * + * @param userData + * @returns {Promise} + */ + updateUserData(userData): Promise { return new Promise((resolve, reject) => { - this.http.post('api/contacts-user/' + this.user.id, {...userData}) + this._httpClient.post('api/contacts-user/' + this.user.id, {...userData}) .subscribe(response => { this.getUserData(); this.getContacts(); @@ -206,7 +239,10 @@ export class ContactsService implements Resolve }); } - deselectContacts() + /** + * Deselect contacts + */ + deselectContacts(): void { this.selectedContacts = []; @@ -214,14 +250,22 @@ export class ContactsService implements Resolve this.onSelectedContactsChanged.next(this.selectedContacts); } - deleteContact(contact) + /** + * Delete contact + * + * @param contact + */ + deleteContact(contact): void { const contactIndex = this.contacts.indexOf(contact); this.contacts.splice(contactIndex, 1); this.onContactsChanged.next(this.contacts); } - deleteSelectedContacts() + /** + * Delete selected contacts + */ + deleteSelectedContacts(): void { for ( const contactId of this.selectedContacts ) { diff --git a/src/app/main/apps/contacts/selected-bar/selected-bar.component.ts b/src/app/main/apps/contacts/selected-bar/selected-bar.component.ts index d9c09a5b..fa499a69 100644 --- a/src/app/main/apps/contacts/selected-bar/selected-bar.component.ts +++ b/src/app/main/apps/contacts/selected-bar/selected-bar.component.ts @@ -1,63 +1,110 @@ -import { Component } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { MatDialog, MatDialogRef } from '@angular/material'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FuseConfirmDialogComponent } from '@fuse/components/confirm-dialog/confirm-dialog.component'; -import { ContactsService } from '../contacts.service'; +import { ContactsService } from 'app/main/apps/contacts/contacts.service'; @Component({ - selector : 'fuse-selected-bar', + selector : 'selected-bar', templateUrl: './selected-bar.component.html', styleUrls : ['./selected-bar.component.scss'] }) -export class FuseContactsSelectedBarComponent +export class ContactsSelectedBarComponent implements OnInit, OnDestroy { - selectedContacts: string[]; + confirmDialogRef: MatDialogRef; hasSelectedContacts: boolean; isIndeterminate: boolean; - confirmDialogRef: MatDialogRef; + selectedContacts: string[]; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ContactsService} _contactsService + * @param {MatDialog} _matDialog + */ constructor( - private contactsService: ContactsService, - public dialog: MatDialog + private _contactsService: ContactsService, + public _matDialog: MatDialog ) { - this.contactsService.onSelectedContactsChanged + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + this._contactsService.onSelectedContactsChanged + .pipe(takeUntil(this._unsubscribeAll)) .subscribe(selectedContacts => { this.selectedContacts = selectedContacts; setTimeout(() => { this.hasSelectedContacts = selectedContacts.length > 0; - this.isIndeterminate = (selectedContacts.length !== this.contactsService.contacts.length && selectedContacts.length > 0); + this.isIndeterminate = (selectedContacts.length !== this._contactsService.contacts.length && selectedContacts.length > 0); }, 0); }); - } - selectAll() + /** + * On destroy + */ + ngOnDestroy(): void { - this.contactsService.selectContacts(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - deselectAll() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Select all + */ + selectAll(): void { - this.contactsService.deselectContacts(); + this._contactsService.selectContacts(); } - deleteSelectedContacts() + /** + * Deselect all + */ + deselectAll(): void { - this.confirmDialogRef = this.dialog.open(FuseConfirmDialogComponent, { + this._contactsService.deselectContacts(); + } + + /** + * Delete selected contacts + */ + deleteSelectedContacts(): void + { + this.confirmDialogRef = this._matDialog.open(FuseConfirmDialogComponent, { disableClose: false }); this.confirmDialogRef.componentInstance.confirmMessage = 'Are you sure you want to delete all selected contacts?'; - this.confirmDialogRef.afterClosed().subscribe(result => { - if ( result ) - { - this.contactsService.deleteSelectedContacts(); - } - this.confirmDialogRef = null; - }); + this.confirmDialogRef.afterClosed() + .subscribe(result => { + if ( result ) + { + this._contactsService.deleteSelectedContacts(); + } + this.confirmDialogRef = null; + }); } - } diff --git a/src/app/main/apps/contacts/sidenavs/main/main.component.ts b/src/app/main/apps/contacts/sidenavs/main/main.component.ts index de4b2275..a9196309 100644 --- a/src/app/main/apps/contacts/sidenavs/main/main.component.ts +++ b/src/app/main/apps/contacts/sidenavs/main/main.component.ts @@ -1,37 +1,75 @@ -import { Component, OnDestroy } from '@angular/core'; -import { Subscription } from 'rxjs'; +import { Component, OnDestroy, OnInit } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; -import { ContactsService } from '../../contacts.service'; +import { ContactsService } from 'app/main/apps/contacts/contacts.service'; @Component({ - selector : 'fuse-contacts-main-sidenav', + selector : 'contacts-main-sidenav', templateUrl: './main.component.html', styleUrls : ['./main.component.scss'] }) -export class FuseContactsMainSidenavComponent implements OnDestroy +export class ContactsMainSidenavComponent implements OnInit, OnDestroy { user: any; filterBy: string; - - onUserDataChangedSubscription: Subscription; - constructor(private contactsService: ContactsService) + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ContactsService} _contactsService + */ + constructor( + private _contactsService: ContactsService + ) { - this.filterBy = this.contactsService.filterBy || 'all'; - this.onUserDataChangedSubscription = - this.contactsService.onUserDataChanged.subscribe(user => { + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + this.filterBy = this._contactsService.filterBy || 'all'; + + this._contactsService.onUserDataChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(user => { this.user = user; }); } - changeFilter(filter) - { - this.filterBy = filter; - this.contactsService.onFilterChanged.next(this.filterBy); - } - + /** + * On destroy + */ ngOnDestroy() { - this.onUserDataChangedSubscription.unsubscribe(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Change the filter + * + * @param filter + */ + changeFilter(filter): void + { + this.filterBy = filter; + this._contactsService.onFilterChanged.next(this.filterBy); } } diff --git a/src/app/main/apps/dashboards/analytics/analytics.component.ts b/src/app/main/apps/dashboards/analytics/analytics.component.ts index c1b78979..41829f65 100644 --- a/src/app/main/apps/dashboards/analytics/analytics.component.ts +++ b/src/app/main/apps/dashboards/analytics/analytics.component.ts @@ -1,36 +1,56 @@ -import { Component, ViewEncapsulation } from '@angular/core'; +import { Component, OnInit, ViewEncapsulation } from '@angular/core'; -import { AnalyticsDashboardService } from './analytics.service'; import { fuseAnimations } from '@fuse/animations'; +import { AnalyticsDashboardService } from 'app/main/apps/dashboards/analytics/analytics.service'; + @Component({ - selector : 'fuse-analytics-dashboard', + selector : 'analytics-dashboard', templateUrl : './analytics.component.html', styleUrls : ['./analytics.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseAnalyticsDashboardComponent +export class AnalyticsDashboardComponent implements OnInit { widgets: any; widget1SelectedYear = '2016'; widget5SelectedDay = 'today'; + /** + * Constructor + * + * @param {AnalyticsDashboardService} _analyticsDashboardService + */ constructor( - private analyticsDashboardService: AnalyticsDashboardService + private _analyticsDashboardService: AnalyticsDashboardService ) { - // Get the widgets from the service - this.widgets = this.analyticsDashboardService.widgets; - // Register the custom chart.js plugin - this.registerCustomChartJSPlugin(); + this._registerCustomChartJSPlugin(); } + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + // Get the widgets from the service + this.widgets = this._analyticsDashboardService.widgets; + } + + // ----------------------------------------------------------------------------------------------------- + // @ Private methods + // ----------------------------------------------------------------------------------------------------- + /** * Register a custom plugin */ - registerCustomChartJSPlugin() + private _registerCustomChartJSPlugin(): void { (window).Chart.plugins.register({ afterDatasetsDraw: function (chart, easing) { diff --git a/src/app/main/apps/dashboards/analytics/analytics.module.ts b/src/app/main/apps/dashboards/analytics/analytics.module.ts index 710521ca..6e4cd406 100644 --- a/src/app/main/apps/dashboards/analytics/analytics.module.ts +++ b/src/app/main/apps/dashboards/analytics/analytics.module.ts @@ -1,8 +1,6 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; - import { MatButtonModule, MatFormFieldModule, MatIconModule, MatMenuModule, MatSelectModule, MatTabsModule } from '@angular/material'; - import { AgmCoreModule } from '@agm/core'; import { ChartsModule } from 'ng2-charts'; import { NgxChartsModule } from '@swimlane/ngx-charts'; @@ -10,14 +8,13 @@ import { NgxChartsModule } from '@swimlane/ngx-charts'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseWidgetModule } from '@fuse/components/widget/widget.module'; -import { FuseAnalyticsDashboardComponent } from './analytics.component'; -import { AnalyticsDashboardService } from './analytics.service'; - +import { AnalyticsDashboardComponent } from 'app/main/apps/dashboards/analytics/analytics.component'; +import { AnalyticsDashboardService } from 'app/main/apps/dashboards/analytics/analytics.service'; const routes: Routes = [ { path : '**', - component: FuseAnalyticsDashboardComponent, + component: AnalyticsDashboardComponent, resolve : { data: AnalyticsDashboardService } @@ -26,7 +23,7 @@ const routes: Routes = [ @NgModule({ declarations: [ - FuseAnalyticsDashboardComponent + AnalyticsDashboardComponent ], imports : [ RouterModule.forChild(routes), @@ -51,7 +48,7 @@ const routes: Routes = [ AnalyticsDashboardService ] }) -export class FuseAnalyticsDashboardModule +export class AnalyticsDashboardModule { } diff --git a/src/app/main/apps/dashboards/analytics/analytics.service.ts b/src/app/main/apps/dashboards/analytics/analytics.service.ts index 47d3097c..69f1fddb 100644 --- a/src/app/main/apps/dashboards/analytics/analytics.service.ts +++ b/src/app/main/apps/dashboards/analytics/analytics.service.ts @@ -8,14 +8,20 @@ export class AnalyticsDashboardService implements Resolve { widgets: any[]; + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ constructor( - private http: HttpClient + private _httpClient: HttpClient ) { } /** - * Resolve + * Resolver + * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state * @returns {Observable | Promise | any} @@ -35,10 +41,15 @@ export class AnalyticsDashboardService implements Resolve }); } + /** + * Get widgets + * + * @returns {Promise} + */ getWidgets(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/analytics-dashboard-widgets') + this._httpClient.get('api/analytics-dashboard-widgets') .subscribe((response: any) => { this.widgets = response; resolve(response); diff --git a/src/app/main/apps/dashboards/project/project.component.ts b/src/app/main/apps/dashboards/project/project.component.ts index deeadfff..fb26613c 100644 --- a/src/app/main/apps/dashboards/project/project.component.ts +++ b/src/app/main/apps/dashboards/project/project.component.ts @@ -1,21 +1,20 @@ import { Component, OnInit, ViewEncapsulation } from '@angular/core'; import { DataSource } from '@angular/cdk/collections'; import { BehaviorSubject, Observable } from 'rxjs'; - import * as shape from 'd3-shape'; import { fuseAnimations } from '@fuse/animations'; -import { ProjectDashboardService } from './project.service'; +import { ProjectDashboardService } from 'app/main/apps/dashboards/project/project.service'; @Component({ - selector : 'fuse-project-dashboard', + selector : 'project-dashboard', templateUrl : './project.component.html', styleUrls : ['./project.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseProjectDashboardComponent implements OnInit +export class ProjectDashboardComponent implements OnInit { projects: any[]; selectedProject: any; @@ -30,12 +29,15 @@ export class FuseProjectDashboardComponent implements OnInit dateNow = Date.now(); - constructor(private projectDashboardService: ProjectDashboardService) + /** + * Constructor + * + * @param {ProjectDashboardService} _projectDashboardService + */ + constructor( + private _projectDashboardService: ProjectDashboardService + ) { - this.projects = this.projectDashboardService.projects; - this.selectedProject = this.projects[0]; - this.widgets = this.projectDashboardService.widgets; - /** * Widget 5 */ @@ -139,8 +141,19 @@ export class FuseProjectDashboardComponent implements OnInit } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { + this.projects = this._projectDashboardService.projects; + this.selectedProject = this.projects[0]; + this.widgets = this._projectDashboardService.widgets; + /** * Widget 11 */ @@ -152,18 +165,30 @@ export class FuseProjectDashboardComponent implements OnInit export class FilesDataSource extends DataSource { - constructor(private widget11) + /** + * Constructor + * + * @param _widget11 + */ + constructor(private _widget11) { super(); } - /** Connect function called by the table to retrieve one stream containing the data to render. */ + /** + * Connect function called by the table to retrieve one stream containing the data to render. + * + * @returns {Observable} + */ connect(): Observable { - return this.widget11.onContactsChanged; + return this._widget11.onContactsChanged; } - disconnect() + /** + * Disconnect + */ + disconnect(): void { } } diff --git a/src/app/main/apps/dashboards/project/project.module.ts b/src/app/main/apps/dashboards/project/project.module.ts index 23dcf8d9..88290f27 100644 --- a/src/app/main/apps/dashboards/project/project.module.ts +++ b/src/app/main/apps/dashboards/project/project.module.ts @@ -1,21 +1,19 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; import { CdkTableModule } from '@angular/cdk/table'; - import { MatButtonModule, MatDividerModule, MatFormFieldModule, MatIconModule, MatMenuModule, MatSelectModule, MatSidenavModule, MatTableModule, MatTabsModule } from '@angular/material'; - import { NgxChartsModule } from '@swimlane/ngx-charts'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseWidgetModule } from '@fuse/components/widget/widget.module'; -import { FuseProjectDashboardComponent } from './project.component'; -import { ProjectDashboardService } from './project.service'; +import { ProjectDashboardComponent } from 'app/main/apps/dashboards/project/project.component'; +import { ProjectDashboardService } from 'app/main/apps/dashboards/project/project.service'; const routes: Routes = [ { path : '**', - component: FuseProjectDashboardComponent, + component: ProjectDashboardComponent, resolve : { data: ProjectDashboardService } @@ -24,7 +22,7 @@ const routes: Routes = [ @NgModule({ declarations: [ - FuseProjectDashboardComponent + ProjectDashboardComponent ], imports : [ RouterModule.forChild(routes), @@ -49,7 +47,7 @@ const routes: Routes = [ ProjectDashboardService ] }) -export class FuseProjectDashboardModule +export class ProjectDashboardModule { } diff --git a/src/app/main/apps/dashboards/project/project.service.ts b/src/app/main/apps/dashboards/project/project.service.ts index a1ee2128..d697fd32 100644 --- a/src/app/main/apps/dashboards/project/project.service.ts +++ b/src/app/main/apps/dashboards/project/project.service.ts @@ -9,14 +9,20 @@ export class ProjectDashboardService implements Resolve projects: any[]; widgets: any[]; + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ constructor( - private http: HttpClient + private _httpClient: HttpClient ) { } /** - * Resolve + * Resolver + * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state * @returns {Observable | Promise | any} @@ -38,10 +44,15 @@ export class ProjectDashboardService implements Resolve }); } + /** + * Get projects + * + * @returns {Promise} + */ getProjects(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/project-dashboard-projects') + this._httpClient.get('api/project-dashboard-projects') .subscribe((response: any) => { this.projects = response; resolve(response); @@ -49,10 +60,15 @@ export class ProjectDashboardService implements Resolve }); } + /** + * Get widgets + * + * @returns {Promise} + */ getWidgets(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/project-dashboard-widgets') + this._httpClient.get('api/project-dashboard-widgets') .subscribe((response: any) => { this.widgets = response; resolve(response); diff --git a/src/app/main/apps/e-commerce/dashboard/dashboard.component.ts b/src/app/main/apps/e-commerce/dashboard/dashboard.component.ts index 5039c66f..684c021f 100644 --- a/src/app/main/apps/e-commerce/dashboard/dashboard.component.ts +++ b/src/app/main/apps/e-commerce/dashboard/dashboard.component.ts @@ -1,17 +1,17 @@ -import { Component, ViewEncapsulation } from '@angular/core'; +import { Component, OnInit, ViewEncapsulation } from '@angular/core'; import { fuseAnimations } from '@fuse/animations'; -import { EcommerceDashboardService } from './dashboard.service'; +import { EcommerceDashboardService } from 'app/main/apps/e-commerce/dashboard/dashboard.service'; @Component({ - selector : 'fuse-e-commerce-dashboard', + selector : 'e-commerce-dashboard', templateUrl : './dashboard.component.html', styleUrls : ['./dashboard.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseEcommerceDashboardComponent +export class EcommerceDashboardComponent implements OnInit { projects: any[]; selectedProject: any; @@ -21,12 +21,10 @@ export class FuseEcommerceDashboardComponent widget6: any = {}; widget7: any = {}; - constructor(private projectsDashboardService: EcommerceDashboardService) + constructor( + private _eCommerceDashboardService: EcommerceDashboardService + ) { - this.projects = this.projectsDashboardService.projects; - this.selectedProject = this.projects[0]; - this.widgets = this.projectsDashboardService.widgets; - /** * Widget 5 */ @@ -74,4 +72,18 @@ export class FuseEcommerceDashboardComponent }; } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + this.projects = this._eCommerceDashboardService.projects; + this.selectedProject = this.projects[0]; + this.widgets = this._eCommerceDashboardService.widgets; + } } diff --git a/src/app/main/apps/e-commerce/dashboard/dashboard.service.ts b/src/app/main/apps/e-commerce/dashboard/dashboard.service.ts index 8810da76..625a215b 100644 --- a/src/app/main/apps/e-commerce/dashboard/dashboard.service.ts +++ b/src/app/main/apps/e-commerce/dashboard/dashboard.service.ts @@ -9,21 +9,26 @@ export class EcommerceDashboardService implements Resolve projects: any[]; widgets: any[]; + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ constructor( - private http: HttpClient + private _httpClient: HttpClient ) { } /** - * Resolve + * Resolver + * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state * @returns {Observable | Promise | any} */ resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable | Promise | any { - return new Promise((resolve, reject) => { Promise.all([ @@ -38,10 +43,15 @@ export class EcommerceDashboardService implements Resolve }); } + /** + * Get projects + * + * @returns {Promise} + */ getProjects(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/project-dashboard-projects') + this._httpClient.get('api/project-dashboard-projects') .subscribe((response: any) => { this.projects = response; resolve(response); @@ -49,10 +59,15 @@ export class EcommerceDashboardService implements Resolve }); } + /** + * Get widgets + * + * @returns {Promise} + */ getWidgets(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/e-commerce-dashboard') + this._httpClient.get('api/e-commerce-dashboard') .subscribe((response: any) => { this.widgets = response; resolve(response); diff --git a/src/app/main/apps/e-commerce/e-commerce.module.ts b/src/app/main/apps/e-commerce/e-commerce.module.ts index f6a09c35..b01a6ff2 100644 --- a/src/app/main/apps/e-commerce/e-commerce.module.ts +++ b/src/app/main/apps/e-commerce/e-commerce.module.ts @@ -1,65 +1,63 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; import { CdkTableModule } from '@angular/cdk/table'; - -import { MatButtonModule, MatChipsModule, MatFormFieldModule, MatIconModule, MatInputModule, MatPaginatorModule, MatRippleModule, MatSelectModule, MatSortModule, MatTableModule, MatTabsModule } from '@angular/material'; - +import { MatButtonModule, MatChipsModule, MatFormFieldModule, MatIconModule, MatInputModule, MatPaginatorModule, MatRippleModule, MatSelectModule, MatSnackBarModule, MatSortModule, MatTableModule, MatTabsModule } from '@angular/material'; import { NgxChartsModule } from '@swimlane/ngx-charts'; import { AgmCoreModule } from '@agm/core'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseWidgetModule } from '@fuse/components/widget/widget.module'; -import { FuseEcommerceDashboardComponent } from './dashboard/dashboard.component'; -import { EcommerceDashboardService } from './dashboard/dashboard.service'; -import { FuseEcommerceProductsComponent } from './products/products.component'; -import { EcommerceProductsService } from './products/products.service'; -import { FuseEcommerceProductComponent } from './product/product.component'; -import { EcommerceProductService } from './product/product.service'; -import { FuseEcommerceOrdersComponent } from './orders/orders.component'; -import { EcommerceOrdersService } from './orders/orders.service'; -import { FuseEcommerceOrderComponent } from './order/order.component'; -import { EcommerceOrderService } from './order/order.service'; +import { EcommerceDashboardComponent } from 'app/main/apps/e-commerce/dashboard/dashboard.component'; +import { EcommerceDashboardService } from 'app/main/apps/e-commerce/dashboard/dashboard.service'; +import { EcommerceProductsComponent } from 'app/main/apps/e-commerce/products/products.component'; +import { EcommerceProductsService } from 'app/main/apps/e-commerce/products/products.service'; +import { EcommerceProductComponent } from 'app/main/apps/e-commerce/product/product.component'; +import { EcommerceProductService } from 'app/main/apps/e-commerce/product/product.service'; +import { EcommerceOrdersComponent } from 'app/main/apps/e-commerce/orders/orders.component'; +import { EcommerceOrdersService } from 'app/main/apps/e-commerce/orders/orders.service'; +import { EcommerceOrderComponent } from 'app/main/apps/e-commerce/order/order.component'; +import { EcommerceOrderService } from 'app/main/apps/e-commerce/order/order.service'; const routes: Routes = [ { path : 'dashboard', - component: FuseEcommerceDashboardComponent, + component: EcommerceDashboardComponent, resolve : { data: EcommerceDashboardService } }, { path : 'products', - component: FuseEcommerceProductsComponent, + component: EcommerceProductsComponent, resolve : { data: EcommerceProductsService } }, { path : 'products/:id', - component: FuseEcommerceProductComponent, + component: EcommerceProductComponent, resolve : { data: EcommerceProductService } }, { path : 'products/:id/:handle', - component: FuseEcommerceProductComponent, + component: EcommerceProductComponent, resolve : { data: EcommerceProductService } }, { path : 'orders', - component: FuseEcommerceOrdersComponent, + component: EcommerceOrdersComponent, resolve : { data: EcommerceOrdersService } }, { path : 'orders/:id', - component: FuseEcommerceOrderComponent, + component: EcommerceOrderComponent, resolve : { data: EcommerceOrderService } @@ -68,11 +66,11 @@ const routes: Routes = [ @NgModule({ declarations: [ - FuseEcommerceDashboardComponent, - FuseEcommerceProductsComponent, - FuseEcommerceProductComponent, - FuseEcommerceOrdersComponent, - FuseEcommerceOrderComponent + EcommerceDashboardComponent, + EcommerceProductsComponent, + EcommerceProductComponent, + EcommerceOrdersComponent, + EcommerceOrderComponent ], imports : [ RouterModule.forChild(routes), @@ -87,6 +85,7 @@ const routes: Routes = [ MatRippleModule, MatSelectModule, MatSortModule, + MatSnackBarModule, MatTableModule, MatTabsModule, @@ -106,6 +105,6 @@ const routes: Routes = [ EcommerceOrderService ] }) -export class FuseEcommerceModule +export class EcommerceModule { } diff --git a/src/app/main/apps/e-commerce/order/order.component.ts b/src/app/main/apps/e-commerce/order/order.component.ts index be7260a3..e51c56e8 100644 --- a/src/app/main/apps/e-commerce/order/order.component.ts +++ b/src/app/main/apps/e-commerce/order/order.component.ts @@ -1,12 +1,13 @@ import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { FormBuilder, FormGroup } from '@angular/forms'; -import { Subscription } from 'rxjs'; +import { Subject} from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; -import { Order } from './order.model'; -import { EcommerceOrderService } from './order.service'; -import { orderStatuses } from './order-statuses'; +import { orderStatuses } from 'app/main/apps/e-commerce/order/order-statuses'; +import { Order } from 'app/main/apps/e-commerce/order/order.model'; +import { EcommerceOrderService } from 'app/main/apps/e-commerce/order/order.service'; @Component({ selector : 'fuse-e-commerce-order', @@ -15,41 +16,73 @@ import { orderStatuses } from './order-statuses'; encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseEcommerceOrderComponent implements OnInit, OnDestroy +export class EcommerceOrderComponent implements OnInit, OnDestroy { - order = new Order(); - onOrderChanged: Subscription; + order: Order; + orderStatuses: any; statusForm: FormGroup; - orderStatuses = orderStatuses; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {EcommerceOrderService} _ecommerceOrderService + * @param {FormBuilder} _formBuilder + */ constructor( - private orderService: EcommerceOrderService, - private formBuilder: FormBuilder, + private _ecommerceOrderService: EcommerceOrderService, + private _formBuilder: FormBuilder ) { + // Set the defaults + this.order = new Order(); + this.orderStatuses = orderStatuses; + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { // Subscribe to update order on changes - this.onOrderChanged = - this.orderService.onOrderChanged - .subscribe(order => { - this.order = new Order(order); - }); + this._ecommerceOrderService.onOrderChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(order => { + this.order = new Order(order); + }); - this.statusForm = this.formBuilder.group({ + this.statusForm = this._formBuilder.group({ newStatus: [''] }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.onOrderChanged.unsubscribe(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - updateStatus() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Update status + */ + updateStatus(): void { const newStatusId = Number.parseInt(this.statusForm.get('newStatus').value); diff --git a/src/app/main/apps/e-commerce/order/order.model.ts b/src/app/main/apps/e-commerce/order/order.model.ts index 9c2fb68d..dd3d4a39 100644 --- a/src/app/main/apps/e-commerce/order/order.model.ts +++ b/src/app/main/apps/e-commerce/order/order.model.ts @@ -15,6 +15,11 @@ export class Order payment: any; shippingDetails: any[]; + /** + * Constructor + * + * @param order + */ constructor(order?) { order = order || {}; diff --git a/src/app/main/apps/e-commerce/order/order.service.ts b/src/app/main/apps/e-commerce/order/order.service.ts index b1f74180..46a7f2fc 100644 --- a/src/app/main/apps/e-commerce/order/order.service.ts +++ b/src/app/main/apps/e-commerce/order/order.service.ts @@ -10,21 +10,26 @@ export class EcommerceOrderService implements Resolve order: any; onOrderChanged: BehaviorSubject = new BehaviorSubject({}); + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ constructor( - private http: HttpClient + private _httpClient: HttpClient ) { } /** - * Resolve + * Resolver + * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state * @returns {Observable | Promise | any} */ resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable | Promise | any { - this.routeParams = route.params; return new Promise((resolve, reject) => { @@ -40,10 +45,15 @@ export class EcommerceOrderService implements Resolve }); } + /** + * Get order + * + * @returns {Promise} + */ getOrder(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/e-commerce-orders/' + this.routeParams.id) + this._httpClient.get('api/e-commerce-orders/' + this.routeParams.id) .subscribe((response: any) => { this.order = response; this.onOrderChanged.next(this.order); @@ -52,20 +62,32 @@ export class EcommerceOrderService implements Resolve }); } - saveOrder(order) + /** + * Save order + * + * @param order + * @returns {Promise} + */ + saveOrder(order): Promise { return new Promise((resolve, reject) => { - this.http.post('api/e-commerce-orders/' + order.id, order) + this._httpClient.post('api/e-commerce-orders/' + order.id, order) .subscribe((response: any) => { resolve(response); }, reject); }); } - addOrder(order) + /** + * Add order + * + * @param order + * @returns {Promise} + */ + addOrder(order): Promise { return new Promise((resolve, reject) => { - this.http.post('api/e-commerce-orders/', order) + this._httpClient.post('api/e-commerce-orders/', order) .subscribe((response: any) => { resolve(response); }, reject); diff --git a/src/app/main/apps/e-commerce/orders/orders.component.ts b/src/app/main/apps/e-commerce/orders/orders.component.ts index abc86808..5b1582ab 100644 --- a/src/app/main/apps/e-commerce/orders/orders.component.ts +++ b/src/app/main/apps/e-commerce/orders/orders.component.ts @@ -1,58 +1,117 @@ -import { Component, ElementRef, OnInit, ViewChild } from '@angular/core'; +import { Component, ElementRef, OnDestroy, OnInit, ViewChild } from '@angular/core'; import { MatPaginator, MatSort } from '@angular/material'; import { DataSource } from '@angular/cdk/collections'; - -import { merge, Observable, BehaviorSubject, fromEvent } from 'rxjs'; +import { merge, Observable, BehaviorSubject, fromEvent, Subject } from 'rxjs'; import { debounceTime, distinctUntilChanged, map } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; import { FuseUtils } from '@fuse/utils'; -import { EcommerceOrdersService } from './orders.service'; +import { EcommerceOrdersService } from 'app/main/apps/e-commerce/orders/orders.service'; +import { takeUntil } from 'rxjs/internal/operators'; @Component({ - selector : 'fuse-e-commerce-orders', + selector : 'e-commerce-orders', templateUrl: './orders.component.html', styleUrls : ['./orders.component.scss'], animations : fuseAnimations }) -export class FuseEcommerceOrdersComponent implements OnInit +export class EcommerceOrdersComponent implements OnInit, OnDestroy { dataSource: FilesDataSource | null; displayedColumns = ['id', 'reference', 'customer', 'total', 'payment', 'status', 'date']; - @ViewChild(MatPaginator) paginator: MatPaginator; - @ViewChild('filter') filter: ElementRef; - @ViewChild(MatSort) sort: MatSort; + @ViewChild(MatPaginator) + paginator: MatPaginator; + @ViewChild('filter') + filter: ElementRef; + + @ViewChild(MatSort) + sort: MatSort; + + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {EcommerceOrdersService} _ecommerceOrdersService + */ constructor( - private ordersService: EcommerceOrdersService + private _ecommerceOrdersService: EcommerceOrdersService ) { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() - { - this.dataSource = new FilesDataSource(this.ordersService, this.paginator, this.sort); + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- - fromEvent(this.filter.nativeElement, 'keyup').pipe( - debounceTime(150), - distinctUntilChanged() - ).subscribe(() => { - if ( !this.dataSource ) - { - return; - } - this.dataSource.filter = this.filter.nativeElement.value; - }); + /** + * On init + */ + ngOnInit(): void + { + this.dataSource = new FilesDataSource(this._ecommerceOrdersService, this.paginator, this.sort); + + fromEvent(this.filter.nativeElement, 'keyup') + .pipe( + takeUntil(this._unsubscribeAll), + debounceTime(150), + distinctUntilChanged() + ) + .subscribe(() => { + if ( !this.dataSource ) + { + return; + } + this.dataSource.filter = this.filter.nativeElement.value; + }); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } } export class FilesDataSource extends DataSource { - _filterChange = new BehaviorSubject(''); - _filteredDataChange = new BehaviorSubject(''); + // Private + private _filterChange = new BehaviorSubject(''); + private _filteredDataChange = new BehaviorSubject(''); + /** + * Constructor + * + * @param {EcommerceOrdersService} _ecommerceOrdersService + * @param {MatPaginator} _matPaginator + * @param {MatSort} _matSort + */ + constructor( + private _ecommerceOrdersService: EcommerceOrdersService, + private _matPaginator: MatPaginator, + private _matSort: MatSort + ) + { + super(); + + this.filteredData = this._ecommerceOrdersService.orders; + } + + // ----------------------------------------------------------------------------------------------------- + // @ Accessors + // ----------------------------------------------------------------------------------------------------- + + // Filtered data get filteredData(): any { return this._filteredDataChange.value; @@ -63,6 +122,7 @@ export class FilesDataSource extends DataSource this._filteredDataChange.next(value); } + // Filter get filter(): string { return this._filterChange.value; @@ -73,29 +133,27 @@ export class FilesDataSource extends DataSource this._filterChange.next(filter); } - constructor( - private ordersService: EcommerceOrdersService, - private _paginator: MatPaginator, - private _sort: MatSort - ) - { - super(); - this.filteredData = this.ordersService.orders; - } + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- - /** Connect function called by the table to retrieve one stream containing the data to render. */ + /** + * Connect function called by the table to retrieve one stream containing the data to render. + * + * @returns {Observable} + */ connect(): Observable { const displayDataChanges = [ - this.ordersService.onOrdersChanged, - this._paginator.page, + this._ecommerceOrdersService.onOrdersChanged, + this._matPaginator.page, this._filterChange, - this._sort.sortChange + this._matSort.sortChange ]; return merge(...displayDataChanges).pipe(map(() => { - let data = this.ordersService.orders.slice(); + let data = this._ecommerceOrdersService.orders.slice(); data = this.filterData(data); @@ -104,14 +162,20 @@ export class FilesDataSource extends DataSource data = this.sortData(data); // Grab the page's slice of data. - const startIndex = this._paginator.pageIndex * this._paginator.pageSize; - return data.splice(startIndex, this._paginator.pageSize); + const startIndex = this._matPaginator.pageIndex * this._matPaginator.pageSize; + return data.splice(startIndex, this._matPaginator.pageSize); }) ); } - filterData(data) + /** + * Filter data + * + * @param data + * @returns {any} + */ + filterData(data): any { if ( !this.filter ) { @@ -120,9 +184,15 @@ export class FilesDataSource extends DataSource return FuseUtils.filterArrayByString(data, this.filter); } + /** + * Sort data + * + * @param data + * @returns {any[]} + */ sortData(data): any[] { - if ( !this._sort.active || this._sort.direction === '' ) + if ( !this._matSort.active || this._matSort.direction === '' ) { return data; } @@ -131,7 +201,7 @@ export class FilesDataSource extends DataSource let propertyA: number | string = ''; let propertyB: number | string = ''; - switch ( this._sort.active ) + switch ( this._matSort.active ) { case 'id': [propertyA, propertyB] = [a.id, b.id]; @@ -159,11 +229,14 @@ export class FilesDataSource extends DataSource const valueA = isNaN(+propertyA) ? propertyA : +propertyA; const valueB = isNaN(+propertyB) ? propertyB : +propertyB; - return (valueA < valueB ? -1 : 1) * (this._sort.direction === 'asc' ? 1 : -1); + return (valueA < valueB ? -1 : 1) * (this._matSort.direction === 'asc' ? 1 : -1); }); } - disconnect() + /** + * Disconnect + */ + disconnect(): void { } } diff --git a/src/app/main/apps/e-commerce/orders/orders.service.ts b/src/app/main/apps/e-commerce/orders/orders.service.ts index 4ade65c8..e557807a 100644 --- a/src/app/main/apps/e-commerce/orders/orders.service.ts +++ b/src/app/main/apps/e-commerce/orders/orders.service.ts @@ -9,21 +9,26 @@ export class EcommerceOrdersService implements Resolve orders: any[]; onOrdersChanged: BehaviorSubject = new BehaviorSubject({}); + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ constructor( - private http: HttpClient + private _httpClient: HttpClient ) { } /** - * Resolve + * Resolver + * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state * @returns {Observable | Promise | any} */ resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable | Promise | any { - return new Promise((resolve, reject) => { Promise.all([ @@ -37,10 +42,15 @@ export class EcommerceOrdersService implements Resolve }); } + /** + * Get orders + * + * @returns {Promise} + */ getOrders(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/e-commerce-orders') + this._httpClient.get('api/e-commerce-orders') .subscribe((response: any) => { this.orders = response; this.onOrdersChanged.next(this.orders); diff --git a/src/app/main/apps/e-commerce/product/product.component.ts b/src/app/main/apps/e-commerce/product/product.component.ts index 76eba648..01a9918a 100644 --- a/src/app/main/apps/e-commerce/product/product.component.ts +++ b/src/app/main/apps/e-commerce/product/product.component.ts @@ -1,68 +1,105 @@ import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { FormBuilder, FormGroup } from '@angular/forms'; +import { Location } from '@angular/common'; import { MatSnackBar } from '@angular/material'; -import { Subscription } from 'rxjs'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; import { FuseUtils } from '@fuse/utils'; -import { Product } from './product.model'; -import { EcommerceProductService } from './product.service'; -import { Location } from '@angular/common'; +import { Product } from 'app/main/apps/e-commerce/product/product.model'; +import { EcommerceProductService } from 'app/main/apps/e-commerce/product/product.service'; @Component({ - selector : 'fuse-e-commerce-product', + selector : 'e-commerce-product', templateUrl : './product.component.html', styleUrls : ['./product.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseEcommerceProductComponent implements OnInit, OnDestroy +export class EcommerceProductComponent implements OnInit, OnDestroy { - product = new Product(); - onProductChanged: Subscription; + product: Product; pageType: string; productForm: FormGroup; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {EcommerceProductService} _ecommerceProductService + * @param {FormBuilder} _formBuilder + * @param {Location} _location + * @param {MatSnackBar} _matSnackBar + */ constructor( - private productService: EcommerceProductService, - private formBuilder: FormBuilder, - public snackBar: MatSnackBar, - private location: Location + private _ecommerceProductService: EcommerceProductService, + private _formBuilder: FormBuilder, + private _location: Location, + private _matSnackBar: MatSnackBar ) { + // Set the default + this.product = new Product(); + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { // Subscribe to update product on changes - this.onProductChanged = - this.productService.onProductChanged - .subscribe(product => { + this._ecommerceProductService.onProductChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(product => { - if ( product ) - { - this.product = new Product(product); - this.pageType = 'edit'; - } - else - { - this.pageType = 'new'; - this.product = new Product(); - } + if ( product ) + { + this.product = new Product(product); + this.pageType = 'edit'; + } + else + { + this.pageType = 'new'; + this.product = new Product(); + } - this.productForm = this.createProductForm(); - }); + this.productForm = this.createProductForm(); + }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.onProductChanged.unsubscribe(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - createProductForm() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Create product form + * + * @returns {FormGroup} + */ + createProductForm(): FormGroup { - return this.formBuilder.group({ + return this._formBuilder.group({ id : [this.product.id], name : [this.product.name], handle : [this.product.handle], @@ -85,42 +122,50 @@ export class FuseEcommerceProductComponent implements OnInit, OnDestroy }); } - saveProduct() + /** + * Save product + */ + saveProduct(): void { const data = this.productForm.getRawValue(); data.handle = FuseUtils.handleize(data.name); - this.productService.saveProduct(data) + + this._ecommerceProductService.saveProduct(data) .then(() => { // Trigger the subscription with new data - this.productService.onProductChanged.next(data); + this._ecommerceProductService.onProductChanged.next(data); // Show the success message - this.snackBar.open('Product saved', 'OK', { + this._matSnackBar.open('Product saved', 'OK', { verticalPosition: 'top', duration : 2000 }); }); } - addProduct() + /** + * Add product + */ + addProduct(): void { const data = this.productForm.getRawValue(); data.handle = FuseUtils.handleize(data.name); - this.productService.addProduct(data) + + this._ecommerceProductService.addProduct(data) .then(() => { // Trigger the subscription with new data - this.productService.onProductChanged.next(data); + this._ecommerceProductService.onProductChanged.next(data); // Show the success message - this.snackBar.open('Product added', 'OK', { + this._matSnackBar.open('Product added', 'OK', { verticalPosition: 'top', duration : 2000 }); // Change the location with new one - this.location.go('apps/e-commerce/products/' + this.product.id + '/' + this.product.handle); + this._location.go('apps/e-commerce/products/' + this.product.id + '/' + this.product.handle); }); } } diff --git a/src/app/main/apps/e-commerce/product/product.model.ts b/src/app/main/apps/e-commerce/product/product.model.ts index a77e2596..3195482e 100644 --- a/src/app/main/apps/e-commerce/product/product.model.ts +++ b/src/app/main/apps/e-commerce/product/product.model.ts @@ -29,6 +29,11 @@ export class Product extraShippingFee: number; active: boolean; + /** + * Constructor + * + * @param product + */ constructor(product?) { product = product || {}; @@ -53,6 +58,11 @@ export class Product this.active = product.active || true; } + /** + * Add category + * + * @param {MatChipInputEvent} event + */ addCategory(event: MatChipInputEvent): void { const input = event.input; @@ -71,7 +81,12 @@ export class Product } } - removeCategory(category) + /** + * Remove category + * + * @param category + */ + removeCategory(category): void { const index = this.categories.indexOf(category); @@ -81,6 +96,11 @@ export class Product } } + /** + * Add tag + * + * @param {MatChipInputEvent} event + */ addTag(event: MatChipInputEvent): void { const input = event.input; @@ -99,7 +119,12 @@ export class Product } } - removeTag(tag) + /** + * Remove tag + * + * @param tag + */ + removeTag(tag): void { const index = this.tags.indexOf(tag); diff --git a/src/app/main/apps/e-commerce/product/product.service.ts b/src/app/main/apps/e-commerce/product/product.service.ts index 50f4aa73..70e79e47 100644 --- a/src/app/main/apps/e-commerce/product/product.service.ts +++ b/src/app/main/apps/e-commerce/product/product.service.ts @@ -10,21 +10,26 @@ export class EcommerceProductService implements Resolve product: any; onProductChanged: BehaviorSubject = new BehaviorSubject({}); + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ constructor( - private http: HttpClient + private _httpClient: HttpClient ) { } /** - * Resolve + * Resolver + * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state * @returns {Observable | Promise | any} */ resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable | Promise | any { - this.routeParams = route.params; return new Promise((resolve, reject) => { @@ -40,6 +45,11 @@ export class EcommerceProductService implements Resolve }); } + /** + * Get product + * + * @returns {Promise} + */ getProduct(): Promise { return new Promise((resolve, reject) => { @@ -50,7 +60,7 @@ export class EcommerceProductService implements Resolve } else { - this.http.get('api/e-commerce-products/' + this.routeParams.id) + this._httpClient.get('api/e-commerce-products/' + this.routeParams.id) .subscribe((response: any) => { this.product = response; this.onProductChanged.next(this.product); @@ -60,20 +70,32 @@ export class EcommerceProductService implements Resolve }); } - saveProduct(product) + /** + * Save product + * + * @param product + * @returns {Promise} + */ + saveProduct(product): Promise { return new Promise((resolve, reject) => { - this.http.post('api/e-commerce-products/' + product.id, product) + this._httpClient.post('api/e-commerce-products/' + product.id, product) .subscribe((response: any) => { resolve(response); }, reject); }); } - addProduct(product) + /** + * Add product + * + * @param product + * @returns {Promise} + */ + addProduct(product): Promise { return new Promise((resolve, reject) => { - this.http.post('api/e-commerce-products/', product) + this._httpClient.post('api/e-commerce-products/', product) .subscribe((response: any) => { resolve(response); }, reject); diff --git a/src/app/main/apps/e-commerce/products/products.component.ts b/src/app/main/apps/e-commerce/products/products.component.ts index 4b36e25f..7a3df669 100644 --- a/src/app/main/apps/e-commerce/products/products.component.ts +++ b/src/app/main/apps/e-commerce/products/products.component.ts @@ -1,59 +1,134 @@ import { Component, ElementRef, OnInit, ViewChild } from '@angular/core'; import { MatPaginator, MatSort } from '@angular/material'; import { DataSource } from '@angular/cdk/collections'; - -import { merge, Observable, BehaviorSubject, fromEvent } from 'rxjs'; +import { merge, Observable, BehaviorSubject, fromEvent, Subject } from 'rxjs'; import { debounceTime, distinctUntilChanged, map } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; import { FuseUtils } from '@fuse/utils'; -import { EcommerceProductsService } from './products.service'; +import { EcommerceProductsService } from 'app/main/apps/e-commerce/products/products.service'; +import { takeUntil } from 'rxjs/internal/operators'; @Component({ - selector : 'fuse-e-commerce-products', + selector : 'e-commerce-products', templateUrl: './products.component.html', styleUrls : ['./products.component.scss'], animations : fuseAnimations }) -export class FuseEcommerceProductsComponent implements OnInit +export class EcommerceProductsComponent implements OnInit { dataSource: FilesDataSource | null; displayedColumns = ['id', 'image', 'name', 'category', 'price', 'quantity', 'active']; - @ViewChild(MatPaginator) paginator: MatPaginator; - @ViewChild('filter') filter: ElementRef; - @ViewChild(MatSort) sort: MatSort; + @ViewChild(MatPaginator) + paginator: MatPaginator; + + @ViewChild(MatSort) + sort: MatSort; + + @ViewChild('filter') + filter: ElementRef; + + // Private + private _unsubscribeAll: Subject; constructor( - private productsService: EcommerceProductsService + private _ecommerceProductsService: EcommerceProductsService ) { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.dataSource = new FilesDataSource(this.productsService, this.paginator, this.sort); + this.dataSource = new FilesDataSource(this._ecommerceProductsService, this.paginator, this.sort); - fromEvent(this.filter.nativeElement, 'keyup').pipe( - debounceTime(150), - distinctUntilChanged() - ).subscribe(() => { - if ( !this.dataSource ) - { - return; - } + fromEvent(this.filter.nativeElement, 'keyup') + .pipe( + takeUntil(this._unsubscribeAll), + debounceTime(150), + distinctUntilChanged() + ) + .subscribe(() => { + if ( !this.dataSource ) + { + return; + } - this.dataSource.filter = this.filter.nativeElement.value; - }); + this.dataSource.filter = this.filter.nativeElement.value; + }); } } export class FilesDataSource extends DataSource { - _filterChange = new BehaviorSubject(''); - _filteredDataChange = new BehaviorSubject(''); + private _filterChange = new BehaviorSubject(''); + private _filteredDataChange = new BehaviorSubject(''); + /** + * Constructor + * + * @param {EcommerceProductsService} _ecommerceProductsService + * @param {MatPaginator} _matPaginator + * @param {MatSort} _matSort + */ + constructor( + private _ecommerceProductsService: EcommerceProductsService, + private _matPaginator: MatPaginator, + private _matSort: MatSort + ) + { + super(); + + this.filteredData = this._ecommerceProductsService.products; + } + + /** + * Connect function called by the table to retrieve one stream containing the data to render. + * + * @returns {Observable} + */ + connect(): Observable + { + const displayDataChanges = [ + this._ecommerceProductsService.onProductsChanged, + this._matPaginator.page, + this._filterChange, + this._matSort.sortChange + ]; + + return merge(...displayDataChanges) + .pipe( + map(() => { + let data = this._ecommerceProductsService.products.slice(); + + data = this.filterData(data); + + this.filteredData = [...data]; + + data = this.sortData(data); + + // Grab the page's slice of data. + const startIndex = this._matPaginator.pageIndex * this._matPaginator.pageSize; + return data.splice(startIndex, this._matPaginator.pageSize); + } + )); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Accessors + // ----------------------------------------------------------------------------------------------------- + + // Filtered data get filteredData(): any { return this._filteredDataChange.value; @@ -64,6 +139,7 @@ export class FilesDataSource extends DataSource this._filteredDataChange.next(value); } + // Filter get filter(): string { return this._filterChange.value; @@ -74,44 +150,17 @@ export class FilesDataSource extends DataSource this._filterChange.next(filter); } - constructor( - private productsService: EcommerceProductsService, - private _paginator: MatPaginator, - private _sort: MatSort - ) - { - super(); - this.filteredData = this.productsService.products; - } + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- - /** Connect function called by the table to retrieve one stream containing the data to render. */ - connect(): Observable - { - const displayDataChanges = [ - this.productsService.onProductsChanged, - this._paginator.page, - this._filterChange, - this._sort.sortChange - ]; - - return merge(...displayDataChanges).pipe(map(() => { - - let data = this.productsService.products.slice(); - - data = this.filterData(data); - - this.filteredData = [...data]; - - data = this.sortData(data); - - // Grab the page's slice of data. - const startIndex = this._paginator.pageIndex * this._paginator.pageSize; - return data.splice(startIndex, this._paginator.pageSize); - } - )); - } - - filterData(data) + /** + * Filter data + * + * @param data + * @returns {any} + */ + filterData(data): any { if ( !this.filter ) { @@ -120,11 +169,15 @@ export class FilesDataSource extends DataSource return FuseUtils.filterArrayByString(data, this.filter); } - sortData(data) - : - any[] + /** + * Sort data + * + * @param data + * @returns {any[]} + */ + sortData(data): any[] { - if ( !this._sort.active || this._sort.direction === '' ) + if ( !this._matSort.active || this._matSort.direction === '' ) { return data; } @@ -133,7 +186,7 @@ export class FilesDataSource extends DataSource let propertyA: number | string = ''; let propertyB: number | string = ''; - switch ( this._sort.active ) + switch ( this._matSort.active ) { case 'id': [propertyA, propertyB] = [a.id, b.id]; @@ -158,11 +211,14 @@ export class FilesDataSource extends DataSource const valueA = isNaN(+propertyA) ? propertyA : +propertyA; const valueB = isNaN(+propertyB) ? propertyB : +propertyB; - return (valueA < valueB ? -1 : 1) * (this._sort.direction === 'asc' ? 1 : -1); + return (valueA < valueB ? -1 : 1) * (this._matSort.direction === 'asc' ? 1 : -1); }); } - disconnect() + /** + * Disconnect + */ + disconnect(): void { } } diff --git a/src/app/main/apps/e-commerce/products/products.service.ts b/src/app/main/apps/e-commerce/products/products.service.ts index 7b48839f..8c691e2e 100644 --- a/src/app/main/apps/e-commerce/products/products.service.ts +++ b/src/app/main/apps/e-commerce/products/products.service.ts @@ -9,21 +9,26 @@ export class EcommerceProductsService implements Resolve products: any[]; onProductsChanged: BehaviorSubject = new BehaviorSubject({}); + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ constructor( - private http: HttpClient + private _httpClient: HttpClient ) { } /** - * Resolve + * Resolver + * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state * @returns {Observable | Promise | any} */ resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable | Promise | any { - return new Promise((resolve, reject) => { Promise.all([ @@ -37,10 +42,15 @@ export class EcommerceProductsService implements Resolve }); } + /** + * Get products + * + * @returns {Promise} + */ getProducts(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/e-commerce-products') + this._httpClient.get('api/e-commerce-products') .subscribe((response: any) => { this.products = response; this.onProductsChanged.next(this.products); diff --git a/src/app/main/apps/file-manager/file-list/file-list.component.ts b/src/app/main/apps/file-manager/file-list/file-list.component.ts index e60a133e..1ae8d725 100644 --- a/src/app/main/apps/file-manager/file-list/file-list.component.ts +++ b/src/app/main/apps/file-manager/file-list/file-list.component.ts @@ -1,58 +1,118 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { DataSource } from '@angular/cdk/collections'; -import { Observable } from 'rxjs'; +import { Observable, Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; -import { FileManagerService } from '../file-manager.service'; -import { fuseAnimations } from '@fuse/animations/index'; +import { fuseAnimations } from '@fuse/animations'; + +import { FileManagerService } from 'app/main/apps/file-manager/file-manager.service'; @Component({ - selector : 'fuse-file-list', + selector : 'file-list', templateUrl: './file-list.component.html', styleUrls : ['./file-list.component.scss'], animations : fuseAnimations }) -export class FuseFileManagerFileListComponent implements OnInit +export class FileManagerFileListComponent implements OnInit, OnDestroy { files: any; dataSource: FilesDataSource | null; displayedColumns = ['icon', 'name', 'type', 'owner', 'size', 'modified', 'detail-button']; selected: any; - constructor(private fileManagerService: FileManagerService) + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FileManagerService} _fileManagerService + */ + constructor( + private _fileManagerService: FileManagerService + ) { - this.fileManagerService.onFilesChanged.subscribe(files => { - this.files = files; - }); - this.fileManagerService.onFileSelected.subscribe(selected => { - this.selected = selected; - }); + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.dataSource = new FilesDataSource(this.fileManagerService); + this.dataSource = new FilesDataSource(this._fileManagerService); + + this._fileManagerService.onFilesChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(files => { + this.files = files; + }); + + this._fileManagerService.onFileSelected + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(selected => { + this.selected = selected; + }); } - onSelect(selected) + /** + * On destroy + */ + ngOnDestroy(): void { - this.fileManagerService.onFileSelected.next(selected); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On select + * + * @param selected + */ + onSelect(selected): void + { + this._fileManagerService.onFileSelected.next(selected); } } export class FilesDataSource extends DataSource { - constructor(private fileManagerService: FileManagerService) + /** + * Constructor + * + * @param {FileManagerService} _fileManagerService + */ + constructor( + private _fileManagerService: FileManagerService + ) { super(); } - /** Connect function called by the table to retrieve one stream containing the data to render. */ + /** + * Connect function called by the table to retrieve one stream containing the data to render. + * + * @returns {Observable} + */ connect(): Observable { - return this.fileManagerService.onFilesChanged; + return this._fileManagerService.onFilesChanged; } - disconnect() + /** + * Disconnect + */ + disconnect(): void { } } diff --git a/src/app/main/apps/file-manager/file-manager.component.html b/src/app/main/apps/file-manager/file-manager.component.html index 8c45ef3d..c8edfce0 100644 --- a/src/app/main/apps/file-manager/file-manager.component.html +++ b/src/app/main/apps/file-manager/file-manager.component.html @@ -5,7 +5,7 @@ - + @@ -61,7 +61,7 @@
- +
@@ -71,7 +71,7 @@ - + diff --git a/src/app/main/apps/file-manager/file-manager.component.ts b/src/app/main/apps/file-manager/file-manager.component.ts index d7a76819..16ac95f0 100644 --- a/src/app/main/apps/file-manager/file-manager.component.ts +++ b/src/app/main/apps/file-manager/file-manager.component.ts @@ -1,30 +1,63 @@ -import { Component, OnInit, ViewEncapsulation } from '@angular/core'; +import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; -import { FileManagerService } from './file-manager.service'; +import { FileManagerService } from 'app/main/apps/file-manager/file-manager.service'; @Component({ - selector : 'fuse-file-manager', + selector : 'file-manager', templateUrl : './file-manager.component.html', styleUrls : ['./file-manager.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseFileManagerComponent implements OnInit +export class FileManagerComponent implements OnInit, OnDestroy { selected: any; pathArr: string[]; - constructor(private fileManagerService: FileManagerService) + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FileManagerService} _fileManagerService + */ + constructor( + private _fileManagerService: FileManagerService + ) { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.fileManagerService.onFileSelected.subscribe(selected => { + this._fileManagerService.onFileSelected + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(selected => { this.selected = selected; this.pathArr = selected.location.split('>'); }); } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } } diff --git a/src/app/main/apps/file-manager/file-manager.module.ts b/src/app/main/apps/file-manager/file-manager.module.ts index ed33ee01..b6f0d7bf 100644 --- a/src/app/main/apps/file-manager/file-manager.module.ts +++ b/src/app/main/apps/file-manager/file-manager.module.ts @@ -1,21 +1,20 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; import { CdkTableModule } from '@angular/cdk/table'; - import { MatButtonModule, MatIconModule, MatRippleModule, MatSidenavModule, MatSlideToggleModule, MatTableModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseFileManagerComponent } from './file-manager.component'; -import { FileManagerService } from './file-manager.service'; -import { FuseFileManagerFileListComponent } from './file-list/file-list.component'; -import { FuseFileManagerMainSidenavComponent } from './sidenavs/main/main.component'; -import { FuseFileManagerDetailsSidenavComponent } from './sidenavs/details/details.component'; +import { FileManagerService } from 'app/main/apps/file-manager/file-manager.service'; +import { FileManagerComponent } from 'app/main/apps/file-manager/file-manager.component'; +import { FileManagerDetailsSidenavComponent } from 'app/main/apps/file-manager/sidenavs/details/details.component'; +import { FileManagerFileListComponent } from 'app/main/apps/file-manager/file-list/file-list.component'; +import { FileManagerMainSidenavComponent } from 'app/main/apps/file-manager/sidenavs/main/main.component'; const routes: Routes = [ { path : '**', - component: FuseFileManagerComponent, + component: FileManagerComponent, children : [], resolve : { files: FileManagerService @@ -25,10 +24,10 @@ const routes: Routes = [ @NgModule({ declarations: [ - FuseFileManagerComponent, - FuseFileManagerFileListComponent, - FuseFileManagerMainSidenavComponent, - FuseFileManagerDetailsSidenavComponent + FileManagerComponent, + FileManagerFileListComponent, + FileManagerMainSidenavComponent, + FileManagerDetailsSidenavComponent ], imports : [ RouterModule.forChild(routes), @@ -47,6 +46,6 @@ const routes: Routes = [ FileManagerService ] }) -export class FuseFileManagerModule +export class FileManagerModule { } diff --git a/src/app/main/apps/file-manager/file-manager.service.ts b/src/app/main/apps/file-manager/file-manager.service.ts index 0ef8bf8d..d8affd98 100644 --- a/src/app/main/apps/file-manager/file-manager.service.ts +++ b/src/app/main/apps/file-manager/file-manager.service.ts @@ -9,12 +9,19 @@ export class FileManagerService implements Resolve onFilesChanged: BehaviorSubject = new BehaviorSubject({}); onFileSelected: BehaviorSubject = new BehaviorSubject({}); - constructor(private http: HttpClient) + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ + constructor( + private _httpClient: HttpClient + ) { } /** - * The File Manager App Main Resolver + * Resolver * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state @@ -22,7 +29,6 @@ export class FileManagerService implements Resolve */ resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable | Promise | any { - return new Promise((resolve, reject) => { Promise.all([ @@ -36,10 +42,15 @@ export class FileManagerService implements Resolve }); } + /** + * Get files + * + * @returns {Promise} + */ getFiles(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/file-manager') + this._httpClient.get('api/file-manager') .subscribe((response: any) => { this.onFilesChanged.next(response); this.onFileSelected.next(response[0]); diff --git a/src/app/main/apps/file-manager/sidenavs/details/details.component.ts b/src/app/main/apps/file-manager/sidenavs/details/details.component.ts index 61385322..b6327e9b 100644 --- a/src/app/main/apps/file-manager/sidenavs/details/details.component.ts +++ b/src/app/main/apps/file-manager/sidenavs/details/details.component.ts @@ -1,30 +1,60 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; -import { fuseAnimations } from '@fuse/animations/index'; +import { fuseAnimations } from '@fuse/animations'; -import { FileManagerService } from '../../file-manager.service'; +import { FileManagerService } from 'app/main/apps/file-manager/file-manager.service'; @Component({ - selector : 'fuse-file-manager-details-sidenav', + selector : 'file-manager-details-sidenav', templateUrl: './details.component.html', styleUrls : ['./details.component.scss'], animations : fuseAnimations }) -export class FuseFileManagerDetailsSidenavComponent implements OnInit +export class FileManagerDetailsSidenavComponent implements OnInit, OnDestroy { - selected: any; - constructor(private fileManagerService: FileManagerService) - { + // Private + private _unsubscribeAll: Subject; + /** + * Constructor + * + * @param {FileManagerService} _fileManagerService + */ + constructor( + private _fileManagerService: FileManagerService + ) + { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.fileManagerService.onFileSelected.subscribe(selected => { - this.selected = selected; - }); + this._fileManagerService.onFileSelected + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(selected => { + this.selected = selected; + }); } + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } } diff --git a/src/app/main/apps/file-manager/sidenavs/main/main.component.ts b/src/app/main/apps/file-manager/sidenavs/main/main.component.ts index eea05124..817f6fb3 100644 --- a/src/app/main/apps/file-manager/sidenavs/main/main.component.ts +++ b/src/app/main/apps/file-manager/sidenavs/main/main.component.ts @@ -1,11 +1,11 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-file-manager-main-sidenav', + selector : 'file-manager-main-sidenav', templateUrl: './main.component.html', styleUrls : ['./main.component.scss'] }) -export class FuseFileManagerMainSidenavComponent +export class FileManagerMainSidenavComponent { selected: any; diff --git a/src/app/main/apps/mail-ngrx/mail.component.ts b/src/app/main/apps/mail-ngrx/mail.component.ts index c218a5d0..9fbbcad6 100644 --- a/src/app/main/apps/mail-ngrx/mail.component.ts +++ b/src/app/main/apps/mail-ngrx/mail.component.ts @@ -52,9 +52,9 @@ export class FuseMailNgrxComponent implements OnInit, OnDestroy this.mails = []; this.selectedMailIds = []; - this.configService.setConfig({ + this.configService.config = { routerAnimation: 'none' - }); + }; } ngOnInit() diff --git a/src/app/main/components-third-party/components-third-party.module.ts b/src/app/main/components-third-party/components-third-party.module.ts index afd4ef64..0b9ae8c9 100644 --- a/src/app/main/components-third-party/components-third-party.module.ts +++ b/src/app/main/components-third-party/components-third-party.module.ts @@ -1,15 +1,12 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatCheckboxModule, MatIconModule } from '@angular/material'; - import { NgxDatatableModule } from '@swimlane/ngx-datatable'; import { FuseSharedModule } from '@fuse/shared.module'; -import { GoogleMapsModule } from './google-maps/google-maps.module'; - -import { FuseNgxDatatableComponent } from './datatable/ngx-datatable.component'; +import { GoogleMapsModule } from 'app/main/components-third-party/google-maps/google-maps.module'; +import { FuseNgxDatatableComponent } from 'app/main/components-third-party/datatable/ngx-datatable.component'; const routes = [ { @@ -36,6 +33,6 @@ const routes = [ GoogleMapsModule ], }) -export class FuseComponentsThirdPartyModule +export class ComponentsThirdPartyModule { } diff --git a/src/app/main/components/angular-material/angular-material.module.ts b/src/app/main/components/angular-material/angular-material.module.ts index da8cee00..2d7420d3 100644 --- a/src/app/main/components/angular-material/angular-material.module.ts +++ b/src/app/main/components/angular-material/angular-material.module.ts @@ -1,15 +1,14 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; -import { MaterialModule } from 'app/main/content/components/angular-material/material.module'; - import { FuseSharedModule } from '@fuse/shared.module'; import { FuseHighlightModule } from '@fuse/components'; import { FuseWidgetModule } from '@fuse/components/widget/widget.module'; -import { EXAMPLE_LIST } from './example-components'; -import { FuseExampleViewerComponent } from './example-viewer/example-viewer'; -import { FuseAngularMaterialComponent } from './angular-material.component'; +import { MaterialModule } from 'app/main/components/angular-material/material.module'; +import { EXAMPLE_LIST } from 'app/main/components/angular-material/example-components'; +import { FuseAngularMaterialComponent } from 'app/main/components/angular-material/angular-material.component'; +import { FuseExampleViewerComponent } from 'app/main/components/angular-material/example-viewer/example-viewer'; const routes: Routes = [ { diff --git a/src/app/main/components/components.module.ts b/src/app/main/components/components.module.ts index cbd8af11..e324f324 100644 --- a/src/app/main/components/components.module.ts +++ b/src/app/main/components/components.module.ts @@ -1,24 +1,20 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatButtonToggleModule, MatFormFieldModule, MatIconModule, MatListModule, MatMenuModule, MatSelectModule, MatSlideToggleModule, MatTabsModule } from '@angular/material'; - import { NgxChartsModule } from '@swimlane/ngx-charts'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseCountdownModule, FuseHighlightModule, FuseMaterialColorPickerModule, FuseWidgetModule } from '@fuse/components'; - -import { FuseAngularMaterialModule } from './angular-material/angular-material.module'; -import { FuseCardsDocsComponent } from './cards/cards.component'; -import { FuseCountdownDocsComponent } from './countdown/countdown.component'; -import { FuseHighlightDocsComponent } from './highlight/highlight.component'; -import { FuseMaterialColorPickerDocsComponent } from './material-color-picker/material-color-picker.component'; -import { FuseMultiLanguageDocsComponent } from './multi-language/multi-language.component'; -import { FuseNavigationDocsComponent } from './navigation/navigation.component'; -import { FuseSearchBarDocsComponent } from './search-bar/search-bar.component'; -import { FuseSidebarDocsComponent } from './sidebar/sidebar.component'; -import { FuseShortcutsDocsComponent } from './shortcuts/shortcuts.component'; -import { FuseWidgetDocsComponent } from './widget/widget.component'; +import { FuseCardsDocsComponent } from 'app/main/components/cards/cards.component'; +import { FuseCountdownDocsComponent } from 'app/main/components/countdown/countdown.component'; +import { FuseHighlightDocsComponent } from 'app/main/components/highlight/highlight.component'; +import { FuseMaterialColorPickerDocsComponent } from 'app/main/components/material-color-picker/material-color-picker.component'; +import { FuseMultiLanguageDocsComponent } from 'app/main/components/multi-language/multi-language.component'; +import { FuseNavigationDocsComponent } from 'app/main/components/navigation/navigation.component'; +import { FuseSearchBarDocsComponent } from 'app/main/components/search-bar/search-bar.component'; +import { FuseSidebarDocsComponent } from 'app/main/components/sidebar/sidebar.component'; +import { FuseShortcutsDocsComponent } from 'app/main/components/shortcuts/shortcuts.component'; +import { FuseWidgetDocsComponent } from 'app/main/components/widget/widget.component'; const routes = [ { @@ -99,6 +95,6 @@ const routes = [ FuseAngularMaterialModule ] }) -export class FuseComponentsModule +export class ComponentsModule { } diff --git a/src/app/main/pages/authentication/forgot-password-2/forgot-password-2.component.ts b/src/app/main/pages/authentication/forgot-password-2/forgot-password-2.component.ts index 18752dc5..ec751674 100644 --- a/src/app/main/pages/authentication/forgot-password-2/forgot-password-2.component.ts +++ b/src/app/main/pages/authentication/forgot-password-2/forgot-password-2.component.ts @@ -1,50 +1,92 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { FormBuilder, FormGroup, Validators } from '@angular/forms'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FuseConfigService } from '@fuse/services/config.service'; import { fuseAnimations } from '@fuse/animations'; @Component({ - selector : 'fuse-forgot-password-2', + selector : 'forgot-password-2', templateUrl: './forgot-password-2.component.html', styleUrls : ['./forgot-password-2.component.scss'], animations : fuseAnimations }) -export class FuseForgotPassword2Component implements OnInit +export class ForgotPassword2Component implements OnInit, OnDestroy { forgotPasswordForm: FormGroup; forgotPasswordFormErrors: any; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + * @param {FormBuilder} _formBuilder + */ constructor( - private fuseConfig: FuseConfigService, - private formBuilder: FormBuilder + private _fuseConfigService: FuseConfigService, + private _formBuilder: FormBuilder ) { - this.fuseConfig.setConfig({ + // Configure the layout + this._fuseConfigService.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; + // Set the defaults this.forgotPasswordFormErrors = { email: {} }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.forgotPasswordForm = this.formBuilder.group({ + this.forgotPasswordForm = this._formBuilder.group({ email: ['', [Validators.required, Validators.email]] }); - this.forgotPasswordForm.valueChanges.subscribe(() => { - this.onForgotPasswordFormValuesChanged(); - }); + this.forgotPasswordForm.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onForgotPasswordFormValuesChanged(); + }); } - onForgotPasswordFormValuesChanged() + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On form values changed + */ + onForgotPasswordFormValuesChanged(): void { for ( const field in this.forgotPasswordFormErrors ) { diff --git a/src/app/main/pages/authentication/forgot-password-2/forgot-password-2.module.ts b/src/app/main/pages/authentication/forgot-password-2/forgot-password-2.module.ts index 8192d5d0..bc985e94 100644 --- a/src/app/main/pages/authentication/forgot-password-2/forgot-password-2.module.ts +++ b/src/app/main/pages/authentication/forgot-password-2/forgot-password-2.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatFormFieldModule, MatInputModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseForgotPassword2Component } from './forgot-password-2.component'; +import { ForgotPassword2Component } from 'app/main/pages/authentication/forgot-password-2/forgot-password-2.component'; const routes = [ { path : 'auth/forgot-password-2', - component: FuseForgotPassword2Component + component: ForgotPassword2Component } ]; @NgModule({ declarations: [ - FuseForgotPassword2Component + ForgotPassword2Component ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/pages/authentication/forgot-password/forgot-password.component.ts b/src/app/main/pages/authentication/forgot-password/forgot-password.component.ts index eebeacf7..f27a85dd 100644 --- a/src/app/main/pages/authentication/forgot-password/forgot-password.component.ts +++ b/src/app/main/pages/authentication/forgot-password/forgot-password.component.ts @@ -1,50 +1,92 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { FormBuilder, FormGroup, Validators } from '@angular/forms'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FuseConfigService } from '@fuse/services/config.service'; import { fuseAnimations } from '@fuse/animations'; @Component({ - selector : 'fuse-forgot-password', + selector : 'forgot-password', templateUrl: './forgot-password.component.html', styleUrls : ['./forgot-password.component.scss'], animations : fuseAnimations }) -export class FuseForgotPasswordComponent implements OnInit +export class ForgotPasswordComponent implements OnInit, OnDestroy { forgotPasswordForm: FormGroup; forgotPasswordFormErrors: any; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + * @param {FormBuilder} _formBuilder + */ constructor( - private fuseConfig: FuseConfigService, - private formBuilder: FormBuilder + private _fuseConfigService: FuseConfigService, + private _formBuilder: FormBuilder ) { - this.fuseConfig.setConfig({ + // Configure the layout + this._fuseConfigService.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; + // Set the defaults this.forgotPasswordFormErrors = { email: {} }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.forgotPasswordForm = this.formBuilder.group({ + this.forgotPasswordForm = this._formBuilder.group({ email: ['', [Validators.required, Validators.email]] }); - this.forgotPasswordForm.valueChanges.subscribe(() => { - this.onForgotPasswordFormValuesChanged(); - }); + this.forgotPasswordForm.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onForgotPasswordFormValuesChanged(); + }); } - onForgotPasswordFormValuesChanged() + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On form values changed + */ + onForgotPasswordFormValuesChanged(): void { for ( const field in this.forgotPasswordFormErrors ) { diff --git a/src/app/main/pages/authentication/forgot-password/forgot-password.module.ts b/src/app/main/pages/authentication/forgot-password/forgot-password.module.ts index 719e4496..c9ac1439 100644 --- a/src/app/main/pages/authentication/forgot-password/forgot-password.module.ts +++ b/src/app/main/pages/authentication/forgot-password/forgot-password.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatFormFieldModule, MatInputModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseForgotPasswordComponent } from './forgot-password.component'; +import { ForgotPasswordComponent } from 'app/main/pages/authentication/forgot-password/forgot-password.component'; const routes = [ { path : 'auth/forgot-password', - component: FuseForgotPasswordComponent + component: ForgotPasswordComponent } ]; @NgModule({ declarations: [ - FuseForgotPasswordComponent + ForgotPasswordComponent ], imports : [ RouterModule.forChild(routes), @@ -25,7 +24,7 @@ const routes = [ MatFormFieldModule, MatInputModule, - FuseSharedModule, + FuseSharedModule ] }) export class ForgotPasswordModule diff --git a/src/app/main/pages/authentication/lock/lock.component.ts b/src/app/main/pages/authentication/lock/lock.component.ts index 11bd2125..ac1398a4 100644 --- a/src/app/main/pages/authentication/lock/lock.component.ts +++ b/src/app/main/pages/authentication/lock/lock.component.ts @@ -1,42 +1,65 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { FormBuilder, FormGroup, Validators } from '@angular/forms'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FuseConfigService } from '@fuse/services/config.service'; import { fuseAnimations } from '@fuse/animations'; @Component({ - selector : 'fuse-lock', + selector : 'lock', templateUrl: './lock.component.html', styleUrls : ['./lock.component.scss'], animations : fuseAnimations }) -export class FuseLockComponent implements OnInit +export class LockComponent implements OnInit, OnDestroy { lockForm: FormGroup; lockFormErrors: any; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + * @param {FormBuilder} _formBuilder + */ constructor( - private fuseConfig: FuseConfigService, - private formBuilder: FormBuilder + private _fuseConfigService: FuseConfigService, + private _formBuilder: FormBuilder ) { - this.fuseConfig.setConfig({ + // Configure the layout + this._fuseConfigService.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; + // Set the defaults this.lockFormErrors = { username: {}, password: {} }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.lockForm = this.formBuilder.group({ + this.lockForm = this._formBuilder.group({ username: [ { value : 'Katherine', @@ -46,12 +69,31 @@ export class FuseLockComponent implements OnInit password: ['', Validators.required] }); - this.lockForm.valueChanges.subscribe(() => { - this.onLockFormValuesChanged(); - }); + this.lockForm.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onLockFormValuesChanged(); + }); } - onLockFormValuesChanged() + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On form values changed + */ + onLockFormValuesChanged(): void { for ( const field in this.lockFormErrors ) { diff --git a/src/app/main/pages/authentication/lock/lock.module.ts b/src/app/main/pages/authentication/lock/lock.module.ts index 0488d20b..22b267f2 100644 --- a/src/app/main/pages/authentication/lock/lock.module.ts +++ b/src/app/main/pages/authentication/lock/lock.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatFormFieldModule, MatIconModule, MatInputModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseLockComponent } from './lock.component'; +import { LockComponent } from 'app/main/pages/authentication/lock/lock.component'; const routes = [ { path : 'auth/lock', - component: FuseLockComponent + component: LockComponent } ]; @NgModule({ declarations: [ - FuseLockComponent + LockComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/pages/authentication/login-2/login-2.component.ts b/src/app/main/pages/authentication/login-2/login-2.component.ts index bc735783..0531a0e2 100644 --- a/src/app/main/pages/authentication/login-2/login-2.component.ts +++ b/src/app/main/pages/authentication/login-2/login-2.component.ts @@ -1,52 +1,94 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { FormBuilder, FormGroup, Validators } from '@angular/forms'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FuseConfigService } from '@fuse/services/config.service'; import { fuseAnimations } from '@fuse/animations'; @Component({ - selector : 'fuse-login-2', + selector : 'login-2', templateUrl: './login-2.component.html', styleUrls : ['./login-2.component.scss'], animations : fuseAnimations }) -export class FuseLogin2Component implements OnInit +export class Login2Component implements OnInit, OnDestroy { loginForm: FormGroup; loginFormErrors: any; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + * @param {FormBuilder} _formBuilder + */ constructor( - private fuseConfig: FuseConfigService, - private formBuilder: FormBuilder + private _fuseConfigService: FuseConfigService, + private _formBuilder: FormBuilder ) { - this.fuseConfig.setConfig({ + // Configure the layout + this._fuseConfigService.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; + // Set the defaults this.loginFormErrors = { email : {}, password: {} }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.loginForm = this.formBuilder.group({ + this.loginForm = this._formBuilder.group({ email : ['', [Validators.required, Validators.email]], password: ['', Validators.required] }); - this.loginForm.valueChanges.subscribe(() => { - this.onLoginFormValuesChanged(); - }); + this.loginForm.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onLoginFormValuesChanged(); + }); } - onLoginFormValuesChanged() + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On form values changed + */ + onLoginFormValuesChanged(): void { for ( const field in this.loginFormErrors ) { diff --git a/src/app/main/pages/authentication/login-2/login-2.module.ts b/src/app/main/pages/authentication/login-2/login-2.module.ts index 9f7f932d..d8f653a7 100644 --- a/src/app/main/pages/authentication/login-2/login-2.module.ts +++ b/src/app/main/pages/authentication/login-2/login-2.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatCheckboxModule, MatFormFieldModule, MatInputModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseLogin2Component } from './login-2.component'; +import { Login2Component } from 'app/main/pages/authentication/login-2/login-2.component'; const routes = [ { path : 'auth/login-2', - component: FuseLogin2Component + component: Login2Component } ]; @NgModule({ declarations: [ - FuseLogin2Component + Login2Component ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/pages/authentication/login/login.component.ts b/src/app/main/pages/authentication/login/login.component.ts index 85e8a952..6f272924 100644 --- a/src/app/main/pages/authentication/login/login.component.ts +++ b/src/app/main/pages/authentication/login/login.component.ts @@ -1,52 +1,94 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { FormBuilder, FormGroup, Validators } from '@angular/forms'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FuseConfigService } from '@fuse/services/config.service'; import { fuseAnimations } from '@fuse/animations'; @Component({ - selector : 'fuse-login', + selector : 'login', templateUrl: './login.component.html', styleUrls : ['./login.component.scss'], animations : fuseAnimations }) -export class FuseLoginComponent implements OnInit +export class LoginComponent implements OnInit, OnDestroy { loginForm: FormGroup; loginFormErrors: any; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + * @param {FormBuilder} _formBuilder + */ constructor( - private fuseConfig: FuseConfigService, - private formBuilder: FormBuilder + private _fuseConfigService: FuseConfigService, + private _formBuilder: FormBuilder ) { - this.fuseConfig.setConfig({ + // Configure the layout + this._fuseConfigService.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; + // Set the defaults this.loginFormErrors = { email : {}, password: {} }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.loginForm = this.formBuilder.group({ + this.loginForm = this._formBuilder.group({ email : ['', [Validators.required, Validators.email]], password: ['', Validators.required] }); - this.loginForm.valueChanges.subscribe(() => { - this.onLoginFormValuesChanged(); - }); + this.loginForm.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onLoginFormValuesChanged(); + }); } - onLoginFormValuesChanged() + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On form values changed + */ + onLoginFormValuesChanged(): void { for ( const field in this.loginFormErrors ) { diff --git a/src/app/main/pages/authentication/login/login.module.ts b/src/app/main/pages/authentication/login/login.module.ts index e5ea2e03..12d5eebd 100644 --- a/src/app/main/pages/authentication/login/login.module.ts +++ b/src/app/main/pages/authentication/login/login.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatCheckboxModule, MatFormFieldModule, MatInputModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseLoginComponent } from './login.component'; +import { LoginComponent } from 'app/main/pages/authentication/login/login.component'; const routes = [ { path : 'auth/login', - component: FuseLoginComponent + component: LoginComponent } ]; @NgModule({ declarations: [ - FuseLoginComponent + LoginComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/pages/authentication/mail-confirm/mail-confirm.component.ts b/src/app/main/pages/authentication/mail-confirm/mail-confirm.component.ts index 8430d99d..56b6788e 100644 --- a/src/app/main/pages/authentication/mail-confirm/mail-confirm.component.ts +++ b/src/app/main/pages/authentication/mail-confirm/mail-confirm.component.ts @@ -9,19 +9,24 @@ import { fuseAnimations } from '@fuse/animations'; styleUrls : ['./mail-confirm.component.scss'], animations : fuseAnimations }) -export class FuseMailConfirmComponent +export class MailConfirmComponent { - + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + */ constructor( - private fuseConfig: FuseConfigService + private _fuseConfigService: FuseConfigService ) { - this.fuseConfig.setConfig({ + // Configure the layout + this._fuseConfigService.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; } } diff --git a/src/app/main/pages/authentication/mail-confirm/mail-confirm.module.ts b/src/app/main/pages/authentication/mail-confirm/mail-confirm.module.ts index 1c56c4a9..bdd2df19 100644 --- a/src/app/main/pages/authentication/mail-confirm/mail-confirm.module.ts +++ b/src/app/main/pages/authentication/mail-confirm/mail-confirm.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatIconModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseMailConfirmComponent } from './mail-confirm.component'; +import { MailConfirmComponent } from 'app/main/pages/authentication/mail-confirm/mail-confirm.component'; const routes = [ { path : 'auth/mail-confirm', - component: FuseMailConfirmComponent + component: MailConfirmComponent } ]; @NgModule({ declarations: [ - FuseMailConfirmComponent + MailConfirmComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/pages/authentication/register-2/register-2.component.ts b/src/app/main/pages/authentication/register-2/register-2.component.ts index 2c2f3350..fb403b1f 100644 --- a/src/app/main/pages/authentication/register-2/register-2.component.ts +++ b/src/app/main/pages/authentication/register-2/register-2.component.ts @@ -1,56 +1,98 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { AbstractControl, FormBuilder, FormGroup, Validators } from '@angular/forms'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FuseConfigService } from '@fuse/services/config.service'; import { fuseAnimations } from '@fuse/animations'; @Component({ - selector : 'fuse-register-2', + selector : 'register-2', templateUrl: './register-2.component.html', styleUrls : ['./register-2.component.scss'], animations : fuseAnimations }) -export class FuseRegister2Component implements OnInit +export class Register2Component implements OnInit, OnDestroy { registerForm: FormGroup; registerFormErrors: any; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + * @param {FormBuilder} _formBuilder + */ constructor( - private fuseConfig: FuseConfigService, - private formBuilder: FormBuilder + private _fuseConfigService: FuseConfigService, + private _formBuilder: FormBuilder ) { - this.fuseConfig.setConfig({ + // Configure the layout + this._fuseConfigService.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; + // Set the defaults this.registerFormErrors = { name : {}, email : {}, password : {}, passwordConfirm: {} }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.registerForm = this.formBuilder.group({ + this.registerForm = this._formBuilder.group({ name : ['', Validators.required], email : ['', [Validators.required, Validators.email]], password : ['', Validators.required], passwordConfirm: ['', [Validators.required, confirmPassword]] }); - this.registerForm.valueChanges.subscribe(() => { + this.registerForm.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { this.onRegisterFormValuesChanged(); }); } - onRegisterFormValuesChanged() + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On form values changed + */ + onRegisterFormValuesChanged(): void { for ( const field in this.registerFormErrors ) { @@ -73,7 +115,13 @@ export class FuseRegister2Component implements OnInit } } -function confirmPassword(control: AbstractControl) +/** + * Confirm password + * + * @param {AbstractControl} control + * @returns {{passwordsNotMatch: boolean}} + */ +function confirmPassword(control: AbstractControl): any { if ( !control.parent || !control ) { diff --git a/src/app/main/pages/authentication/register-2/register-2.module.ts b/src/app/main/pages/authentication/register-2/register-2.module.ts index 68458fb5..3b689cb3 100644 --- a/src/app/main/pages/authentication/register-2/register-2.module.ts +++ b/src/app/main/pages/authentication/register-2/register-2.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatCheckboxModule, MatFormFieldModule, MatInputModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseRegister2Component } from './register-2.component'; +import { Register2Component } from 'app/main/pages/authentication/register-2/register-2.component'; const routes = [ { path : 'auth/register-2', - component: FuseRegister2Component + component: Register2Component } ]; @NgModule({ declarations: [ - FuseRegister2Component + Register2Component ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/pages/authentication/register/register.component.ts b/src/app/main/pages/authentication/register/register.component.ts index fea8d9ec..0002f0cd 100644 --- a/src/app/main/pages/authentication/register/register.component.ts +++ b/src/app/main/pages/authentication/register/register.component.ts @@ -1,56 +1,92 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { AbstractControl, FormBuilder, FormGroup, Validators } from '@angular/forms'; import { FuseConfigService } from '@fuse/services/config.service'; import { fuseAnimations } from '@fuse/animations'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/internal/operators'; @Component({ - selector : 'fuse-register', + selector : 'register', templateUrl: './register.component.html', styleUrls : ['./register.component.scss'], animations : fuseAnimations }) -export class FuseRegisterComponent implements OnInit +export class RegisterComponent implements OnInit, OnDestroy { registerForm: FormGroup; registerFormErrors: any; + // Private + private _unsubscribeAll: Subject; + constructor( - private fuseConfig: FuseConfigService, - private formBuilder: FormBuilder + private _fuseConfigService: FuseConfigService, + private _formBuilder: FormBuilder ) { - this.fuseConfig.setConfig({ + // Configure the layout + this._fuseConfigService.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; + // Set the defaults this.registerFormErrors = { name : {}, email : {}, password : {}, passwordConfirm: {} }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.registerForm = this.formBuilder.group({ + this.registerForm = this._formBuilder.group({ name : ['', Validators.required], email : ['', [Validators.required, Validators.email]], password : ['', Validators.required], passwordConfirm: ['', [Validators.required, confirmPassword]] }); - this.registerForm.valueChanges.subscribe(() => { - this.onRegisterFormValuesChanged(); - }); + this.registerForm.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onRegisterFormValuesChanged(); + }); } - onRegisterFormValuesChanged() + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On form values changed + */ + onRegisterFormValuesChanged(): void { for ( const field in this.registerFormErrors ) { @@ -73,7 +109,13 @@ export class FuseRegisterComponent implements OnInit } } -function confirmPassword(control: AbstractControl) +/** + * Confirm password + * + * @param {AbstractControl} control + * @returns {{passwordsNotMatch: boolean}} + */ +function confirmPassword(control: AbstractControl): any { if ( !control.parent || !control ) { diff --git a/src/app/main/pages/authentication/register/register.module.ts b/src/app/main/pages/authentication/register/register.module.ts index f2c80a88..117198e9 100644 --- a/src/app/main/pages/authentication/register/register.module.ts +++ b/src/app/main/pages/authentication/register/register.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatCheckboxModule, MatFormFieldModule, MatInputModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseRegisterComponent } from './register.component'; +import { RegisterComponent } from 'app/main/pages/authentication/register/register.component'; const routes = [ { path : 'auth/register', - component: FuseRegisterComponent + component: RegisterComponent } ]; @NgModule({ declarations: [ - FuseRegisterComponent + RegisterComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/pages/authentication/reset-password-2/reset-password-2.component.ts b/src/app/main/pages/authentication/reset-password-2/reset-password-2.component.ts index dea9e605..da812b29 100644 --- a/src/app/main/pages/authentication/reset-password-2/reset-password-2.component.ts +++ b/src/app/main/pages/authentication/reset-password-2/reset-password-2.component.ts @@ -1,54 +1,90 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { AbstractControl, FormBuilder, FormGroup, Validators } from '@angular/forms'; import { FuseConfigService } from '@fuse/services/config.service'; import { fuseAnimations } from '@fuse/animations'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/internal/operators'; @Component({ - selector : 'fuse-reset-password-2', + selector : 'reset-password-2', templateUrl: './reset-password-2.component.html', styleUrls : ['./reset-password-2.component.scss'], animations : fuseAnimations }) -export class FuseResetPassword2Component implements OnInit +export class ResetPassword2Component implements OnInit, OnDestroy { resetPasswordForm: FormGroup; resetPasswordFormErrors: any; + // Private + private _unsubscribeAll: Subject; + constructor( - private fuseConfig: FuseConfigService, - private formBuilder: FormBuilder + private _fuseConfigService: FuseConfigService, + private _formBuilder: FormBuilder ) { - this.fuseConfig.setConfig({ + // Configure the layout + this._fuseConfigService.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; + // Set the defaults this.resetPasswordFormErrors = { email : {}, password : {}, passwordConfirm: {} }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.resetPasswordForm = this.formBuilder.group({ + this.resetPasswordForm = this._formBuilder.group({ email : ['', [Validators.required, Validators.email]], password : ['', Validators.required], passwordConfirm: ['', [Validators.required, confirmPassword]] }); - this.resetPasswordForm.valueChanges.subscribe(() => { - this.onResetPasswordFormValuesChanged(); - }); + this.resetPasswordForm.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onResetPasswordFormValuesChanged(); + }); } - onResetPasswordFormValuesChanged() + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On form values changed + */ + onResetPasswordFormValuesChanged(): void { for ( const field in this.resetPasswordFormErrors ) { @@ -71,7 +107,13 @@ export class FuseResetPassword2Component implements OnInit } } -function confirmPassword(control: AbstractControl) +/** + * Confirm password + * + * @param {AbstractControl} control + * @returns {{passwordsNotMatch: boolean}} + */ +function confirmPassword(control: AbstractControl): any { if ( !control.parent || !control ) { diff --git a/src/app/main/pages/authentication/reset-password-2/reset-password-2.module.ts b/src/app/main/pages/authentication/reset-password-2/reset-password-2.module.ts index ef10b6f8..5d70a2a0 100644 --- a/src/app/main/pages/authentication/reset-password-2/reset-password-2.module.ts +++ b/src/app/main/pages/authentication/reset-password-2/reset-password-2.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatFormFieldModule, MatInputModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseResetPassword2Component } from './reset-password-2.component'; +import { ResetPassword2Component } from 'app/main/pages/authentication/reset-password-2/reset-password-2.component'; const routes = [ { path : 'auth/reset-password-2', - component: FuseResetPassword2Component + component: ResetPassword2Component } ]; @NgModule({ declarations: [ - FuseResetPassword2Component + ResetPassword2Component ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/pages/authentication/reset-password/reset-password.component.ts b/src/app/main/pages/authentication/reset-password/reset-password.component.ts index 3c86a632..749d5a4b 100644 --- a/src/app/main/pages/authentication/reset-password/reset-password.component.ts +++ b/src/app/main/pages/authentication/reset-password/reset-password.component.ts @@ -1,54 +1,96 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { AbstractControl, FormBuilder, FormGroup, Validators } from '@angular/forms'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FuseConfigService } from '@fuse/services/config.service'; import { fuseAnimations } from '@fuse/animations'; @Component({ - selector : 'fuse-reset-password', + selector : 'reset-password', templateUrl: './reset-password.component.html', styleUrls : ['./reset-password.component.scss'], animations : fuseAnimations }) -export class FuseResetPasswordComponent implements OnInit +export class ResetPasswordComponent implements OnInit, OnDestroy { resetPasswordForm: FormGroup; resetPasswordFormErrors: any; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + * @param {FormBuilder} _formBuilder + */ constructor( - private fuseConfig: FuseConfigService, - private formBuilder: FormBuilder + private _fuseConfigService: FuseConfigService, + private _formBuilder: FormBuilder ) { - this.fuseConfig.setConfig({ + // Configure the layout + this._fuseConfigService.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; + // Set the defaults this.resetPasswordFormErrors = { email : {}, password : {}, passwordConfirm: {} }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.resetPasswordForm = this.formBuilder.group({ + this.resetPasswordForm = this._formBuilder.group({ email : ['', [Validators.required, Validators.email]], password : ['', Validators.required], passwordConfirm: ['', [Validators.required, confirmPassword]] }); - this.resetPasswordForm.valueChanges.subscribe(() => { - this.onResetPasswordFormValuesChanged(); - }); + this.resetPasswordForm.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onResetPasswordFormValuesChanged(); + }); } - onResetPasswordFormValuesChanged() + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On form values changed + */ + onResetPasswordFormValuesChanged(): void { for ( const field in this.resetPasswordFormErrors ) { @@ -71,7 +113,13 @@ export class FuseResetPasswordComponent implements OnInit } } -function confirmPassword(control: AbstractControl) +/** + * Confirm password + * + * @param {AbstractControl} control + * @returns {{passwordsNotMatch: boolean}} + */ +function confirmPassword(control: AbstractControl): any { if ( !control.parent || !control ) { diff --git a/src/app/main/pages/authentication/reset-password/reset-password.module.ts b/src/app/main/pages/authentication/reset-password/reset-password.module.ts index 21f8e358..ed454e5d 100644 --- a/src/app/main/pages/authentication/reset-password/reset-password.module.ts +++ b/src/app/main/pages/authentication/reset-password/reset-password.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatButtonModule, MatFormFieldModule, MatInputModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseResetPasswordComponent } from './reset-password.component'; +import { ResetPasswordComponent } from 'app/main/pages/authentication/reset-password/reset-password.component'; const routes = [ { path : 'auth/reset-password', - component: FuseResetPasswordComponent + component: ResetPasswordComponent } ]; @NgModule({ declarations: [ - FuseResetPasswordComponent + ResetPasswordComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/pages/coming-soon/coming-soon.component.ts b/src/app/main/pages/coming-soon/coming-soon.component.ts index 53b252c1..ba95f31c 100644 --- a/src/app/main/pages/coming-soon/coming-soon.component.ts +++ b/src/app/main/pages/coming-soon/coming-soon.component.ts @@ -20,13 +20,13 @@ export class FuseComingSoonComponent implements OnInit private formBuilder: FormBuilder ) { - this.fuseConfig.setConfig({ + this.fuseConfig.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; this.comingSoonFormErrors = { email: {} diff --git a/src/app/main/pages/errors/404/error-404.component.ts b/src/app/main/pages/errors/404/error-404.component.ts index 135c99da..d1e1f17c 100644 --- a/src/app/main/pages/errors/404/error-404.component.ts +++ b/src/app/main/pages/errors/404/error-404.component.ts @@ -13,12 +13,12 @@ export class FuseError404Component private fuseConfig: FuseConfigService ) { - this.fuseConfig.setConfig({ + this.fuseConfig.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; } } diff --git a/src/app/main/pages/errors/500/error-500.component.ts b/src/app/main/pages/errors/500/error-500.component.ts index b4014e47..4225f9a9 100644 --- a/src/app/main/pages/errors/500/error-500.component.ts +++ b/src/app/main/pages/errors/500/error-500.component.ts @@ -13,12 +13,12 @@ export class FuseError500Component private fuseConfig: FuseConfigService ) { - this.fuseConfig.setConfig({ + this.fuseConfig.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; } } diff --git a/src/app/main/pages/maintenance/maintenance.component.ts b/src/app/main/pages/maintenance/maintenance.component.ts index 8ba28d25..cdedd8f7 100644 --- a/src/app/main/pages/maintenance/maintenance.component.ts +++ b/src/app/main/pages/maintenance/maintenance.component.ts @@ -15,12 +15,12 @@ export class FuseMaintenanceComponent private fuseConfig: FuseConfigService ) { - this.fuseConfig.setConfig({ + this.fuseConfig.config = { layout: { navigation: 'none', toolbar : 'none', footer : 'none' } - }); + }; } } diff --git a/src/app/main/pages/pages.module.ts b/src/app/main/pages/pages.module.ts index 96a6ba58..8cef2f0e 100644 --- a/src/app/main/pages/pages.module.ts +++ b/src/app/main/pages/pages.module.ts @@ -1,30 +1,30 @@ import { NgModule } from '@angular/core'; -import { LoginModule } from './authentication/login/login.module'; -import { Login2Module } from './authentication/login-2/login-2.module'; -import { RegisterModule } from './authentication/register/register.module'; -import { Register2Module } from './authentication/register-2/register-2.module'; -import { ForgotPasswordModule } from './authentication/forgot-password/forgot-password.module'; -import { ForgotPassword2Module } from './authentication/forgot-password-2/forgot-password-2.module'; -import { ResetPasswordModule } from './authentication/reset-password/reset-password.module'; -import { ResetPassword2Module } from './authentication/reset-password-2/reset-password-2.module'; -import { LockModule } from './authentication/lock/lock.module'; -import { MailConfirmModule } from './authentication/mail-confirm/mail-confirm.module'; -import { ComingSoonModule } from './coming-soon/coming-soon.module'; -import { Error404Module } from './errors/404/error-404.module'; -import { Error500Module } from './errors/500/error-500.module'; -import { InvoiceCompactModule } from './invoices/compact/compact.module'; -import { InvoiceModernModule } from './invoices/modern/modern.module'; -import { MaintenanceModule } from './maintenance/maintenence.module'; -import { PricingModule } from './pricing/pricing.module'; -import { ProfileModule } from './profile/profile.module'; -import { SearchModule } from './search/search.module'; -import { FaqModule } from './faq/faq.module'; -import { KnowledgeBaseModule } from './knowledge-base/knowledge-base.module'; +import { LoginModule } from 'app/main/pages/authentication/login/login.module'; +import { Login2Module } from 'app/main/pages/authentication/login-2/login-2.module'; +import { RegisterModule } from 'app/main/pages/authentication/register/register.module'; +import { Register2Module } from 'app/main/pages/authentication/register-2/register-2.module'; +import { ForgotPasswordModule } from 'app/main/pages/authentication/forgot-password/forgot-password.module'; +import { ForgotPassword2Module } from 'app/main/pages/authentication/forgot-password-2/forgot-password-2.module'; +import { ResetPasswordModule } from 'app/main/pages/authentication/reset-password/reset-password.module'; +import { ResetPassword2Module } from 'app/main/pages/authentication/reset-password-2/reset-password-2.module'; +import { LockModule } from 'app/main/pages/authentication/lock/lock.module'; +import { MailConfirmModule } from 'app/main/pages/authentication/mail-confirm/mail-confirm.module'; +import { ComingSoonModule } from 'app/main/pages/coming-soon/coming-soon.module'; +import { Error404Module } from 'app/main/pages/errors/404/error-404.module'; +import { Error500Module } from 'app/main/pages/errors/500/error-500.module'; +import { InvoiceModernModule } from 'app/main/pages/invoices/modern/modern.module'; +import { InvoiceCompactModule } from 'app/main/pages/invoices/compact/compact.module'; +import { MaintenanceModule } from 'app/main/pages/maintenance/maintenence.module'; +import { PricingModule } from 'app/main/pages/pricing/pricing.module'; +import { ProfileModule } from 'app/main/pages/profile/profile.module'; +import { SearchModule } from 'app/main/pages/search/search.module'; +import { FaqModule } from 'app/main/pages/faq/faq.module'; +import { KnowledgeBaseModule } from 'app/main/pages/knowledge-base/knowledge-base.module'; @NgModule({ imports: [ - // Auth + // Authentication LoginModule, Login2Module, RegisterModule, @@ -66,7 +66,7 @@ import { KnowledgeBaseModule } from './knowledge-base/knowledge-base.module'; KnowledgeBaseModule ] }) -export class FusePagesModule +export class PagesModule { } diff --git a/src/app/main/services/services.module.ts b/src/app/main/services/services.module.ts index 6c44c3b3..202d3b15 100644 --- a/src/app/main/services/services.module.ts +++ b/src/app/main/services/services.module.ts @@ -1,13 +1,12 @@ import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; - import { MatIconModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseHighlightModule } from '@fuse/components'; -import { FuseConfigServiceDocsComponent } from './config/config.component'; -import { FuseSplashScreenServiceDocsComponent } from './splash-screen/splash-screen.component'; +import { FuseConfigServiceDocsComponent } from 'app/main/services/config/config.component'; +import { FuseSplashScreenServiceDocsComponent } from 'app/main/services/splash-screen/splash-screen.component'; const routes = [ { @@ -35,6 +34,6 @@ const routes = [ ], }) -export class FuseServicesModule +export class ServicesModule { } diff --git a/src/app/main/ui/ui.module.ts b/src/app/main/ui/ui.module.ts index 31acd6a4..f6798a1c 100644 --- a/src/app/main/ui/ui.module.ts +++ b/src/app/main/ui/ui.module.ts @@ -1,11 +1,11 @@ import { NgModule } from '@angular/core'; -import { UIFormsModule } from './forms/forms.module'; -import { UIIconsModule } from './icons/icons.module'; -import { UITypographyModule } from './typography/typography.module'; -import { UIHelperClassesModule } from './helper-classes/helper-classes.module'; -import { UIPageLayoutsModule } from './page-layouts/page-layouts.module'; -import { UIColorsModule } from './colors/colors.module'; +import { UIFormsModule } from 'app/main/ui/forms/forms.module'; +import { UIIconsModule } from 'app/main/ui/icons/icons.module'; +import { UITypographyModule } from 'app/main/ui/typography/typography.module'; +import { UIHelperClassesModule } from 'app/main/ui/helper-classes/helper-classes.module'; +import { UIPageLayoutsModule } from 'app/main/ui/page-layouts/page-layouts.module'; +import { UIColorsModule } from 'app/main/ui/colors/colors.module'; @NgModule({ imports: [ diff --git a/src/app/store/actions/router.action.ts b/src/app/store/actions/router.action.ts index 52fcf954..169d86d6 100644 --- a/src/app/store/actions/router.action.ts +++ b/src/app/store/actions/router.action.ts @@ -9,6 +9,11 @@ export class Go implements Action { readonly type = GO; + /** + * Constructor + * + * @param {{path: any[]; query?: object; extras?: NavigationExtras}} payload + */ constructor( public payload: { path: any[]; diff --git a/src/app/store/effects/router.effect.ts b/src/app/store/effects/router.effect.ts index f0935b78..a9cbf25e 100644 --- a/src/app/store/effects/router.effect.ts +++ b/src/app/store/effects/router.effect.ts @@ -1,15 +1,21 @@ import { Injectable } from '@angular/core'; import { Router } from '@angular/router'; import { Location } from '@angular/common'; - import { Effect, Actions } from '@ngrx/effects'; -import * as RouterActions from '../actions/router.action'; - import { tap, map } from 'rxjs/operators'; +import * as RouterActions from 'app/store/actions/router.action'; + @Injectable() export class RouterEffects { + /** + * Constructor + * + * @param {Actions} actions$ + * @param {Router} router + * @param {Location} location + */ constructor( private actions$: Actions, private router: Router, @@ -18,6 +24,9 @@ export class RouterEffects { } + /** + * Navigate + */ @Effect({dispatch: false}) navigate$ = this.actions$.ofType(RouterActions.GO).pipe( map((action: RouterActions.Go) => action.payload), @@ -26,11 +35,19 @@ export class RouterEffects }) ); + /** + * Navigate back + * @type {Observable} + */ @Effect({dispatch: false}) navigateBack$ = this.actions$ .ofType(RouterActions.BACK) .pipe(tap(() => this.location.back())); + /** + * Navigate forward + * @type {Observable} + */ @Effect({dispatch: false}) navigateForward$ = this.actions$ .ofType(RouterActions.FORWARD) diff --git a/src/app/store/reducers/index.ts b/src/app/store/reducers/index.ts index 42278dca..d8d0c987 100644 --- a/src/app/store/reducers/index.ts +++ b/src/app/store/reducers/index.ts @@ -1,10 +1,5 @@ -import { - ActivatedRouteSnapshot, - RouterStateSnapshot, - Params -} from '@angular/router'; +import { ActivatedRouteSnapshot, RouterStateSnapshot, Params } from '@angular/router'; import { createFeatureSelector, ActionReducerMap } from '@ngrx/store'; - import * as fromRouter from '@ngrx/router-store'; export interface RouterStateUrl diff --git a/src/app/store/store.module.ts b/src/app/store/store.module.ts index 29e51c04..1db8e786 100644 --- a/src/app/store/store.module.ts +++ b/src/app/store/store.module.ts @@ -3,9 +3,10 @@ import { EffectsModule } from '@ngrx/effects'; import { MetaReducer, StoreModule } from '@ngrx/store'; import { NgModule } from '@angular/core'; import { storeFreeze } from 'ngrx-store-freeze'; -import { environment } from '../../environments/environment'; import { RouterStateSerializer, StoreRouterConnectingModule } from '@ngrx/router-store'; -import { reducers, effects, CustomSerializer } from './index'; + +import { environment } from 'environments/environment'; +import { reducers, effects, CustomSerializer } from 'app/store'; export const metaReducers: MetaReducer[] = !environment.production ? [storeFreeze] diff --git a/src/tslint.json b/src/tslint.json index 04494aa2..d88db874 100644 --- a/src/tslint.json +++ b/src/tslint.json @@ -4,14 +4,23 @@ "directive-selector": [ true, "attribute", - "fuse", + [ + "fuse", + "" + ], "camelCase" ], "component-selector": [ true, "element", - "fuse", - "kebab-case" + [ + "fuse", + "" + ], + [ + "kebab-case", + "camelCase" + ] ] } } diff --git a/tslint.json b/tslint.json index 6583c181..eca56dcb 100644 --- a/tslint.json +++ b/tslint.json @@ -90,6 +90,11 @@ true, "allow-null-check" ], + "typedef": [ + true, + "call-signature", + "property-declaration" + ], "typedef-whitespace": [ true, { From 126ba35d3d64ef68641850d398cbb98fa04706e0 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Sun, 20 May 2018 10:19:15 +0300 Subject: [PATCH 07/80] Updated Angular and various other packages --- package-lock.json | 541 +++++++++++++++++++++++++++++++++++----------- package.json | 30 +-- 2 files changed, 429 insertions(+), 142 deletions(-) diff --git a/package-lock.json b/package-lock.json index a830dc31..35ecb7c4 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,27 +10,27 @@ "integrity": "sha512-3bdfvkWDmJszpj/F6Fzgv7sks0cs/cUEQPfs37tcJFz3jc62SsXy4TGb/WJT8FpH2nSGE6DonP8lXuFxB0lblQ==" }, "@angular-devkit/architect": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/@angular-devkit/architect/-/architect-0.6.1.tgz", - "integrity": "sha512-sYoqm3d7UlCsGJLL/UIanxctNl6JP/QK89mCcBClU4AO6hbpdKydov+A159Zg082RUJoy1JYplh1uUx0HstrJg==", + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/@angular-devkit/architect/-/architect-0.6.3.tgz", + "integrity": "sha512-w9tK3VACU+CnOQQZT6o7QO2brn/OVNDf2Y11rI+ZQH7UIn6N0ZFoMl9WyFB//K2Gkoa7hAobykhRTtP8lrTF1g==", "dev": true, "requires": { - "@angular-devkit/core": "0.6.1", + "@angular-devkit/core": "0.6.3", "rxjs": "^6.0.0" } }, "@angular-devkit/build-angular": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/@angular-devkit/build-angular/-/build-angular-0.6.1.tgz", - "integrity": "sha512-pXMjwdWkhEDAt3JVmwdpzwj+4KELsH6htP9W55vkjVHzPnq4Ps/w0mDzDifLsiV9u3FILTacu+X6foMfDJylzw==", + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/@angular-devkit/build-angular/-/build-angular-0.6.3.tgz", + "integrity": "sha512-ce+uAXQXyuMy6IxSnsGKeHlLVjsI77DblNvkcO1NilP7iYxujEJx6qDq/Hrf1uhuqRpm+8pt5zY6QD90gQrDcg==", "dev": true, "requires": { - "@angular-devkit/architect": "0.6.1", - "@angular-devkit/build-optimizer": "0.6.1", - "@angular-devkit/core": "0.6.1", - "@ngtools/webpack": "6.0.1", + "@angular-devkit/architect": "0.6.3", + "@angular-devkit/build-optimizer": "0.6.3", + "@angular-devkit/core": "0.6.3", + "@ngtools/webpack": "6.0.3", "ajv": "~6.4.0", - "autoprefixer": "^8.1.0", + "autoprefixer": "^8.4.1", "cache-loader": "^1.2.2", "chalk": "~2.2.2", "circular-dependency-plugin": "^5.0.2", @@ -42,21 +42,21 @@ "istanbul": "^0.4.5", "istanbul-instrumenter-loader": "^3.0.1", "karma-source-map-support": "^1.2.0", - "less": "^3.0.2", + "less": "^3.0.4", "less-loader": "^4.1.0", "license-webpack-plugin": "^1.3.1", "lodash": "^4.17.4", "memory-fs": "^0.4.1", "mini-css-extract-plugin": "~0.4.0", "minimatch": "^3.0.4", - "node-sass": "^4.8.3", + "node-sass": "^4.9.0", "opn": "^5.1.0", "parse5": "^4.0.0", "portfinder": "^1.0.13", - "postcss": "^6.0.19", + "postcss": "^6.0.22", "postcss-import": "^11.1.0", - "postcss-loader": "^2.1.4", - "postcss-url": "^7.3.1", + "postcss-loader": "^2.1.5", + "postcss-url": "^7.3.2", "raw-loader": "^0.5.1", "resolve": "^1.5.0", "rxjs": "^6.0.0", @@ -70,7 +70,7 @@ "tree-kill": "^1.2.0", "uglifyjs-webpack-plugin": "^1.2.5", "url-loader": "^1.0.1", - "webpack": "~4.6.0", + "webpack": "~4.8.1", "webpack-dev-middleware": "^3.1.3", "webpack-dev-server": "^3.1.4", "webpack-merge": "^4.1.2", @@ -79,9 +79,9 @@ } }, "@angular-devkit/build-optimizer": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/@angular-devkit/build-optimizer/-/build-optimizer-0.6.1.tgz", - "integrity": "sha512-7jfSrjMkEArTtHEStxQQYaApAigQh4PlKy0+utH/6AYEt1F9+ENSksKSb2Q5E0wSq2CMHBtrpHjyYHNpASl0ng==", + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/@angular-devkit/build-optimizer/-/build-optimizer-0.6.3.tgz", + "integrity": "sha512-C0LGWh7+rYjpE1T1guaq9EMovwhEJ1QR25qjJxUoYvN+sM+MfVpMhoa6ruqnxh+eQCfRiMdIsnbOboiZxNHTQw==", "dev": true, "requires": { "loader-utils": "^1.1.0", @@ -91,9 +91,9 @@ } }, "@angular-devkit/core": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/@angular-devkit/core/-/core-0.6.1.tgz", - "integrity": "sha512-wRsuc1zuW57IQdx7dVOut7AUgAMIxnmIk3DKzLeNhLEKpMaGbwpznULbQWJtEZetwPbZ7pMeKT0nkXMIsQ92Gg==", + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/@angular-devkit/core/-/core-0.6.3.tgz", + "integrity": "sha512-97hFVW6in8oYJUEqjmUP0Tb/mPlTG3sc0THpe5MCGEkDPjlp2cObt9rUCAVOjugBlScV8rzTpVQ+95PT60Py8A==", "dev": true, "requires": { "ajv": "~6.4.0", @@ -103,19 +103,19 @@ } }, "@angular-devkit/schematics": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/@angular-devkit/schematics/-/schematics-0.6.1.tgz", - "integrity": "sha512-SF+S+T446u/outrRzsSd6rh5gxGIx2Zpu21msDJCxa1AKuN06QRtuvP0Hlb+34XKXzui4HkRBgLdKjoJgvFtrw==", + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/@angular-devkit/schematics/-/schematics-0.6.3.tgz", + "integrity": "sha512-dXlyVNuFRhiOnhAk0NojEUThLrZBpVZmWvEQ4h/pnyHS0P9CfnHqJ8DCcCrjOwYkzdBwBrYchXOCYfo8zuxYGw==", "dev": true, "requires": { - "@angular-devkit/core": "0.6.1", + "@angular-devkit/core": "0.6.3", "rxjs": "^6.0.0" } }, "@angular/animations": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/animations/-/animations-6.0.1.tgz", - "integrity": "sha512-L/8v0j50VPKX08gvdHpzYnkKzqvBJ/RDH74aqOGV637Nsa3hxe0yyq7FNg0t7pRsGk3k0b6RXeBlosKo7Sj7rA==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/animations/-/animations-6.0.2.tgz", + "integrity": "sha512-QoNJ/L0Xgtrj1KBp8wvxhHwRt+sQ5tBihWm82UbNgN82ZNnfNzQoAqtahbZN5AY7XFmGbDX+lVt3TdO8omXhmg==", "requires": { "tslib": "^1.9.0" } @@ -129,16 +129,16 @@ } }, "@angular/cli": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/cli/-/cli-6.0.1.tgz", - "integrity": "sha512-jS2CZl5Kk2tFvEzU7BJjOqTrMt4ogjxuvB7rxwl/TMHVhCpvlSg5FtJtc2pVw+3HAH9nwMSkjKL75HSXcg7eDg==", + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/@angular/cli/-/cli-6.0.3.tgz", + "integrity": "sha512-G8jfgJublsRjveX1P+F5awHvpC07mKAF7f5lebowIs+QAHSOD6HxQ/JhMbJTwz/aj20iWgZOygA5LhkP0Wr+UQ==", "dev": true, "requires": { - "@angular-devkit/architect": "0.6.1", - "@angular-devkit/core": "0.6.1", - "@angular-devkit/schematics": "0.6.1", - "@schematics/angular": "0.6.1", - "@schematics/update": "0.6.1", + "@angular-devkit/architect": "0.6.3", + "@angular-devkit/core": "0.6.3", + "@angular-devkit/schematics": "0.6.3", + "@schematics/angular": "0.6.3", + "@schematics/update": "0.6.3", "opn": "~5.3.0", "resolve": "^1.1.7", "rxjs": "^6.0.0", @@ -166,25 +166,25 @@ } }, "@angular/common": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/common/-/common-6.0.1.tgz", - "integrity": "sha512-okxtOHE05Eaa7w6YCL2idXUHPTwrea5CEVXjA36zSZ9qtlB/IYcjYI9Opo5l8SE5Qy/eqpDdoanax1NM6xbtqw==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/common/-/common-6.0.2.tgz", + "integrity": "sha512-Yc3NnLGs1ltnDhUCOoMCQMRSkJv/sCv+jKx3uSdrvd8Y55APl2boZhZUK4WphPfWIkpvC7odpiLXAmnVgP6vcw==", "requires": { "tslib": "^1.9.0" } }, "@angular/compiler": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/compiler/-/compiler-6.0.1.tgz", - "integrity": "sha512-yGucUdNo/8gWIWScpMu9gDYh9wOse+OXJapqBR7JtUowW24PWgICTslWbre4d0PAcueaWhLQo4YqqF689UDfhQ==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/compiler/-/compiler-6.0.2.tgz", + "integrity": "sha512-uKuM7dcTWwcElklT4E/tckp5fnGNUq4wDna3gZWO6fvc7FQK0SUU4l+A6C1d5YdCRgAsv6gxIrk3MxbSF9UwEw==", "requires": { "tslib": "^1.9.0" } }, "@angular/compiler-cli": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/compiler-cli/-/compiler-cli-6.0.1.tgz", - "integrity": "sha512-P34AwBlnIIwreWhoi8CpEtM3Rxo/eiPKKszF9FRFDihbKZamXQP7mITONSW5Pj6lVqnfP0fiFXTwnfmnxXDUIg==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/compiler-cli/-/compiler-cli-6.0.2.tgz", + "integrity": "sha512-6hupeihL+MKYbP0xvHZiaVpYVF1XAlLpI1aTVLUhpzgnR8vgXCwni9iJlr7BZFyicVgApn6l7Oh2xIvMWftYhw==", "dev": true, "requires": { "chokidar": "^1.4.2", @@ -327,9 +327,9 @@ } }, "@angular/core": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/core/-/core-6.0.1.tgz", - "integrity": "sha512-w9fYaWSk0WrtdvKOvH5KDoRaZ3FhleKVgbbJ0skMsgmro1vrO5j2iIO88AJdbT7k+FAyC+eTtNS8Koqd4ranQg==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/core/-/core-6.0.2.tgz", + "integrity": "sha512-+ahJofKZFyaq0kLhKUOCa3Fo4WQ4mkMmYRqwFjKgjPupzPgMh0FkBsojuP1WiBd5KTIkv7U8B4sTziUxRDrKgg==", "requires": { "tslib": "^1.9.0" } @@ -343,25 +343,25 @@ } }, "@angular/forms": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/forms/-/forms-6.0.1.tgz", - "integrity": "sha512-YCKTxWh1HmYhXXyFYR/V+pxMqD+02Q5TjDOlzBond5uQUSxC+oJEfhUWUuCYi4QmnTsfWnaI0RKwKsBQvmDzIA==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/forms/-/forms-6.0.2.tgz", + "integrity": "sha512-Oc234cLjTj1tx2gF/nS/TIC3Auc+LCyC8H6GYqTxXQUyZQeGHqUptvDQz3KwM9Num3EKFUr9J2yzGPnz6lZVmQ==", "requires": { "tslib": "^1.9.0" } }, "@angular/http": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/http/-/http-6.0.1.tgz", - "integrity": "sha512-h60MgZg8/m6Rh0X9NTqwzBVDArXwoEOxz79FvQ29tppZejAHPdv0fQyck+3U6I+wOEGvJq03z8unl1Szji2rXg==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/http/-/http-6.0.2.tgz", + "integrity": "sha512-BONrdNMKOaQdXiWnrCAaUiP1akf/nuUG6xm/PJe684SrgcqWHN4JJuwgMhGRGIZZCIKEWcIEaZSp+DbWqnj1kg==", "requires": { "tslib": "^1.9.0" } }, "@angular/language-service": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/language-service/-/language-service-6.0.1.tgz", - "integrity": "sha512-T8FcxeD5nOaIWa23CJVR3tUzapiiHWHttA9PD1Jl/OwFSibxCtPyuTN/H+sHzxXwPNBz/TI3gES5Pcn6FzMt4w==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/language-service/-/language-service-6.0.2.tgz", + "integrity": "sha512-EznIei5QGv4Hv+RtfCnI8TQPW7gLZBw7LrGPXSbwV/CXfY11ziEsd/h1lBfN3Wch3soIOXs3Qqk3zx//MrBG/Q==", "dev": true }, "@angular/material": { @@ -381,25 +381,25 @@ } }, "@angular/platform-browser": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/platform-browser/-/platform-browser-6.0.1.tgz", - "integrity": "sha512-F5eu2kHBtd7CqEuYI8CArEY8qYVBIQIYxEAmczyNOv3CLqxdEq23GLVFMDiVT7RpzaZPIxFoGvhEhnUhDeaVDw==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/platform-browser/-/platform-browser-6.0.2.tgz", + "integrity": "sha512-iMBHckhknJ8Wfw9ZVloiw0WPZDtzQFLE2e7D42of7SgXuHloStXUchb0qLr6ZTZwTY0oBPSvDKgJJVmEjZUZvw==", "requires": { "tslib": "^1.9.0" } }, "@angular/platform-browser-dynamic": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/platform-browser-dynamic/-/platform-browser-dynamic-6.0.1.tgz", - "integrity": "sha512-eKZRua98kEC0THSEeGXSk7j9wGn3AtrvElsY59bt7gnWWU4nY6y7Dem6kVjXb+MDkH9ESPyC0uavARdUq2kYuw==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/platform-browser-dynamic/-/platform-browser-dynamic-6.0.2.tgz", + "integrity": "sha512-g1EC0wIWd4OhcEvUnisTfp3y0eMAXgXbACdtgsrozG//xzyqiRFUnBTYTAP4ecninCEltyZYK7EBGfzp8KwQjw==", "requires": { "tslib": "^1.9.0" } }, "@angular/router": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@angular/router/-/router-6.0.1.tgz", - "integrity": "sha512-NcVCLCEhV+999/RvED/JwKjAVi288V3wF5SNS/E4NiLU13FCDy6jO32+BhVRgJt/XLNY4IxnXUISukkMBGPI8Q==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@angular/router/-/router-6.0.2.tgz", + "integrity": "sha512-XqTtfs/UzT2k2MeVQG1pOP+wR1zcH8V71S6kmWIwFcfyKUgZfIm45sNsZyBZPwY2RUqwCeZYQFjPlVW8wD1PBw==", "requires": { "tslib": "^1.9.0" } @@ -431,12 +431,12 @@ "integrity": "sha512-KwmMELWY+WA1fL/myhQGiqM1uvRIjQ7yUaViVwknhRf7UsBPlWTMrSiFqUIb3QkwGYnVdqRjdYVQrJTIdJpolQ==" }, "@ngtools/webpack": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/@ngtools/webpack/-/webpack-6.0.1.tgz", - "integrity": "sha512-PV3UNQINVxHZA1kkWaVds4GJaNXjMCJep0otkHP6ODZ3NNMnrKS8RS9HeqFUxQ+r4GnKj4qctbsdm3awRr1DsA==", + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/@ngtools/webpack/-/webpack-6.0.3.tgz", + "integrity": "sha512-wrhSFItcZp4Yzp6lgSuy23YdhaUs9D+KdGZPjwzzXtJIJCSzGkWuXzwlCwyKSFRQ6thyH/T3nffpHNaS3dWn2A==", "dev": true, "requires": { - "@angular-devkit/core": "0.6.1", + "@angular-devkit/core": "0.6.3", "tree-kill": "^1.0.0", "webpack-sources": "^1.1.0" } @@ -450,24 +450,24 @@ } }, "@schematics/angular": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/@schematics/angular/-/angular-0.6.1.tgz", - "integrity": "sha512-onvYJtpqwwaqDlqrJ6RPNN2uj5Y1DzRhYQeLHEUFYROHXC/JYrIRf1f1pV4VAPYVqsPq8ELa9Ts431/HdTjCEA==", + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/@schematics/angular/-/angular-0.6.3.tgz", + "integrity": "sha512-YhldE1K6x/8D0PxFusjtB32iOAayyD1PSxPCx/q7I7T6x/lG7l35ZDV6ZZE6bDvIaxQBsjhIm8ACy2n+xwFxTA==", "dev": true, "requires": { - "@angular-devkit/core": "0.6.1", - "@angular-devkit/schematics": "0.6.1", + "@angular-devkit/core": "0.6.3", + "@angular-devkit/schematics": "0.6.3", "typescript": ">=2.6.2 <2.8" } }, "@schematics/update": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/@schematics/update/-/update-0.6.1.tgz", - "integrity": "sha512-hywO6GmvjhubNkZqMweUER0IIKkauEQpVBg3TTUG9mR5sDa95dp/wsuU98wVGXYcO/dD6cw8MrwQYNV3YtqCUw==", + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/@schematics/update/-/update-0.6.3.tgz", + "integrity": "sha512-UsKrg02+jwdsz9BdMVxDMeAZCF+c+dvHRWww4D2RcNzWdCTVWeBqRAmlreJJ0TGE54r7PEBnmQe0t5mS4F3d4w==", "dev": true, "requires": { - "@angular-devkit/core": "0.6.1", - "@angular-devkit/schematics": "0.6.1", + "@angular-devkit/core": "0.6.3", + "@angular-devkit/schematics": "0.6.3", "npm-registry-client": "^8.5.1", "rxjs": "^6.0.0", "semver": "^5.3.0", @@ -536,9 +536,9 @@ } }, "@types/lodash": { - "version": "4.14.108", - "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.108.tgz", - "integrity": "sha512-WD2vUOKfBBVHxWUV9iMR9RMfpuf8HquxWeAq2yqGVL7Nc4JW2+sQama0pREMqzNI3Tutj0PyxYUJwuoxxvX+xA==", + "version": "4.14.109", + "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.109.tgz", + "integrity": "sha512-hop8SdPUEzbcJm6aTsmuwjIYQo1tqLseKCM+s2bBqTU2gErwI4fE+aqUVOlscPSQbKHKgtMMPoC+h4AIGOJYvw==", "dev": true }, "@types/node": { @@ -564,6 +564,219 @@ "integrity": "sha512-UBYHWph6P3tutkbXpW6XYg9ZPbTKjw/YC2hGG1/GEvWwTbvezBUv3h+mmUFw79T3RFPnmedpiXdOBbXX+4l0jg==", "dev": true }, + "@webassemblyjs/ast": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.4.3.tgz", + "integrity": "sha512-S6npYhPcTHDYe9nlsKa9CyWByFi8Vj8HovcAgtmMAQZUOczOZbQ8CnwMYKYC5HEZzxEE+oY0jfQk4cVlI3J59Q==", + "dev": true, + "requires": { + "@webassemblyjs/helper-wasm-bytecode": "1.4.3", + "@webassemblyjs/wast-parser": "1.4.3", + "debug": "^3.1.0", + "webassemblyjs": "1.4.3" + }, + "dependencies": { + "debug": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", + "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + } + } + }, + "@webassemblyjs/floating-point-hex-parser": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.4.3.tgz", + "integrity": "sha512-3zTkSFswwZOPNHnzkP9ONq4bjJSeKVMcuahGXubrlLmZP8fmTIJ58dW7h/zOVWiFSuG2em3/HH3BlCN7wyu9Rw==", + "dev": true + }, + "@webassemblyjs/helper-buffer": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.4.3.tgz", + "integrity": "sha512-e8+KZHh+RV8MUvoSRtuT1sFXskFnWG9vbDy47Oa166xX+l0dD5sERJ21g5/tcH8Yo95e9IN3u7Jc3NbhnUcSkw==", + "dev": true, + "requires": { + "debug": "^3.1.0" + }, + "dependencies": { + "debug": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", + "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + } + } + }, + "@webassemblyjs/helper-code-frame": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-code-frame/-/helper-code-frame-1.4.3.tgz", + "integrity": "sha512-9FgHEtNsZQYaKrGCtsjswBil48Qp1agrzRcPzCbQloCoaTbOXLJ9IRmqT+uEZbenpULLRNFugz3I4uw18hJM8w==", + "dev": true, + "requires": { + "@webassemblyjs/wast-printer": "1.4.3" + } + }, + "@webassemblyjs/helper-fsm": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-fsm/-/helper-fsm-1.4.3.tgz", + "integrity": "sha512-JINY76U+702IRf7ePukOt037RwmtH59JHvcdWbTTyHi18ixmQ+uOuNhcdCcQHTquDAH35/QgFlp3Y9KqtyJsCQ==", + "dev": true + }, + "@webassemblyjs/helper-wasm-bytecode": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.4.3.tgz", + "integrity": "sha512-I7bS+HaO0K07Io89qhJv+z1QipTpuramGwUSDkwEaficbSvCcL92CUZEtgykfNtk5wb0CoLQwWlmXTwGbNZUeQ==", + "dev": true + }, + "@webassemblyjs/helper-wasm-section": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.4.3.tgz", + "integrity": "sha512-p0yeeO/h2r30PyjnJX9xXSR6EDcvJd/jC6xa/Pxg4lpfcNi7JUswOpqDToZQ55HMMVhXDih/yqkaywHWGLxqyQ==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.4.3", + "@webassemblyjs/helper-buffer": "1.4.3", + "@webassemblyjs/helper-wasm-bytecode": "1.4.3", + "@webassemblyjs/wasm-gen": "1.4.3", + "debug": "^3.1.0" + }, + "dependencies": { + "debug": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", + "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + } + } + }, + "@webassemblyjs/leb128": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.4.3.tgz", + "integrity": "sha512-4u0LJLSPzuRDWHwdqsrThYn+WqMFVqbI2ltNrHvZZkzFPO8XOZ0HFQ5eVc4jY/TNHgXcnwrHjONhPGYuuf//KQ==", + "dev": true, + "requires": { + "leb": "^0.3.0" + } + }, + "@webassemblyjs/validation": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/validation/-/validation-1.4.3.tgz", + "integrity": "sha512-R+rRMKfhd9mq0rj2mhU9A9NKI2l/Rw65vIYzz4lui7eTKPcCu1l7iZNi4b9Gen8D42Sqh/KGiaQNk/x5Tn/iBQ==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.4.3" + } + }, + "@webassemblyjs/wasm-edit": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.4.3.tgz", + "integrity": "sha512-qzuwUn771PV6/LilqkXcS0ozJYAeY/OKbXIWU3a8gexuqb6De2p4ya/baBeH5JQ2WJdfhWhSvSbu86Vienttpw==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.4.3", + "@webassemblyjs/helper-buffer": "1.4.3", + "@webassemblyjs/helper-wasm-bytecode": "1.4.3", + "@webassemblyjs/helper-wasm-section": "1.4.3", + "@webassemblyjs/wasm-gen": "1.4.3", + "@webassemblyjs/wasm-opt": "1.4.3", + "@webassemblyjs/wasm-parser": "1.4.3", + "@webassemblyjs/wast-printer": "1.4.3", + "debug": "^3.1.0" + }, + "dependencies": { + "debug": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", + "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + } + } + }, + "@webassemblyjs/wasm-gen": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.4.3.tgz", + "integrity": "sha512-eR394T8dHZfpLJ7U/Z5pFSvxl1L63JdREebpv9gYc55zLhzzdJPAuxjBYT4XqevUdW67qU2s0nNA3kBuNJHbaQ==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.4.3", + "@webassemblyjs/helper-wasm-bytecode": "1.4.3", + "@webassemblyjs/leb128": "1.4.3" + } + }, + "@webassemblyjs/wasm-opt": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.4.3.tgz", + "integrity": "sha512-7Gp+nschuKiDuAL1xmp4Xz0rgEbxioFXw4nCFYEmy+ytynhBnTeGc9W9cB1XRu1w8pqRU2lbj2VBBA4cL5Z2Kw==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.4.3", + "@webassemblyjs/helper-buffer": "1.4.3", + "@webassemblyjs/wasm-gen": "1.4.3", + "@webassemblyjs/wasm-parser": "1.4.3", + "debug": "^3.1.0" + }, + "dependencies": { + "debug": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", + "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + } + } + }, + "@webassemblyjs/wasm-parser": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.4.3.tgz", + "integrity": "sha512-KXBjtlwA3BVukR/yWHC9GF+SCzBcgj0a7lm92kTOaa4cbjaTaa47bCjXw6cX4SGQpkncB9PU2hHGYVyyI7wFRg==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.4.3", + "@webassemblyjs/helper-wasm-bytecode": "1.4.3", + "@webassemblyjs/leb128": "1.4.3", + "@webassemblyjs/wasm-parser": "1.4.3", + "webassemblyjs": "1.4.3" + } + }, + "@webassemblyjs/wast-parser": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-parser/-/wast-parser-1.4.3.tgz", + "integrity": "sha512-QhCsQzqV0CpsEkRYyTzQDilCNUZ+5j92f+g35bHHNqS22FppNTywNFfHPq8ZWZfYCgbectc+PoghD+xfzVFh1Q==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.4.3", + "@webassemblyjs/floating-point-hex-parser": "1.4.3", + "@webassemblyjs/helper-code-frame": "1.4.3", + "@webassemblyjs/helper-fsm": "1.4.3", + "long": "^3.2.0", + "webassemblyjs": "1.4.3" + } + }, + "@webassemblyjs/wast-printer": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.4.3.tgz", + "integrity": "sha512-EgXk4anf8jKmuZJsqD8qy5bz2frEQhBvZruv+bqwNoLWUItjNSFygk8ywL3JTEz9KtxTlAmqTXNrdD1d9gNDtg==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.4.3", + "@webassemblyjs/wast-parser": "1.4.3", + "long": "^3.2.0" + } + }, "abbrev": { "version": "1.0.9", "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.0.9.tgz", @@ -918,7 +1131,8 @@ "version": "0.1.3", "resolved": "https://registry.npmjs.org/async-foreach/-/async-foreach-0.1.3.tgz", "integrity": "sha1-NhIfhFwFeBct5Bmpfb6x0W7DRUI=", - "dev": true + "dev": true, + "optional": true }, "async-limiter": { "version": "1.0.0", @@ -1234,6 +1448,7 @@ "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=", "dev": true, + "optional": true, "requires": { "inherits": "~2.0.0" } @@ -1603,9 +1818,9 @@ } }, "caniuse-lite": { - "version": "1.0.30000840", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000840.tgz", - "integrity": "sha512-Lw6AaouV6lh7TgIdQtLiUFKKO2mtDnZFkzCq5/V6tqs4ZI0OGVSDCEt1uegZ3OOBEBUYuVw3Hhr9DQSbgVofFA==", + "version": "1.0.30000843", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000843.tgz", + "integrity": "sha512-1ntiW826MhRBmM0CeI7w1cQr16gxwOoM8doJWh3BFalPZoKWdZXs27Bc04xth/3NR1/wNXn9cpP4F92lVenCvg==", "dev": true }, "caseless": { @@ -2188,6 +2403,7 @@ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-3.0.1.tgz", "integrity": "sha1-ElYDfsufDF9549bvE14wdwGEuYI=", "dev": true, + "optional": true, "requires": { "lru-cache": "^4.0.1", "which": "^1.2.9" @@ -2992,9 +3208,9 @@ "dev": true }, "electron-to-chromium": { - "version": "1.3.45", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.45.tgz", - "integrity": "sha1-RYrBscXHYM6IEaFtK/vZfsMLr7g=", + "version": "1.3.47", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.47.tgz", + "integrity": "sha1-dk6IfKkQTQGgrI6r7n38DizhQQQ=", "dev": true }, "elliptic": { @@ -4507,6 +4723,7 @@ "resolved": "https://registry.npmjs.org/gaze/-/gaze-1.1.2.tgz", "integrity": "sha1-hHIkZ3rbiHDWeSV+0ziP22HkAQU=", "dev": true, + "optional": true, "requires": { "globule": "^1.0.0" } @@ -4515,13 +4732,15 @@ "version": "2.0.0", "resolved": "https://registry.npmjs.org/generate-function/-/generate-function-2.0.0.tgz", "integrity": "sha1-aFj+fAlpt9TpCTM3ZHrHn2DfvnQ=", - "dev": true + "dev": true, + "optional": true }, "generate-object-property": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/generate-object-property/-/generate-object-property-1.2.0.tgz", "integrity": "sha1-nA4cQDCM6AT0eDYYuTf6iPmdUNA=", "dev": true, + "optional": true, "requires": { "is-property": "^1.0.0" } @@ -4655,6 +4874,7 @@ "resolved": "https://registry.npmjs.org/globule/-/globule-1.2.0.tgz", "integrity": "sha1-HcScaCLdnoovoAuiopUAboZkvQk=", "dev": true, + "optional": true, "requires": { "glob": "~7.1.1", "lodash": "~4.17.4", @@ -5176,7 +5396,8 @@ "version": "2.0.0", "resolved": "https://registry.npmjs.org/in-publish/-/in-publish-2.0.0.tgz", "integrity": "sha1-4g/146KvwmkDILbcVSaCqcf631E=", - "dev": true + "dev": true, + "optional": true }, "indent-string": { "version": "2.1.0", @@ -5416,13 +5637,15 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-my-ip-valid/-/is-my-ip-valid-1.0.0.tgz", "integrity": "sha512-gmh/eWXROncUzRnIa1Ubrt5b8ep/MGSnfAUI3aRp+sqTCs1tv1Isl8d8F6JmkN3dXKc3ehZMrtiPN9eL03NuaQ==", - "dev": true + "dev": true, + "optional": true }, "is-my-json-valid": { "version": "2.17.2", "resolved": "https://registry.npmjs.org/is-my-json-valid/-/is-my-json-valid-2.17.2.tgz", "integrity": "sha512-IBhBslgngMQN8DDSppmgDv7RNrlFotuuDsKcrCP3+HbFaVivIBU7u9oiiErw8sH4ynx3+gOGQ3q2otkgiSi6kg==", "dev": true, + "optional": true, "requires": { "generate-function": "^2.0.0", "generate-object-property": "^1.1.0", @@ -5517,7 +5740,8 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/is-property/-/is-property-1.0.2.tgz", "integrity": "sha1-V/4cTkhHTt1lsJkR8msc1Ald2oQ=", - "dev": true + "dev": true, + "optional": true }, "is-regex": { "version": "1.0.4", @@ -5851,10 +6075,11 @@ "dev": true }, "js-base64": { - "version": "2.4.3", - "resolved": "https://registry.npmjs.org/js-base64/-/js-base64-2.4.3.tgz", - "integrity": "sha512-H7ErYLM34CvDMto3GbD6xD0JLUGYXR3QTcH6B/tr4Hi/QpSThnCsIp+Sy5FRTw3B0d6py4HcNkW7nO/wdtGWEw==", - "dev": true + "version": "2.4.5", + "resolved": "https://registry.npmjs.org/js-base64/-/js-base64-2.4.5.tgz", + "integrity": "sha512-aUnNwqMOXw3yvErjMPSQu6qIIzUmT1e5KcU1OZxRDU1g/am6mzBvcrmLAYwzmB59BHPrh5/tKaiF4OPhqRWESQ==", + "dev": true, + "optional": true }, "js-tokens": { "version": "3.0.2", @@ -5927,7 +6152,8 @@ "version": "4.0.1", "resolved": "https://registry.npmjs.org/jsonpointer/-/jsonpointer-4.0.1.tgz", "integrity": "sha1-T9kss04OnbPInIYi7PUfm5eMbLk=", - "dev": true + "dev": true, + "optional": true }, "jsprim": { "version": "1.4.1", @@ -6234,6 +6460,12 @@ "invert-kv": "^1.0.0" } }, + "leb": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/leb/-/leb-0.3.0.tgz", + "integrity": "sha1-Mr7p+tFoMo1q6oUi2DP0GA7tHaM=", + "dev": true + }, "less": { "version": "3.0.4", "resolved": "https://registry.npmjs.org/less/-/less-3.0.4.tgz", @@ -6355,7 +6587,8 @@ "version": "4.2.0", "resolved": "https://registry.npmjs.org/lodash.assign/-/lodash.assign-4.2.0.tgz", "integrity": "sha1-DZnzzNem0mHRm9rrkkUAXShYCOc=", - "dev": true + "dev": true, + "optional": true }, "lodash.clonedeep": { "version": "4.5.0", @@ -6367,7 +6600,8 @@ "version": "4.6.1", "resolved": "https://registry.npmjs.org/lodash.mergewith/-/lodash.mergewith-4.6.1.tgz", "integrity": "sha512-eWw5r+PYICtEBgrBE5hhlT6aAa75f411bgDz/ZL2KZqYV03USvucsxcHUIlGTDTECs1eunpI7HOV7U+WLDvNdQ==", - "dev": true + "dev": true, + "optional": true }, "lodash.tail": { "version": "4.1.1", @@ -6442,6 +6676,12 @@ "object.assign": "^4.1.0" } }, + "long": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/long/-/long-3.2.0.tgz", + "integrity": "sha1-2CG3E4yhy1gcFymQ7xTbIAtcR0s=", + "dev": true + }, "longest": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz", @@ -6804,7 +7044,8 @@ "version": "2.10.0", "resolved": "https://registry.npmjs.org/nan/-/nan-2.10.0.tgz", "integrity": "sha512-bAdJv7fBLhWC+/Bls0Oza+mvTaNQtP+1RyhhhvD95pgUJz6XM5IzgmxOkItJ9tkoCiplvAnXI1tNmmUD/eScyA==", - "dev": true + "dev": true, + "optional": true }, "nanomatch": { "version": "1.2.9", @@ -6853,9 +7094,9 @@ } }, "ngrx-store-freeze": { - "version": "0.2.2", - "resolved": "https://registry.npmjs.org/ngrx-store-freeze/-/ngrx-store-freeze-0.2.2.tgz", - "integrity": "sha512-t3e6yanpqFv+nsLulh9vz0WBSefjjKtv9ZPd0CylW+mTmylBQgAb+VRWPrbmp78HCsKU0d0lZNbYD8Qd6edcGA==", + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/ngrx-store-freeze/-/ngrx-store-freeze-0.2.3.tgz", + "integrity": "sha512-IO2zBWMAyAWZgK6zbPhmR3tNRgW+jfi/Z+Xkvaa42w6eYNQ8bEwYv7uxZo/3MQJ5RglxZ+6KsDLXPzjN+ZUEZw==", "requires": { "deep-freeze-strict": "^1.1.1" } @@ -6890,6 +7131,7 @@ "resolved": "https://registry.npmjs.org/node-gyp/-/node-gyp-3.6.2.tgz", "integrity": "sha1-m/vlRWIoYoSDjnUOrAUpWFP6HGA=", "dev": true, + "optional": true, "requires": { "fstream": "^1.0.0", "glob": "^7.0.3", @@ -6910,7 +7152,8 @@ "version": "5.3.0", "resolved": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", "integrity": "sha1-myzl094C0XxgEq0yaqa00M9U+U8=", - "dev": true + "dev": true, + "optional": true } } }, @@ -6958,6 +7201,7 @@ "resolved": "https://registry.npmjs.org/node-sass/-/node-sass-4.9.0.tgz", "integrity": "sha512-QFHfrZl6lqRU3csypwviz2XLgGNOoWQbo2GOvtsfQqOfL4cy1BtWnhx/XUeAO9LT3ahBzSRXcEO6DdvAH9DzSg==", "dev": true, + "optional": true, "requires": { "async-foreach": "^0.1.3", "chalk": "^1.1.1", @@ -6990,13 +7234,15 @@ "version": "0.2.0", "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-0.2.0.tgz", "integrity": "sha1-104bh+ev/A24qttwIfP+SBAasjQ=", - "dev": true + "dev": true, + "optional": true }, "aws-sign2": { "version": "0.6.0", "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.6.0.tgz", "integrity": "sha1-FDQt0428yU0OW4fXY81jYSwOeU8=", - "dev": true + "dev": true, + "optional": true }, "boom": { "version": "2.10.1", @@ -7011,7 +7257,8 @@ "version": "0.11.0", "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.11.0.tgz", "integrity": "sha1-cVuW6phBWTzDMGeSP17GDr2k99c=", - "dev": true + "dev": true, + "optional": true }, "chalk": { "version": "1.1.3", @@ -7031,6 +7278,7 @@ "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-2.0.5.tgz", "integrity": "sha1-O9/s3GCBR8HGcgL6KR59ylnqo7g=", "dev": true, + "optional": true, "requires": { "boom": "2.x.x" } @@ -7040,6 +7288,7 @@ "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.1.4.tgz", "integrity": "sha1-M8GDrPGTJ27KqYFDpp6Uv+4XUNE=", "dev": true, + "optional": true, "requires": { "asynckit": "^0.4.0", "combined-stream": "^1.0.5", @@ -7051,6 +7300,7 @@ "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-2.0.6.tgz", "integrity": "sha1-zcvAgYgmWtEZtqWnyKtw7s+10n0=", "dev": true, + "optional": true, "requires": { "chalk": "^1.1.1", "commander": "^2.9.0", @@ -7063,6 +7313,7 @@ "resolved": "https://registry.npmjs.org/hawk/-/hawk-3.1.3.tgz", "integrity": "sha1-B4REvXwWQLD+VA0sm3PVlnjo4cQ=", "dev": true, + "optional": true, "requires": { "boom": "2.x.x", "cryptiles": "2.x.x", @@ -7081,6 +7332,7 @@ "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.1.1.tgz", "integrity": "sha1-33LiZwZs0Kxn+3at+OE0qPvPkb8=", "dev": true, + "optional": true, "requires": { "assert-plus": "^0.2.0", "jsprim": "^1.2.2", @@ -7091,13 +7343,15 @@ "version": "6.3.2", "resolved": "https://registry.npmjs.org/qs/-/qs-6.3.2.tgz", "integrity": "sha1-51vV9uJoEioqDgvaYwslUMFmUCw=", - "dev": true + "dev": true, + "optional": true }, "request": { "version": "2.79.0", "resolved": "https://registry.npmjs.org/request/-/request-2.79.0.tgz", "integrity": "sha1-Tf5b9r6LjNw3/Pk+BLZVd3InEN4=", "dev": true, + "optional": true, "requires": { "aws-sign2": "~0.6.0", "aws4": "^1.2.1", @@ -7126,6 +7380,7 @@ "resolved": "https://registry.npmjs.org/sntp/-/sntp-1.0.9.tgz", "integrity": "sha1-ZUEYTMkK7qbG57NeJlkIJEPGYZg=", "dev": true, + "optional": true, "requires": { "hoek": "2.x.x" } @@ -7140,7 +7395,8 @@ "version": "0.4.3", "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.4.3.tgz", "integrity": "sha1-Y3PbdpCf5XDgjXNYM2Xtgop07us=", - "dev": true + "dev": true, + "optional": true } } }, @@ -7485,6 +7741,7 @@ "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-1.4.0.tgz", "integrity": "sha1-IPnxeuKe00XoveWDsT0gCYA8FNk=", "dev": true, + "optional": true, "requires": { "lcid": "^1.0.0" } @@ -8136,9 +8393,9 @@ } }, "pumpify": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.5.0.tgz", - "integrity": "sha512-UWi0klDoq8xtVzlMRgENV9F7iCTZExaJQSQL187UXsxpk9NnrKGqTqqUNYAKGOzucSOxs2+jUnRNI+rLviPhJg==", + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.5.1.tgz", + "integrity": "sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ==", "dev": true, "requires": { "duplexify": "^3.6.0", @@ -8699,6 +8956,7 @@ "resolved": "https://registry.npmjs.org/sass-graph/-/sass-graph-2.2.4.tgz", "integrity": "sha1-E/vWPNHK8JCLn9k0dq1DpR0eC0k=", "dev": true, + "optional": true, "requires": { "glob": "^7.0.0", "lodash": "^4.0.0", @@ -8710,13 +8968,15 @@ "version": "3.0.0", "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo=", - "dev": true + "dev": true, + "optional": true }, "cliui": { "version": "3.2.0", "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz", "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=", "dev": true, + "optional": true, "requires": { "string-width": "^1.0.1", "strip-ansi": "^3.0.1", @@ -8727,13 +8987,15 @@ "version": "3.2.1", "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=", - "dev": true + "dev": true, + "optional": true }, "yargs": { "version": "7.1.0", "resolved": "https://registry.npmjs.org/yargs/-/yargs-7.1.0.tgz", "integrity": "sha1-a6MY6xaWFyf10oT46gA+jWFU0Mg=", "dev": true, + "optional": true, "requires": { "camelcase": "^3.0.0", "cliui": "^3.2.0", @@ -8795,6 +9057,7 @@ "resolved": "https://registry.npmjs.org/scss-tokenizer/-/scss-tokenizer-0.2.3.tgz", "integrity": "sha1-jrBtualyMzOCTT9VMGQRSYR85dE=", "dev": true, + "optional": true, "requires": { "js-base64": "^2.1.8", "source-map": "^0.4.2" @@ -8805,6 +9068,7 @@ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", "dev": true, + "optional": true, "requires": { "amdefine": ">=0.0.4" } @@ -9543,6 +9807,7 @@ "resolved": "https://registry.npmjs.org/stdout-stream/-/stdout-stream-1.4.0.tgz", "integrity": "sha1-osfIWH5U2UJ+qe2zrD8s1SLfN4s=", "dev": true, + "optional": true, "requires": { "readable-stream": "^2.0.1" } @@ -9731,6 +9996,7 @@ "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", "dev": true, + "optional": true, "requires": { "block-stream": "*", "fstream": "^1.0.2", @@ -9894,6 +10160,7 @@ "resolved": "https://registry.npmjs.org/true-case-path/-/true-case-path-1.0.2.tgz", "integrity": "sha1-fskRMJJHZsf1c74wIMNPj9/QDWI=", "dev": true, + "optional": true, "requires": { "glob": "^6.0.4" }, @@ -9903,6 +10170,7 @@ "resolved": "https://registry.npmjs.org/glob/-/glob-6.0.4.tgz", "integrity": "sha1-DwiGD2oVUSey+t1PnOJLGqtuTSI=", "dev": true, + "optional": true, "requires": { "inflight": "^1.0.4", "inherits": "2", @@ -10251,9 +10519,9 @@ } }, "upath": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/upath/-/upath-1.0.5.tgz", - "integrity": "sha512-qbKn90aDQ0YEwvXoLqj0oiuUYroLX2lVHZ+b+xwjozFasAOC4GneDq5+OaIG5Zj+jFmbz/uO+f7a9qxjktJQww==", + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/upath/-/upath-1.1.0.tgz", + "integrity": "sha512-bzpH/oBhoS/QI/YtbkqCg6VEiPYjSZtrHQM6/QnJS6OL9pKUFLqb3aFh4Scvwm45+7iAgiMkLhSbaZxUqmrprw==", "dev": true }, "upper-case": { @@ -10476,6 +10744,19 @@ "resolved": "https://registry.npmjs.org/web-animations-js/-/web-animations-js-2.3.1.tgz", "integrity": "sha1-Om2bwVGWN3qQ+OKAP6UmIWWwRRA=" }, + "webassemblyjs": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/webassemblyjs/-/webassemblyjs-1.4.3.tgz", + "integrity": "sha512-4lOV1Lv6olz0PJkDGQEp82HempAn147e6BXijWDzz9g7/2nSebVP9GVg62Fz5ZAs55mxq13GA0XLyvY8XkyDjg==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.4.3", + "@webassemblyjs/validation": "1.4.3", + "@webassemblyjs/wasm-parser": "1.4.3", + "@webassemblyjs/wast-parser": "1.4.3", + "long": "^3.2.0" + } + }, "webdriver-js-extender": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/webdriver-js-extender/-/webdriver-js-extender-1.0.0.tgz", @@ -10524,11 +10805,14 @@ } }, "webpack": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-4.6.0.tgz", - "integrity": "sha512-Fu/k/3fZeGtIhuFkiYpIy1UDHhMiGKjG4FFPVuvG+5Os2lWA1ttWpmi9Qnn6AgfZqj9MvhZW/rmj/ip+nHr06g==", + "version": "4.8.3", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-4.8.3.tgz", + "integrity": "sha512-/hfAjBISycdK597lxONjKEFX7dSIU1PsYwC3XlXUXoykWBlv9QV5HnO+ql3HvrrgfBJ7WXdnjO9iGPR2aAc5sw==", "dev": true, "requires": { + "@webassemblyjs/ast": "1.4.3", + "@webassemblyjs/wasm-edit": "1.4.3", + "@webassemblyjs/wasm-parser": "1.4.3", "acorn": "^5.0.0", "acorn-dynamic-import": "^3.0.0", "ajv": "^6.1.0", @@ -10886,7 +11170,8 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/which-module/-/which-module-1.0.0.tgz", "integrity": "sha1-u6Y8qGGUiZT/MHc2CJ47lgJsKk8=", - "dev": true + "dev": true, + "optional": true }, "wide-align": { "version": "1.1.2", @@ -11026,6 +11311,7 @@ "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-5.0.0.tgz", "integrity": "sha1-J17PDX/+Bcd+ZOfIbkzZS/DhIoo=", "dev": true, + "optional": true, "requires": { "camelcase": "^3.0.0" }, @@ -11034,7 +11320,8 @@ "version": "3.0.0", "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo=", - "dev": true + "dev": true, + "optional": true } } }, diff --git a/package.json b/package.json index c0a44ef7..2a19757d 100644 --- a/package.json +++ b/package.json @@ -19,19 +19,19 @@ "private": true, "dependencies": { "@agm/core": "1.0.0-beta.2", - "@angular/animations": "6.0.1", + "@angular/animations": "6.0.2", "@angular/cdk": "6.0.2", - "@angular/common": "6.0.1", - "@angular/compiler": "6.0.1", - "@angular/core": "6.0.1", + "@angular/common": "6.0.2", + "@angular/compiler": "6.0.2", + "@angular/core": "6.0.2", "@angular/flex-layout": "6.0.0-beta.15", - "@angular/forms": "6.0.1", - "@angular/http": "6.0.1", + "@angular/forms": "6.0.2", + "@angular/http": "6.0.2", "@angular/material": "6.0.2", "@angular/material-moment-adapter": "6.0.2", - "@angular/platform-browser": "6.0.1", - "@angular/platform-browser-dynamic": "6.0.1", - "@angular/router": "6.0.1", + "@angular/platform-browser": "6.0.2", + "@angular/platform-browser-dynamic": "6.0.2", + "@angular/router": "6.0.2", "@ngrx/effects": "6.0.0-beta.3", "@ngrx/router-store": "6.0.0-beta.3", "@ngrx/store": "6.0.0-beta.3", @@ -51,7 +51,7 @@ "lodash": "4.17.10", "moment": "2.22.1", "ng2-charts": "1.6.0", - "ngrx-store-freeze": "0.2.2", + "ngrx-store-freeze": "0.2.3", "ngx-color-picker": "6.1.0", "ngx-cookie-service": "1.0.10", "perfect-scrollbar": "1.3.0", @@ -62,14 +62,14 @@ "zone.js": "0.8.26" }, "devDependencies": { - "@angular/cli": "6.0.1", - "@angular/compiler-cli": "6.0.1", - "@angular/language-service": "6.0.1", - "@angular-devkit/build-angular": "0.6.1", + "@angular/cli": "6.0.3", + "@angular/compiler-cli": "6.0.2", + "@angular/language-service": "6.0.2", + "@angular-devkit/build-angular": "0.6.3", "@angularclass/hmr": "2.1.3", "@types/jasmine": "2.8.7", "@types/jasminewd2": "2.0.3", - "@types/lodash": "4.14.108", + "@types/lodash": "4.14.109", "@types/node": "8.9.5", "codelyzer": "4.2.1", "jasmine-core": "2.99.1", From 880529ad624dfb0881fc9cae7a21e01373b22254 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Sun, 20 May 2018 16:03:11 +0300 Subject: [PATCH 08/80] Temporary solution to the ngx-translate issue while we are working on a better solution --- src/app/app.component.ts | 13 +++++++++---- src/app/main/toolbar/toolbar.component.ts | 23 ++++++++++++++++++++--- 2 files changed, 29 insertions(+), 7 deletions(-) diff --git a/src/app/app.component.ts b/src/app/app.component.ts index 9a7d71d2..d65a1d7c 100644 --- a/src/app/app.component.ts +++ b/src/app/app.component.ts @@ -28,10 +28,15 @@ export class AppComponent // Set the default language this.translate.setDefaultLang('en'); - // Set the navigation translations - this.fuseTranslationLoader.loadTranslations(navigationEnglish, navigationTurkish); + // Give Angular some time to finish loading navigation before + // loading navigation translations + setTimeout(() => { - // Use a language - this.translate.use('en'); + // Set the navigation translations + this.fuseTranslationLoader.loadTranslations(navigationEnglish, navigationTurkish); + + // Use a language + this.translate.use('en'); + }); } } diff --git a/src/app/main/toolbar/toolbar.component.ts b/src/app/main/toolbar/toolbar.component.ts index f5cab4b4..a24447be 100644 --- a/src/app/main/toolbar/toolbar.component.ts +++ b/src/app/main/toolbar/toolbar.component.ts @@ -1,7 +1,8 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { NavigationEnd, NavigationStart, Router } from '@angular/router'; import { TranslateService } from '@ngx-translate/core'; import * as _ from 'lodash'; +import { Subscription } from 'rxjs'; import { FuseConfigService } from '@fuse/services/config.service'; import { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service'; @@ -14,7 +15,7 @@ import { navigation } from 'app/navigation/navigation'; styleUrls : ['./toolbar.component.scss'] }) -export class FuseToolbarComponent implements OnInit +export class FuseToolbarComponent implements OnInit, OnDestroy { userStatusOptions: any[]; languages: any; @@ -23,6 +24,7 @@ export class FuseToolbarComponent implements OnInit horizontalNav: boolean; noNav: boolean; navigation: any; + languageChangeSubscription: Subscription; constructor( private router: Router, @@ -94,7 +96,22 @@ export class FuseToolbarComponent implements OnInit ngOnInit() { - this.selectedLanguage = _.find(this.languages, {'id': this.translate.currentLang}); + // Set the default language by hand to prevent + // errors while the translation service being + // initialized + this.selectedLanguage = this.languages[0]; + + // Subscribe to the language changes + this.languageChangeSubscription = + this.translate.onLangChange.subscribe((event) => { + this.selectedLanguage = _.find(this.languages, {'id': event.lang}); + }); + + } + + ngOnDestroy() + { + this.languageChangeSubscription.unsubscribe(); } toggleSidebarOpened(key) From 742da904da0d4a4c0fb6e5af536f4947e4747b35 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Mon, 21 May 2018 15:42:34 +0300 Subject: [PATCH 09/80] Improving the codebase (wip) --- src/app/app.module.ts | 4 + src/app/main/apps/academy/course.service.ts | 4 +- src/app/main/apps/academy/courses.service.ts | 7 +- src/app/main/apps/apps.module.ts | 2 +- src/app/main/apps/calendar/calendar.module.ts | 3 +- .../main/apps/calendar/calendar.service.ts | 5 +- .../event-form/event-form.component.html | 8 +- .../event-form/event-form.component.ts | 6 +- src/app/main/apps/chat/chat.service.ts | 124 ++++++----- .../contact-form/contact-form.component.html | 8 +- .../contact-form/contact-form.component.ts | 5 +- .../main/apps/contacts/contacts.component.ts | 2 +- .../main/apps/contacts/contacts.service.ts | 16 +- .../apps/e-commerce/order/order.component.ts | 2 +- .../apps/e-commerce/order/order.service.ts | 4 +- .../apps/e-commerce/orders/orders.service.ts | 4 +- .../e-commerce/product/product.service.ts | 4 +- .../e-commerce/products/products.service.ts | 4 +- .../apps/file-manager/file-manager.service.ts | 9 +- .../dialogs/compose/compose.component.html | 6 +- .../dialogs/compose/compose.component.ts | 33 ++- .../mail-details/mail-details.component.ts | 80 +++++-- .../mail-list-item.component.ts | 4 +- .../mail-list/mail-list.component.html | 6 +- .../mail-list/mail-list.component.ts | 47 ++-- .../main/apps/mail-ngrx/mail.component.html | 8 +- .../main/apps/mail-ngrx/mail.component.scss | 12 +- src/app/main/apps/mail-ngrx/mail.component.ts | 135 ++++++++---- src/app/main/apps/mail-ngrx/mail.model.ts | 25 ++- src/app/main/apps/mail-ngrx/mail.module.ts | 50 ++--- src/app/main/apps/mail-ngrx/mail.service.ts | 66 ++++-- .../sidenavs/main/main-sidenav.component.ts | 45 ++-- .../mail-ngrx/store/guards/resolve.guard.ts | 68 ++++-- .../store/reducers/filters.reducer.ts | 2 +- .../store/reducers/folders.reducer.ts | 2 +- .../store/reducers/labels.reducer.ts | 2 +- .../mail-ngrx/store/reducers/mails.reducer.ts | 2 +- .../main/apps/mail-ngrx/store/store.module.ts | 2 +- .../dialogs/compose/compose.component.html | 6 +- .../mail/dialogs/compose/compose.component.ts | 34 ++- .../mail-details/mail-details.component.ts | 90 +++++--- .../mail-list-item.component.ts | 101 ++++++--- .../mail/mail-list/mail-list.component.html | 8 +- .../mail/mail-list/mail-list.component.ts | 139 +++++++----- src/app/main/apps/mail/mail.component.html | 8 +- src/app/main/apps/mail/mail.component.scss | 12 +- src/app/main/apps/mail/mail.component.ts | 201 ++++++++++------- src/app/main/apps/mail/mail.model.ts | 5 + src/app/main/apps/mail/mail.module.ts | 46 ++-- src/app/main/apps/mail/mail.service.ts | 93 +++++--- .../sidenavs/main/main-sidenav.component.ts | 95 +++++--- src/app/main/apps/scrumboard/board.model.ts | 5 + .../board/add-list/add-list.component.ts | 54 +++-- .../scrumboard/board/board.component.html | 18 +- .../apps/scrumboard/board/board.component.ts | 85 ++++--- .../board/dialogs/card/card.component.html | 6 +- .../board/dialogs/card/card.component.ts | 161 ++++++++------ .../label-selector.component.ts | 100 ++++++--- .../edit-board-name.component.ts | 46 +++- .../board/list/add-card/add-card.component.ts | 52 ++++- .../board/list/card/card.component.ts | 33 ++- .../edit-list-name.component.ts | 55 +++-- .../scrumboard/board/list/list.component.html | 22 +- .../scrumboard/board/list/list.component.ts | 118 +++++++--- .../board-color-selector.component.ts | 66 ++++-- .../sidenavs/settings/settings.component.html | 4 +- .../sidenavs/settings/settings.component.ts | 66 ++++-- src/app/main/apps/scrumboard/card.model.ts | 5 + src/app/main/apps/scrumboard/list.model.ts | 5 + .../apps/scrumboard/scrumboard.component.ts | 69 ++++-- .../main/apps/scrumboard/scrumboard.module.ts | 59 +++-- .../apps/scrumboard/scrumboard.service.ts | 116 ++++++++-- .../sidenavs/main/main-sidenav.component.ts | 84 ++++--- .../todo-details/todo-details.component.ts | 208 +++++++++++------- .../todo-list-item.component.ts | 122 ++++++---- .../todo/todo-list/todo-list.component.html | 18 +- .../todo/todo-list/todo-list.component.ts | 137 +++++++----- src/app/main/apps/todo/todo.component.html | 8 +- src/app/main/apps/todo/todo.component.scss | 12 +- src/app/main/apps/todo/todo.component.ts | 172 +++++++++------ src/app/main/apps/todo/todo.model.ts | 25 ++- src/app/main/apps/todo/todo.module.ts | 38 ++-- src/app/main/apps/todo/todo.service.ts | 112 +++++++--- src/app/main/components/components.module.ts | 3 +- .../multi-language.component.html | 2 +- .../coming-soon/coming-soon.component.ts | 66 +++++- .../pages/coming-soon/coming-soon.module.ts | 6 +- .../pages/errors/404/error-404.component.ts | 12 +- .../main/pages/errors/404/error-404.module.ts | 7 +- .../pages/errors/500/error-500.component.ts | 5 +- .../main/pages/errors/500/error-500.module.ts | 6 +- src/app/main/pages/faq/faq.component.ts | 99 ++++++--- src/app/main/pages/faq/faq.module.ts | 8 +- src/app/main/pages/faq/faq.service.ts | 19 +- .../invoices/compact/compact.component.ts | 42 +++- .../pages/invoices/compact/compact.module.ts | 8 +- .../main/pages/invoices/invoice.service.ts | 19 +- .../pages/invoices/modern/modern.component.ts | 48 +++- .../pages/invoices/modern/modern.module.ts | 8 +- .../dialogs/article/article.component.html | 6 +- .../dialogs/article/article.component.ts | 8 +- .../knowledge-base.component.ts | 73 ++++-- .../knowledge-base/knowledge-base.module.ts | 15 +- .../knowledge-base/knowledge-base.service.ts | 18 +- .../maintenance/maintenance.component.ts | 14 +- .../pages/maintenance/maintenence.module.ts | 6 +- src/app/main/pages/pricing/pricing.module.ts | 19 +- .../pricing/style-1/style-1.component.ts | 7 +- .../pricing/style-2/style-2.component.ts | 7 +- .../pricing/style-3/style-3.component.ts | 7 +- .../main/pages/profile/profile.component.html | 4 +- .../main/pages/profile/profile.component.ts | 8 +- src/app/main/pages/profile/profile.module.ts | 20 +- src/app/main/pages/profile/profile.service.ts | 28 ++- .../profile/tabs/about/about.component.ts | 50 ++++- .../photos-videos/photos-videos.component.ts | 53 ++++- .../tabs/timeline/timeline.component.ts | 45 +++- .../main/pages/search/search.component.html | 4 +- src/app/main/pages/search/search.component.ts | 7 +- src/app/main/pages/search/search.module.ts | 18 +- src/app/main/pages/search/search.service.ts | 23 +- .../search/tabs/classic/classic.component.ts | 53 ++++- .../search/tabs/table/table.component.ts | 77 +++++-- src/app/navigation/navigation.ts | 2 + 124 files changed, 3174 insertions(+), 1491 deletions(-) diff --git a/src/app/app.module.ts b/src/app/app.module.ts index de296e12..b664f2fb 100644 --- a/src/app/app.module.ts +++ b/src/app/app.module.ts @@ -3,6 +3,7 @@ import { BrowserModule } from '@angular/platform-browser'; import { HttpClientModule } from '@angular/common/http'; import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; import { RouterModule, Routes } from '@angular/router'; +import { MatMomentDateModule } from '@angular/material-moment-adapter'; import { InMemoryWebApiModule } from 'angular-in-memory-web-api'; import { TranslateModule } from '@ngx-translate/core'; import 'hammerjs'; @@ -64,6 +65,9 @@ const appRoutes: Routes = [ passThruUnknownUrl: true }), + // Material moment date module + MatMomentDateModule, + // Fuse modules FuseModule.forRoot(fuseConfig), FuseSharedModule, diff --git a/src/app/main/apps/academy/course.service.ts b/src/app/main/apps/academy/course.service.ts index 024a65cd..4143dd4e 100644 --- a/src/app/main/apps/academy/course.service.ts +++ b/src/app/main/apps/academy/course.service.ts @@ -6,7 +6,7 @@ import { BehaviorSubject, Observable } from 'rxjs'; @Injectable() export class AcademyCourseService implements Resolve { - onCourseChanged: BehaviorSubject = new BehaviorSubject({}); + onCourseChanged: BehaviorSubject; /** * Constructor @@ -17,6 +17,8 @@ export class AcademyCourseService implements Resolve private _httpClient: HttpClient ) { + // Set the defaults + this.onCourseChanged = new BehaviorSubject({}); } // ----------------------------------------------------------------------------------------------------- diff --git a/src/app/main/apps/academy/courses.service.ts b/src/app/main/apps/academy/courses.service.ts index 5f8776cb..06613028 100644 --- a/src/app/main/apps/academy/courses.service.ts +++ b/src/app/main/apps/academy/courses.service.ts @@ -6,8 +6,8 @@ import { BehaviorSubject, Observable } from 'rxjs'; @Injectable() export class AcademyCoursesService implements Resolve { - onCategoriesChanged: BehaviorSubject = new BehaviorSubject({}); - onCoursesChanged: BehaviorSubject = new BehaviorSubject({}); + onCategoriesChanged: BehaviorSubject; + onCoursesChanged: BehaviorSubject; /** * Constructor @@ -18,6 +18,9 @@ export class AcademyCoursesService implements Resolve private _httpClient: HttpClient ) { + // Set the defaults + this.onCategoriesChanged = new BehaviorSubject({}); + this.onCoursesChanged = new BehaviorSubject({}); } // ----------------------------------------------------------------------------------------------------- diff --git a/src/app/main/apps/apps.module.ts b/src/app/main/apps/apps.module.ts index 98a60a34..8ead8245 100644 --- a/src/app/main/apps/apps.module.ts +++ b/src/app/main/apps/apps.module.ts @@ -14,7 +14,7 @@ const routes = [ }, { path : 'mail', - loadChildren: './mail/mail.module#FuseMailModule' + loadChildren: './mail/mail.module#MailModule' }, { path : 'mail-ngrx', diff --git a/src/app/main/apps/calendar/calendar.module.ts b/src/app/main/apps/calendar/calendar.module.ts index e72231d6..dd9c0c0b 100644 --- a/src/app/main/apps/calendar/calendar.module.ts +++ b/src/app/main/apps/calendar/calendar.module.ts @@ -1,6 +1,6 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; -import { MatButtonModule, MatDatepickerModule, MatFormFieldModule, MatIconModule, MatInputModule, MatSlideToggleModule, MatToolbarModule } from '@angular/material'; +import { MatButtonModule, MatDatepickerModule, MatDialogModule, MatFormFieldModule, MatIconModule, MatInputModule, MatSlideToggleModule, MatToolbarModule } from '@angular/material'; import { ColorPickerModule } from 'ngx-color-picker'; import { CalendarModule as AngularCalendarModule } from 'angular-calendar'; @@ -32,6 +32,7 @@ const routes: Routes = [ MatButtonModule, MatDatepickerModule, + MatDialogModule, MatFormFieldModule, MatIconModule, MatInputModule, diff --git a/src/app/main/apps/calendar/calendar.service.ts b/src/app/main/apps/calendar/calendar.service.ts index 3d0554c3..21dc56e9 100644 --- a/src/app/main/apps/calendar/calendar.service.ts +++ b/src/app/main/apps/calendar/calendar.service.ts @@ -7,7 +7,7 @@ import { Observable, Subject } from 'rxjs'; export class CalendarService implements Resolve { events: any; - onEventsUpdated = new Subject(); + onEventsUpdated: Subject; /** * Constructor @@ -18,7 +18,8 @@ export class CalendarService implements Resolve private _httpClient: HttpClient ) { - + // Set the defaults + this.onEventsUpdated = new Subject(); } // ----------------------------------------------------------------------------------------------------- diff --git a/src/app/main/apps/calendar/event-form/event-form.component.html b/src/app/main/apps/calendar/event-form/event-form.component.html index 32a805f4..40deeb94 100644 --- a/src/app/main/apps/calendar/event-form/event-form.component.html +++ b/src/app/main/apps/calendar/event-form/event-form.component.html @@ -2,7 +2,7 @@ {{dialogTitle}} - @@ -117,7 +117,7 @@ @@ -98,7 +98,7 @@ @@ -86,7 +86,7 @@
- diff --git a/src/app/main/apps/mail-ngrx/dialogs/compose/compose.component.ts b/src/app/main/apps/mail-ngrx/dialogs/compose/compose.component.ts index 65286173..4e3d6d6f 100644 --- a/src/app/main/apps/mail-ngrx/dialogs/compose/compose.component.ts +++ b/src/app/main/apps/mail-ngrx/dialogs/compose/compose.component.ts @@ -3,27 +3,44 @@ import { FormBuilder, FormGroup } from '@angular/forms'; import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material'; @Component({ - selector : 'fuse-mail-compose', + selector : 'mail-compose', templateUrl : './compose.component.html', styleUrls : ['./compose.component.scss'], encapsulation: ViewEncapsulation.None }) -export class FuseMailNgrxComposeDialogComponent +export class MailNgrxComposeDialogComponent { composeForm: FormGroup; + /** + * Constructor + * + * @param {MatDialogRef} _matDialogRef + * @param _data + * @param {FormBuilder} _formBuilder + */ constructor( - public dialogRef: MatDialogRef, - @Inject(MAT_DIALOG_DATA) private data: any, - private formBuilder: FormBuilder + private _matDialogRef: MatDialogRef, + @Inject(MAT_DIALOG_DATA) private _data: any, + private _formBuilder: FormBuilder ) { + // Set the defaults this.composeForm = this.createComposeForm(); } - - createComposeForm() + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Create compose form + * + * @returns {FormGroup} + */ + createComposeForm(): FormGroup { - return this.formBuilder.group({ + return this._formBuilder.group({ from : { value : ['johndoe@creapond.com'], disabled: [true] diff --git a/src/app/main/apps/mail-ngrx/mail-details/mail-details.component.ts b/src/app/main/apps/mail-ngrx/mail-details/mail-details.component.ts index f3640888..3c80a9e1 100644 --- a/src/app/main/apps/mail-ngrx/mail-details/mail-details.component.ts +++ b/src/app/main/apps/mail-ngrx/mail-details/mail-details.component.ts @@ -2,38 +2,62 @@ import { ChangeDetectionStrategy, Component, Input, OnChanges } from '@angular/c import { Store } from '@ngrx/store'; import { Observable } from 'rxjs'; -import { Mail } from '../mail.model'; -import * as fromStore from '../store'; -import { MailNgrxService } from '../mail.service'; +import { Mail } from 'app/main/apps/mail-ngrx/mail.model'; +import * as fromStore from 'app/main/apps/mail-ngrx/store'; +import { MailNgrxService } from 'app/main/apps/mail-ngrx/mail.service'; @Component({ - selector : 'fuse-mail-details', + selector : 'mail-details', templateUrl : './mail-details.component.html', styleUrls : ['./mail-details.component.scss'], changeDetection: ChangeDetectionStrategy.OnPush }) -export class FuseMailNgrxDetailsComponent implements OnChanges +export class MailNgrxDetailsComponent implements OnChanges { - labels$: Observable; - @Input('mail') mailInput: Mail; - mail: Mail; - showDetails = false; + @Input('mail') + mailInput: Mail; + labels$: Observable; + mail: Mail; + showDetails: boolean; + + /** + * Constructor + * + * @param {MailNgrxService} _mailNgrxService + * @param {Store} _store + */ constructor( - private mailService: MailNgrxService, - private store: Store + private _mailNgrxService: MailNgrxService, + private _store: Store ) { - this.labels$ = this.store.select(fromStore.getLabelsArr); + // Set the defaults + this.labels$ = this._store.select(fromStore.getLabelsArr); + this.showDetails = false; } - ngOnChanges() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On changes + */ + ngOnChanges(): void { this.updateModel(this.mailInput); this.markAsRead(); } - markAsRead() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Mark as read + */ + markAsRead(): void { if ( this.mail && !this.mail.read ) { @@ -42,28 +66,46 @@ export class FuseMailNgrxDetailsComponent implements OnChanges } } - toggleStar(event) + /** + * Toggle star + * + * @param event + */ + toggleStar(event): void { event.stopPropagation(); this.mail.toggleStar(); this.updateMail(); } - toggleImportant(event) + /** + * Toggle important + * + * @param event + */ + toggleImportant(event): void { event.stopPropagation(); this.mail.toggleImportant(); this.updateMail(); } - updateModel(data) + /** + * Update model + * + * @param data + */ + updateModel(data): void { this.mail = !data ? null : new Mail({...data}); } - updateMail() + /** + * Update the mail + */ + updateMail(): void { - this.store.dispatch(new fromStore.UpdateMail(this.mail)); + this._store.dispatch(new fromStore.UpdateMail(this.mail)); this.updateModel(this.mail); } } diff --git a/src/app/main/apps/mail-ngrx/mail-list/mail-list-item/mail-list-item.component.ts b/src/app/main/apps/mail-ngrx/mail-list/mail-list-item/mail-list-item.component.ts index f4a2d719..4ec6b611 100644 --- a/src/app/main/apps/mail-ngrx/mail-list/mail-list-item/mail-list-item.component.ts +++ b/src/app/main/apps/mail-ngrx/mail-list/mail-list-item/mail-list-item.component.ts @@ -7,12 +7,12 @@ import { Mail } from '../../mail.model'; import * as fromStore from '../../store'; @Component({ - selector : 'fuse-mail-list-item', + selector : 'mail-list-item', templateUrl : './mail-list-item.component.html', styleUrls : ['./mail-list-item.component.scss'], changeDetection: ChangeDetectionStrategy.OnPush }) -export class FuseMailNgrxListItemComponent implements OnInit +export class MailNgrxListItemComponent implements OnInit { @Input() mail: Mail; @HostBinding('class.selected') selected: boolean; diff --git a/src/app/main/apps/mail-ngrx/mail-list/mail-list.component.html b/src/app/main/apps/mail-ngrx/mail-list/mail-list.component.html index bb5903db..94e1ff3b 100644 --- a/src/app/main/apps/mail-ngrx/mail-list/mail-list.component.html +++ b/src/app/main/apps/mail-ngrx/mail-list/mail-list.component.html @@ -3,7 +3,7 @@
- - + +
diff --git a/src/app/main/apps/mail-ngrx/mail-list/mail-list.component.ts b/src/app/main/apps/mail-ngrx/mail-list/mail-list.component.ts index 0b1c0ac7..54237b1e 100644 --- a/src/app/main/apps/mail-ngrx/mail-list/mail-list.component.ts +++ b/src/app/main/apps/mail-ngrx/mail-list/mail-list.component.ts @@ -1,49 +1,64 @@ import { ChangeDetectionStrategy, Component, Input } from '@angular/core'; import { ActivatedRoute, Router } from '@angular/router'; -import { Mail } from '../mail.model'; -import { MailNgrxService } from '../mail.service'; +import { Mail } from 'app/main/apps/mail-ngrx/mail.model'; +import { MailNgrxService } from 'app/main/apps/mail-ngrx/mail.service'; @Component({ - selector : 'fuse-mail-list', + selector : 'mail-list', templateUrl : './mail-list.component.html', styleUrls : ['./mail-list.component.scss'], changeDetection: ChangeDetectionStrategy.OnPush }) -export class FuseMailNgrxListComponent +export class MailNgrxListComponent { - @Input() mails: Mail[]; - @Input() currentMail: Mail[]; + @Input() + mails: Mail[]; + @Input() + currentMail: Mail[]; + + /** + * Constructor + * + * @param {ActivatedRoute} _activatedRoute + * @param {MailNgrxService} _mailNgrxService + * @param {Router} _router + */ constructor( - private route: ActivatedRoute, - private mailService: MailNgrxService, - private router: Router + private _activatedRoute: ActivatedRoute, + private _mailNgrxService: MailNgrxService, + private _router: Router ) { } + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + /** * Read mail + * * @param mailId */ - readMail(mailId) + readMail(mailId): void { - const labelHandle = this.route.snapshot.params.labelHandle, - filterHandle = this.route.snapshot.params.filterHandle, - folderHandle = this.route.snapshot.params.folderHandle; + const labelHandle = this._activatedRoute.snapshot.params.labelHandle, + filterHandle = this._activatedRoute.snapshot.params.filterHandle, + folderHandle = this._activatedRoute.snapshot.params.folderHandle; if ( labelHandle ) { - this.router.navigate(['apps/mail-ngrx/label/' + labelHandle + '/' + mailId]); + this._router.navigate(['apps/mail-ngrx/label/' + labelHandle + '/' + mailId]); } else if ( filterHandle ) { - this.router.navigate(['apps/mail-ngrx/filter/' + filterHandle + '/' + mailId]); + this._router.navigate(['apps/mail-ngrx/filter/' + filterHandle + '/' + mailId]); } else { - this.router.navigate(['apps/mail-ngrx/' + folderHandle + '/' + mailId]); + this._router.navigate(['apps/mail-ngrx/' + folderHandle + '/' + mailId]); } } } diff --git a/src/app/main/apps/mail-ngrx/mail.component.html b/src/app/main/apps/mail-ngrx/mail.component.html index 13a31fbc..701983ae 100644 --- a/src/app/main/apps/mail-ngrx/mail.component.html +++ b/src/app/main/apps/mail-ngrx/mail.component.html @@ -9,7 +9,7 @@ - + @@ -88,7 +88,7 @@
-
@@ -98,8 +98,8 @@
- - + +
diff --git a/src/app/main/apps/mail-ngrx/mail.component.scss b/src/app/main/apps/mail-ngrx/mail.component.scss index cca33765..f401db44 100644 --- a/src/app/main/apps/mail-ngrx/mail.component.scss +++ b/src/app/main/apps/mail-ngrx/mail.component.scss @@ -40,16 +40,16 @@ @include media-breakpoint(xs) { - fuse-mail-list { + mail-list { border-right: none; } - fuse-mail-list, - fuse-mail-details { + mail-list, + mail-details { flex: 1 0 100%; } - fuse-mail-details { + mail-details { display: none !important; } @@ -65,11 +65,11 @@ .content { - fuse-mail-list { + mail-list { display: none !important; } - fuse-mail-details { + mail-details { display: flex !important; } } diff --git a/src/app/main/apps/mail-ngrx/mail.component.ts b/src/app/main/apps/mail-ngrx/mail.component.ts index 9fbbcad6..51833271 100644 --- a/src/app/main/apps/mail-ngrx/mail.component.ts +++ b/src/app/main/apps/mail-ngrx/mail.component.ts @@ -10,16 +10,17 @@ import { FuseConfigService } from '@fuse/services/config.service'; import { Mail } from 'app/main/apps/mail-ngrx/mail.model'; import { MailNgrxService } from 'app/main/apps/mail-ngrx/mail.service'; import * as fromStore from 'app/main/apps/mail-ngrx/store'; + import { locale as english } from 'app/main/apps/mail-ngrx/i18n/en'; import { locale as turkish } from 'app/main/apps/mail-ngrx/i18n/tr'; @Component({ - selector : 'fuse-mail', + selector : 'mail-ngrx', templateUrl : './mail.component.html', styleUrls : ['./mail.component.scss'], changeDetection: ChangeDetectionStrategy.OnPush }) -export class FuseMailNgrxComponent implements OnInit, OnDestroy +export class MailNgrxComponent implements OnInit, OnDestroy { hasSelectedMails: boolean; isIndeterminate: boolean; @@ -33,31 +34,49 @@ export class FuseMailNgrxComponent implements OnInit, OnDestroy mails: Mail[]; selectedMailIds: string[]; + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + * @param {MailNgrxService} _mailNgrxService + * @param {FuseTranslationLoaderService} _fuseTranslationLoaderService + * @param {Store} _store + * @param {ChangeDetectorRef} _changeDetectorRef + */ constructor( - private configService: FuseConfigService, - private mailService: MailNgrxService, - private translationLoader: FuseTranslationLoaderService, - private store: Store, - private cd: ChangeDetectorRef + private _fuseConfigService: FuseConfigService, + private _mailNgrxService: MailNgrxService, + private _fuseTranslationLoaderService: FuseTranslationLoaderService, + private _store: Store, + private _changeDetectorRef: ChangeDetectorRef ) { - this.searchInput = new FormControl(''); - this.translationLoader.loadTranslations(english, turkish); - this.currentMail$ = this.store.select(fromStore.getCurrentMail); - this.mails$ = this.store.select(fromStore.getMailsArr); - this.folders$ = this.store.select(fromStore.getFoldersArr); - this.labels$ = this.store.select(fromStore.getLabelsArr); - this.selectedMailIds$ = this.store.select(fromStore.getSelectedMailIds); - this.searchText$ = this.store.select(fromStore.getSearchText); - this.mails = []; - this.selectedMailIds = []; - - this.configService.config = { + // Configure the layout + this._fuseConfigService.config = { routerAnimation: 'none' }; + + // Set the defaults + this.searchInput = new FormControl(''); + this._fuseTranslationLoaderService.loadTranslations(english, turkish); + this.currentMail$ = this._store.select(fromStore.getCurrentMail); + this.mails$ = this._store.select(fromStore.getMailsArr); + this.folders$ = this._store.select(fromStore.getFoldersArr); + this.labels$ = this._store.select(fromStore.getLabelsArr); + this.selectedMailIds$ = this._store.select(fromStore.getSelectedMailIds); + this.searchText$ = this._store.select(fromStore.getSearchText); + this.mails = []; + this.selectedMailIds = []; } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { this.mails$.subscribe(mails => { this.mails = mails; @@ -79,16 +98,28 @@ export class FuseMailNgrxComponent implements OnInit, OnDestroy debounceTime(300), distinctUntilChanged() ).subscribe(searchText => { - this.store.dispatch(new fromStore.SetSearchText(searchText)); + this._store.dispatch(new fromStore.SetSearchText(searchText)); }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.cd.detach(); + this._changeDetectorRef.detach(); } - toggleSelectAll(ev) + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Toggle select all + * + * @param ev + */ + toggleSelectAll(ev): void { ev.preventDefault(); @@ -102,41 +133,69 @@ export class FuseMailNgrxComponent implements OnInit, OnDestroy } } - selectAllMails() + /** + * Select all mails + */ + selectAllMails(): void { - this.store.dispatch(new fromStore.SelectAllMails()); + this._store.dispatch(new fromStore.SelectAllMails()); } - deselectAllMails() + /** + * Deselect all mails + */ + deselectAllMails(): void { - this.store.dispatch(new fromStore.DeselectAllMails()); + this._store.dispatch(new fromStore.DeselectAllMails()); } - selectMailsByParameter(parameter, value) + /** + * Select mails by parameter + * + * @param parameter + * @param value + */ + selectMailsByParameter(parameter, value): void { - this.store.dispatch(new fromStore.SelectMailsByParameter({ + this._store.dispatch(new fromStore.SelectMailsByParameter({ parameter, value })); } - toggleLabelOnSelectedMails(labelId) + /** + * Toggle label on selected mails + * + * @param labelId + */ + toggleLabelOnSelectedMails(labelId): void { - this.store.dispatch(new fromStore.AddLabelOnSelectedMails(labelId)); + this._store.dispatch(new fromStore.AddLabelOnSelectedMails(labelId)); } - setFolderOnSelectedMails(folderId) + /** + * Set folder on selected mails + * + * @param folderId + */ + setFolderOnSelectedMails(folderId): void { - this.store.dispatch(new fromStore.SetFolderOnSelectedMails(folderId)); + this._store.dispatch(new fromStore.SetFolderOnSelectedMails(folderId)); } - deSelectCurrentMail() + /** + * Deselect current mail + */ + deselectCurrentMail(): void { - this.store.dispatch(new fromStore.SetCurrentMail('')); + this._store.dispatch(new fromStore.SetCurrentMail('')); } - refresh() + /** + * Refresh + */ + refresh(): void { - this.cd.markForCheck(); + this._changeDetectorRef.markForCheck(); } } diff --git a/src/app/main/apps/mail-ngrx/mail.model.ts b/src/app/main/apps/mail-ngrx/mail.model.ts index 725bc915..0c015c30 100644 --- a/src/app/main/apps/mail-ngrx/mail.model.ts +++ b/src/app/main/apps/mail-ngrx/mail.model.ts @@ -27,6 +27,11 @@ export class Mail labels: string[]; folder: string; + /** + * Constructor + * + * @param mail + */ constructor(mail) { this.id = mail.id; @@ -44,22 +49,34 @@ export class Mail this.folder = mail.folder; } - toggleStar() + /** + * Toggle star + */ + toggleStar(): void { this.starred = !this.starred; } - toggleImportant() + /** + * Toggle important + */ + toggleImportant(): void { this.important = !this.important; } - markRead() + /** + * Mark as read + */ + markRead(): void { this.read = true; } - markUnRead() + /** + * Mark as unread + */ + markUnread(): void { this.read = false; } diff --git a/src/app/main/apps/mail-ngrx/mail.module.ts b/src/app/main/apps/mail-ngrx/mail.module.ts index 84653891..78ca98e7 100644 --- a/src/app/main/apps/mail-ngrx/mail.module.ts +++ b/src/app/main/apps/mail-ngrx/mail.module.ts @@ -5,45 +5,45 @@ import { TranslateModule } from '@ngx-translate/core'; import { FuseSharedModule } from '@fuse/shared.module'; -import { MailAppStoreModule } from 'app/main/apps/mail-ngrx/store/store.module'; import * as fromGuards from 'app/main/apps/mail-ngrx/store/guards/index'; -import { FuseMailNgrxComponent } from 'app/main/apps/mail-ngrx/mail.component'; -import { FuseMailNgrxListComponent } from 'app/main/apps/mail-ngrx/mail-list/mail-list.component'; -import { FuseMailNgrxListItemComponent } from 'app/main/apps/mail-ngrx/mail-list/mail-list-item/mail-list-item.component'; -import { FuseMailNgrxDetailsComponent } from 'app/main/apps/mail-ngrx/mail-details/mail-details.component'; -import { FuseMailNgrxMainSidenavComponent } from 'app/main/apps/mail-ngrx/sidenavs/main/main-sidenav.component'; -import { FuseMailNgrxComposeDialogComponent } from 'app/main/apps/mail-ngrx/dialogs/compose/compose.component'; +import { MailNgrxStoreModule } from 'app/main/apps/mail-ngrx/store/store.module'; +import { MailNgrxComponent } from 'app/main/apps/mail-ngrx/mail.component'; +import { MailNgrxListComponent } from 'app/main/apps/mail-ngrx/mail-list/mail-list.component'; +import { MailNgrxListItemComponent } from 'app/main/apps/mail-ngrx/mail-list/mail-list-item/mail-list-item.component'; +import { MailNgrxDetailsComponent } from 'app/main/apps/mail-ngrx/mail-details/mail-details.component'; +import { MailNgrxMainSidenavComponent } from 'app/main/apps/mail-ngrx/sidenavs/main/main-sidenav.component'; +import { MailNgrxComposeDialogComponent } from 'app/main/apps/mail-ngrx/dialogs/compose/compose.component'; import { MailNgrxService } from 'app/main/apps/mail-ngrx/mail.service'; const routes: Routes = [ { path : 'label/:labelHandle', - component : FuseMailNgrxComponent, + component : MailNgrxComponent, canActivate: [fromGuards.ResolveGuard] }, { path : 'label/:labelHandle/:mailId', - component : FuseMailNgrxComponent, + component : MailNgrxComponent, canActivate: [fromGuards.ResolveGuard] }, { - path : 'filter/:filterHandle', - component: FuseMailNgrxComponent, + path : 'filter/:filterHandle', + component : MailNgrxComponent, canActivate: [fromGuards.ResolveGuard] }, { - path : 'filter/:filterHandle/:mailId', - component: FuseMailNgrxComponent, + path : 'filter/:filterHandle/:mailId', + component : MailNgrxComponent, canActivate: [fromGuards.ResolveGuard] }, { - path : ':folderHandle', - component: FuseMailNgrxComponent, + path : ':folderHandle', + component : MailNgrxComponent, canActivate: [fromGuards.ResolveGuard] }, { - path : ':folderHandle/:mailId', - component: FuseMailNgrxComponent, + path : ':folderHandle/:mailId', + component : MailNgrxComponent, canActivate: [fromGuards.ResolveGuard] }, { @@ -54,12 +54,12 @@ const routes: Routes = [ @NgModule({ declarations : [ - FuseMailNgrxComponent, - FuseMailNgrxListComponent, - FuseMailNgrxListItemComponent, - FuseMailNgrxDetailsComponent, - FuseMailNgrxMainSidenavComponent, - FuseMailNgrxComposeDialogComponent + MailNgrxComponent, + MailNgrxListComponent, + MailNgrxListItemComponent, + MailNgrxDetailsComponent, + MailNgrxMainSidenavComponent, + MailNgrxComposeDialogComponent ], imports : [ RouterModule.forChild(routes), @@ -80,13 +80,13 @@ const routes: Routes = [ FuseSharedModule, - MailAppStoreModule + MailNgrxStoreModule ], providers : [ MailNgrxService, fromGuards.ResolveGuard ], - entryComponents: [FuseMailNgrxComposeDialogComponent] + entryComponents: [MailNgrxComposeDialogComponent] }) export class FuseMailNgrxModule { diff --git a/src/app/main/apps/mail-ngrx/mail.service.ts b/src/app/main/apps/mail-ngrx/mail.service.ts index 26cbd9a8..ec1a6aad 100644 --- a/src/app/main/apps/mail-ngrx/mail.service.ts +++ b/src/app/main/apps/mail-ngrx/mail.service.ts @@ -16,72 +16,108 @@ export class MailNgrxService selectedMails: Mail[]; mails: Mail[]; + /** + * Constructor + * + * @param {HttpClient} _httpClient + * @param {Store} _store + */ constructor( - private http: HttpClient, - private store: Store + private _httpClient: HttpClient, + private _store: Store ) { - this.store.select(getFoldersArr).subscribe(folders => { + this._store.select(getFoldersArr).subscribe(folders => { this.foldersArr = folders; }); - this.store.select(getFiltersArr).subscribe(filters => { + + this._store.select(getFiltersArr).subscribe(filters => { this.filtersArr = filters; }); - this.store.select(getLabelsArr).subscribe(labels => { + + this._store.select(getLabelsArr).subscribe(labels => { this.labelsArr = labels; }); - this.store.select(getMailsArr).subscribe(mails => { + + this._store.select(getMailsArr).subscribe(mails => { this.mails = mails; }); this.selectedMails = []; } + /** + * Get all mails + * + * @returns {Observable} + */ getAllMails(): Observable { - return this.http.get('api/mail-mails'); + return this._httpClient.get('api/mail-mails'); } + /** + * Get folders + * + * @returns {Observable} + */ getFolders(): Observable { - return this.http.get('api/mail-folders'); + return this._httpClient.get('api/mail-folders'); } + /** + * Get filters + * + * @returns {Observable} + */ getFilters(): Observable { - return this.http.get('api/mail-filters'); + return this._httpClient.get('api/mail-filters'); } + /** + * Get labels + * + * @returns {Observable} + */ getLabels(): Observable { - return this.http.get('api/mail-labels'); + return this._httpClient.get('api/mail-labels'); } + /** + * Get mails + * + * @param handle + * @returns {Observable} + */ getMails(handle): Observable { if ( handle.id === 'labelHandle' ) { const labelId = this.labelsArr.find(label => label.handle === handle.value).id; - return this.http.get('api/mail-mails?labels=' + labelId); + return this._httpClient.get('api/mail-mails?labels=' + labelId); } else if ( handle.id === 'filterHandle' ) { - return this.http.get('api/mail-mails?' + handle.value + '=true'); + return this._httpClient.get('api/mail-mails?' + handle.value + '=true'); } else // folderHandle { const folderId = this.foldersArr.find(folder => folder.handle === handle.value).id; - return this.http.get('api/mail-mails?folder=' + folderId); + return this._httpClient.get('api/mail-mails?folder=' + folderId); } } /** * Update the mail + * * @param mail * @returns {Promise} */ - updateMail(mail) + updateMail(mail): any { - return this.http.post('api/mail-mails/' + mail.id, {...mail}); + return this._httpClient.post('api/mail-mails/' + mail.id, {...mail}); } } diff --git a/src/app/main/apps/mail-ngrx/sidenavs/main/main-sidenav.component.ts b/src/app/main/apps/mail-ngrx/sidenavs/main/main-sidenav.component.ts index 742a497d..11dfcfab 100644 --- a/src/app/main/apps/mail-ngrx/sidenavs/main/main-sidenav.component.ts +++ b/src/app/main/apps/mail-ngrx/sidenavs/main/main-sidenav.component.ts @@ -4,17 +4,17 @@ import { FormGroup } from '@angular/forms'; import { Store } from '@ngrx/store'; import { Observable } from 'rxjs'; -import { MailNgrxService } from '../../mail.service'; -import * as fromStore from './../../store'; -import { FuseMailNgrxComposeDialogComponent } from '../../dialogs/compose/compose.component'; +import { MailNgrxService } from 'app/main/apps/mail-ngrx/mail.service'; +import * as fromStore from 'app/main/apps/mail-ngrx/store'; +import { MailNgrxComposeDialogComponent } from 'app/main/apps/mail-ngrx/dialogs/compose/compose.component'; @Component({ - selector : 'fuse-mail-main-sidenav', + selector : 'mail-main-sidenav', templateUrl : './main-sidenav.component.html', styleUrls : ['./main-sidenav.component.scss'], changeDetection: ChangeDetectionStrategy.OnPush }) -export class FuseMailNgrxMainSidenavComponent +export class MailNgrxMainSidenavComponent { labels: any[]; accounts: object; @@ -25,30 +25,43 @@ export class FuseMailNgrxMainSidenavComponent filters$: Observable; labels$: Observable; + /** + * Constructor + * + * @param {MailNgrxService} _mailNgrxService + * @param {MatDialog} _matDialog + * @param {Store} _store + */ constructor( - private mailService: MailNgrxService, - public dialog: MatDialog, - private store: Store + private _mailNgrxService: MailNgrxService, + private _matDialog: MatDialog, + private _store: Store ) { - // Data + // Set the defaults this.accounts = { 'creapond' : 'johndoe@creapond.com', 'withinpixels': 'johndoe@withinpixels.com' }; - this.selectedAccount = 'creapond'; - - this.folders$ = this.store.select(fromStore.getFoldersArr); - this.filters$ = this.store.select(fromStore.getFiltersArr); - this.labels$ = this.store.select(fromStore.getLabelsArr); + this.folders$ = this._store.select(fromStore.getFoldersArr); + this.filters$ = this._store.select(fromStore.getFiltersArr); + this.labels$ = this._store.select(fromStore.getLabelsArr); } - composeDialog() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Compose dialog + */ + composeDialog(): void { - this.dialogRef = this.dialog.open(FuseMailNgrxComposeDialogComponent, { + this.dialogRef = this._matDialog.open(MailNgrxComposeDialogComponent, { panelClass: 'mail-compose-dialog' }); + this.dialogRef.afterClosed() .subscribe(response => { if ( !response ) diff --git a/src/app/main/apps/mail-ngrx/store/guards/resolve.guard.ts b/src/app/main/apps/mail-ngrx/store/guards/resolve.guard.ts index 6fa3324d..a563cd62 100644 --- a/src/app/main/apps/mail-ngrx/store/guards/resolve.guard.ts +++ b/src/app/main/apps/mail-ngrx/store/guards/resolve.guard.ts @@ -16,11 +16,16 @@ export class ResolveGuard implements CanActivate { routerState: any; + /** + * Constructor + * + * @param {Store} _store + */ constructor( - private store: Store + private _store: Store ) { - this.store.select(getRouterState).subscribe(routerState => { + this._store.select(getRouterState).subscribe(routerState => { if ( routerState ) { this.routerState = routerState.state; @@ -28,6 +33,13 @@ export class ResolveGuard implements CanActivate }); } + /** + * Can activate + * + * @param {ActivatedRouteSnapshot} route + * @param {RouterStateSnapshot} state + * @returns {Observable} + */ canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable { return this.checkStore().pipe( @@ -36,32 +48,42 @@ export class ResolveGuard implements CanActivate ); } + /** + * Check store + * + * @returns {Observable} + */ checkStore(): Observable { return forkJoin( - this.getFolders(), - this.getFilters(), - this.getLabels() - ) + this.getFolders(), + this.getFilters(), + this.getLabels() + ) .pipe( - filter(([foldersLoaded, filtersLoaded, labelsLoaded]) => filtersLoaded && foldersLoaded && labelsLoaded), + filter(([foldersLoaded, filtersLoaded, labelsLoaded]) => !!(foldersLoaded && filtersLoaded && labelsLoaded)), take(1), switchMap(() => this.getMails() ), take(1), - map(() => this.store.dispatch(new fromStore.SetCurrentMail(this.routerState.params.mailId))) + map(() => this._store.dispatch(new fromStore.SetCurrentMail(this.routerState.params.mailId))) ); } - getFolders() + /** + * Get folders + * + * @returns {Observable} + */ + getFolders(): any { - return this.store.select(getFoldersLoaded) + return this._store.select(getFoldersLoaded) .pipe( tap(loaded => { if ( !loaded ) { - this.store.dispatch(new fromStore.GetFolders([])); + this._store.dispatch(new fromStore.GetFolders([])); } }), filter(loaded => loaded), @@ -71,16 +93,17 @@ export class ResolveGuard implements CanActivate /** * Get Filters + * * @returns {Observable} */ - getFilters() + getFilters(): any { - return this.store.select(getFiltersLoaded) + return this._store.select(getFiltersLoaded) .pipe( tap(loaded => { if ( !loaded ) { - this.store.dispatch(new fromStore.GetFilters([])); + this._store.dispatch(new fromStore.GetFilters([])); } }), filter(loaded => loaded), @@ -92,14 +115,14 @@ export class ResolveGuard implements CanActivate * Get Labels * @returns {Observable} */ - getLabels() + getLabels(): any { - return this.store.select(getLabelsLoaded) + return this._store.select(getLabelsLoaded) .pipe( tap(loaded => { if ( !loaded ) { - this.store.dispatch(new fromStore.GetLabels([])); + this._store.dispatch(new fromStore.GetLabels([])); } }), filter(loaded => loaded), @@ -109,19 +132,20 @@ export class ResolveGuard implements CanActivate /** * Get Mails + * * @returns {Observable} */ - getMails() + getMails(): any { - return this.store.select(getMailsLoaded) + return this._store.select(getMailsLoaded) .pipe( tap((loaded: any) => { if ( !this.routerState.params[loaded.id] || this.routerState.params[loaded.id] !== loaded.value ) { - this.store.dispatch(new fromStore.GetMails()); - this.store.dispatch(new fromStore.SetSearchText('')); - this.store.dispatch(new fromStore.DeselectAllMails()); + this._store.dispatch(new fromStore.GetMails()); + this._store.dispatch(new fromStore.SetSearchText('')); + this._store.dispatch(new fromStore.DeselectAllMails()); } }), filter((loaded: any) => { diff --git a/src/app/main/apps/mail-ngrx/store/reducers/filters.reducer.ts b/src/app/main/apps/mail-ngrx/store/reducers/filters.reducer.ts index 1251a19d..ed8e8e05 100644 --- a/src/app/main/apps/mail-ngrx/store/reducers/filters.reducer.ts +++ b/src/app/main/apps/mail-ngrx/store/reducers/filters.reducer.ts @@ -2,7 +2,7 @@ import * as FiltersActions from 'app/main/apps/mail-ngrx/store/actions/filters.a export interface FiltersState { - entities: { [id: number]: any }; + entities?: { [id: number]: any }; loading: boolean; loaded: boolean; } diff --git a/src/app/main/apps/mail-ngrx/store/reducers/folders.reducer.ts b/src/app/main/apps/mail-ngrx/store/reducers/folders.reducer.ts index 9fe04dc5..37056ad5 100644 --- a/src/app/main/apps/mail-ngrx/store/reducers/folders.reducer.ts +++ b/src/app/main/apps/mail-ngrx/store/reducers/folders.reducer.ts @@ -2,7 +2,7 @@ import * as FoldersActions from 'app/main/apps/mail-ngrx/store/actions/folders.a export interface FoldersState { - entities: { [id: number]: any }; + entities?: { [id: number]: any }; loading: boolean; loaded: boolean; } diff --git a/src/app/main/apps/mail-ngrx/store/reducers/labels.reducer.ts b/src/app/main/apps/mail-ngrx/store/reducers/labels.reducer.ts index f6052b5b..af819e67 100644 --- a/src/app/main/apps/mail-ngrx/store/reducers/labels.reducer.ts +++ b/src/app/main/apps/mail-ngrx/store/reducers/labels.reducer.ts @@ -2,7 +2,7 @@ import * as LabelsActions from 'app/main/apps/mail-ngrx/store/actions/labels.act export interface LabelsState { - entities: { [id: number]: any }; + entities?: { [id: number]: any }; loading: boolean; loaded: boolean; } diff --git a/src/app/main/apps/mail-ngrx/store/reducers/mails.reducer.ts b/src/app/main/apps/mail-ngrx/store/reducers/mails.reducer.ts index cd62c048..d33cbf2b 100644 --- a/src/app/main/apps/mail-ngrx/store/reducers/mails.reducer.ts +++ b/src/app/main/apps/mail-ngrx/store/reducers/mails.reducer.ts @@ -3,7 +3,7 @@ import { Mail } from 'app/main/apps/mail-ngrx/mail.model'; export interface MailsState { - entities: { [id: number]: Mail }; + entities?: { [id: number]: Mail }; currentMail: any; selectedMailIds: string[]; searchText: string; diff --git a/src/app/main/apps/mail-ngrx/store/store.module.ts b/src/app/main/apps/mail-ngrx/store/store.module.ts index 0a955f92..bc9c41a2 100644 --- a/src/app/main/apps/mail-ngrx/store/store.module.ts +++ b/src/app/main/apps/mail-ngrx/store/store.module.ts @@ -12,6 +12,6 @@ import { effects } from 'app/main/apps/mail-ngrx/store/effects'; ], providers: [] }) -export class MailAppStoreModule +export class MailNgrxStoreModule { } diff --git a/src/app/main/apps/mail/dialogs/compose/compose.component.html b/src/app/main/apps/mail/dialogs/compose/compose.component.html index b6e132d8..7a8971bd 100644 --- a/src/app/main/apps/mail/dialogs/compose/compose.component.html +++ b/src/app/main/apps/mail/dialogs/compose/compose.component.html @@ -2,7 +2,7 @@ New Message - @@ -91,7 +91,7 @@
-
- - + +
diff --git a/src/app/main/apps/mail/mail-list/mail-list.component.ts b/src/app/main/apps/mail/mail-list/mail-list.component.ts index be4341d5..b59ec11e 100644 --- a/src/app/main/apps/mail/mail-list/mail-list.component.ts +++ b/src/app/main/apps/mail/mail-list/mail-list.component.ts @@ -1,109 +1,134 @@ import { Component, OnDestroy, OnInit } from '@angular/core'; import { Location } from '@angular/common'; import { ActivatedRoute } from '@angular/router'; -import { Subscription } from 'rxjs'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; -import { Mail } from '../mail.model'; -import { MailService } from '../mail.service'; +import { Mail } from 'app/main/apps/mail/mail.model'; +import { MailService } from 'app/main/apps/mail/mail.service'; @Component({ - selector : 'fuse-mail-list', + selector : 'mail-list', templateUrl: './mail-list.component.html', styleUrls : ['./mail-list.component.scss'], animations : fuseAnimations }) -export class FuseMailListComponent implements OnInit, OnDestroy +export class MailListComponent implements OnInit, OnDestroy { mails: Mail[]; currentMail: Mail; - onMailsChanged: Subscription; - onCurrentMailChanged: Subscription; + // Private + private _unsubscribeAll: Subject; + /** + * Constructor + * + * @param {ActivatedRoute} _activatedRoute + * @param {MailService} _mailService + * @param {Location} _location + */ constructor( - private route: ActivatedRoute, - private mailService: MailService, - private location: Location + private _activatedRoute: ActivatedRoute, + private _mailService: MailService, + private _location: Location ) { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { // Subscribe to update mails on changes - this.onMailsChanged = - this.mailService.onMailsChanged - .subscribe(mails => { - this.mails = mails; - }); + this._mailService.onMailsChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(mails => { + this.mails = mails; + }); // Subscribe to update current mail on changes - this.onCurrentMailChanged = - this.mailService.onCurrentMailChanged - .subscribe(currentMail => { - if ( !currentMail ) + this._mailService.onCurrentMailChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(currentMail => { + if ( !currentMail ) + { + // Set the current mail id to null to deselect the current mail + this.currentMail = null; + + // Handle the location changes + const labelHandle = this._activatedRoute.snapshot.params.labelHandle, + filterHandle = this._activatedRoute.snapshot.params.filterHandle, + folderHandle = this._activatedRoute.snapshot.params.folderHandle; + + if ( labelHandle ) { - // Set the current mail id to null to deselect the current mail - this.currentMail = null; - - // Handle the location changes - const labelHandle = this.route.snapshot.params.labelHandle, - filterHandle = this.route.snapshot.params.filterHandle, - folderHandle = this.route.snapshot.params.folderHandle; - - if ( labelHandle ) - { - this.location.go('apps/mail/label/' + labelHandle); - } - else if ( filterHandle ) - { - this.location.go('apps/mail/filter/' + filterHandle); - } - else - { - this.location.go('apps/mail/' + folderHandle); - } + this._location.go('apps/mail/label/' + labelHandle); + } + else if ( filterHandle ) + { + this._location.go('apps/mail/filter/' + filterHandle); } else { - this.currentMail = currentMail; + this._location.go('apps/mail/' + folderHandle); } - }); - } - - ngOnDestroy() - { - this.onMailsChanged.unsubscribe(); - this.onCurrentMailChanged.unsubscribe(); + } + else + { + this.currentMail = currentMail; + } + }); } + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + /** * Read mail + * * @param mailId */ - readMail(mailId) + readMail(mailId): void { - const labelHandle = this.route.snapshot.params.labelHandle, - filterHandle = this.route.snapshot.params.filterHandle, - folderHandle = this.route.snapshot.params.folderHandle; + const labelHandle = this._activatedRoute.snapshot.params.labelHandle, + filterHandle = this._activatedRoute.snapshot.params.filterHandle, + folderHandle = this._activatedRoute.snapshot.params.folderHandle; if ( labelHandle ) { - this.location.go('apps/mail/label/' + labelHandle + '/' + mailId); + this._location.go('apps/mail/label/' + labelHandle + '/' + mailId); } else if ( filterHandle ) { - this.location.go('apps/mail/filter/' + filterHandle + '/' + mailId); + this._location.go('apps/mail/filter/' + filterHandle + '/' + mailId); } else { - this.location.go('apps/mail/' + folderHandle + '/' + mailId); + this._location.go('apps/mail/' + folderHandle + '/' + mailId); } // Set current mail - this.mailService.setCurrentMail(mailId); + this._mailService.setCurrentMail(mailId); } - } diff --git a/src/app/main/apps/mail/mail.component.html b/src/app/main/apps/mail/mail.component.html index 004880f8..570edba8 100644 --- a/src/app/main/apps/mail/mail.component.html +++ b/src/app/main/apps/mail/mail.component.html @@ -9,7 +9,7 @@ - + @@ -86,7 +86,7 @@
-
@@ -96,8 +96,8 @@
- - + +
diff --git a/src/app/main/apps/mail/mail.component.scss b/src/app/main/apps/mail/mail.component.scss index cca33765..f401db44 100644 --- a/src/app/main/apps/mail/mail.component.scss +++ b/src/app/main/apps/mail/mail.component.scss @@ -40,16 +40,16 @@ @include media-breakpoint(xs) { - fuse-mail-list { + mail-list { border-right: none; } - fuse-mail-list, - fuse-mail-details { + mail-list, + mail-details { flex: 1 0 100%; } - fuse-mail-details { + mail-details { display: none !important; } @@ -65,11 +65,11 @@ .content { - fuse-mail-list { + mail-list { display: none !important; } - fuse-mail-details { + mail-details { display: flex !important; } } diff --git a/src/app/main/apps/mail/mail.component.ts b/src/app/main/apps/mail/mail.component.ts index c8bdc84c..2142b9c3 100644 --- a/src/app/main/apps/mail/mail.component.ts +++ b/src/app/main/apps/mail/mail.component.ts @@ -1,22 +1,23 @@ import { Component, OnDestroy, OnInit } from '@angular/core'; import { FormControl } from '@angular/forms'; - -import { Subscription } from 'rxjs'; -import { debounceTime, distinctUntilChanged } from 'rxjs/operators'; +import { Subject } from 'rxjs'; +import { debounceTime, distinctUntilChanged, takeUntil } from 'rxjs/operators'; import { FuseTranslationLoaderService } from '@fuse/services/translation-loader.service'; -import { Mail } from './mail.model'; -import { MailService } from './mail.service'; -import { locale as english } from './i18n/en'; -import { locale as turkish } from './i18n/tr'; +import { Mail } from 'app/main/apps/mail/mail.model'; +import { MailService } from 'app/main/apps/mail/mail.service'; + +import { locale as english } from 'app/main/apps/mail//i18n/en'; +import { locale as turkish } from 'app/main/apps/mail//i18n/tr'; +import { FuseConfigService } from '@fuse/services/config.service'; @Component({ - selector : 'fuse-mail', + selector : 'mail', templateUrl: './mail.component.html', styleUrls : ['./mail.component.scss'] }) -export class FuseMailComponent implements OnInit, OnDestroy +export class MailComponent implements OnInit, OnDestroy { hasSelectedMails: boolean; isIndeterminate: boolean; @@ -26,110 +27,162 @@ export class FuseMailComponent implements OnInit, OnDestroy searchInput: FormControl; currentMail: Mail; - onSelectedMailsChanged: Subscription; - onFoldersChanged: Subscription; - onFiltersChanged: Subscription; - onLabelsChanged: Subscription; - onCurrentMailChanged: Subscription; + // Private + private _unsubscribeAll: Subject; + /** + * Constructor + * + * @param {MailService} _mailService + * @param {FuseConfigService} _fuseConfigService + * @param {FuseTranslationLoaderService} _fuseTranslationLoaderService + */ constructor( - private mailService: MailService, - private fuseTranslationLoader: FuseTranslationLoaderService + private _mailService: MailService, + private _fuseConfigService: FuseConfigService, + private _fuseTranslationLoaderService: FuseTranslationLoaderService ) { + // Configure the layout + this._fuseConfigService.config = { + routerAnimation: 'none' + }; + + // Load the translations + this._fuseTranslationLoaderService.loadTranslations(english, turkish); + + // Set the defaults this.searchInput = new FormControl(''); - this.fuseTranslationLoader.loadTranslations(english, turkish); + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.onSelectedMailsChanged = - this.mailService.onSelectedMailsChanged - .subscribe(selectedMails => { + this._mailService.onSelectedMailsChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(selectedMails => { + setTimeout(() => { + this.hasSelectedMails = selectedMails.length > 0; + this.isIndeterminate = (selectedMails.length !== this._mailService.mails.length && selectedMails.length > 0); + }, 0); + }); - setTimeout(() => { - this.hasSelectedMails = selectedMails.length > 0; - this.isIndeterminate = (selectedMails.length !== this.mailService.mails.length && selectedMails.length > 0); - }, 0); - }); + this._mailService.onFoldersChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(folders => { + this.folders = this._mailService.folders; + }); - this.onFoldersChanged = - this.mailService.onFoldersChanged - .subscribe(folders => { - this.folders = this.mailService.folders; - }); + this._mailService.onFiltersChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(folders => { + this.filters = this._mailService.filters; + }); - this.onFiltersChanged = - this.mailService.onFiltersChanged - .subscribe(folders => { - this.filters = this.mailService.filters; - }); + this._mailService.onLabelsChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(labels => { + this.labels = this._mailService.labels; + }); - this.onLabelsChanged = - this.mailService.onLabelsChanged - .subscribe(labels => { - this.labels = this.mailService.labels; - }); - - this.onCurrentMailChanged = - this.mailService.onCurrentMailChanged - .subscribe(currentMail => { - if ( !currentMail ) - { - this.currentMail = null; - } - else - { - this.currentMail = currentMail; - } - }); + this._mailService.onCurrentMailChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(currentMail => { + if ( !currentMail ) + { + this.currentMail = null; + } + else + { + this.currentMail = currentMail; + } + }); this.searchInput.valueChanges.pipe( + takeUntil(this._unsubscribeAll), debounceTime(300), distinctUntilChanged() ) .subscribe(searchText => { - this.mailService.onSearchTextChanged.next(searchText); + this._mailService.onSearchTextChanged.next(searchText); }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.onSelectedMailsChanged.unsubscribe(); - this.onFoldersChanged.unsubscribe(); - this.onFiltersChanged.unsubscribe(); - this.onLabelsChanged.unsubscribe(); - this.onCurrentMailChanged.unsubscribe(); - + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - toggleSelectAll() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Toggle select all + */ + toggleSelectAll(): void { - this.mailService.toggleSelectAll(); + this._mailService.toggleSelectAll(); } - selectMails(filterParameter?, filterValue?) + /** + * Select mails + * + * @param filterParameter + * @param filterValue + */ + selectMails(filterParameter?, filterValue?): void { - this.mailService.selectMails(filterParameter, filterValue); + this._mailService.selectMails(filterParameter, filterValue); } - deselectMails() + /** + * Deselect mails + */ + deselectMails(): void { - this.mailService.deselectMails(); + this._mailService.deselectMails(); } - deSelectCurrentMail() + /** + * Deselect current mail + */ + deselectCurrentMail(): void { - this.mailService.onCurrentMailChanged.next(null); + this._mailService.onCurrentMailChanged.next(null); } - toggleLabelOnSelectedMails(labelId) + /** + * Toggle label on selected mails + * + * @param labelId + */ + toggleLabelOnSelectedMails(labelId): void { - this.mailService.toggleLabelOnSelectedMails(labelId); + this._mailService.toggleLabelOnSelectedMails(labelId); } - setFolderOnSelectedMails(folderId) + /** + * Set folder on selected mails + * + * @param folderId + */ + setFolderOnSelectedMails(folderId): void { - this.mailService.setFolderOnSelectedMails(folderId); + this._mailService.setFolderOnSelectedMails(folderId); } } diff --git a/src/app/main/apps/mail/mail.model.ts b/src/app/main/apps/mail/mail.model.ts index 42ff6cf5..7b36a600 100644 --- a/src/app/main/apps/mail/mail.model.ts +++ b/src/app/main/apps/mail/mail.model.ts @@ -27,6 +27,11 @@ export class Mail labels: string[]; folder: string; + /** + * Constructor + * + * @param mail + */ constructor(mail) { this.id = mail.id; diff --git a/src/app/main/apps/mail/mail.module.ts b/src/app/main/apps/mail/mail.module.ts index a9b177f9..4066b864 100644 --- a/src/app/main/apps/mail/mail.module.ts +++ b/src/app/main/apps/mail/mail.module.ts @@ -1,59 +1,57 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; - import { MatButtonModule, MatCheckboxModule, MatDialogModule, MatFormFieldModule, MatIconModule, MatInputModule, MatMenuModule, MatRippleModule, MatSelectModule, MatSidenavModule, MatToolbarModule } from '@angular/material'; - import { TranslateModule } from '@ngx-translate/core'; import { FuseSharedModule } from '@fuse/shared.module'; -import { MailService } from './mail.service'; -import { FuseMailComponent } from './mail.component'; -import { FuseMailMainSidenavComponent } from './sidenavs/main/main-sidenav.component'; -import { FuseMailListItemComponent } from './mail-list/mail-list-item/mail-list-item.component'; -import { FuseMailListComponent } from './mail-list/mail-list.component'; -import { FuseMailDetailsComponent } from './mail-details/mail-details.component'; -import { FuseMailComposeDialogComponent } from './dialogs/compose/compose.component'; +import { MailService } from 'app/main/apps/mail/mail.service'; +import { MailComponent } from 'app/main/apps/mail/mail.component'; +import { MailListComponent } from 'app/main/apps/mail/mail-list/mail-list.component'; +import { MailListItemComponent } from 'app/main/apps/mail/mail-list/mail-list-item/mail-list-item.component'; +import { MailDetailsComponent } from 'app/main/apps/mail/mail-details/mail-details.component'; +import { MailMainSidenavComponent } from 'app/main/apps/mail/sidenavs/main/main-sidenav.component'; +import { MailComposeDialogComponent } from 'app/main/apps/mail/dialogs/compose/compose.component'; const routes: Routes = [ { path : 'label/:labelHandle', - component: FuseMailComponent, + component: MailComponent, resolve : { mail: MailService } }, { path : 'label/:labelHandle/:mailId', - component: FuseMailComponent, + component: MailComponent, resolve : { mail: MailService } }, { path : 'filter/:filterHandle', - component: FuseMailComponent, + component: MailComponent, resolve : { mail: MailService } }, { path : 'filter/:filterHandle/:mailId', - component: FuseMailComponent, + component: MailComponent, resolve : { mail: MailService } }, { path : ':folderHandle', - component: FuseMailComponent, + component: MailComponent, resolve : { mail: MailService } }, { path : ':folderHandle/:mailId', - component: FuseMailComponent, + component: MailComponent, resolve : { mail: MailService } @@ -66,12 +64,12 @@ const routes: Routes = [ @NgModule({ declarations : [ - FuseMailComponent, - FuseMailListComponent, - FuseMailListItemComponent, - FuseMailDetailsComponent, - FuseMailMainSidenavComponent, - FuseMailComposeDialogComponent + MailComponent, + MailListComponent, + MailListItemComponent, + MailDetailsComponent, + MailMainSidenavComponent, + MailComposeDialogComponent ], imports : [ RouterModule.forChild(routes), @@ -95,8 +93,10 @@ const routes: Routes = [ providers : [ MailService ], - entryComponents: [FuseMailComposeDialogComponent] + entryComponents: [ + MailComposeDialogComponent + ] }) -export class FuseMailModule +export class MailModule { } diff --git a/src/app/main/apps/mail/mail.service.ts b/src/app/main/apps/mail/mail.service.ts index de0c7d50..95dcdca8 100644 --- a/src/app/main/apps/mail/mail.service.ts +++ b/src/app/main/apps/mail/mail.service.ts @@ -5,7 +5,7 @@ import { BehaviorSubject, Observable } from 'rxjs'; import { FuseUtils } from '@fuse/utils'; -import { Mail } from './mail.model'; +import { Mail } from 'app/main/apps/mail/mail.model'; @Injectable() export class MailService implements Resolve @@ -20,22 +20,37 @@ export class MailService implements Resolve labels: any[]; routeParams: any; - onMailsChanged: BehaviorSubject = new BehaviorSubject([]); - onSelectedMailsChanged: BehaviorSubject = new BehaviorSubject([]); - onCurrentMailChanged: BehaviorSubject = new BehaviorSubject([]); + onMailsChanged: BehaviorSubject; + onSelectedMailsChanged: BehaviorSubject; + onCurrentMailChanged: BehaviorSubject; + onFoldersChanged: BehaviorSubject; + onFiltersChanged: BehaviorSubject; + onLabelsChanged: BehaviorSubject; + onSearchTextChanged: BehaviorSubject; - onFoldersChanged: BehaviorSubject = new BehaviorSubject([]); - onFiltersChanged: BehaviorSubject = new BehaviorSubject([]); - onLabelsChanged: BehaviorSubject = new BehaviorSubject([]); - onSearchTextChanged: BehaviorSubject = new BehaviorSubject(''); - - constructor(private http: HttpClient) + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ + constructor( + private _httpClient: HttpClient + ) { + // Set the defaults this.selectedMails = []; + this.onMailsChanged = new BehaviorSubject([]); + this.onSelectedMailsChanged = new BehaviorSubject([]); + this.onCurrentMailChanged = new BehaviorSubject([]); + this.onFoldersChanged = new BehaviorSubject([]); + this.onFiltersChanged = new BehaviorSubject([]); + this.onLabelsChanged = new BehaviorSubject([]); + this.onSearchTextChanged = new BehaviorSubject(''); } /** - * Resolve + * Resolver + * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state * @returns {Observable | Promise | any} @@ -83,12 +98,13 @@ export class MailService implements Resolve /** * Get all folders + * * @returns {Promise} */ getFolders(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/mail-folders') + this._httpClient.get('api/mail-folders') .subscribe((response: any) => { this.folders = response; this.onFoldersChanged.next(this.folders); @@ -99,12 +115,13 @@ export class MailService implements Resolve /** * Get all filters + * * @returns {Promise} */ getFilters(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/mail-filters') + this._httpClient.get('api/mail-filters') .subscribe((response: any) => { this.filters = response; this.onFiltersChanged.next(this.filters); @@ -115,12 +132,13 @@ export class MailService implements Resolve /** * Get all labels + * * @returns {Promise} */ getLabels(): Promise { return new Promise((resolve, reject) => { - this.http.get('api/mail-labels') + this._httpClient.get('api/mail-labels') .subscribe((response: any) => { this.labels = response; this.onLabelsChanged.next(this.labels); @@ -131,6 +149,7 @@ export class MailService implements Resolve /** * Get all mails + * * @returns {Promise} */ getMails(): Promise @@ -150,6 +169,7 @@ export class MailService implements Resolve /** * Get mails by folder + * * @param handle * @returns {Promise} */ @@ -157,12 +177,12 @@ export class MailService implements Resolve { return new Promise((resolve, reject) => { - this.http.get('api/mail-folders?handle=' + handle) + this._httpClient.get('api/mail-folders?handle=' + handle) .subscribe((folders: any) => { const folderId = folders[0].id; - this.http.get('api/mail-mails?folder=' + folderId) + this._httpClient.get('api/mail-mails?folder=' + folderId) .subscribe((mails: any) => { this.mails = mails.map(mail => { @@ -182,6 +202,7 @@ export class MailService implements Resolve /** * Get mails by filter + * * @param handle * @returns {Promise} */ @@ -189,7 +210,7 @@ export class MailService implements Resolve { return new Promise((resolve, reject) => { - this.http.get('api/mail-mails?' + handle + '=true') + this._httpClient.get('api/mail-mails?' + handle + '=true') .subscribe((mails: any) => { this.mails = mails.map(mail => { @@ -208,18 +229,19 @@ export class MailService implements Resolve /** * Get mails by label + * * @param handle * @returns {Promise} */ getMailsByLabel(handle): Promise { return new Promise((resolve, reject) => { - this.http.get('api/mail-labels?handle=' + handle) + this._httpClient.get('api/mail-labels?handle=' + handle) .subscribe((labels: any) => { const labelId = labels[0].id; - this.http.get('api/mail-mails?labels=' + labelId) + this._httpClient.get('api/mail-mails?labels=' + labelId) .subscribe((mails: any) => { this.mails = mails.map(mail => { @@ -239,9 +261,10 @@ export class MailService implements Resolve /** * Toggle selected mail by id + * * @param id */ - toggleSelectedMail(id) + toggleSelectedMail(id): void { // First, check if we already have that mail as selected... if ( this.selectedMails.length > 0 ) @@ -281,7 +304,7 @@ export class MailService implements Resolve /** * Toggle select all */ - toggleSelectAll() + toggleSelectAll(): void { if ( this.selectedMails.length > 0 ) { @@ -294,7 +317,13 @@ export class MailService implements Resolve } - selectMails(filterParameter?, filterValue?) + /** + * Select mails + * + * @param filterParameter + * @param filterValue + */ + selectMails(filterParameter?, filterValue?): void { this.selectedMails = []; @@ -316,7 +345,10 @@ export class MailService implements Resolve this.onSelectedMailsChanged.next(this.selectedMails); } - deselectMails() + /** + * Deselect mails + */ + deselectMails(): void { this.selectedMails = []; @@ -326,9 +358,10 @@ export class MailService implements Resolve /** * Set current mail by id + * * @param id */ - setCurrentMail(id) + setCurrentMail(id): void { this.currentMail = this.mails.find(mail => { return mail.id === id; @@ -339,9 +372,10 @@ export class MailService implements Resolve /** * Toggle label on selected mails + * * @param labelId */ - toggleLabelOnSelectedMails(labelId) + toggleLabelOnSelectedMails(labelId): void { this.selectedMails.map(mail => { @@ -362,9 +396,10 @@ export class MailService implements Resolve /** * Set folder on selected mails + * * @param folderId */ - setFolderOnSelectedMails(folderId) + setFolderOnSelectedMails(folderId): void { this.selectedMails.map(mail => { mail.folder = folderId; @@ -377,14 +412,15 @@ export class MailService implements Resolve /** * Update the mail + * * @param mail * @returns {Promise} */ - updateMail(mail) + updateMail(mail): Promise { return new Promise((resolve, reject) => { - this.http.post('api/mail-mails/' + mail.id, {...mail}) + this._httpClient.post('api/mail-mails/' + mail.id, {...mail}) .subscribe(response => { this.getMails().then(mails => { @@ -400,5 +436,4 @@ export class MailService implements Resolve }); }); } - } diff --git a/src/app/main/apps/mail/sidenavs/main/main-sidenav.component.ts b/src/app/main/apps/mail/sidenavs/main/main-sidenav.component.ts index f086c281..dab4d5b5 100644 --- a/src/app/main/apps/mail/sidenavs/main/main-sidenav.component.ts +++ b/src/app/main/apps/mail/sidenavs/main/main-sidenav.component.ts @@ -1,20 +1,21 @@ import { Component, OnDestroy, OnInit } from '@angular/core'; import { FormGroup } from '@angular/forms'; import { MatDialog } from '@angular/material'; -import { Subscription } from 'rxjs'; import { fuseAnimations } from '@fuse/animations'; -import { MailService } from '../../mail.service'; -import { FuseMailComposeDialogComponent } from '../../dialogs/compose/compose.component'; +import { MailService } from 'app/main/apps/mail/mail.service'; +import { MailComposeDialogComponent } from 'app/main/apps/mail/dialogs/compose/compose.component'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; @Component({ - selector : 'fuse-mail-main-sidenav', + selector : 'mail-main-sidenav', templateUrl: './main-sidenav.component.html', styleUrls : ['./main-sidenav.component.scss'], animations : fuseAnimations }) -export class FuseMailMainSidenavComponent implements OnInit, OnDestroy +export class MailMainSidenavComponent implements OnInit, OnDestroy { folders: any[]; filters: any[]; @@ -23,55 +24,79 @@ export class FuseMailMainSidenavComponent implements OnInit, OnDestroy selectedAccount: string; dialogRef: any; - onFoldersChanged: Subscription; - onFiltersChanged: Subscription; - onLabelsChanged: Subscription; + // Private + private _unsubscribeAll: Subject; + /** + * Constructor + * + * @param {MailService} _mailService + * @param {MatDialog} _matDialog + */ constructor( - private mailService: MailService, - public dialog: MatDialog + private _mailService: MailService, + public _matDialog: MatDialog ) { - // Data + // Set the defaults this.accounts = { 'creapond' : 'johndoe@creapond.com', 'withinpixels': 'johndoe@withinpixels.com' }; - this.selectedAccount = 'creapond'; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.onFoldersChanged = - this.mailService.onFoldersChanged - .subscribe(folders => { - this.folders = folders; - }); + this._mailService.onFoldersChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(folders => { + this.folders = folders; + }); - this.onFiltersChanged = - this.mailService.onFiltersChanged - .subscribe(filters => { - this.filters = filters; - }); + this._mailService.onFiltersChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(filters => { + this.filters = filters; + }); - this.onLabelsChanged = - this.mailService.onLabelsChanged - .subscribe(labels => { - this.labels = labels; - }); + this._mailService.onLabelsChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(labels => { + this.labels = labels; + }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.onFoldersChanged.unsubscribe(); - this.onFiltersChanged.unsubscribe(); - this.onLabelsChanged.unsubscribe(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - - composeDialog() + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Compose dialog + */ + composeDialog(): void { - this.dialogRef = this.dialog.open(FuseMailComposeDialogComponent, { + this.dialogRef = this._matDialog.open(MailComposeDialogComponent, { panelClass: 'mail-compose-dialog' }); this.dialogRef.afterClosed() diff --git a/src/app/main/apps/scrumboard/board.model.ts b/src/app/main/apps/scrumboard/board.model.ts index 3f061428..3b987661 100644 --- a/src/app/main/apps/scrumboard/board.model.ts +++ b/src/app/main/apps/scrumboard/board.model.ts @@ -67,6 +67,11 @@ export class Board color: string }[]; + /** + * Constructor + * + * @param board + */ constructor(board) { this.name = board.name || 'Untitled Board'; diff --git a/src/app/main/apps/scrumboard/board/add-list/add-list.component.ts b/src/app/main/apps/scrumboard/board/add-list/add-list.component.ts index fc0fcddb..bf74e6b1 100644 --- a/src/app/main/apps/scrumboard/board/add-list/add-list.component.ts +++ b/src/app/main/apps/scrumboard/board/add-list/add-list.component.ts @@ -2,49 +2,77 @@ import { Component, EventEmitter, Output, ViewChild } from '@angular/core'; import { FormBuilder, FormGroup } from '@angular/forms'; @Component({ - selector : 'fuse-scrumboard-board-add-list', + selector : 'scrumboard-board-add-list', templateUrl: './add-list.component.html', styleUrls : ['./add-list.component.scss'] }) -export class FuseScrumboardBoardAddListComponent +export class ScrumboardBoardAddListComponent { - formActive = false; + formActive: boolean; form: FormGroup; - @Output() onlistAdd = new EventEmitter(); - @ViewChild('nameInput') nameInputField; + @Output() + onListAdd: EventEmitter; + + @ViewChild('nameInput') + nameInputField; + + /** + * Constructor + * + * @param {FormBuilder} _formBuilder + */ constructor( - private formBuilder: FormBuilder + private _formBuilder: FormBuilder ) { + // Set the defaults + this.formActive = false; + this.onListAdd = new EventEmitter(); } - - openForm() + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Open form + */ + openForm(): void { - this.form = this.formBuilder.group({ + this.form = this._formBuilder.group({ name: [''] }); this.formActive = true; this.focusNameField(); } - closeForm() + /** + * Close form + */ + closeForm(): void { this.formActive = false; } - focusNameField() + /** + * Focus to the name field + */ + focusNameField(): void { setTimeout(() => { this.nameInputField.nativeElement.focus(); }); } - onFormSubmit() + /** + * On form submit + */ + onFormSubmit(): void { if ( this.form.valid ) { - this.onlistAdd.next(this.form.getRawValue().name); + this.onListAdd.next(this.form.getRawValue().name); this.formActive = false; } } diff --git a/src/app/main/apps/scrumboard/board/board.component.html b/src/app/main/apps/scrumboard/board/board.component.html index f2d4cfae..e98bb873 100644 --- a/src/app/main/apps/scrumboard/board/board.component.html +++ b/src/app/main/apps/scrumboard/board/board.component.html @@ -26,10 +26,10 @@ fxFlex="1 0 100%" fxFlex.gt-xs="1 0 auto" fxFlexOrder="1" fxFlexOrder.gt-xs="2"> remove_red_eye - - + @@ -58,21 +58,21 @@ *fuseIfOnDom [@animateStagger]="{value:'50'}"> - - + - - + + @@ -82,7 +82,7 @@ - +
diff --git a/src/app/main/apps/scrumboard/board/board.component.ts b/src/app/main/apps/scrumboard/board/board.component.ts index 85ac0bc8..d225089c 100644 --- a/src/app/main/apps/scrumboard/board/board.component.ts +++ b/src/app/main/apps/scrumboard/board/board.component.ts @@ -1,65 +1,100 @@ import { Component, OnDestroy, OnInit } from '@angular/core'; import { Location } from '@angular/common'; import { ActivatedRoute } from '@angular/router'; - -import { Subscription } from 'rxjs'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; -import { List } from '../list.model'; -import { ScrumboardService } from '../scrumboard.service'; +import { ScrumboardService } from 'app/main/apps/scrumboard/scrumboard.service'; +import { List } from 'app/main/apps/scrumboard/list.model'; @Component({ - selector : 'fuse-scrumboard-board', + selector : 'scrumboard-board', templateUrl: './board.component.html', styleUrls : ['./board.component.scss'], animations : fuseAnimations }) -export class FuseScrumboardBoardComponent implements OnInit, OnDestroy +export class ScrumboardBoardComponent implements OnInit, OnDestroy { board: any; - onBoardChanged: Subscription; + + // Private + private _unsubscribeAll: Subject; constructor( - private route: ActivatedRoute, - private location: Location, - private scrumboardService: ScrumboardService + private _activatedRoute: ActivatedRoute, + private _location: Location, + private _scrumboardService: ScrumboardService ) { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.onBoardChanged = - this.scrumboardService.onBoardChanged - .subscribe(board => { - this.board = board; - }); + this._scrumboardService.onBoardChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(board => { + this.board = board; + }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.onBoardChanged.unsubscribe(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - onListAdd(newListName) + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On list add + * + * @param newListName + */ + onListAdd(newListName): void { if ( newListName === '' ) { return; } - this.scrumboardService.addList(new List({name: newListName})); + this._scrumboardService.addList(new List({name: newListName})); } - onBoardNameChanged(newName) + /** + * On board name changed + * + * @param newName + */ + onBoardNameChanged(newName): void { - this.scrumboardService.updateBoard(); - this.location.go('/apps/scrumboard/boards/' + this.board.id + '/' + this.board.uri); + this._scrumboardService.updateBoard(); + this._location.go('/apps/scrumboard/boards/' + this.board.id + '/' + this.board.uri); } - onDrop(ev) + /** + * On drop + * + * @param ev + */ + onDrop(ev): void { - this.scrumboardService.updateBoard(); + this._scrumboardService.updateBoard(); } } diff --git a/src/app/main/apps/scrumboard/board/dialogs/card/card.component.html b/src/app/main/apps/scrumboard/board/dialogs/card/card.component.html index caa2f1b3..3dbb896a 100644 --- a/src/app/main/apps/scrumboard/board/dialogs/card/card.component.html +++ b/src/app/main/apps/scrumboard/board/dialogs/card/card.component.html @@ -35,8 +35,8 @@ - + @@ -130,7 +130,7 @@ - diff --git a/src/app/main/apps/scrumboard/board/dialogs/card/card.component.ts b/src/app/main/apps/scrumboard/board/dialogs/card/card.component.ts index a8c8dff9..4bc04c73 100644 --- a/src/app/main/apps/scrumboard/board/dialogs/card/card.component.ts +++ b/src/app/main/apps/scrumboard/board/dialogs/card/card.component.ts @@ -1,74 +1,108 @@ import { Component, Inject, OnDestroy, OnInit, ViewChild, ViewEncapsulation } from '@angular/core'; import { NgForm } from '@angular/forms/src/forms'; import { MAT_DIALOG_DATA, MatDialog, MatDialogRef, MatMenuTrigger } from '@angular/material'; - -import { Subscription } from 'rxjs'; +import { Subject } from 'rxjs'; import { FuseConfirmDialogComponent } from '@fuse/components/confirm-dialog/confirm-dialog.component'; import { FuseUtils } from '@fuse/utils'; -import { ScrumboardService } from '../../../scrumboard.service'; +import { ScrumboardService } from 'app/main/apps/scrumboard/scrumboard.service'; +import { takeUntil } from 'rxjs/operators'; @Component({ - selector : 'fuse-scrumboard-board-card-dialog', + selector : 'scrumboard-board-card-dialog', templateUrl : './card.component.html', styleUrls : ['./card.component.scss'], encapsulation: ViewEncapsulation.None }) -export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy +export class ScrumboardCardDialogComponent implements OnInit, OnDestroy { card: any; board: any; list: any; - onBoardChanged: Subscription; toggleInArray = FuseUtils.toggleInArray; - - @ViewChild('checklistMenuTrigger') checklistMenu: MatMenuTrigger; - @ViewChild('newCheckListTitleField') newCheckListTitleField; - confirmDialogRef: MatDialogRef; + @ViewChild('checklistMenuTrigger') + checklistMenu: MatMenuTrigger; + + @ViewChild('newCheckListTitleField') + newCheckListTitleField; + + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {MatDialogRef} _matDialogRef + * @param _data + * @param {MatDialog} _matDialog + * @param {ScrumboardService} _scrumboardService + */ constructor( - public dialogRef: MatDialogRef, - @Inject(MAT_DIALOG_DATA) private data: any, - public dialog: MatDialog, - private scrumboardService: ScrumboardService + private _matDialogRef: MatDialogRef, + @Inject(MAT_DIALOG_DATA) private _data: any, + private _matDialog: MatDialog, + private _scrumboardService: ScrumboardService ) { - + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.onBoardChanged = - this.scrumboardService.onBoardChanged - .subscribe(board => { - this.board = board; + this._scrumboardService.onBoardChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(board => { + this.board = board; - this.card = this.board.cards.find((_card) => { - return this.data.cardId === _card.id; - }); - - this.list = this.board.lists.find((_list) => { - return this.data.listId === _list.id; - }); + this.card = this.board.cards.find((_card) => { + return this._data.cardId === _card.id; }); + + this.list = this.board.lists.find((_list) => { + return this._data.listId === _list.id; + }); + }); } /** - * Remove Due date + * On destroy */ - removeDueDate() + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Remove due date + */ + removeDueDate(): void { this.card.due = ''; this.updateCard(); } /** - * Toggle Subscribe + * Toggle subscribe */ - toggleSubscribe() + toggleSubscribe(): void { this.card.subscribed = !this.card.subscribed; @@ -76,10 +110,11 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy } /** - * Toggle Cover Image + * Toggle cover image + * * @param attachmentId */ - toggleCoverImage(attachmentId) + toggleCoverImage(attachmentId): void { if ( this.card.idAttachmentCover === attachmentId ) { @@ -94,10 +129,11 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy } /** - * Remove Attachment + * Remove attachment + * * @param attachment */ - removeAttachment(attachment) + removeAttachment(attachment): void { if ( attachment.id === this.card.idAttachmentCover ) { @@ -110,10 +146,11 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy } /** - * Remove Checklist + * Remove checklist + * * @param checklist */ - removeChecklist(checklist) + removeChecklist(checklist): void { this.card.checklists.splice(this.card.checklists.indexOf(checklist), 1); @@ -121,10 +158,11 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy } /** - * Update Checked Count + * Update checked count + * * @param list */ - updateCheckedCount(list) + updateCheckedCount(list): void { const checkItems = list.checkItems; let checkedItems = 0; @@ -154,11 +192,12 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy } /** - * Remove Checklist Item + * Remove checklist item + * * @param checkItem * @param checklist */ - removeChecklistItem(checkItem, checklist) + removeChecklistItem(checkItem, checklist): void { checklist.checkItems.splice(checklist.checkItems.indexOf(checkItem), 1); @@ -168,11 +207,12 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy } /** - * Add Check Item + * Add check item + * * @param {NgForm} form * @param checkList */ - addCheckItem(form: NgForm, checkList) + addCheckItem(form: NgForm, checkList): void { const checkItemVal = form.value.checkItem; @@ -196,10 +236,11 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy } /** - * Add Checklist + * Add checklist + * * @param {NgForm} form */ - addChecklist(form: NgForm) + addChecklist(form: NgForm): void { this.card.checklists.push({ id : FuseUtils.generateGUID(), @@ -215,9 +256,9 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy } /** - * On Checklist Menu Open + * On checklist menu open */ - onChecklistMenuOpen() + onChecklistMenuOpen(): void { setTimeout(() => { this.newCheckListTitleField.nativeElement.focus(); @@ -225,10 +266,11 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy } /** - * Add New Comment + * Add new comment + * * @param {NgForm} form */ - addNewComment(form: NgForm) + addNewComment(form: NgForm): void { const newCommentText = form.value.newComment; @@ -246,11 +288,11 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy } /** - * Remove Card + * Remove card */ - removeCard() + removeCard(): void { - this.confirmDialogRef = this.dialog.open(FuseConfirmDialogComponent, { + this.confirmDialogRef = this._matDialog.open(FuseConfirmDialogComponent, { disableClose: false }); @@ -259,22 +301,17 @@ export class FuseScrumboardCardDialogComponent implements OnInit, OnDestroy this.confirmDialogRef.afterClosed().subscribe(result => { if ( result ) { - this.dialogRef.close(); - this.scrumboardService.removeCard(this.card.id, this.list.id); + this._matDialogRef.close(); + this._scrumboardService.removeCard(this.card.id, this.list.id); } }); } /** - * Update Card + * Update card */ - updateCard() + updateCard(): void { - this.scrumboardService.updateCard(this.card); - } - - ngOnDestroy() - { - this.onBoardChanged.unsubscribe(); + this._scrumboardService.updateCard(this.card); } } diff --git a/src/app/main/apps/scrumboard/board/dialogs/card/label-selector/label-selector.component.ts b/src/app/main/apps/scrumboard/board/dialogs/card/label-selector/label-selector.component.ts index 3008a485..46cb3bca 100644 --- a/src/app/main/apps/scrumboard/board/dialogs/card/label-selector/label-selector.component.ts +++ b/src/app/main/apps/scrumboard/board/dialogs/card/label-selector/label-selector.component.ts @@ -1,68 +1,110 @@ import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewEncapsulation } from '@angular/core'; - -import { Subscription } from 'rxjs'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; import { FuseUtils } from '@fuse/utils'; -import { ScrumboardService } from '../../../../scrumboard.service'; +import { ScrumboardService } from 'app/main/apps/scrumboard/scrumboard.service'; @Component({ - selector : 'fuse-scrumboard-label-selector', + selector : 'scrumboard-label-selector', templateUrl : './label-selector.component.html', styleUrls : ['./label-selector.component.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseScrumboardLabelSelectorComponent implements OnInit, OnDestroy +export class ScrumboardLabelSelectorComponent implements OnInit, OnDestroy { + @Input('card') + card: any; + + @Output() + onCardLabelsChange: EventEmitter; + board: any; - @Input('card') card: any; - @Output() onCardLabelsChange = new EventEmitter(); - - labelsMenuView = 'labels'; + labelsMenuView: string; selectedLabel: any; - newLabel = { - 'id' : '', - 'name' : '', - 'color': 'mat-blue-400-bg' - }; - toggleInArray = FuseUtils.toggleInArray; + newLabel: any; + toggleInArray: any; - onBoardChanged: Subscription; + // Private + private _unsubscribeAll: Subject; + /** + * Constructor + * + * @param {ScrumboardService} _scrumboardService + */ constructor( - private scrumboardService: ScrumboardService + private _scrumboardService: ScrumboardService ) { + // Set the defaults + this.onCardLabelsChange = new EventEmitter(); + this.labelsMenuView = 'labels'; + this.newLabel = { + 'id' : '', + 'name' : '', + 'color': 'mat-blue-400-bg' + }; + this.toggleInArray = FuseUtils.toggleInArray; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.onBoardChanged = - this.scrumboardService.onBoardChanged - .subscribe(board => { - this.board = board; - }); + this._scrumboardService.onBoardChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(board => { + this.board = board; + }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.onBoardChanged.unsubscribe(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - cardLabelsChanged() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Card labels changed + */ + cardLabelsChanged(): void { this.onCardLabelsChange.next(); } - onLabelChange() + /** + * On label change + */ + onLabelChange(): void { - this.scrumboardService.updateBoard(); + this._scrumboardService.updateBoard(); } - addNewLabel() + /** + * Add new label + */ + addNewLabel(): void { this.newLabel.id = FuseUtils.generateGUID(); this.board.labels.push(Object.assign({}, this.newLabel)); diff --git a/src/app/main/apps/scrumboard/board/edit-board-name/edit-board-name.component.ts b/src/app/main/apps/scrumboard/board/edit-board-name/edit-board-name.component.ts index 68f67b92..66ab3c71 100644 --- a/src/app/main/apps/scrumboard/board/edit-board-name/edit-board-name.component.ts +++ b/src/app/main/apps/scrumboard/board/edit-board-name/edit-board-name.component.ts @@ -2,25 +2,41 @@ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core import { FormBuilder, FormGroup } from '@angular/forms'; @Component({ - selector : 'fuse-scrumboard-edit-board-name', + selector : 'scrumboard-edit-board-name', templateUrl: './edit-board-name.component.html', styleUrls : ['./edit-board-name.component.scss'] }) -export class FuseScrumboardEditBoardNameComponent +export class ScrumboardEditBoardNameComponent { - formActive = false; + formActive: boolean; form: FormGroup; - @Input() board; - @Output() onNameChanged = new EventEmitter(); - @ViewChild('nameInput') nameInputField; + + @Input() + board; + + @Output() + onNameChanged: EventEmitter; + + @ViewChild('nameInput') + nameInputField; constructor( private formBuilder: FormBuilder ) { + // Set the defaults + this.formActive = false; + this.onNameChanged = new EventEmitter(); } - openForm() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Open form + */ + openForm(): void { this.form = this.formBuilder.group({ name: [this.board.name] @@ -29,19 +45,28 @@ export class FuseScrumboardEditBoardNameComponent this.focusNameField(); } - closeForm() + /** + * Close form + */ + closeForm(): void { this.formActive = false; } - focusNameField() + /** + * Focus to the name field + */ + focusNameField(): void { setTimeout(() => { this.nameInputField.nativeElement.focus(); }); } - onFormSubmit() + /** + * On form submit + */ + onFormSubmit(): void { if ( this.form.valid ) { @@ -52,5 +77,4 @@ export class FuseScrumboardEditBoardNameComponent this.formActive = false; } } - } diff --git a/src/app/main/apps/scrumboard/board/list/add-card/add-card.component.ts b/src/app/main/apps/scrumboard/board/list/add-card/add-card.component.ts index e3381072..4a2268d3 100644 --- a/src/app/main/apps/scrumboard/board/list/add-card/add-card.component.ts +++ b/src/app/main/apps/scrumboard/board/list/add-card/add-card.component.ts @@ -2,45 +2,73 @@ import { Component, EventEmitter, Output, ViewChild } from '@angular/core'; import { FormBuilder, FormGroup } from '@angular/forms'; @Component({ - selector : 'fuse-scrumboard-board-add-card', + selector : 'scrumboard-board-add-card', templateUrl: './add-card.component.html', styleUrls : ['./add-card.component.scss'] }) -export class FuseScrumboardBoardAddCardComponent +export class ScrumboardBoardAddCardComponent { - formActive = false; + formActive: boolean; form: FormGroup; - @Output() onCardAdd = new EventEmitter(); - @ViewChild('nameInput') nameInputField; + @Output() + onCardAdd: EventEmitter; + + @ViewChild('nameInput') + nameInputField; + + /** + * Constructor + * + * @param {FormBuilder} _formBuilder + */ constructor( - private formBuilder: FormBuilder + private _formBuilder: FormBuilder ) { + // Set the defaults + this.formActive = false; + this.onCardAdd = new EventEmitter(); } - - openForm() + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Open the form + */ + openForm(): void { - this.form = this.formBuilder.group({ + this.form = this._formBuilder.group({ name: '' }); this.formActive = true; this.focusNameField(); } - closeForm() + /** + * Close the form + */ + closeForm(): void { this.formActive = false; } - focusNameField() + /** + * Focus to the name field + */ + focusNameField(): void { setTimeout(() => { this.nameInputField.nativeElement.focus(); }); } - onFormSubmit() + /** + * On form submit + */ + onFormSubmit(): void { if ( this.form.valid ) { diff --git a/src/app/main/apps/scrumboard/board/list/card/card.component.ts b/src/app/main/apps/scrumboard/board/list/card/card.component.ts index 9ec11bd9..0c47bf23 100644 --- a/src/app/main/apps/scrumboard/board/list/card/card.component.ts +++ b/src/app/main/apps/scrumboard/board/list/card/card.component.ts @@ -3,40 +3,57 @@ import { ActivatedRoute } from '@angular/router'; import * as moment from 'moment'; @Component({ - selector : 'fuse-scrumboard-board-card', + selector : 'scrumboard-board-card', templateUrl : './card.component.html', styleUrls : ['./card.component.scss'], encapsulation: ViewEncapsulation.None }) -export class FuseScrumboardBoardCardComponent implements OnInit +export class ScrumboardBoardCardComponent implements OnInit { - @Input() cardId; + @Input() + cardId; + card: any; board: any; + /** + * Constructor + * + * @param {ActivatedRoute} _activatedRoute + */ constructor( - private route: ActivatedRoute, + private _activatedRoute: ActivatedRoute ) { } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.board = this.route.snapshot.data.board; + this.board = this._activatedRoute.snapshot.data.board; this.card = this.board.cards.filter((card) => { return this.cardId === card.id; })[0]; } + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + /** * Is the card overdue? * * @param cardDate * @returns {boolean} */ - isOverdue(cardDate) + isOverdue(cardDate): boolean { return moment() > moment(new Date(cardDate)); } - } diff --git a/src/app/main/apps/scrumboard/board/list/edit-list-name/edit-list-name.component.ts b/src/app/main/apps/scrumboard/board/list/edit-list-name/edit-list-name.component.ts index 56591cb1..55cf831d 100644 --- a/src/app/main/apps/scrumboard/board/list/edit-list-name/edit-list-name.component.ts +++ b/src/app/main/apps/scrumboard/board/list/edit-list-name/edit-list-name.component.ts @@ -2,46 +2,76 @@ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core import { FormBuilder, FormGroup } from '@angular/forms'; @Component({ - selector : 'fuse-scrumboard-board-edit-list-name', + selector : 'scrumboard-board-edit-list-name', templateUrl: './edit-list-name.component.html', styleUrls : ['./edit-list-name.component.scss'] }) -export class FuseScrumboardBoardEditListNameComponent +export class ScrumboardBoardEditListNameComponent { - formActive = false; + formActive: boolean; form: FormGroup; - @Input() list; - @Output() onNameChanged = new EventEmitter(); - @ViewChild('nameInput') nameInputField; + @Input() + list; + + @Output() + onNameChanged: EventEmitter; + + @ViewChild('nameInput') + nameInputField; + + /** + * Constructor + * + * @param {FormBuilder} _formBuilder + */ constructor( - private formBuilder: FormBuilder + private _formBuilder: FormBuilder ) { + // Set the defaults + this.formActive = false; + this.onNameChanged = new EventEmitter(); } - openForm() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Open the form + */ + openForm(): void { - this.form = this.formBuilder.group({ + this.form = this._formBuilder.group({ name: [this.list.name] }); this.formActive = true; this.focusNameField(); } - closeForm() + /** + * Close the form + */ + closeForm(): void { this.formActive = false; } - focusNameField() + /** + * Focus to the name field + */ + focusNameField(): void { setTimeout(() => { this.nameInputField.nativeElement.focus(); }); } - onFormSubmit() + /** + * On form submit + */ + onFormSubmit(): void { if ( this.form.valid ) { @@ -50,5 +80,4 @@ export class FuseScrumboardBoardEditListNameComponent this.formActive = false; } } - } diff --git a/src/app/main/apps/scrumboard/board/list/list.component.html b/src/app/main/apps/scrumboard/board/list/list.component.html index 2899c33c..33324778 100644 --- a/src/app/main/apps/scrumboard/board/list/list.component.html +++ b/src/app/main/apps/scrumboard/board/list/list.component.html @@ -3,11 +3,11 @@
- - +
diff --git a/src/app/main/apps/scrumboard/board/list/list.component.ts b/src/app/main/apps/scrumboard/board/list/list.component.ts index d90ecc5e..15093f75 100644 --- a/src/app/main/apps/scrumboard/board/list/list.component.ts +++ b/src/app/main/apps/scrumboard/board/list/list.component.ts @@ -1,78 +1,122 @@ import { Component, Input, OnDestroy, OnInit, ViewChild, ViewEncapsulation } from '@angular/core'; import { ActivatedRoute } from '@angular/router'; import { MatDialog, MatDialogRef } from '@angular/material'; - -import { Subscription } from 'rxjs'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { FuseConfirmDialogComponent } from '@fuse/components/confirm-dialog/confirm-dialog.component'; import { FusePerfectScrollbarDirective } from '@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive'; -import { Card } from '../../card.model'; -import { ScrumboardService } from '../../scrumboard.service'; -import { FuseScrumboardCardDialogComponent } from '../dialogs/card/card.component'; +import { ScrumboardService } from 'app/main/apps/scrumboard/scrumboard.service'; +import { Card } from 'app/main/apps/scrumboard/card.model'; +import { ScrumboardCardDialogComponent } from 'app/main/apps/scrumboard/board/dialogs/card/card.component'; @Component({ - selector : 'fuse-scrumboard-board-list', + selector : 'scrumboard-board-list', templateUrl : './list.component.html', styleUrls : ['./list.component.scss'], encapsulation: ViewEncapsulation.None }) -export class FuseScrumboardBoardListComponent implements OnInit, OnDestroy +export class ScrumboardBoardListComponent implements OnInit, OnDestroy { board: any; dialogRef: any; - @Input() list; - @ViewChild(FusePerfectScrollbarDirective) listScroll: FusePerfectScrollbarDirective; + @Input() + list; + + @ViewChild(FusePerfectScrollbarDirective) + listScroll: FusePerfectScrollbarDirective; - onBoardChanged: Subscription; confirmDialogRef: MatDialogRef; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ActivatedRoute} _activatedRoute + * @param {ScrumboardService} _scrumboardService + * @param {MatDialog} _matDialog + */ constructor( - private route: ActivatedRoute, - private scrumboardService: ScrumboardService, - public dialog: MatDialog + private _activatedRoute: ActivatedRoute, + private _scrumboardService: ScrumboardService, + private _matDialog: MatDialog ) { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.onBoardChanged = - this.scrumboardService.onBoardChanged - .subscribe(board => { - this.board = board; - }); + this._scrumboardService.onBoardChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(board => { + this.board = board; + }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.onBoardChanged.unsubscribe(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - onListNameChanged(newListName) + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On list name changed + * + * @param newListName + */ + onListNameChanged(newListName): void { this.list.name = newListName; } - onCardAdd(newCardName) + /** + * On card added + * + * @param newCardName + */ + onCardAdd(newCardName): void { if ( newCardName === '' ) { return; } - this.scrumboardService.addCard(this.list.id, new Card({name: newCardName})); + this._scrumboardService.addCard(this.list.id, new Card({name: newCardName})); setTimeout(() => { this.listScroll.scrollToBottom(0, 400); }); - } - removeList(listId) + /** + * Remove list + * + * @param listId + */ + removeList(listId): void { - this.confirmDialogRef = this.dialog.open(FuseConfirmDialogComponent, { + this.confirmDialogRef = this._matDialog.open(FuseConfirmDialogComponent, { disableClose: false }); @@ -81,14 +125,19 @@ export class FuseScrumboardBoardListComponent implements OnInit, OnDestroy this.confirmDialogRef.afterClosed().subscribe(result => { if ( result ) { - this.scrumboardService.removeList(listId); + this._scrumboardService.removeList(listId); } }); } - openCardDialog(cardId) + /** + * Open card dialog + * + * @param cardId + */ + openCardDialog(cardId): void { - this.dialogRef = this.dialog.open(FuseScrumboardCardDialogComponent, { + this.dialogRef = this._matDialog.open(ScrumboardCardDialogComponent, { panelClass: 'scrumboard-card-dialog', data : { cardId: cardId, @@ -101,8 +150,13 @@ export class FuseScrumboardBoardListComponent implements OnInit, OnDestroy }); } - onDrop(ev) + /** + * On drop + * + * @param ev + */ + onDrop(ev): void { - this.scrumboardService.updateBoard(); + this._scrumboardService.updateBoard(); } } diff --git a/src/app/main/apps/scrumboard/board/sidenavs/settings/board-color-selector/board-color-selector.component.ts b/src/app/main/apps/scrumboard/board/sidenavs/settings/board-color-selector/board-color-selector.component.ts index f5f0f0f6..239ee075 100644 --- a/src/app/main/apps/scrumboard/board/sidenavs/settings/board-color-selector/board-color-selector.component.ts +++ b/src/app/main/apps/scrumboard/board/sidenavs/settings/board-color-selector/board-color-selector.component.ts @@ -1,46 +1,78 @@ import { Component, OnDestroy, OnInit } from '@angular/core'; - -import { Subscription } from 'rxjs'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; import { MatColors } from '@fuse/mat-colors'; -import { ScrumboardService } from '../../../../scrumboard.service'; +import { ScrumboardService } from 'app/main/apps/scrumboard/scrumboard.service'; @Component({ - selector : 'fuse-scrumboard-board-color-selector', + selector : 'scrumboard-board-color-selector', templateUrl: './board-color-selector.component.html', styleUrls : ['./board-color-selector.component.scss'] }) -export class FuseScrumboardBoardColorSelectorComponent implements OnInit, OnDestroy +export class ScrumboardBoardColorSelectorComponent implements OnInit, OnDestroy { colors: any; board: any; - onBoardChanged: Subscription; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ScrumboardService} _scrumboardService + */ constructor( - private scrumboardService: ScrumboardService + private _scrumboardService: ScrumboardService ) { + // Set the defaults this.colors = MatColors.all; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.onBoardChanged = - this.scrumboardService.onBoardChanged - .subscribe(board => { - this.board = board; - }); + this._scrumboardService.onBoardChanged + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(board => { + this.board = board; + }); } - ngOnDestroy() + /** + * On destroy + */ + ngOnDestroy(): void { - this.onBoardChanged.unsubscribe(); + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } - setColor(color) + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Set the color + * + * @param color + */ + setColor(color): void { this.board.settings.color = color; - this.scrumboardService.updateBoard(); + this._scrumboardService.updateBoard(); } } diff --git a/src/app/main/apps/scrumboard/board/sidenavs/settings/settings.component.html b/src/app/main/apps/scrumboard/board/sidenavs/settings/settings.component.html index e407b7ec..effbb249 100644 --- a/src/app/main/apps/scrumboard/board/sidenavs/settings/settings.component.html +++ b/src/app/main/apps/scrumboard/board/sidenavs/settings/settings.component.html @@ -28,7 +28,7 @@
diff --git a/src/app/main/components/angular-material/angular-material.component.ts b/src/app/main/components/angular-material/angular-material.component.ts index 6f511c5a..4e56c1f2 100644 --- a/src/app/main/components/angular-material/angular-material.component.ts +++ b/src/app/main/components/angular-material/angular-material.component.ts @@ -1,33 +1,60 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { ActivatedRoute } from '@angular/router'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; -import { COMPONENT_MAP } from './example-components'; +import { COMPONENT_MAP } from 'app/main/components/angular-material/example-components'; @Component({ - selector : 'fuse-angular-material', + selector : 'angular-material', templateUrl: './angular-material.component.html', styleUrls : ['./angular-material.component.scss'] }) -export class FuseAngularMaterialComponent implements OnInit +export class AngularMaterialComponent implements OnInit, OnDestroy { id: string; title: string; examples: any; + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {ActivatedRoute} _activatedRoute + */ constructor( - private route: ActivatedRoute + private _activatedRoute: ActivatedRoute ) { + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + /** + * On init + */ + ngOnInit(): void { - this.route.params.subscribe(params => { - this.id = params['id']; - const _title = this.id.replace('-', ' '); - this.title = _title.charAt(0).toUpperCase() + _title.substring(1); - this.examples = COMPONENT_MAP[this.id]; - }); + this._activatedRoute.params + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(params => { + this.id = params['id']; + const _title = this.id.replace('-', ' '); + this.title = _title.charAt(0).toUpperCase() + _title.substring(1); + this.examples = COMPONENT_MAP[this.id]; + }); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } } diff --git a/src/app/main/components/angular-material/angular-material.module.ts b/src/app/main/components/angular-material/angular-material.module.ts index 2d7420d3..c82a0729 100644 --- a/src/app/main/components/angular-material/angular-material.module.ts +++ b/src/app/main/components/angular-material/angular-material.module.ts @@ -7,8 +7,8 @@ import { FuseWidgetModule } from '@fuse/components/widget/widget.module'; import { MaterialModule } from 'app/main/components/angular-material/material.module'; import { EXAMPLE_LIST } from 'app/main/components/angular-material/example-components'; -import { FuseAngularMaterialComponent } from 'app/main/components/angular-material/angular-material.component'; -import { FuseExampleViewerComponent } from 'app/main/components/angular-material/example-viewer/example-viewer'; +import { AngularMaterialComponent } from 'app/main/components/angular-material/angular-material.component'; +import { ExampleViewerComponent } from 'app/main/components/angular-material/example-viewer/example-viewer'; const routes: Routes = [ { @@ -16,7 +16,7 @@ const routes: Routes = [ children: [ { path : ':id', - component: FuseAngularMaterialComponent + component: AngularMaterialComponent } ] } @@ -25,8 +25,8 @@ const routes: Routes = [ @NgModule({ declarations : [ [...EXAMPLE_LIST], - FuseAngularMaterialComponent, - FuseExampleViewerComponent + AngularMaterialComponent, + ExampleViewerComponent ], imports : [ RouterModule.forChild(routes), @@ -39,7 +39,7 @@ const routes: Routes = [ ], entryComponents: EXAMPLE_LIST, }) -export class FuseAngularMaterialModule +export class AngularMaterialModule { } diff --git a/src/app/main/components/angular-material/example-viewer/example-viewer.scss b/src/app/main/components/angular-material/example-viewer/example-viewer.scss index 90324b70..244aed9c 100644 --- a/src/app/main/components/angular-material/example-viewer/example-viewer.scss +++ b/src/app/main/components/angular-material/example-viewer/example-viewer.scss @@ -1,6 +1,6 @@ @import "src/@fuse/scss/fuse"; -fuse-example-viewer { +example-viewer { display: block; padding: 24px 0; diff --git a/src/app/main/components/angular-material/example-viewer/example-viewer.ts b/src/app/main/components/angular-material/example-viewer/example-viewer.ts index 1ba7cda1..8bbfac1c 100644 --- a/src/app/main/components/angular-material/example-viewer/example-viewer.ts +++ b/src/app/main/components/angular-material/example-viewer/example-viewer.ts @@ -1,14 +1,13 @@ import { AfterViewInit, Component, ComponentFactoryResolver, ComponentRef, Input, OnDestroy, ViewChild, ViewContainerRef, ViewEncapsulation } from '@angular/core'; import { MatSnackBar } from '@angular/material'; - import 'prismjs/components/prism-scss'; import 'prismjs/components/prism-typescript'; -import { EXAMPLE_COMPONENTS } from '../example-components'; - import { fuseAnimations } from '@fuse/animations'; import { FuseCopierService } from '@fuse/services/copier.service'; +import { EXAMPLE_COMPONENTS } from 'app/main/components/angular-material/example-components'; + export interface LiveExample { title: string; @@ -18,65 +17,65 @@ export interface LiveExample } @Component({ - selector : 'fuse-example-viewer', + selector : 'example-viewer', templateUrl : './example-viewer.html', styleUrls : ['./example-viewer.scss'], encapsulation: ViewEncapsulation.None, animations : fuseAnimations }) -export class FuseExampleViewerComponent implements AfterViewInit, OnDestroy +export class ExampleViewerComponent implements AfterViewInit, OnDestroy { + _example: string; + exampleData: LiveExample; + showSource: boolean; previewRef: ComponentRef; - selectedIndex = 0; + selectedIndex: number; + + @ViewChild('previewContainer', {read: ViewContainerRef}) + private _previewContainer: ViewContainerRef; + + /** + * Constructor + * + * @param {MatSnackBar} _matSnackBar + * @param {FuseCopierService} _fuseCopierService + * @param {ComponentFactoryResolver} _componentFactoryResolver + */ + constructor( + private _matSnackBar: MatSnackBar, + private _fuseCopierService: FuseCopierService, + private _componentFactoryResolver: ComponentFactoryResolver + ) + { + // Set the defaults + this.selectedIndex = 0; + this.showSource = false; + } + + // ----------------------------------------------------------------------------------------------------- + // @ Accessors + // ----------------------------------------------------------------------------------------------------- + + /** + * Container + * + * @param {ViewContainerRef} value + */ + set container(value: ViewContainerRef) + { + this._previewContainer = value; + } get container(): ViewContainerRef { return this._previewContainer; } - set container(value: ViewContainerRef) - { - this._previewContainer = value; - } - - @ViewChild('previewContainer', {read: ViewContainerRef}) private _previewContainer: ViewContainerRef; - - /** String key of the currently displayed example. */ - _example: string; - exampleData: LiveExample; - - /** Whether the source for the example is being displayed. */ - showSource = false; - - constructor( - private snackbar: MatSnackBar, - private copier: FuseCopierService, - private _resolver: ComponentFactoryResolver - ) - { - } - - ngAfterViewInit() - { - setTimeout(() => { - const cmpFactory = this._resolver.resolveComponentFactory(this.exampleData.component); - this.previewRef = this._previewContainer.createComponent(cmpFactory); - }, 0); - } - - ngOnDestroy() - { - if ( this.previewRef ) - { - this.previewRef.destroy(); - } - } - - get example() - { - return this._example; - } - + /** + * Example + * + * @param {string} example + */ @Input() set example(example: string) { @@ -91,20 +90,63 @@ export class FuseExampleViewerComponent implements AfterViewInit, OnDestroy } } + get example(): string + { + return this._example; + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * After view init + */ + ngAfterViewInit(): void + { + setTimeout(() => { + const cmpFactory = this._componentFactoryResolver.resolveComponentFactory(this.exampleData.component); + this.previewRef = this._previewContainer.createComponent(cmpFactory); + }, 0); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + if ( this.previewRef ) + { + this.previewRef.destroy(); + } + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Toggle source view + */ toggleSourceView(): void { this.showSource = !this.showSource; } - copySource(text: string) + /** + * Copy the source + * + * @param {string} text + */ + copySource(text: string): void { - if ( this.copier.copyText(text) ) + if ( this._fuseCopierService.copyText(text) ) { - this.snackbar.open('Code copied', '', {duration: 2500}); + this._matSnackBar.open('Code copied', '', {duration: 2500}); } else { - this.snackbar.open('Copy failed. Please try again!', '', {duration: 2500}); + this._matSnackBar.open('Copy failed. Please try again!', '', {duration: 2500}); } } } diff --git a/src/app/main/components/cards/cards.component.ts b/src/app/main/components/cards/cards.component.ts index 4fe7bd7b..4f0578b9 100644 --- a/src/app/main/components/cards/cards.component.ts +++ b/src/app/main/components/cards/cards.component.ts @@ -4,206 +4,213 @@ import * as shape from 'd3-shape'; import { fuseAnimations } from '@fuse/animations'; @Component({ - selector : 'fuse-cards-docs', + selector : 'cards-docs', templateUrl: './cards.component.html', styleUrls : ['./cards.component.scss'], animations : fuseAnimations }) -export class FuseCardsDocsComponent +export class CardsDocsComponent { - view = 'preview'; - - // Card 9 - card9Expanded = false; - - // Card 10 - card10Expanded = false; - - // Card 19 - card19 = { - scheme: { - domain: ['#5c84f1'] - }, - data : [ - { - 'name' : 'GOOG', - 'series': [ - { - 'name' : 'Jan 1', - 'value': 540.2 - }, - { - 'name' : 'Jan 2', - 'value': 539.4 - }, - { - 'name' : 'Jan 3', - 'value': 538.9 - }, - { - 'name' : 'Jan 4', - 'value': 539.6 - }, - { - 'name' : 'Jan 5', - 'value': 540 - }, - { - 'name' : 'Jan 6', - 'value': 540.2 - }, - { - 'name' : 'Jan 7', - 'value': 540.48 - } - ] - } - ], - curve : shape.curveBasis - }; - - // Card 24 - card24 = { - scheme : { - domain: ['#4867d2', '#5c84f1', '#89a9f4'] - }, - devices: [ - { - 'name' : 'Desktop', - 'value' : 92.8, - 'change': -0.6 - }, - { - 'name' : 'Mobile', - 'value' : 6.1, - 'change': 0.7 - }, - { - 'name' : 'Tablet', - 'value' : 1.1, - 'change': 0.1 - } - ] - }; - - // Card 25 - card25 = { - scheme: { - domain: ['#5c84f1'] - }, - data : [ - { - 'name' : 'Monday', - 'value': 221 - }, - { - 'name' : 'Tuesday', - 'value': 428 - }, - { - 'name' : 'Wednesday', - 'value': 492 - }, - { - 'name' : 'Thursday', - 'value': 471 - }, - { - 'name' : 'Friday', - 'value': 413 - }, - { - 'name' : 'Saturday', - 'value': 344 - }, - { - 'name' : 'Sunday', - 'value': 294 - } - ] - }; - - // Card 26 - card26 = { - scheme: { - domain: ['#5c84f1'] - }, - data : [ - { - 'name' : 'Impressions', - 'series': [ - { - 'name' : 'Jan 1', - 'value': 670000 - }, - { - 'name' : 'Jan 2', - 'value': 540000 - }, - { - 'name' : 'Jan 3', - 'value': 820000 - }, - { - 'name' : 'Jan 4', - 'value': 570000 - }, - { - 'name' : 'Jan 5', - 'value': 720000 - }, - { - 'name' : 'Jan 6', - 'value': 570000 - }, - { - 'name' : 'Jan 7', - 'value': 870000 - }, - { - 'name' : 'Jan 8', - 'value': 720000 - }, - { - 'name' : 'Jan 9', - 'value': 890000 - }, - { - 'name' : 'Jan 10', - 'value': 987000 - }, - { - 'name' : 'Jan 11', - 'value': 1120000 - }, - { - 'name' : 'Jan 12', - 'value': 1360000 - }, - { - 'name' : 'Jan 13', - 'value': 1100000 - }, - { - 'name' : 'Jan 14', - 'value': 1490000 - }, - { - 'name' : 'Jan 15', - 'value': 980000 - } - ] - } - ], - curve : shape.curveBasis - }; + view: string; + card9Expanded: boolean; + card10Expanded: boolean; + card19: any; + card24: any; + card25: any; + card26: any; constructor() { + // Set the defaults + this.view = 'preview'; + + this.card9Expanded = false; + this.card10Expanded = false; + this.card19 = { + scheme: { + domain: ['#5c84f1'] + }, + data : [ + { + 'name' : 'GOOG', + 'series': [ + { + 'name' : 'Jan 1', + 'value': 540.2 + }, + { + 'name' : 'Jan 2', + 'value': 539.4 + }, + { + 'name' : 'Jan 3', + 'value': 538.9 + }, + { + 'name' : 'Jan 4', + 'value': 539.6 + }, + { + 'name' : 'Jan 5', + 'value': 540 + }, + { + 'name' : 'Jan 6', + 'value': 540.2 + }, + { + 'name' : 'Jan 7', + 'value': 540.48 + } + ] + } + ], + curve : shape.curveBasis + }; + + this.card24 = { + scheme : { + domain: ['#4867d2', '#5c84f1', '#89a9f4'] + }, + devices: [ + { + 'name' : 'Desktop', + 'value' : 92.8, + 'change': -0.6 + }, + { + 'name' : 'Mobile', + 'value' : 6.1, + 'change': 0.7 + }, + { + 'name' : 'Tablet', + 'value' : 1.1, + 'change': 0.1 + } + ] + }; + + this.card25 = { + scheme: { + domain: ['#5c84f1'] + }, + data : [ + { + 'name' : 'Monday', + 'value': 221 + }, + { + 'name' : 'Tuesday', + 'value': 428 + }, + { + 'name' : 'Wednesday', + 'value': 492 + }, + { + 'name' : 'Thursday', + 'value': 471 + }, + { + 'name' : 'Friday', + 'value': 413 + }, + { + 'name' : 'Saturday', + 'value': 344 + }, + { + 'name' : 'Sunday', + 'value': 294 + } + ] + }; + + this.card26 = { + scheme: { + domain: ['#5c84f1'] + }, + data : [ + { + 'name' : 'Impressions', + 'series': [ + { + 'name' : 'Jan 1', + 'value': 670000 + }, + { + 'name' : 'Jan 2', + 'value': 540000 + }, + { + 'name' : 'Jan 3', + 'value': 820000 + }, + { + 'name' : 'Jan 4', + 'value': 570000 + }, + { + 'name' : 'Jan 5', + 'value': 720000 + }, + { + 'name' : 'Jan 6', + 'value': 570000 + }, + { + 'name' : 'Jan 7', + 'value': 870000 + }, + { + 'name' : 'Jan 8', + 'value': 720000 + }, + { + 'name' : 'Jan 9', + 'value': 890000 + }, + { + 'name' : 'Jan 10', + 'value': 987000 + }, + { + 'name' : 'Jan 11', + 'value': 1120000 + }, + { + 'name' : 'Jan 12', + 'value': 1360000 + }, + { + 'name' : 'Jan 13', + 'value': 1100000 + }, + { + 'name' : 'Jan 14', + 'value': 1490000 + }, + { + 'name' : 'Jan 15', + 'value': 980000 + } + ] + } + ], + curve : shape.curveBasis + }; } - toggleView() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Toggle the view + */ + toggleView(): void { if ( this.view === 'preview' ) { diff --git a/src/app/main/components/components.module.ts b/src/app/main/components/components.module.ts index 89eb62f7..0a53c9a7 100644 --- a/src/app/main/components/components.module.ts +++ b/src/app/main/components/components.module.ts @@ -4,73 +4,74 @@ import { MatButtonModule, MatButtonToggleModule, MatFormFieldModule, MatIconModu import { NgxChartsModule } from '@swimlane/ngx-charts'; import { FuseSharedModule } from '@fuse/shared.module'; + import { FuseCountdownModule, FuseHighlightModule, FuseMaterialColorPickerModule, FuseWidgetModule } from '@fuse/components'; -import { FuseCardsDocsComponent } from 'app/main/components/cards/cards.component'; -import { FuseCountdownDocsComponent } from 'app/main/components/countdown/countdown.component'; -import { FuseHighlightDocsComponent } from 'app/main/components/highlight/highlight.component'; -import { FuseMaterialColorPickerDocsComponent } from 'app/main/components/material-color-picker/material-color-picker.component'; -import { FuseMultiLanguageDocsComponent } from 'app/main/components/multi-language/multi-language.component'; -import { FuseNavigationDocsComponent } from 'app/main/components/navigation/navigation.component'; -import { FuseSearchBarDocsComponent } from 'app/main/components/search-bar/search-bar.component'; -import { FuseSidebarDocsComponent } from 'app/main/components/sidebar/sidebar.component'; -import { FuseShortcutsDocsComponent } from 'app/main/components/shortcuts/shortcuts.component'; -import { FuseWidgetDocsComponent } from 'app/main/components/widget/widget.component'; +import { CardsDocsComponent } from 'app/main/components/cards/cards.component'; +import { CountdownDocsComponent } from 'app/main/components/countdown/countdown.component'; +import { HighlightDocsComponent } from 'app/main/components/highlight/highlight.component'; +import { MaterialColorPickerDocsComponent } from 'app/main/components/material-color-picker/material-color-picker.component'; +import { MultiLanguageDocsComponent } from 'app/main/components/multi-language/multi-language.component'; +import { NavigationDocsComponent } from 'app/main/components/navigation/navigation.component'; +import { SearchBarDocsComponent } from 'app/main/components/search-bar/search-bar.component'; +import { SidebarDocsComponent } from 'app/main/components/sidebar/sidebar.component'; +import { ShortcutsDocsComponent } from 'app/main/components/shortcuts/shortcuts.component'; +import { WidgetDocsComponent } from 'app/main/components/widget/widget.component'; const routes = [ { path : 'cards', - component: FuseCardsDocsComponent + component: CardsDocsComponent }, { path : 'countdown', - component: FuseCountdownDocsComponent + component: CountdownDocsComponent }, { path : 'highlight', - component: FuseHighlightDocsComponent + component: HighlightDocsComponent }, { path : 'material-color-picker', - component: FuseMaterialColorPickerDocsComponent + component: MaterialColorPickerDocsComponent }, { path : 'multi-language', - component: FuseMultiLanguageDocsComponent + component: MultiLanguageDocsComponent }, { path : 'navigation', - component: FuseNavigationDocsComponent + component: NavigationDocsComponent }, { path : 'search-bar', - component: FuseSearchBarDocsComponent + component: SearchBarDocsComponent }, { path : 'sidebar', - component: FuseSidebarDocsComponent + component: SidebarDocsComponent }, { path : 'shortcuts', - component: FuseShortcutsDocsComponent + component: ShortcutsDocsComponent }, { path : 'widget', - component: FuseWidgetDocsComponent + component: WidgetDocsComponent } ]; @NgModule({ declarations: [ - FuseCardsDocsComponent, - FuseCountdownDocsComponent, - FuseHighlightDocsComponent, - FuseMaterialColorPickerDocsComponent, - FuseMultiLanguageDocsComponent, - FuseNavigationDocsComponent, - FuseSearchBarDocsComponent, - FuseSidebarDocsComponent, - FuseShortcutsDocsComponent, - FuseWidgetDocsComponent + CardsDocsComponent, + CountdownDocsComponent, + HighlightDocsComponent, + MaterialColorPickerDocsComponent, + MultiLanguageDocsComponent, + NavigationDocsComponent, + SearchBarDocsComponent, + SidebarDocsComponent, + ShortcutsDocsComponent, + WidgetDocsComponent ], imports : [ RouterModule.forChild(routes), @@ -88,6 +89,7 @@ const routes = [ NgxChartsModule, FuseSharedModule, + FuseCountdownModule, FuseHighlightModule, FuseMaterialColorPickerModule, diff --git a/src/app/main/components/countdown/countdown.component.ts b/src/app/main/components/countdown/countdown.component.ts index 94378858..6c525efa 100644 --- a/src/app/main/components/countdown/countdown.component.ts +++ b/src/app/main/components/countdown/countdown.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-countdown-docs', + selector : 'countdown-docs', templateUrl: './countdown.component.html', styleUrls : ['./countdown.component.scss'] }) -export class FuseCountdownDocsComponent +export class CountdownDocsComponent { + /** + * Constructor + */ constructor() { diff --git a/src/app/main/components/highlight/highlight.component.ts b/src/app/main/components/highlight/highlight.component.ts index 46b3f84e..d78b0004 100644 --- a/src/app/main/components/highlight/highlight.component.ts +++ b/src/app/main/components/highlight/highlight.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-highlight-docs', + selector : 'highlight-docs', templateUrl: './highlight.component.html', styleUrls : ['./highlight.component.scss'] }) -export class FuseHighlightDocsComponent +export class HighlightDocsComponent { + /** + * Constructor + */ constructor() { diff --git a/src/app/main/components/material-color-picker/material-color-picker.component.ts b/src/app/main/components/material-color-picker/material-color-picker.component.ts index cdfdfe5a..11fd9d1d 100644 --- a/src/app/main/components/material-color-picker/material-color-picker.component.ts +++ b/src/app/main/components/material-color-picker/material-color-picker.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-material-color-picker-docs', + selector : 'material-color-picker-docs', templateUrl: './material-color-picker.component.html', styleUrls : ['./material-color-picker.component.scss'] }) -export class FuseMaterialColorPickerDocsComponent +export class MaterialColorPickerDocsComponent { + /** + * Constructor + */ constructor() { diff --git a/src/app/main/components/multi-language/multi-language.component.html b/src/app/main/components/multi-language/multi-language.component.html index 7b7c2f51..5032fe83 100644 --- a/src/app/main/components/multi-language/multi-language.component.html +++ b/src/app/main/components/multi-language/multi-language.component.html @@ -86,7 +86,7 @@ import { locale as turkish } from './i18n/tr'; @Component({ - selector : 'fuse-mail', + selector : 'mail', templateUrl: './mail.component.html', styleUrls : ['./mail.component.scss'] }) diff --git a/src/app/main/components/multi-language/multi-language.component.ts b/src/app/main/components/multi-language/multi-language.component.ts index fc9385a4..f12c82e7 100644 --- a/src/app/main/components/multi-language/multi-language.component.ts +++ b/src/app/main/components/multi-language/multi-language.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-multi-language-docs', + selector : 'multi-language-docs', templateUrl: './multi-language.component.html', styleUrls : ['./multi-language.component.scss'] }) -export class FuseMultiLanguageDocsComponent +export class MultiLanguageDocsComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/components/navigation/navigation.component.ts b/src/app/main/components/navigation/navigation.component.ts index 7a1181f9..2f34bbd1 100644 --- a/src/app/main/components/navigation/navigation.component.ts +++ b/src/app/main/components/navigation/navigation.component.ts @@ -3,21 +3,33 @@ import { Component } from '@angular/core'; import { navigation } from 'app/navigation/navigation'; @Component({ - selector : 'fuse-navigation-docs', + selector : 'navigation-docs', templateUrl: './navigation.component.html', styleUrls : ['./navigation.component.scss'] }) -export class FuseNavigationDocsComponent +export class NavigationDocsComponent { navigation: any; - hidden = false; + hidden: boolean; + /** + * Constructor + */ constructor() { + // Set the defaults this.navigation = navigation; + this.hidden = false; } - showHideCalendarMenuItem() + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Show/hide calendar menu item + */ + showHideCalendarMenuItem(): void { // Get the calendar item from the navigation const calendarNavItem = this.navigation[0].children[1]; @@ -27,7 +39,10 @@ export class FuseNavigationDocsComponent calendarNavItem.hidden = this.hidden; } - updateMailBadge() + /** + * Update mail badge + */ + updateMailBadge(): void { // Get the mail nav item const mailNavItem = this.navigation[0].children[4]; @@ -36,7 +51,10 @@ export class FuseNavigationDocsComponent mailNavItem.badge.title = 35; } - addSubitemToCalendar() + /** + * Add subitem to the calendar + */ + addSubitemToCalendar(): void { // Prepare the new nav item const newNavItem = { @@ -59,7 +77,10 @@ export class FuseNavigationDocsComponent calendarNavItem.children.push(newNavItem); } - addNavItemWithCustomFunction() + /** + * Add a nav item with custom function + */ + addNavItemWithCustomFunction(): void { // Prepare the new nav item const newNavItem = { diff --git a/src/app/main/components/search-bar/search-bar.component.ts b/src/app/main/components/search-bar/search-bar.component.ts index f9856b2e..130f179f 100644 --- a/src/app/main/components/search-bar/search-bar.component.ts +++ b/src/app/main/components/search-bar/search-bar.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-search-bar-docs', + selector : 'search-bar-docs', templateUrl: './search-bar.component.html', styleUrls : ['./search-bar.component.scss'] }) -export class FuseSearchBarDocsComponent +export class SearchBarDocsComponent { + /** + * Constructor + */ constructor() { diff --git a/src/app/main/components/shortcuts/shortcuts.component.ts b/src/app/main/components/shortcuts/shortcuts.component.ts index 69cc9890..d34619a6 100644 --- a/src/app/main/components/shortcuts/shortcuts.component.ts +++ b/src/app/main/components/shortcuts/shortcuts.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-shortcuts-docs', + selector : 'shortcuts-docs', templateUrl: './shortcuts.component.html', styleUrls : ['./shortcuts.component.scss'] }) -export class FuseShortcutsDocsComponent +export class ShortcutsDocsComponent { + /** + * Constructor + */ constructor() { diff --git a/src/app/main/components/sidebar/sidebar.component.ts b/src/app/main/components/sidebar/sidebar.component.ts index ed91b597..0eeda631 100644 --- a/src/app/main/components/sidebar/sidebar.component.ts +++ b/src/app/main/components/sidebar/sidebar.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-sidebar-docs', + selector : 'sidebar-docs', templateUrl: './sidebar.component.html', styleUrls : ['./sidebar.component.scss'] }) -export class FuseSidebarDocsComponent +export class SidebarDocsComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/components/widget/widget.component.ts b/src/app/main/components/widget/widget.component.ts index 3fbb3bd2..b581012e 100644 --- a/src/app/main/components/widget/widget.component.ts +++ b/src/app/main/components/widget/widget.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-widget-docs', + selector : 'widget-docs', templateUrl: './widget.component.html', styleUrls : ['./widget.component.scss'] }) -export class FuseWidgetDocsComponent +export class WidgetDocsComponent { + /** + * Constructor + */ constructor() { diff --git a/src/app/main/pages/authentication/mail-confirm/mail-confirm.component.ts b/src/app/main/pages/authentication/mail-confirm/mail-confirm.component.ts index 56b6788e..35495d64 100644 --- a/src/app/main/pages/authentication/mail-confirm/mail-confirm.component.ts +++ b/src/app/main/pages/authentication/mail-confirm/mail-confirm.component.ts @@ -4,7 +4,7 @@ import { FuseConfigService } from '@fuse/services/config.service'; import { fuseAnimations } from '@fuse/animations'; @Component({ - selector : 'fuse-mail-confirm', + selector : 'mail-confirm', templateUrl: './mail-confirm.component.html', styleUrls : ['./mail-confirm.component.scss'], animations : fuseAnimations diff --git a/src/app/main/pages/errors/404/error-404.component.ts b/src/app/main/pages/errors/404/error-404.component.ts index 3544b2a9..04c0048b 100644 --- a/src/app/main/pages/errors/404/error-404.component.ts +++ b/src/app/main/pages/errors/404/error-404.component.ts @@ -3,7 +3,7 @@ import { Component } from '@angular/core'; import { FuseConfigService } from '@fuse/services/config.service'; @Component({ - selector : 'fuse-error-404', + selector : 'error-404', templateUrl: './error-404.component.html', styleUrls : ['./error-404.component.scss'] }) diff --git a/src/app/main/pages/profile/profile.component.html b/src/app/main/pages/profile/profile.component.html index 8be37f77..35f630bc 100644 --- a/src/app/main/pages/profile/profile.component.html +++ b/src/app/main/pages/profile/profile.component.html @@ -27,7 +27,7 @@ - + diff --git a/src/app/main/pages/profile/profile.module.ts b/src/app/main/pages/profile/profile.module.ts index 6cb704d3..7d0a35fd 100644 --- a/src/app/main/pages/profile/profile.module.ts +++ b/src/app/main/pages/profile/profile.module.ts @@ -6,7 +6,7 @@ import { FuseSharedModule } from '@fuse/shared.module'; import { ProfileService } from 'app/main/pages/profile/profile.service'; import { ProfileComponent } from 'app/main/pages/profile/profile.component'; -import { FuseProfileTimelineComponent } from 'app/main/pages/profile/tabs/timeline/timeline.component'; +import { ProfileTimelineComponent } from 'app/main/pages/profile/tabs/timeline/timeline.component'; import { ProfileAboutComponent } from 'app/main/pages/profile/tabs/about/about.component'; import { ProfilePhotosVideosComponent } from 'app/main/pages/profile/tabs/photos-videos/photos-videos.component'; @@ -24,7 +24,7 @@ const routes = [ @NgModule({ declarations: [ ProfileComponent, - FuseProfileTimelineComponent, + ProfileTimelineComponent, ProfileAboutComponent, ProfilePhotosVideosComponent ], diff --git a/src/app/main/pages/profile/tabs/timeline/timeline.component.ts b/src/app/main/pages/profile/tabs/timeline/timeline.component.ts index 886b24ed..9c905b66 100644 --- a/src/app/main/pages/profile/tabs/timeline/timeline.component.ts +++ b/src/app/main/pages/profile/tabs/timeline/timeline.component.ts @@ -7,12 +7,12 @@ import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; @Component({ - selector : 'fuse-profile-timeline', + selector : 'profile-timeline', templateUrl: './timeline.component.html', styleUrls : ['./timeline.component.scss'], animations : fuseAnimations }) -export class FuseProfileTimelineComponent implements OnInit, OnDestroy +export class ProfileTimelineComponent implements OnInit, OnDestroy { timeline: any; diff --git a/src/app/main/services/config/config.component.ts b/src/app/main/services/config/config.component.ts index 8eea59a5..d2fe116a 100644 --- a/src/app/main/services/config/config.component.ts +++ b/src/app/main/services/config/config.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-config-service-docs', + selector : 'config-service-docs', templateUrl: './config.component.html', styleUrls : ['./config.component.scss'] }) -export class FuseConfigServiceDocsComponent +export class ConfigServiceDocsComponent { + /** + * Constructor + */ constructor() { diff --git a/src/app/main/services/services.module.ts b/src/app/main/services/services.module.ts index 202d3b15..d4a4d036 100644 --- a/src/app/main/services/services.module.ts +++ b/src/app/main/services/services.module.ts @@ -5,24 +5,24 @@ import { MatIconModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseHighlightModule } from '@fuse/components'; -import { FuseConfigServiceDocsComponent } from 'app/main/services/config/config.component'; -import { FuseSplashScreenServiceDocsComponent } from 'app/main/services/splash-screen/splash-screen.component'; +import { ConfigServiceDocsComponent } from 'app/main/services/config/config.component'; +import { SplashScreenServiceDocsComponent } from 'app/main/services/splash-screen/splash-screen.component'; const routes = [ { path : 'config', - component: FuseConfigServiceDocsComponent + component: ConfigServiceDocsComponent }, { path : 'splash-screen', - component: FuseSplashScreenServiceDocsComponent + component: SplashScreenServiceDocsComponent } ]; @NgModule({ declarations: [ - FuseConfigServiceDocsComponent, - FuseSplashScreenServiceDocsComponent + ConfigServiceDocsComponent, + SplashScreenServiceDocsComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/services/splash-screen/splash-screen.component.ts b/src/app/main/services/splash-screen/splash-screen.component.ts index d28b2d01..cefe9e52 100644 --- a/src/app/main/services/splash-screen/splash-screen.component.ts +++ b/src/app/main/services/splash-screen/splash-screen.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-splash-screen-service-docs', + selector : 'splash-screen-service-docs', templateUrl: './splash-screen.component.html', styleUrls : ['./splash-screen.component.scss'] }) -export class FuseSplashScreenServiceDocsComponent +export class SplashScreenServiceDocsComponent { + /** + * Constructor + */ constructor() { diff --git a/src/app/main/ui/colors/colors.component.ts b/src/app/main/ui/colors/colors.component.ts index 65a38fe9..f336f69d 100644 --- a/src/app/main/ui/colors/colors.component.ts +++ b/src/app/main/ui/colors/colors.component.ts @@ -3,28 +3,47 @@ import { Component, OnInit } from '@angular/core'; import { MatColors } from '@fuse/mat-colors'; @Component({ - selector : 'fuse-colors', + selector : 'colors', templateUrl: './colors.component.html', styleUrls : ['./colors.component.scss'] }) -export class FuseColorsComponent +export class ColorsComponent { colors: {}; selectedColor: string; selectedColorDefaultValue: string; + /** + * Constructor + */ constructor() { + // Set the defaults this.colors = MatColors.all; - this.updateSelectedColor('primary'); + this._updateSelectedColor('primary'); } - selectColor(selected) + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Select color + * + * @param selected + */ + selectColor(selected): void { - this.updateSelectedColor(selected.tab.textLabel); + this._updateSelectedColor(selected.tab.textLabel); } - private updateSelectedColor(colorName) + /** + * Update selected color + * + * @param colorName + * @private + */ + private _updateSelectedColor(colorName): void { this.selectedColor = colorName; this.selectedColorDefaultValue = MatColors.getColor(this.selectedColor)[500]; diff --git a/src/app/main/ui/colors/colors.module.ts b/src/app/main/ui/colors/colors.module.ts index 2c8a6379..72f377ae 100644 --- a/src/app/main/ui/colors/colors.module.ts +++ b/src/app/main/ui/colors/colors.module.ts @@ -1,23 +1,22 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; - import { MatButtonModule, MatIconModule, MatTabsModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseDemoModule } from '@fuse/components/demo/demo.module'; -import { FuseColorsComponent } from './colors.component'; +import { ColorsComponent } from 'app/main/ui/colors/colors.component'; const routes: Routes = [ { path : 'colors', - component: FuseColorsComponent + component: ColorsComponent } ]; @NgModule({ declarations: [ - FuseColorsComponent + ColorsComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/ui/forms/forms.component.ts b/src/app/main/ui/forms/forms.component.ts index 297701ed..ca09a013 100644 --- a/src/app/main/ui/forms/forms.component.ts +++ b/src/app/main/ui/forms/forms.component.ts @@ -1,12 +1,14 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { FormBuilder, FormGroup, Validators } from '@angular/forms'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; @Component({ - selector : 'fuse-forms', + selector : 'forms', templateUrl: './forms.component.html', styleUrls : ['./forms.component.scss'] }) -export class FuseFormsComponent implements OnInit +export class FormsComponent implements OnInit, OnDestroy { form: FormGroup; formErrors: any; @@ -27,7 +29,17 @@ export class FuseFormsComponent implements OnInit verticalStepperStep2Errors: any; verticalStepperStep3Errors: any; - constructor(private formBuilder: FormBuilder) + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FormBuilder} _formBuilder + */ + constructor( + private _formBuilder: FormBuilder + ) { // Reactive form errors this.formErrors = { @@ -73,12 +85,22 @@ export class FuseFormsComponent implements OnInit state : {}, postalCode: {} }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { // Reactive Form - this.form = this.formBuilder.group({ + this.form = this._formBuilder.group({ company : [ { value : 'Google', @@ -95,68 +117,99 @@ export class FuseFormsComponent implements OnInit country : ['', Validators.required] }); - this.form.valueChanges.subscribe(() => { - this.onFormValuesChanged(); - }); + this.form.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onFormValuesChanged(); + }); // Horizontal Stepper form steps - this.horizontalStepperStep1 = this.formBuilder.group({ + this.horizontalStepperStep1 = this._formBuilder.group({ firstName: ['', Validators.required], lastName : ['', Validators.required] }); - this.horizontalStepperStep2 = this.formBuilder.group({ + this.horizontalStepperStep2 = this._formBuilder.group({ address: ['', Validators.required] }); - this.horizontalStepperStep3 = this.formBuilder.group({ + this.horizontalStepperStep3 = this._formBuilder.group({ city : ['', Validators.required], state : ['', Validators.required], postalCode: ['', [Validators.required, Validators.maxLength(5)]] }); - this.horizontalStepperStep1.valueChanges.subscribe(() => { - this.onFormValuesChanged(); - }); + this.horizontalStepperStep1.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onFormValuesChanged(); + }); - this.horizontalStepperStep2.valueChanges.subscribe(() => { - this.onFormValuesChanged(); - }); + this.horizontalStepperStep2.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onFormValuesChanged(); + }); - this.horizontalStepperStep3.valueChanges.subscribe(() => { - this.onFormValuesChanged(); - }); + this.horizontalStepperStep3.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onFormValuesChanged(); + }); // Vertical Stepper form stepper - this.verticalStepperStep1 = this.formBuilder.group({ + this.verticalStepperStep1 = this._formBuilder.group({ firstName: ['', Validators.required], lastName : ['', Validators.required] }); - this.verticalStepperStep2 = this.formBuilder.group({ + this.verticalStepperStep2 = this._formBuilder.group({ address: ['', Validators.required] }); - this.verticalStepperStep3 = this.formBuilder.group({ + this.verticalStepperStep3 = this._formBuilder.group({ city : ['', Validators.required], state : ['', Validators.required], postalCode: ['', [Validators.required, Validators.maxLength(5)]] }); - this.verticalStepperStep1.valueChanges.subscribe(() => { - this.onFormValuesChanged(); - }); + this.verticalStepperStep1.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onFormValuesChanged(); + }); - this.verticalStepperStep2.valueChanges.subscribe(() => { - this.onFormValuesChanged(); - }); + this.verticalStepperStep2.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onFormValuesChanged(); + }); - this.verticalStepperStep3.valueChanges.subscribe(() => { - this.onFormValuesChanged(); - }); + this.verticalStepperStep3.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe(() => { + this.onFormValuesChanged(); + }); } - onFormValuesChanged() + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * On form values changed + */ + onFormValuesChanged(): void { for ( const field in this.formErrors ) { @@ -178,12 +231,18 @@ export class FuseFormsComponent implements OnInit } } - finishHorizontalStepper() + /** + * Finish the horizontal stepper + */ + finishHorizontalStepper(): void { alert('You have finished the horizontal stepper!'); } - finishVerticalStepper() + /** + * Finish the vertical stepper + */ + finishVerticalStepper(): void { alert('You have finished the vertical stepper!'); } diff --git a/src/app/main/ui/forms/forms.module.ts b/src/app/main/ui/forms/forms.module.ts index c9fc1d6e..bd667254 100644 --- a/src/app/main/ui/forms/forms.module.ts +++ b/src/app/main/ui/forms/forms.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; - import { MatButtonModule, MatFormFieldModule, MatIconModule, MatInputModule, MatSelectModule, MatStepperModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseFormsComponent } from './forms.component'; +import { FormsComponent } from 'app/main/ui/forms/forms.component'; const routes: Routes = [ { path : 'forms', - component: FuseFormsComponent + component: FormsComponent } ]; @NgModule({ declarations: [ - FuseFormsComponent + FormsComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/ui/helper-classes/helper-classes.component.html b/src/app/main/ui/helper-classes/helper-classes.component.html index 5bd37fc4..a470baa4 100644 --- a/src/app/main/ui/helper-classes/helper-classes.component.html +++ b/src/app/main/ui/helper-classes/helper-classes.component.html @@ -20,13 +20,13 @@ - + - + diff --git a/src/app/main/ui/helper-classes/helper-classes.component.ts b/src/app/main/ui/helper-classes/helper-classes.component.ts index 7372b0a3..036abefb 100644 --- a/src/app/main/ui/helper-classes/helper-classes.component.ts +++ b/src/app/main/ui/helper-classes/helper-classes.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-helper-classes', + selector : 'helper-classes', templateUrl: './helper-classes.component.html', styleUrls : ['./helper-classes.component.scss'] }) -export class FuseHelperClassesComponent +export class HelperClassesComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/helper-classes/helper-classes.module.ts b/src/app/main/ui/helper-classes/helper-classes.module.ts index 31ee6c1f..0b09b802 100644 --- a/src/app/main/ui/helper-classes/helper-classes.module.ts +++ b/src/app/main/ui/helper-classes/helper-classes.module.ts @@ -1,27 +1,26 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; - import { MatIconModule, MatTabsModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseHighlightModule } from '@fuse/components'; -import { FuseHelperClassesComponent } from './helper-classes.component'; -import { FuseHelperClassesPaddingMarginComponent } from './tabs/padding-margin/padding-margin.component'; -import { FuseHelperClassesWidthHeightComponent } from './tabs/width-height/width-height.component'; +import { HelperClassesComponent } from 'app/main/ui/helper-classes/helper-classes.component'; +import { HelperClassesPaddingMarginComponent } from 'app/main/ui/helper-classes/tabs/padding-margin/padding-margin.component'; +import { HelperClassesWidthHeightComponent } from 'app/main/ui/helper-classes/tabs/width-height/width-height.component'; const routes: Routes = [ { path : 'helper-classes', - component: FuseHelperClassesComponent + component: HelperClassesComponent } ]; @NgModule({ declarations: [ - FuseHelperClassesComponent, - FuseHelperClassesPaddingMarginComponent, - FuseHelperClassesWidthHeightComponent + HelperClassesComponent, + HelperClassesPaddingMarginComponent, + HelperClassesWidthHeightComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/ui/helper-classes/tabs/padding-margin/padding-margin.component.ts b/src/app/main/ui/helper-classes/tabs/padding-margin/padding-margin.component.ts index e4a02a32..387c9753 100644 --- a/src/app/main/ui/helper-classes/tabs/padding-margin/padding-margin.component.ts +++ b/src/app/main/ui/helper-classes/tabs/padding-margin/padding-margin.component.ts @@ -1,13 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-helper-classes-padding-margin', + selector : 'helper-classes-padding-margin', templateUrl: './padding-margin.component.html', styleUrls : ['./padding-margin.component.scss'] }) -export class FuseHelperClassesPaddingMarginComponent +export class HelperClassesPaddingMarginComponent { - + /** + * Constructor + */ constructor() { diff --git a/src/app/main/ui/helper-classes/tabs/width-height/width-height.component.ts b/src/app/main/ui/helper-classes/tabs/width-height/width-height.component.ts index fe5b14cf..323b733f 100644 --- a/src/app/main/ui/helper-classes/tabs/width-height/width-height.component.ts +++ b/src/app/main/ui/helper-classes/tabs/width-height/width-height.component.ts @@ -1,13 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-helper-classes-width-height', + selector : 'helper-classes-width-height', templateUrl: './width-height.component.html', styleUrls : ['./width-height.component.scss'] }) -export class FuseHelperClassesWidthHeightComponent +export class HelperClassesWidthHeightComponent { - + /** + * Constructor + */ constructor() { diff --git a/src/app/main/ui/icons/icons.component.ts b/src/app/main/ui/icons/icons.component.ts index 188de0dd..e289964a 100644 --- a/src/app/main/ui/icons/icons.component.ts +++ b/src/app/main/ui/icons/icons.component.ts @@ -1,24 +1,49 @@ -import { Component, OnInit } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { HttpClient } from '@angular/common/http'; +import { takeUntil } from 'rxjs/operators'; +import { Subject } from 'rxjs'; @Component({ - selector : 'fuse-icons', + selector : 'icons', templateUrl: './icons.component.html', styleUrls : ['./icons.component.scss'] }) -export class FuseIconsComponent implements OnInit +export class IconsComponent implements OnInit, OnDestroy { icons: string[]; filteredIcons: string[]; - loading = true; + loading: boolean; - constructor(private http: HttpClient) + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {HttpClient} _httpClient + */ + constructor( + private _httpClient: HttpClient + ) { + // Set the defaults + this.loading = true; + + // Set the private defaults + this._unsubscribeAll = new Subject(); } - ngOnInit() + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void { - this.http.get('api/icons') + this._httpClient.get('api/icons') + .pipe(takeUntil(this._unsubscribeAll)) .subscribe((icons: any) => { this.icons = icons; this.filteredIcons = this.icons; @@ -26,7 +51,26 @@ export class FuseIconsComponent implements OnInit }); } - filterIcons(event) + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Filter icons + * + * @param event + */ + filterIcons(event): void { const value = event.target.value; diff --git a/src/app/main/ui/icons/icons.module.ts b/src/app/main/ui/icons/icons.module.ts index 8e14e039..464185b5 100644 --- a/src/app/main/ui/icons/icons.module.ts +++ b/src/app/main/ui/icons/icons.module.ts @@ -1,22 +1,21 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; - import { MatButtonModule, MatFormFieldModule, MatIconModule, MatInputModule, MatProgressSpinnerModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; -import { FuseIconsComponent } from './icons.component'; +import { IconsComponent } from 'app/main/ui/icons/icons.component'; const routes: Routes = [ { path : 'icons', - component: FuseIconsComponent + component: IconsComponent } ]; @NgModule({ declarations: [ - FuseIconsComponent + IconsComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/ui/page-layouts/blank/blank.component.ts b/src/app/main/ui/page-layouts/blank/blank.component.ts index 9b47592b..cfbf76b0 100644 --- a/src/app/main/ui/page-layouts/blank/blank.component.ts +++ b/src/app/main/ui/page-layouts/blank/blank.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-blank', + selector : 'blank', templateUrl: './blank.component.html', styleUrls : ['./blank.component.scss'] }) -export class FuseBlankComponent +export class BlankComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.ts b/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.ts index 3b886572..f05d08d6 100644 --- a/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.ts +++ b/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-carded-fullwidth-2', + selector : 'carded-fullwidth-2', templateUrl: './fullwidth-2.component.html', styleUrls : ['./fullwidth-2.component.scss'] }) -export class FuseCardedFullWidth2Component +export class CardedFullWidth2Component { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts b/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts index b6862012..7128f849 100644 --- a/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts +++ b/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-carded-fullwidth', + selector : 'carded-fullwidth', templateUrl: './fullwidth.component.html', styleUrls : ['./fullwidth.component.scss'] }) -export class FuseCardedFullWidthComponent +export class CardedFullWidthComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.ts b/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.ts index 8c03df33..e715bb04 100644 --- a/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.ts +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-carded-left-sidenav-2-tabbed', + selector : 'carded-left-sidenav-2-tabbed', templateUrl: './left-sidenav-2-tabbed.component.html', styleUrls : ['./left-sidenav-2-tabbed.component.scss'] }) -export class FuseCardedLeftSidenav2TabbedComponent +export class CardedLeftSidenav2TabbedComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.ts b/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.ts index 2e51b725..6ef5d61a 100644 --- a/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.ts +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-carded-left-sidenav-2', + selector : 'carded-left-sidenav-2', templateUrl: './left-sidenav-2.component.html', styleUrls : ['./left-sidenav-2.component.scss'] }) -export class FuseCardedLeftSidenav2Component +export class CardedLeftSidenav2Component { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.ts b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.ts index 0a44a54a..e1cc2130 100644 --- a/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.ts +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-carded-left-sidenav-tabbed', + selector : 'carded-left-sidenav-tabbed', templateUrl: './left-sidenav-tabbed.component.html', styleUrls : ['./left-sidenav-tabbed.component.scss'] }) -export class FuseCardedLeftSidenavTabbedComponent +export class CardedLeftSidenavTabbedComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.ts b/src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.ts index f92c2514..babe06ef 100644 --- a/src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.ts +++ b/src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-carded-left-sidenav', + selector : 'carded-left-sidenav', templateUrl: './left-sidenav.component.html', styleUrls : ['./left-sidenav.component.scss'] }) -export class FuseCardedLeftSidenavComponent +export class CardedLeftSidenavComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.ts b/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.ts index ceaec07f..83585df2 100644 --- a/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.ts +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-carded-right-sidenav-2-tabbed', + selector : 'carded-right-sidenav-2-tabbed', templateUrl: './right-sidenav-2-tabbed.component.html', styleUrls : ['./right-sidenav-2-tabbed.component.scss'] }) -export class FuseCardedRightSidenav2TabbedComponent +export class CardedRightSidenav2TabbedComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.ts b/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.ts index 001d16f1..8b1c9d9c 100644 --- a/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.ts +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-carded-right-sidenav-2', + selector : 'carded-right-sidenav-2', templateUrl: './right-sidenav-2.component.html', styleUrls : ['./right-sidenav-2.component.scss'] }) -export class FuseCardedRightSidenav2Component +export class CardedRightSidenav2Component { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.ts b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.ts index 371cb1ef..2e5dedfe 100644 --- a/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.ts +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-carded-right-sidenav-tabbed', + selector : 'carded-right-sidenav-tabbed', templateUrl: './right-sidenav-tabbed.component.html', styleUrls : ['./right-sidenav-tabbed.component.scss'] }) -export class FuseCardedRightSidenavTabbedComponent +export class CardedRightSidenavTabbedComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.ts b/src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.ts index abe45083..7ea8b054 100644 --- a/src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.ts +++ b/src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-carded-right-sidenav', + selector : 'carded-right-sidenav', templateUrl: './right-sidenav.component.html', styleUrls : ['./right-sidenav.component.scss'] }) -export class FuseCardedRightSidenavComponent +export class CardedRightSidenavComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/page-layouts.module.ts b/src/app/main/ui/page-layouts/page-layouts.module.ts index f300822f..45041b57 100644 --- a/src/app/main/ui/page-layouts/page-layouts.module.ts +++ b/src/app/main/ui/page-layouts/page-layouts.module.ts @@ -1,131 +1,130 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; - import { MatButtonModule, MatIconModule, MatSidenavModule, MatTabsModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseDemoModule } from '@fuse/components/demo/demo.module'; -import { FuseCardedFullWidthComponent } from './carded/fullwidth/fullwidth.component'; -import { FuseCardedFullWidth2Component } from './carded/fullwidth-2/fullwidth-2.component'; -import { FuseCardedLeftSidenavComponent } from './carded/left-sidenav/left-sidenav.component'; -import { FuseCardedLeftSidenavTabbedComponent } from './carded/left-sidenav-tabbed/left-sidenav-tabbed.component'; -import { FuseCardedLeftSidenav2Component } from './carded/left-sidenav-2/left-sidenav-2.component'; -import { FuseCardedLeftSidenav2TabbedComponent } from './carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component'; -import { FuseCardedRightSidenavComponent } from './carded/right-sidenav/right-sidenav.component'; -import { FuseCardedRightSidenavTabbedComponent } from './carded/right-sidenav-tabbed/right-sidenav-tabbed.component'; -import { FuseCardedRightSidenav2Component } from './carded/right-sidenav-2/right-sidenav-2.component'; -import { FuseCardedRightSidenav2TabbedComponent } from './carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component'; -import { FuseSimpleFullWidthComponent } from './simple/fullwidth/fullwidth.component'; -import { FuseSimpleLeftSidenavComponent } from './simple/left-sidenav/left-sidenav.component'; -import { FuseSimpleLeftSidenav2Component } from './simple/left-sidenav-2/left-sidenav-2.component'; -import { FuseSimpleLeftSidenav3Component } from './simple/left-sidenav-3/left-sidenav-3.component'; -import { FuseSimpleRightSidenavComponent } from './simple/right-sidenav/right-sidenav.component'; -import { FuseSimpleRightSidenav2Component } from './simple/right-sidenav-2/right-sidenav-2.component'; -import { FuseSimpleRightSidenav3Component } from './simple/right-sidenav-3/right-sidenav-3.component'; -import { FuseTabbedComponent } from './simple/tabbed/tabbed.component'; -import { FuseBlankComponent } from './blank/blank.component'; +import { CardedFullWidthComponent } from 'app/main/ui/page-layouts/carded/fullwidth/fullwidth.component'; +import { CardedFullWidth2Component } from 'app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component'; +import { CardedLeftSidenavComponent } from 'app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component'; +import { CardedLeftSidenavTabbedComponent } from 'app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component'; +import { CardedLeftSidenav2Component } from 'app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component'; +import { CardedLeftSidenav2TabbedComponent } from 'app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component'; +import { CardedRightSidenavComponent } from 'app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component'; +import { CardedRightSidenavTabbedComponent } from 'app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component'; +import { CardedRightSidenav2Component } from 'app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component'; +import { CardedRightSidenav2TabbedComponent } from 'app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component'; +import { SimpleFullWidthComponent } from 'app/main/ui/page-layouts/simple/fullwidth/fullwidth.component'; +import { SimpleLeftSidenavComponent } from 'app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component'; +import { SimpleLeftSidenav2Component } from 'app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component'; +import { SimpleLeftSidenav3Component } from 'app/main/ui/page-layouts/simple/left-sidenav-3/left-sidenav-3.component'; +import { SimpleRightSidenavComponent } from 'app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component'; +import { SimpleRightSidenav2Component } from 'app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component'; +import { SimpleRightSidenav3Component } from 'app/main/ui/page-layouts/simple/right-sidenav-3/right-sidenav-3.component'; +import { TabbedComponent } from 'app/main/ui/page-layouts/simple/tabbed/tabbed.component'; +import { BlankComponent } from 'app/main/ui/page-layouts/blank/blank.component'; const routes: Routes = [ { path : 'page-layouts/carded/full-width', - component: FuseCardedFullWidthComponent + component: CardedFullWidthComponent }, { path : 'page-layouts/carded/full-width-2', - component: FuseCardedFullWidth2Component + component: CardedFullWidth2Component }, { path : 'page-layouts/carded/left-sidenav', - component: FuseCardedLeftSidenavComponent + component: CardedLeftSidenavComponent }, { path : 'page-layouts/carded/left-sidenav-tabbed', - component: FuseCardedLeftSidenavTabbedComponent + component: CardedLeftSidenavTabbedComponent }, { path : 'page-layouts/carded/left-sidenav-2', - component: FuseCardedLeftSidenav2Component + component: CardedLeftSidenav2Component }, { path : 'page-layouts/carded/left-sidenav-2-tabbed', - component: FuseCardedLeftSidenav2TabbedComponent + component: CardedLeftSidenav2TabbedComponent }, { path : 'page-layouts/carded/right-sidenav', - component: FuseCardedRightSidenavComponent + component: CardedRightSidenavComponent }, { path : 'page-layouts/carded/right-sidenav-tabbed', - component: FuseCardedRightSidenavTabbedComponent + component: CardedRightSidenavTabbedComponent }, { path : 'page-layouts/carded/right-sidenav-2', - component: FuseCardedRightSidenav2Component + component: CardedRightSidenav2Component }, { path : 'page-layouts/carded/right-sidenav-2-tabbed', - component: FuseCardedRightSidenav2TabbedComponent + component: CardedRightSidenav2TabbedComponent }, { path : 'page-layouts/simple/full-width', - component: FuseSimpleFullWidthComponent + component: SimpleFullWidthComponent }, { path : 'page-layouts/simple/left-sidenav', - component: FuseSimpleLeftSidenavComponent + component: SimpleLeftSidenavComponent }, { path : 'page-layouts/simple/left-sidenav-2', - component: FuseSimpleLeftSidenav2Component + component: SimpleLeftSidenav2Component }, { path : 'page-layouts/simple/left-sidenav-3', - component: FuseSimpleLeftSidenav3Component + component: SimpleLeftSidenav3Component }, { path : 'page-layouts/simple/right-sidenav', - component: FuseSimpleRightSidenavComponent + component: SimpleRightSidenavComponent }, { path : 'page-layouts/simple/right-sidenav-2', - component: FuseSimpleRightSidenav2Component + component: SimpleRightSidenav2Component }, { path : 'page-layouts/simple/right-sidenav-3', - component: FuseSimpleRightSidenav3Component + component: SimpleRightSidenav3Component }, { path : 'page-layouts/simple/tabbed', - component: FuseTabbedComponent + component: TabbedComponent }, { path : 'page-layouts/blank', - component: FuseBlankComponent + component: BlankComponent } ]; @NgModule({ declarations: [ - FuseCardedFullWidthComponent, - FuseCardedFullWidth2Component, - FuseCardedLeftSidenavComponent, - FuseCardedLeftSidenavTabbedComponent, - FuseCardedLeftSidenav2Component, - FuseCardedLeftSidenav2TabbedComponent, - FuseCardedRightSidenavComponent, - FuseCardedRightSidenavTabbedComponent, - FuseCardedRightSidenav2Component, - FuseCardedRightSidenav2TabbedComponent, - FuseSimpleFullWidthComponent, - FuseSimpleLeftSidenavComponent, - FuseSimpleLeftSidenav2Component, - FuseSimpleLeftSidenav3Component, - FuseSimpleRightSidenavComponent, - FuseSimpleRightSidenav2Component, - FuseSimpleRightSidenav3Component, - FuseTabbedComponent, - FuseBlankComponent + CardedFullWidthComponent, + CardedFullWidth2Component, + CardedLeftSidenavComponent, + CardedLeftSidenavTabbedComponent, + CardedLeftSidenav2Component, + CardedLeftSidenav2TabbedComponent, + CardedRightSidenavComponent, + CardedRightSidenavTabbedComponent, + CardedRightSidenav2Component, + CardedRightSidenav2TabbedComponent, + SimpleFullWidthComponent, + SimpleLeftSidenavComponent, + SimpleLeftSidenav2Component, + SimpleLeftSidenav3Component, + SimpleRightSidenavComponent, + SimpleRightSidenav2Component, + SimpleRightSidenav3Component, + TabbedComponent, + BlankComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.ts b/src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.ts index 074ad5d1..d0c7414d 100644 --- a/src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.ts +++ b/src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-simple-fullwidth', + selector : 'simple-fullwidth', templateUrl: './fullwidth.component.html', styleUrls : ['./fullwidth.component.scss'] }) -export class FuseSimpleFullWidthComponent +export class SimpleFullWidthComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.ts b/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.ts index d6805429..3d1b0aa2 100644 --- a/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.ts +++ b/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-simple-left-sidenav-2', + selector : 'simple-left-sidenav-2', templateUrl: './left-sidenav-2.component.html', styleUrls : ['./left-sidenav-2.component.scss'] }) -export class FuseSimpleLeftSidenav2Component +export class SimpleLeftSidenav2Component { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/simple/left-sidenav-3/left-sidenav-3.component.ts b/src/app/main/ui/page-layouts/simple/left-sidenav-3/left-sidenav-3.component.ts index 2a86f582..ad6b586f 100644 --- a/src/app/main/ui/page-layouts/simple/left-sidenav-3/left-sidenav-3.component.ts +++ b/src/app/main/ui/page-layouts/simple/left-sidenav-3/left-sidenav-3.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-simple-left-sidenav-3', + selector : 'simple-left-sidenav-3', templateUrl: './left-sidenav-3.component.html', styleUrls : ['./left-sidenav-3.component.scss'] }) -export class FuseSimpleLeftSidenav3Component +export class SimpleLeftSidenav3Component { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.ts b/src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.ts index 9d07e40b..682b638a 100644 --- a/src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.ts +++ b/src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-simple-left-sidenav', + selector : 'simple-left-sidenav', templateUrl: './left-sidenav.component.html', styleUrls : ['./left-sidenav.component.scss'] }) -export class FuseSimpleLeftSidenavComponent +export class SimpleLeftSidenavComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.ts b/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.ts index 7f32155d..bd43f140 100644 --- a/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.ts +++ b/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-simple-right-sidenav-2', + selector : 'simple-right-sidenav-2', templateUrl: './right-sidenav-2.component.html', styleUrls : ['./right-sidenav-2.component.scss'] }) -export class FuseSimpleRightSidenav2Component +export class SimpleRightSidenav2Component { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav-3/right-sidenav-3.component.ts b/src/app/main/ui/page-layouts/simple/right-sidenav-3/right-sidenav-3.component.ts index bb2b476e..446da2de 100644 --- a/src/app/main/ui/page-layouts/simple/right-sidenav-3/right-sidenav-3.component.ts +++ b/src/app/main/ui/page-layouts/simple/right-sidenav-3/right-sidenav-3.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-simple-right-sidenav-3', + selector : 'simple-right-sidenav-3', templateUrl: './right-sidenav-3.component.html', styleUrls : ['./right-sidenav-3.component.scss'] }) -export class FuseSimpleRightSidenav3Component +export class SimpleRightSidenav3Component { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.ts b/src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.ts index 186cfa71..bd3ab81d 100644 --- a/src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.ts +++ b/src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-simple-right-sidenav', + selector : 'simple-right-sidenav', templateUrl: './right-sidenav.component.html', styleUrls : ['./right-sidenav.component.scss'] }) -export class FuseSimpleRightSidenavComponent +export class SimpleRightSidenavComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.ts b/src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.ts index 70e6cdf1..6e01380f 100644 --- a/src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.ts +++ b/src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-tabbed', + selector : 'tabbed', templateUrl: './tabbed.component.html', styleUrls : ['./tabbed.component.scss'] }) -export class FuseTabbedComponent +export class TabbedComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/typography/tabs/blockquotes-lists/blockquotes-lists.component.ts b/src/app/main/ui/typography/tabs/blockquotes-lists/blockquotes-lists.component.ts index 5ed7aa4d..c3954e51 100644 --- a/src/app/main/ui/typography/tabs/blockquotes-lists/blockquotes-lists.component.ts +++ b/src/app/main/ui/typography/tabs/blockquotes-lists/blockquotes-lists.component.ts @@ -1,13 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-typography-blockquotes-lists', + selector : 'typography-blockquotes-lists', templateUrl: './blockquotes-lists.component.html', styleUrls : ['./blockquotes-lists.component.scss'] }) -export class FuseTypographyBlockquotesListsComponent +export class TypographyBlockquotesListsComponent { - + /** + * Constructor + */ constructor() { diff --git a/src/app/main/ui/typography/tabs/headings/headings.component.ts b/src/app/main/ui/typography/tabs/headings/headings.component.ts index eaee877b..c4cac991 100644 --- a/src/app/main/ui/typography/tabs/headings/headings.component.ts +++ b/src/app/main/ui/typography/tabs/headings/headings.component.ts @@ -1,13 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-typography-headings', + selector : 'typography-headings', templateUrl: './headings.component.html', styleUrls : ['./headings.component.scss'] }) -export class FuseTypographyHeadingsComponent +export class TypographyHeadingsComponent { - + /** + * Constructor + */ constructor() { diff --git a/src/app/main/ui/typography/tabs/helpers/helpers.component.ts b/src/app/main/ui/typography/tabs/helpers/helpers.component.ts index 77a27901..b2867300 100644 --- a/src/app/main/ui/typography/tabs/helpers/helpers.component.ts +++ b/src/app/main/ui/typography/tabs/helpers/helpers.component.ts @@ -1,13 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-typography-helpers', + selector : 'typography-helpers', templateUrl: './helpers.component.html', styleUrls : ['./helpers.component.scss'] }) -export class FuseTypographyHelpersComponent +export class TypographyHelpersComponent { - + /** + * Constructor + */ constructor() { diff --git a/src/app/main/ui/typography/tabs/inline-text-elements/inline-text-elements.component.ts b/src/app/main/ui/typography/tabs/inline-text-elements/inline-text-elements.component.ts index 47e078e9..f5aa289c 100644 --- a/src/app/main/ui/typography/tabs/inline-text-elements/inline-text-elements.component.ts +++ b/src/app/main/ui/typography/tabs/inline-text-elements/inline-text-elements.component.ts @@ -1,13 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-typography-inline-text-elements', + selector : 'typography-inline-text-elements', templateUrl: './inline-text-elements.component.html', styleUrls : ['./inline-text-elements.component.scss'] }) -export class FuseTypographyInlineTextElementsComponent +export class TypographyInlineTextElementsComponent { - + /** + * Constructor + */ constructor() { diff --git a/src/app/main/ui/typography/typography.component.html b/src/app/main/ui/typography/typography.component.html index d20c1f29..7762f434 100644 --- a/src/app/main/ui/typography/typography.component.html +++ b/src/app/main/ui/typography/typography.component.html @@ -20,25 +20,25 @@ - + - + - + - + diff --git a/src/app/main/ui/typography/typography.component.ts b/src/app/main/ui/typography/typography.component.ts index 44e979b7..6c1de786 100644 --- a/src/app/main/ui/typography/typography.component.ts +++ b/src/app/main/ui/typography/typography.component.ts @@ -1,12 +1,15 @@ import { Component } from '@angular/core'; @Component({ - selector : 'fuse-typography', + selector : 'typography', templateUrl: './typography.component.html', styleUrls : ['./typography.component.scss'] }) -export class FuseTypographyComponent +export class TypographyComponent { + /** + * Constructor + */ constructor() { } diff --git a/src/app/main/ui/typography/typography.module.ts b/src/app/main/ui/typography/typography.module.ts index bf4e2321..34ba3129 100644 --- a/src/app/main/ui/typography/typography.module.ts +++ b/src/app/main/ui/typography/typography.module.ts @@ -1,31 +1,30 @@ import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router'; - import { MatIconModule, MatTabsModule } from '@angular/material'; import { FuseSharedModule } from '@fuse/shared.module'; import { FuseHighlightModule } from '@fuse/components'; -import { FuseTypographyComponent } from './typography.component'; -import { FuseTypographyHeadingsComponent } from './tabs/headings/headings.component'; -import { FuseTypographyInlineTextElementsComponent } from './tabs/inline-text-elements/inline-text-elements.component'; -import { FuseTypographyBlockquotesListsComponent } from './tabs/blockquotes-lists/blockquotes-lists.component'; -import { FuseTypographyHelpersComponent } from './tabs/helpers/helpers.component'; +import { TypographyComponent } from 'app/main/ui/typography/typography.component'; +import { TypographyHeadingsComponent } from 'app/main/ui/typography/tabs/headings/headings.component'; +import { TypographyInlineTextElementsComponent } from 'app/main/ui/typography/tabs/inline-text-elements/inline-text-elements.component'; +import { TypographyBlockquotesListsComponent } from 'app/main/ui/typography/tabs/blockquotes-lists/blockquotes-lists.component'; +import { TypographyHelpersComponent } from 'app/main/ui/typography/tabs/helpers/helpers.component'; const routes: Routes = [ { path : 'typography', - component: FuseTypographyComponent + component: TypographyComponent } ]; @NgModule({ declarations: [ - FuseTypographyComponent, - FuseTypographyHeadingsComponent, - FuseTypographyInlineTextElementsComponent, - FuseTypographyBlockquotesListsComponent, - FuseTypographyHelpersComponent + TypographyComponent, + TypographyHeadingsComponent, + TypographyInlineTextElementsComponent, + TypographyBlockquotesListsComponent, + TypographyHelpersComponent ], imports : [ RouterModule.forChild(routes), diff --git a/src/app/main/ui/ui.module.ts b/src/app/main/ui/ui.module.ts index f6798a1c..1d594101 100644 --- a/src/app/main/ui/ui.module.ts +++ b/src/app/main/ui/ui.module.ts @@ -17,6 +17,6 @@ import { UIColorsModule } from 'app/main/ui/colors/colors.module'; UIColorsModule ] }) -export class FuseUIModule +export class UIModule { } diff --git a/src/index.html b/src/index.html index 865a7105..cbb463c6 100644 --- a/src/index.html +++ b/src/index.html @@ -213,7 +213,7 @@ - + From 5d000a849dfe39f8535c8a5d5a82921dd5abfcbd Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Sun, 27 May 2018 16:54:20 +0300 Subject: [PATCH 11/80] Updated couple packages --- package-lock.json | 188 +++++++++++++++++++++++----------------------- package.json | 26 +++---- 2 files changed, 107 insertions(+), 107 deletions(-) diff --git a/package-lock.json b/package-lock.json index 25c63050..e7f6bd3a 100644 --- a/package-lock.json +++ b/package-lock.json @@ -5,30 +5,30 @@ "requires": true, "dependencies": { "@agm/core": { - "version": "1.0.0-beta.2", - "resolved": "https://registry.npmjs.org/@agm/core/-/core-1.0.0-beta.2.tgz", - "integrity": "sha512-3bdfvkWDmJszpj/F6Fzgv7sks0cs/cUEQPfs37tcJFz3jc62SsXy4TGb/WJT8FpH2nSGE6DonP8lXuFxB0lblQ==" + "version": "1.0.0-beta.3", + "resolved": "https://registry.npmjs.org/@agm/core/-/core-1.0.0-beta.3.tgz", + "integrity": "sha512-nsyergarmMB4JCw7KGujj86ulgRYhEk8zXKRiJZdnju/irLvazQ/9Anlfsf1Rc5yph8sZrmQDwqLGZ6AqHhnzA==" }, "@angular-devkit/architect": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/@angular-devkit/architect/-/architect-0.6.3.tgz", - "integrity": "sha512-w9tK3VACU+CnOQQZT6o7QO2brn/OVNDf2Y11rI+ZQH7UIn6N0ZFoMl9WyFB//K2Gkoa7hAobykhRTtP8lrTF1g==", + "version": "0.6.5", + "resolved": "https://registry.npmjs.org/@angular-devkit/architect/-/architect-0.6.5.tgz", + "integrity": "sha512-HlCCnpg301XGbNAycPCadZlSVCOHlFtw2qz2zzNBIWW2Cbi9q3eazWCg/OeD237qgJ8hxvGSkOi7vWG2AoYkIg==", "dev": true, "requires": { - "@angular-devkit/core": "0.6.3", + "@angular-devkit/core": "0.6.5", "rxjs": "^6.0.0" } }, "@angular-devkit/build-angular": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/@angular-devkit/build-angular/-/build-angular-0.6.3.tgz", - "integrity": "sha512-ce+uAXQXyuMy6IxSnsGKeHlLVjsI77DblNvkcO1NilP7iYxujEJx6qDq/Hrf1uhuqRpm+8pt5zY6QD90gQrDcg==", + "version": "0.6.5", + "resolved": "https://registry.npmjs.org/@angular-devkit/build-angular/-/build-angular-0.6.5.tgz", + "integrity": "sha512-+ikh/nntfIgpIV5meunbWKdQQ0nlx/hR94UDo0YwpZjJPScEBrd3i3nhoAw6iTK1PfoGwYXSzZTnTJyQAGMUAg==", "dev": true, "requires": { - "@angular-devkit/architect": "0.6.3", - "@angular-devkit/build-optimizer": "0.6.3", - "@angular-devkit/core": "0.6.3", - "@ngtools/webpack": "6.0.3", + "@angular-devkit/architect": "0.6.5", + "@angular-devkit/build-optimizer": "0.6.5", + "@angular-devkit/core": "0.6.5", + "@ngtools/webpack": "6.0.5", "ajv": "~6.4.0", "autoprefixer": "^8.4.1", "cache-loader": "^1.2.2", @@ -79,9 +79,9 @@ } }, "@angular-devkit/build-optimizer": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/@angular-devkit/build-optimizer/-/build-optimizer-0.6.3.tgz", - "integrity": "sha512-C0LGWh7+rYjpE1T1guaq9EMovwhEJ1QR25qjJxUoYvN+sM+MfVpMhoa6ruqnxh+eQCfRiMdIsnbOboiZxNHTQw==", + "version": "0.6.5", + "resolved": "https://registry.npmjs.org/@angular-devkit/build-optimizer/-/build-optimizer-0.6.5.tgz", + "integrity": "sha512-GXV3XLHvzmXwBRcpaXKiMrAFq0t8VTq9GwsQk9W1diUstlNCnuNSmwj1fpJxR23pPsH+5mvrrfWYdoXt8TWzHw==", "dev": true, "requires": { "loader-utils": "^1.1.0", @@ -91,9 +91,9 @@ } }, "@angular-devkit/core": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/@angular-devkit/core/-/core-0.6.3.tgz", - "integrity": "sha512-97hFVW6in8oYJUEqjmUP0Tb/mPlTG3sc0THpe5MCGEkDPjlp2cObt9rUCAVOjugBlScV8rzTpVQ+95PT60Py8A==", + "version": "0.6.5", + "resolved": "https://registry.npmjs.org/@angular-devkit/core/-/core-0.6.5.tgz", + "integrity": "sha512-DpowzV6ObjVJb6ccElAD5rlqL9BN32ZGspg14YVyXf9mlmcNw3gm+P9BGIhuwJ8rt9fqmse87W59/Z2MLUTVkQ==", "dev": true, "requires": { "ajv": "~6.4.0", @@ -103,12 +103,12 @@ } }, "@angular-devkit/schematics": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/@angular-devkit/schematics/-/schematics-0.6.3.tgz", - "integrity": "sha512-dXlyVNuFRhiOnhAk0NojEUThLrZBpVZmWvEQ4h/pnyHS0P9CfnHqJ8DCcCrjOwYkzdBwBrYchXOCYfo8zuxYGw==", + "version": "0.6.5", + "resolved": "https://registry.npmjs.org/@angular-devkit/schematics/-/schematics-0.6.5.tgz", + "integrity": "sha512-clyw0IBe0i257r35E/BHIYdwERwOwYwLD/PXMCb3bd1thD75S4sxHmLV5NHnn2S32y+mqm12/Q7006XUD/yi1g==", "dev": true, "requires": { - "@angular-devkit/core": "0.6.3", + "@angular-devkit/core": "0.6.5", "rxjs": "^6.0.0" } }, @@ -129,16 +129,16 @@ } }, "@angular/cli": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/@angular/cli/-/cli-6.0.3.tgz", - "integrity": "sha512-G8jfgJublsRjveX1P+F5awHvpC07mKAF7f5lebowIs+QAHSOD6HxQ/JhMbJTwz/aj20iWgZOygA5LhkP0Wr+UQ==", + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/@angular/cli/-/cli-6.0.5.tgz", + "integrity": "sha512-aJXdLe8IELMtAhrEm9bU5bIKXr7E6LkNQXZfdpFuoTnh8S8EYRHD/QO6RhS/IpuRWMnLN2C7hsgRIQr1uBzNlg==", "dev": true, "requires": { - "@angular-devkit/architect": "0.6.3", - "@angular-devkit/core": "0.6.3", - "@angular-devkit/schematics": "0.6.3", - "@schematics/angular": "0.6.3", - "@schematics/update": "0.6.3", + "@angular-devkit/architect": "0.6.5", + "@angular-devkit/core": "0.6.5", + "@angular-devkit/schematics": "0.6.5", + "@schematics/angular": "0.6.5", + "@schematics/update": "0.6.5", "opn": "~5.3.0", "resolve": "^1.1.7", "rxjs": "^6.0.0", @@ -411,32 +411,32 @@ "dev": true }, "@ngrx/effects": { - "version": "6.0.0-beta.3", - "resolved": "https://registry.npmjs.org/@ngrx/effects/-/effects-6.0.0-beta.3.tgz", - "integrity": "sha512-THTjnYUKFxPJCtxaKZepTnwGm0Zn5826qbNIpcTITjfIDXstOufAtb5CGH07zXrfJ8Ipdir/7bPE46kAdU4lkg==" + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@ngrx/effects/-/effects-6.0.1.tgz", + "integrity": "sha512-YS68D7E1qKbbOIzV6Iyfv6BY3CrTNi8nBgGJ6whTi6f7Y0apXySvNj9aOQyzuJsePWziu6h0uJhy2ZFT/iELyg==" }, "@ngrx/router-store": { - "version": "6.0.0-beta.3", - "resolved": "https://registry.npmjs.org/@ngrx/router-store/-/router-store-6.0.0-beta.3.tgz", - "integrity": "sha512-x5Z9G0H/3HTh+1UDceflGhk/2gfzbDTyOg6yhrzxAp9daD7wUPr21Jk+ecw3NqKMvqn3SDQIkWjwPdO756xrYw==" + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@ngrx/router-store/-/router-store-6.0.1.tgz", + "integrity": "sha512-Nz6HI6cGcWZtRP8Z1eWH0jhkmukQYSpH5AptCcXMjOP2MorHv23Ddw1O+0W6hF8SYX1JvGdaQ2BUJS00MaKfKw==" }, "@ngrx/store": { - "version": "6.0.0-beta.3", - "resolved": "https://registry.npmjs.org/@ngrx/store/-/store-6.0.0-beta.3.tgz", - "integrity": "sha512-LOQdv2bt3KsFHEYBcNZdVoRZGSBlHBF9C51siPABSWfAenwrNiOz9Ga/qe4hl3cfM3UoCNIYtdsbZ2N/ZCY5RQ==" + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@ngrx/store/-/store-6.0.1.tgz", + "integrity": "sha512-cSgfT8CgpOr6BOQac9M3DH6QQC5gxCVjdEcZH//Zn/kwdse86X73iK7KWv6B6AiIEdyVbFfggXNZwd/HiyLGOA==" }, "@ngrx/store-devtools": { - "version": "6.0.0-beta.3", - "resolved": "https://registry.npmjs.org/@ngrx/store-devtools/-/store-devtools-6.0.0-beta.3.tgz", - "integrity": "sha512-KwmMELWY+WA1fL/myhQGiqM1uvRIjQ7yUaViVwknhRf7UsBPlWTMrSiFqUIb3QkwGYnVdqRjdYVQrJTIdJpolQ==" + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@ngrx/store-devtools/-/store-devtools-6.0.1.tgz", + "integrity": "sha512-eZyguQvIltJuhCVgPPR1IyMAztykRuvGalwCH1G2ODWKGZPNrWlJbxVMqzUeSJTBS268RIFIkMTwEDKi/xCQoQ==" }, "@ngtools/webpack": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/@ngtools/webpack/-/webpack-6.0.3.tgz", - "integrity": "sha512-wrhSFItcZp4Yzp6lgSuy23YdhaUs9D+KdGZPjwzzXtJIJCSzGkWuXzwlCwyKSFRQ6thyH/T3nffpHNaS3dWn2A==", + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/@ngtools/webpack/-/webpack-6.0.5.tgz", + "integrity": "sha512-bJwsBW9X9mX8nk8JJDyNZuglL8Ym/RQVM1kmLvUztgQSAMnBo046zDWEkjamXxxiTvznwHpwQTVgUzEEVdAQjg==", "dev": true, "requires": { - "@angular-devkit/core": "0.6.3", + "@angular-devkit/core": "0.6.5", "tree-kill": "^1.0.0", "webpack-sources": "^1.1.0" } @@ -450,24 +450,24 @@ } }, "@schematics/angular": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/@schematics/angular/-/angular-0.6.3.tgz", - "integrity": "sha512-YhldE1K6x/8D0PxFusjtB32iOAayyD1PSxPCx/q7I7T6x/lG7l35ZDV6ZZE6bDvIaxQBsjhIm8ACy2n+xwFxTA==", + "version": "0.6.5", + "resolved": "https://registry.npmjs.org/@schematics/angular/-/angular-0.6.5.tgz", + "integrity": "sha512-oB9j+IqVtoSn3kEV6mnBslG8pxaOlUW2Kw7aCVf9DzEqTZEH5awKuPuhRkAVyiXdwHPDn21xoUGVRLy4y/BafA==", "dev": true, "requires": { - "@angular-devkit/core": "0.6.3", - "@angular-devkit/schematics": "0.6.3", + "@angular-devkit/core": "0.6.5", + "@angular-devkit/schematics": "0.6.5", "typescript": ">=2.6.2 <2.8" } }, "@schematics/update": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/@schematics/update/-/update-0.6.3.tgz", - "integrity": "sha512-UsKrg02+jwdsz9BdMVxDMeAZCF+c+dvHRWww4D2RcNzWdCTVWeBqRAmlreJJ0TGE54r7PEBnmQe0t5mS4F3d4w==", + "version": "0.6.5", + "resolved": "https://registry.npmjs.org/@schematics/update/-/update-0.6.5.tgz", + "integrity": "sha512-Gpp3d7KPmheM61WLJ4YEse4YpR5l0PZm/pR1cy8LfA+s6y3SiX/uHy9rtrmLMa4mUZeNwu2M8j8Eu5aPgtsCWw==", "dev": true, "requires": { - "@angular-devkit/core": "0.6.3", - "@angular-devkit/schematics": "0.6.3", + "@angular-devkit/core": "0.6.5", + "@angular-devkit/schematics": "0.6.5", "npm-registry-client": "^8.5.1", "rxjs": "^6.0.0", "semver": "^5.3.0", @@ -484,9 +484,9 @@ } }, "@swimlane/ngx-charts": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/@swimlane/ngx-charts/-/ngx-charts-8.0.1.tgz", - "integrity": "sha512-YiCKol5JiOZ8o6IuQxJ9FRlbjkeKVrdLc8QEQqYANpXbV72H9n59qNeZBwLsEvxl3bkmXDWY0G4xW00NnWCN8w==", + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/@swimlane/ngx-charts/-/ngx-charts-8.0.2.tgz", + "integrity": "sha512-6n5YzsmDrS6d2Aqdo/5ZJ068P8ENBGKyYDq11Be6Ned/TQg1yE5YhoDICmZEKbbKs4fmRZf2ipVFsclCkRWrIg==", "requires": { "d3-array": "^1.2.1", "d3-brush": "^1.0.4", @@ -507,9 +507,9 @@ "integrity": "sha512-77iNYReNBsPg/cbXxSaOP6JkG3hcuETn/pW/Gy62PlMxH9Oxgs+Gv3oSUQ5nVY3ePBP44JyidG/iP1CMaICGOA==" }, "@swimlane/ngx-dnd": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/@swimlane/ngx-dnd/-/ngx-dnd-4.0.1.tgz", - "integrity": "sha512-Ya2zKD3p/XSMLOctnFIXD3Gg+M2lF90ocxnD6ibNcUeKKKpuWkG3ThzcwXuUpTyW6k45VwmeWHDWlgn8qp40Qw==", + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@swimlane/ngx-dnd/-/ngx-dnd-4.0.2.tgz", + "integrity": "sha512-bjujqo1mfztxBefu9pDD6o2Ut11b8PLnmaHpOB3RkyIsrfYnmMhfwOUNdx0nuhUH7PI2qIK5JK+HXxSL8eKgGA==", "requires": { "@swimlane/dragula": "^3.7.3", "@types/dragula": "^2.1.33" @@ -973,9 +973,9 @@ "dev": true }, "are-we-there-yet": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz", - "integrity": "sha1-u13KOCu5TwXhUZQ3PRb9O6HKEQ0=", + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", + "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", "dev": true, "requires": { "delegates": "^1.0.0", @@ -1158,13 +1158,13 @@ "dev": true }, "autoprefixer": { - "version": "8.5.0", - "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-8.5.0.tgz", - "integrity": "sha512-buY1XxFoBrXvLsoFb0jP+niSu1tCj2RwMwHj96+RfQ8DJTgb0vUhh0dg6wjJT3JzsFYBrkSj8/sGtarNdlxTFw==", + "version": "8.5.1", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-8.5.1.tgz", + "integrity": "sha512-0zXQ6OqbnVaplQKkKTASxHFPMNy6WfrXS5QRDJ4zTDxEBB3r7NPDSK4h9KCyQi1tq0tX5MsN4RdzChVBn2k/aw==", "dev": true, "requires": { - "browserslist": "^3.2.7", - "caniuse-lite": "^1.0.30000839", + "browserslist": "^3.2.8", + "caniuse-lite": "^1.0.30000846", "normalize-range": "^0.1.2", "num2fraction": "^1.2.2", "postcss": "^6.0.22", @@ -1818,9 +1818,9 @@ } }, "caniuse-lite": { - "version": "1.0.30000844", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000844.tgz", - "integrity": "sha512-UpKQE7y6dLHhlv75UyBCRiun34Q+bmxyX3zS+ve9M07YG52tRafOvop9N9d5jC+sikKuG7UMweJKJNts4FVehA==", + "version": "1.0.30000846", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000846.tgz", + "integrity": "sha512-qxUOHr5mTaadWH1ap0ueivHd8x42Bnemcn+JutVr7GWmm2bU4zoBhjuv5QdXgALQnnT626lOQros7cCDf8PwCg==", "dev": true }, "caseless": { @@ -2328,9 +2328,9 @@ } }, "core-js": { - "version": "2.5.6", - "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.6.tgz", - "integrity": "sha512-lQUVfQi0aLix2xpyjrrJEvfuYCqPc/HwmTKsC/VNf8q0zsjX7SQZtp4+oRONN5Tsur9GDETPjj+Ub2iDiGZfSQ==" + "version": "2.5.7", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.7.tgz", + "integrity": "sha512-RszJCAxg/PP6uzXVXL6BsxSXx/B05oJAQ2vkJRjyjrEcNVycaqOmNb5OTxZPE3xa5gwZduqza6L9JOCenh/Ecw==" }, "core-util-is": { "version": "1.0.2", @@ -7102,9 +7102,9 @@ } }, "ngx-color-picker": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/ngx-color-picker/-/ngx-color-picker-6.2.0.tgz", - "integrity": "sha512-Rm7rhr9I4LvjbtZLLvWgGlY0yFAcc5VCaGhd9TZr24NFtQhGgxmqmQNr3YD4UEdojSMh2kJm22Flenjb5TYQYw==" + "version": "6.3.2", + "resolved": "https://registry.npmjs.org/ngx-color-picker/-/ngx-color-picker-6.3.2.tgz", + "integrity": "sha512-d44v2a9GrYFiW/pkwr0gFhPL0rUF9N7pDtS8HwZjgmygrw+Zb0IeyHc7ewsl0ewwA3xrPOwmPRs5Z7rSwxcIfQ==" }, "ngx-cookie-service": { "version": "1.0.10", @@ -8404,9 +8404,9 @@ } }, "punycode": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.0.tgz", - "integrity": "sha1-X4Y+3Im5bbCQdLrXlHvwkFbKTn0=", + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", + "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", "dev": true }, "q": { @@ -8927,9 +8927,9 @@ } }, "rxjs-compat": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/rxjs-compat/-/rxjs-compat-6.1.0.tgz", - "integrity": "sha512-x5L1KQy1RqDRpPadN5iDOx71TV9Wqmlmu6OOEn3tFFgaTCB0/N+Lmby/rZHgJ6JEPzzt0nD9Zv+kS53E5JIR5g==" + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/rxjs-compat/-/rxjs-compat-6.2.0.tgz", + "integrity": "sha512-kFX7NSIgyzqn3+J5F/w75R72wDOICXwArbXyPU1neE4laOEwxkMTm+2oAZXN82yb+yli+j+c5USgbGLfphTCTA==" }, "safe-buffer": { "version": "5.1.2", @@ -10835,9 +10835,9 @@ } }, "webpack-bundle-analyzer": { - "version": "2.11.3", - "resolved": "https://registry.npmjs.org/webpack-bundle-analyzer/-/webpack-bundle-analyzer-2.11.3.tgz", - "integrity": "sha512-MaHZkX9mNGeJLbVT70bNfftSBBdl3w9Q1ThnrH7SESF47SollWm12MwDgjhf8C16R/Ur56PInrLYf0FJIOg24g==", + "version": "2.13.1", + "resolved": "https://registry.npmjs.org/webpack-bundle-analyzer/-/webpack-bundle-analyzer-2.13.1.tgz", + "integrity": "sha512-rwxyfecTAxoarCC9VlHlIpfQCmmJ/qWD5bpbjkof+7HrNhTNZIwZITxN6CdlYL2axGmwNUQ+tFgcSOiNXMf/sQ==", "dev": true, "requires": { "acorn": "^5.3.0", @@ -11174,12 +11174,12 @@ "optional": true }, "wide-align": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.2.tgz", - "integrity": "sha512-ijDLlyQ7s6x1JgCLur53osjm/UXUYD9+0PbYKrBsYisYXzCxN+HC3mYDNy/dWdmf3AwqwU3CXwDCvsNgGK1S0w==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", + "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", "dev": true, "requires": { - "string-width": "^1.0.2" + "string-width": "^1.0.2 || 2" } }, "window-size": { diff --git a/package.json b/package.json index a0aab823..931d5168 100644 --- a/package.json +++ b/package.json @@ -18,7 +18,7 @@ }, "private": true, "dependencies": { - "@agm/core": "1.0.0-beta.2", + "@agm/core": "1.0.0-beta.3", "@angular/animations": "6.0.3", "@angular/cdk": "6.1.0", "@angular/common": "6.0.3", @@ -32,40 +32,40 @@ "@angular/platform-browser": "6.0.3", "@angular/platform-browser-dynamic": "6.0.3", "@angular/router": "6.0.3", - "@ngrx/effects": "6.0.0-beta.3", - "@ngrx/router-store": "6.0.0-beta.3", - "@ngrx/store": "6.0.0-beta.3", - "@ngrx/store-devtools": "6.0.0-beta.3", + "@ngrx/effects": "6.0.1", + "@ngrx/router-store": "6.0.1", + "@ngrx/store": "6.0.1", + "@ngrx/store-devtools": "6.0.1", "@ngx-translate/core": "10.0.2", - "@swimlane/ngx-charts": "8.0.1", + "@swimlane/ngx-charts": "8.0.2", "@swimlane/ngx-datatable": "13.0.0", - "@swimlane/ngx-dnd": "4.0.1", + "@swimlane/ngx-dnd": "4.0.2", "@types/prismjs": "1.9.0", "angular-calendar": "0.25.2", "angular-in-memory-web-api": "0.6.0", "chart.js": "2.7.2", "classlist.js": "1.1.20150312", - "core-js": "2.5.6", + "core-js": "2.5.7", "d3": "5.4.0", "hammerjs": "2.0.8", "lodash": "4.17.10", "moment": "2.22.1", "ng2-charts": "1.6.0", "ngrx-store-freeze": "0.2.3", - "ngx-color-picker": "6.2.0", + "ngx-color-picker": "6.3.2", "ngx-cookie-service": "1.0.10", "perfect-scrollbar": "1.3.0", "prismjs": "1.14.0", "rxjs": "6.2.0", - "rxjs-compat": "6.1.0", + "rxjs-compat": "6.2.0", "web-animations-js": "2.3.1", "zone.js": "0.8.26" }, "devDependencies": { - "@angular/cli": "6.0.3", + "@angular/cli": "6.0.5", "@angular/compiler-cli": "6.0.3", "@angular/language-service": "6.0.3", - "@angular-devkit/build-angular": "0.6.3", + "@angular-devkit/build-angular": "0.6.5", "@angularclass/hmr": "2.1.3", "@types/jasmine": "2.8.7", "@types/jasminewd2": "2.0.3", @@ -83,6 +83,6 @@ "ts-node": "5.0.1", "tslint": "5.9.1", "typescript": "2.7.2", - "webpack-bundle-analyzer": "2.11.3" + "webpack-bundle-analyzer": "2.13.1" } } From 27197a55dcdc20072b261dc4f2dde16b84069f9d Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Sun, 27 May 2018 16:55:46 +0300 Subject: [PATCH 12/80] Improving the codebase --- .../directives/fuse-if-on-dom/fuse-if-on-dom.directive.ts | 4 +++- .../fuse-mat-sidenav/fuse-mat-sidenav.directive.ts | 5 ++++- src/@fuse/services/match-media.service.ts | 1 + .../{blocks => components}/content/content.component.html | 0 4 files changed, 8 insertions(+), 2 deletions(-) rename src/app/layout/{blocks => components}/content/content.component.html (100%) diff --git a/src/@fuse/directives/fuse-if-on-dom/fuse-if-on-dom.directive.ts b/src/@fuse/directives/fuse-if-on-dom/fuse-if-on-dom.directive.ts index cfe1cfb3..73b4af5d 100644 --- a/src/@fuse/directives/fuse-if-on-dom/fuse-if-on-dom.directive.ts +++ b/src/@fuse/directives/fuse-if-on-dom/fuse-if-on-dom.directive.ts @@ -5,7 +5,7 @@ import { AfterContentChecked, Directive, ElementRef, TemplateRef, ViewContainerR }) export class FuseIfOnDomDirective implements AfterContentChecked { - isCreated = false; + isCreated: boolean; /** * Constructor @@ -20,6 +20,8 @@ export class FuseIfOnDomDirective implements AfterContentChecked private _viewContainerRef: ViewContainerRef ) { + // Set the defaults + this.isCreated = false; } // ----------------------------------------------------------------------------------------------------- diff --git a/src/@fuse/directives/fuse-mat-sidenav/fuse-mat-sidenav.directive.ts b/src/@fuse/directives/fuse-mat-sidenav/fuse-mat-sidenav.directive.ts index 52570a7b..7b79144c 100644 --- a/src/@fuse/directives/fuse-mat-sidenav/fuse-mat-sidenav.directive.ts +++ b/src/@fuse/directives/fuse-mat-sidenav/fuse-mat-sidenav.directive.ts @@ -13,7 +13,7 @@ import { FuseMatSidenavHelperService } from '@fuse/directives/fuse-mat-sidenav/f export class FuseMatSidenavHelperDirective implements OnInit, OnDestroy { @HostBinding('class.mat-is-locked-open') - isLockedOpen = true; + isLockedOpen: boolean; @Input('fuseMatSidenavHelper') id: string; @@ -39,6 +39,9 @@ export class FuseMatSidenavHelperDirective implements OnInit, OnDestroy private _observableMedia: ObservableMedia ) { + // Set the defaults + this.isLockedOpen = true; + // Set the private defaults this._unsubscribeAll = new Subject(); } diff --git a/src/@fuse/services/match-media.service.ts b/src/@fuse/services/match-media.service.ts index 22159936..fdaa1f3c 100644 --- a/src/@fuse/services/match-media.service.ts +++ b/src/@fuse/services/match-media.service.ts @@ -45,4 +45,5 @@ export class FuseMatchMediaService } }); } + } diff --git a/src/app/layout/blocks/content/content.component.html b/src/app/layout/components/content/content.component.html similarity index 100% rename from src/app/layout/blocks/content/content.component.html rename to src/app/layout/components/content/content.component.html From 02f305be1f441bba28302c0b3e4db86854ae5747 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Sun, 27 May 2018 16:56:50 +0300 Subject: [PATCH 13/80] Improved the FusePerfectScrollbar directive, not directives can be controlled individually by adding a boolean value to them --- .../fuse-perfect-scrollbar.directive.ts | 158 ++++++++++++++---- 1 file changed, 121 insertions(+), 37 deletions(-) diff --git a/src/@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive.ts b/src/@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive.ts index 9e4a7c9a..135e65c8 100644 --- a/src/@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive.ts +++ b/src/@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive.ts @@ -1,4 +1,4 @@ -import { AfterViewInit, Directive, ElementRef, HostListener, OnDestroy, OnInit } from '@angular/core'; +import { AfterViewInit, Directive, ElementRef, HostListener, Input, OnDestroy } from '@angular/core'; import { Platform } from '@angular/cdk/platform'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; @@ -10,14 +10,14 @@ import { FuseConfigService } from '@fuse/services/config.service'; @Directive({ selector: '[fusePerfectScrollbar]' }) -export class FusePerfectScrollbarDirective implements OnInit, AfterViewInit, OnDestroy +export class FusePerfectScrollbarDirective implements AfterViewInit, OnDestroy { - isDisableCustomScrollbars = false; - isMobile = false; - isInitialized = true; + isInitialized: boolean; + isMobile: boolean; ps: PerfectScrollbar; // Private + private _enabled: boolean | ''; private _unsubscribeAll: Subject; /** @@ -33,66 +33,150 @@ export class FusePerfectScrollbarDirective implements OnInit, AfterViewInit, OnD private _platform: Platform ) { + // Set the defaults + this.isInitialized = false; + this.isMobile = false; + // Set the private defaults + this._enabled = false; this._unsubscribeAll = new Subject(); } + // ----------------------------------------------------------------------------------------------------- + // @ Accessors + // ----------------------------------------------------------------------------------------------------- + + /** + * Is enabled + * + * @param {boolean | ""} value + */ + @Input('fusePerfectScrollbar') + set enabled(value: boolean | '') + { + // If nothing is provided with the directive (empty string), + // we will take that as a true + if ( value === '' ) + { + value = true; + } + + // Return, if both values are the same + if ( this.enabled === value ) + { + return; + } + + // Store the value + this._enabled = value; + + // If enabled... + if ( this.enabled ) + { + // Init the directive + this._init(); + } + else + { + // Otherwise destroy it + this._destroy(); + } + } + + get enabled(): boolean | '' + { + return this._enabled; + } + // ----------------------------------------------------------------------------------------------------- // @ Lifecycle hooks // ----------------------------------------------------------------------------------------------------- - /** - * On init - */ - ngOnInit(): void - { - this._fuseConfigService.config - .pipe(takeUntil(this._unsubscribeAll)) - .subscribe( - (settings) => { - this.isDisableCustomScrollbars = !settings.customScrollbars; - } - ); - - if ( this._platform.ANDROID || this._platform.IOS ) - { - this.isMobile = true; - } - } - /** * After view init */ ngAfterViewInit(): void { - if ( this.isMobile || this.isDisableCustomScrollbars ) - { - this.isInitialized = false; - return; - } + // Check if scrollbars enabled or not from the main config + this._fuseConfigService.config + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe( + (settings) => { + this.enabled = settings.customScrollbars; + } + ); - // Initialize the perfect-scrollbar - this.ps = new PerfectScrollbar(this.elementRef.nativeElement, { - wheelPropagation: true - }); + // this._init(); } /** * On destroy */ ngOnDestroy(): void + { + this._destroy(); + + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Private methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Initialize + * + * @private + */ + _init(): void + { + // Return, if already initialized + if ( this.isInitialized ) + { + return; + } + + // Check if is mobile + if ( this._platform.ANDROID || this._platform.IOS ) + { + this.isMobile = true; + } + + // Return if it's mobile + if ( this.isMobile ) + { + // Return... + return; + } + + // Initialize the perfect-scrollbar + this.isInitialized = true; + + this.ps = new PerfectScrollbar(this.elementRef.nativeElement, { + wheelPropagation: true + }); + } + + /** + * Destroy + * + * @private + */ + _destroy(): void { if ( !this.isInitialized || !this.ps ) { return; } - // Unsubscribe from all subscriptions - this._unsubscribeAll.next(); - this._unsubscribeAll.complete(); - // Destroy the perfect-scrollbar this.ps.destroy(); + + // Clean up + this.ps = null; + this.isInitialized = false; } // ----------------------------------------------------------------------------------------------------- From 96351653168c81c97a92e18bf6ba96eab8a4866b Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Sun, 27 May 2018 16:57:54 +0300 Subject: [PATCH 14/80] (Config Service) Added ability to access to the default config and reset to it --- src/@fuse/services/config.service.ts | 29 +++++++++++++++++++++++++--- 1 file changed, 26 insertions(+), 3 deletions(-) diff --git a/src/@fuse/services/config.service.ts b/src/@fuse/services/config.service.ts index 8f07ee15..e753f337 100644 --- a/src/@fuse/services/config.service.ts +++ b/src/@fuse/services/config.service.ts @@ -59,6 +59,16 @@ export class FuseConfigService return this._configSubject.asObservable(); } + /** + * Get default config + * + * @returns {any} + */ + get defaultConfig(): any + { + return this._defaultConfig; + } + // ----------------------------------------------------------------------------------------------------- // @ Private methods // ----------------------------------------------------------------------------------------------------- @@ -78,11 +88,11 @@ export class FuseConfigService this._defaultConfig.customScrollbars = false; } - // Set the settings from the default settings + // Set the config from the default config this._configSubject = new BehaviorSubject(_.cloneDeep(this._defaultConfig)); - // Reload the default settings on every navigation start if - // the current settings are different from defaults + // Reload the default config on every navigation start if + // the current config is different from the default one this._router.events .pipe(filter(event => event instanceof NavigationStart)) .subscribe(() => { @@ -92,5 +102,18 @@ export class FuseConfigService } }); } + + // ----------------------------------------------------------------------------------------------------- + // @ Public methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Reset to the default config + */ + resetToDefaults(): void + { + // Set the config from the default config + this._configSubject.next(_.cloneDeep(this._defaultConfig)); + } } From 745c51878d16495e3cab43534fd5f826a893141d Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Sun, 27 May 2018 16:58:26 +0300 Subject: [PATCH 15/80] Small color adjustments --- src/@fuse/components/sidebar/sidebar.component.scss | 1 + src/app/main/apps/e-commerce/dashboard/dashboard.component.html | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/src/@fuse/components/sidebar/sidebar.component.scss b/src/@fuse/components/sidebar/sidebar.component.scss index 1ba10735..25b9b5ef 100644 --- a/src/@fuse/components/sidebar/sidebar.component.scss +++ b/src/@fuse/components/sidebar/sidebar.component.scss @@ -15,6 +15,7 @@ fuse-sidebar { transition-duration: 150ms; transition-timing-function: ease-in-out; box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.35); + background: white; &.left-aligned { left: 0; diff --git a/src/app/main/apps/e-commerce/dashboard/dashboard.component.html b/src/app/main/apps/e-commerce/dashboard/dashboard.component.html index 49164a6b..6e2054fc 100644 --- a/src/app/main/apps/e-commerce/dashboard/dashboard.component.html +++ b/src/app/main/apps/e-commerce/dashboard/dashboard.component.html @@ -1,4 +1,4 @@ -
+
From c6969cf9dfae38164c435a5cad7914f4f8f5772b Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Mon, 28 May 2018 12:31:54 +0300 Subject: [PATCH 16/80] (Navigation) Improved navigation service for easier navigation management --- .../navigation/navigation.service.ts | 246 +++++++++++++++++- 1 file changed, 239 insertions(+), 7 deletions(-) diff --git a/src/@fuse/components/navigation/navigation.service.ts b/src/@fuse/components/navigation/navigation.service.ts index 677c5ca3..490f895c 100644 --- a/src/@fuse/components/navigation/navigation.service.ts +++ b/src/@fuse/components/navigation/navigation.service.ts @@ -1,25 +1,139 @@ import { Injectable } from '@angular/core'; -import { Subject } from 'rxjs'; +import { BehaviorSubject, Observable, Subject } from 'rxjs'; @Injectable() export class FuseNavigationService { flatNavigation: any[] = []; - onItemCollapsed: Subject = new Subject; - onItemCollapseToggled: Subject = new Subject; + onItemCollapsed: Subject; + onItemCollapseToggled: Subject; + + // Private + private _onNavigationChanged: BehaviorSubject; + private _onNavigationRegistered: BehaviorSubject; + private _onNavigationUnregistered: BehaviorSubject; + + private _currentNavigationKey: string; + private _registry: { [key: string]: any } = {}; /** * Constructor */ constructor() { + // Set the defaults + this.onItemCollapsed = new Subject(); + this.onItemCollapseToggled = new Subject(); + + // Set the private defaults + this._currentNavigationKey = null; + this._onNavigationChanged = new BehaviorSubject(null); + this._onNavigationRegistered = new BehaviorSubject(null); + this._onNavigationUnregistered = new BehaviorSubject(null); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Accessors + // ----------------------------------------------------------------------------------------------------- + + /** + * Get onNavigationChanged + * + * @returns {Observable} + */ + get onNavigationChanged(): Observable + { + return this._onNavigationChanged.asObservable(); + } + + /** + * Get onNavigationRegistered + * + * @returns {Observable} + */ + get onNavigationRegistered(): Observable + { + return this._onNavigationRegistered.asObservable(); + } + + /** + * Get onNavigationUnregistered + * + * @returns {Observable} + */ + get onNavigationUnregistered(): Observable + { + return this._onNavigationUnregistered.asObservable(); } // ----------------------------------------------------------------------------------------------------- // @ Public methods // ----------------------------------------------------------------------------------------------------- + /** + * Register the given navigation + * with the given key + * + * @param key + * @param navigation + */ + register(key, navigation): void + { + // Check if the key already being used + if ( this._registry[key] ) + { + console.error(`The navigation with the key '${key}' already exists. Either unregister it first or use a unique key.`); + + return; + } + + // Add to the registry + this._registry[key] = navigation; + + // Notify the subject + this._onNavigationRegistered.next([key, navigation]); + } + + /** + * Unregister the navigation from the registry + * @param key + */ + unregister(key): void + { + // Check if the navigation exists + if ( !this._registry[key] ) + { + console.warn(`The navigation with the key '${key}' doesn't exist in the registry.`); + } + + // Unregister the sidebar + delete this._registry[key]; + + // Notify the subject + this._onNavigationUnregistered.next(key); + } + + /** + * Get navigation from registry by key + * + * @param key + * @returns {any} + */ + getNavigation(key): any + { + // Check if the navigation exists + if ( !this._registry[key] ) + { + console.warn(`The navigation with the key '${key}' doesn't exist in the registry.`); + + return; + } + + // Return the sidebar + return this._registry[key]; + } + /** * Get flattened navigation array * @@ -33,10 +147,15 @@ export class FuseNavigationService if ( navItem.type === 'item' ) { this.flatNavigation.push({ - title: navItem.title, - type : navItem.type, - icon : navItem.icon || false, - url : navItem.url + id : navItem.id || null, + title : navItem.title || null, + translate : navItem.translate || null, + type : navItem.type, + icon : navItem.icon || null, + url : navItem.url || null, + function : navItem.function || null, + exactMatch: navItem.exactMatch || false, + badge : navItem.badge || null }); continue; @@ -53,4 +172,117 @@ export class FuseNavigationService return this.flatNavigation; } + + /** + * Get the current navigation + * + * @returns {any} + */ + getCurrentNavigation(): any + { + if ( !this._currentNavigationKey ) + { + console.warn(`The current navigation is not set.`); + + return; + } + + return this.getNavigation(this._currentNavigationKey); + } + + /** + * Set the navigation with the key + * as the current navigation + * + * @param key + */ + setCurrentNavigation(key): void + { + // Check if the sidebar exists + if ( !this._registry[key] ) + { + console.warn(`The navigation with the key '${key}' doesn't exist in the registry.`); + + return; + } + + // Set the current navigation key + this._currentNavigationKey = key; + + // Notify the subject + this._onNavigationChanged.next(key); + } + + /** + * Get navigation item by id from the + * current navigation + * + * @param id + * @param {any} navigation + * @returns {any | boolean} + */ + getNavigationItem(id, navigation = null): any | boolean + { + if ( !navigation ) + { + navigation = this.getCurrentNavigation(); + } + + for ( const item of navigation ) + { + if ( item.id === id ) + { + return item; + } + + if ( item.children ) + { + this.getNavigationItem(id, item.children); + } + } + + return false; + } + + /** + * Add a navigation item to the specified location + * + * @param item + * @param id + */ + addNavigationItem(item, id): void + { + // Get the current navigation + const navigation: any[] = this.getCurrentNavigation(); + + // Add to the end of the navigation + if ( id === 'end' ) + { + navigation.push(item); + + return; + } + + // Add to the start of the navigation + if ( id === 'start' ) + { + navigation.unshift(item); + } + + // Add it to a specific location + const parent: any = this.getNavigationItem(id); + + if ( parent ) + { + // Check if parent has a children entry, + // and add it if it doesn't + if ( !parent.children ) + { + parent.children = []; + } + + // Add the item + parent.children.push(item); + } + } } From 1e6bd8139c4a19b4b289a973116cba97717a7a88 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Mon, 28 May 2018 12:32:29 +0300 Subject: [PATCH 17/80] Removed bg color from body --- src/index.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/index.html b/src/index.html index cbb463c6..534f3c25 100644 --- a/src/index.html +++ b/src/index.html @@ -181,7 +181,7 @@ - + From 850e43c6538e15c68641f3b34a0e0d748ec4b183 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Mon, 28 May 2018 16:04:27 +0300 Subject: [PATCH 18/80] (Navigation) Improved navigation service --- .../navigation/navigation.service.ts | 71 ++++++++++++++++++- 1 file changed, 70 insertions(+), 1 deletion(-) diff --git a/src/@fuse/components/navigation/navigation.service.ts b/src/@fuse/components/navigation/navigation.service.ts index 490f895c..49995acb 100644 --- a/src/@fuse/components/navigation/navigation.service.ts +++ b/src/@fuse/components/navigation/navigation.service.ts @@ -237,7 +237,49 @@ export class FuseNavigationService if ( item.children ) { - this.getNavigationItem(id, item.children); + const childItem = this.getNavigationItem(id, item.children); + + if ( childItem ) + { + return childItem; + } + } + } + + return false; + } + + /** + * Get the parent of the navigation item + * with the id + * + * @param id + * @param {any} navigation + * @param parent + */ + getNavigationItemParent(id, navigation = null, parent = null): any + { + if ( !navigation ) + { + navigation = this.getCurrentNavigation(); + parent = navigation; + } + + for ( const item of navigation ) + { + if ( item.id === id ) + { + return parent; + } + + if ( item.children ) + { + const childItem = this.getNavigationItemParent(id, item.children, item); + + if ( childItem ) + { + return childItem; + } } } @@ -285,4 +327,31 @@ export class FuseNavigationService parent.children.push(item); } } + + /** + * Remove navigation item with the given id + * + * @param id + */ + removeNavigationItem(id): void + { + const item = this.getNavigationItem(id); + + // Return, if there is not such an item + if ( !item ) + { + return; + } + + // Get the parent of the item + let parent = this.getNavigationItemParent(id); + + // This check is required because of the first level + // of the navigation, since the first level is not + // inside the 'children' array + parent = parent.children || parent; + + // Remove the item + parent.splice(parent.indexOf(item), 1); + } } From 0ac4e6c220484d6117c3adde39f172889f4f4ca5 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Mon, 28 May 2018 17:41:33 +0300 Subject: [PATCH 19/80] (Academy app) Small shadow adjustment --- src/app/main/apps/academy/courses/courses.component.scss | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/app/main/apps/academy/courses/courses.component.scss b/src/app/main/apps/academy/courses/courses.component.scss index b1af425f..9340c26b 100644 --- a/src/app/main/apps/academy/courses/courses.component.scss +++ b/src/app/main/apps/academy/courses/courses.component.scss @@ -112,7 +112,7 @@ min-height: 240px; transition: box-shadow 150ms ease-in-out; - @include mat-elevation(1); + @include mat-elevation(3); .header { color: white; From 70d895c6ed623cd58f8446ccafe742318a26764f Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Tue, 29 May 2018 14:58:48 +0300 Subject: [PATCH 20/80] New layout system (wip) --- .editorconfig | 17 +- .../search-bar/search-bar.component.ts | 2 +- .../shortcuts/shortcuts.component.ts | 2 +- .../theme-options.component.html | 222 +++++++++++------- .../theme-options/theme-options.component.ts | 101 +++++++- .../theme-options/theme-options.module.ts | 3 +- src/@fuse/scss/partials/_global.scss | 16 +- src/@fuse/types/fuse-config.ts | 22 ++ src/@fuse/types/index.ts | 1 + src/app/app.component.html | 15 +- src/app/app.component.scss | 6 + src/app/app.component.ts | 53 ++++- src/app/fuse-config/index.ts | 31 +-- .../blocks/content/content.component.scss | 3 - .../components/content/content.component.scss | 11 + .../content/content.component.ts | 11 +- .../content/content.module.ts | 2 +- .../footer/footer.component.html | 0 .../footer/footer.component.scss | 2 +- .../footer/footer.component.ts | 0 .../footer/footer.module.ts | 2 +- .../navbar/navbar.component.html | 0 .../navbar/navbar.component.scss | 0 .../navbar/navbar.component.ts | 12 +- .../navbar/navbar.module.ts | 2 +- .../quick-panel/quick-panel.component.html | 0 .../quick-panel/quick-panel.component.scss | 0 .../quick-panel/quick-panel.component.ts | 0 .../quick-panel/quick-panel.module.ts | 2 +- .../toolbar/toolbar.component.html | 4 +- .../toolbar/toolbar.component.scss | 0 .../toolbar/toolbar.component.ts | 4 +- .../toolbar/toolbar.module.ts | 2 +- .../layout-1/layout-1.component.html | 91 +++++++ .../layout-1/layout-1.component.scss | 131 +++++++++++ .../layout-1/layout-1.component.ts} | 8 +- .../horizontal/layout-1/layout-1.module.ts | 38 +++ src/app/layout/layout.module.ts | 12 +- .../vertical/basic/basic.component.html | 77 ------ .../vertical/basic/basic.component.scss | 75 ------ src/app/layout/vertical/basic/basic.module.ts | 38 --- .../vertical/layout-1/layout-1.component.html | 83 +++++++ .../vertical/layout-1/layout-1.component.scss | 117 +++++++++ .../vertical/layout-1/layout-1.component.ts | 64 +++++ .../vertical/layout-1/layout-1.module.ts | 35 +++ .../vertical/layout-2/layout-2.component.html | 83 +++++++ .../vertical/layout-2/layout-2.component.scss | 53 +++++ .../vertical/layout-2/layout-2.component.ts | 64 +++++ .../vertical/layout-2/layout-2.module.ts | 35 +++ .../vertical/layout-3/layout-3.component.html | 83 +++++++ .../vertical/layout-3/layout-3.component.scss | 45 ++++ .../vertical/layout-3/layout-3.component.ts | 64 +++++ .../vertical/layout-3/layout-3.module.ts | 35 +++ .../fullwidth-2/fullwidth-2.component.html | 4 +- .../carded/fullwidth/fullwidth.component.ts | 76 +++++- .../left-sidenav-2-tabbed.component.html | 2 +- .../left-sidenav-2.component.html | 2 +- .../right-sidenav-2-tabbed.component.html | 2 +- .../right-sidenav-2.component.html | 2 +- .../left-sidenav-2.component.html | 2 +- .../right-sidenav-2.component.html | 2 +- 61 files changed, 1508 insertions(+), 363 deletions(-) create mode 100644 src/@fuse/types/fuse-config.ts create mode 100644 src/@fuse/types/index.ts delete mode 100644 src/app/layout/blocks/content/content.component.scss create mode 100644 src/app/layout/components/content/content.component.scss rename src/app/layout/{blocks => components}/content/content.component.ts (91%) rename src/app/layout/{blocks => components}/content/content.module.ts (81%) rename src/app/layout/{blocks => components}/footer/footer.component.html (100%) rename src/app/layout/{blocks => components}/footer/footer.component.scss (94%) rename src/app/layout/{blocks => components}/footer/footer.component.ts (100%) rename src/app/layout/{blocks => components}/footer/footer.module.ts (85%) rename src/app/layout/{blocks => components}/navbar/navbar.component.html (100%) rename src/app/layout/{blocks => components}/navbar/navbar.component.scss (100%) rename src/app/layout/{blocks => components}/navbar/navbar.component.ts (93%) rename src/app/layout/{blocks => components}/navbar/navbar.module.ts (86%) rename src/app/layout/{blocks => components}/quick-panel/quick-panel.component.html (100%) rename src/app/layout/{blocks => components}/quick-panel/quick-panel.component.scss (100%) rename src/app/layout/{blocks => components}/quick-panel/quick-panel.component.ts (100%) rename src/app/layout/{blocks => components}/quick-panel/quick-panel.module.ts (83%) rename src/app/layout/{blocks => components}/toolbar/toolbar.component.html (96%) rename src/app/layout/{blocks => components}/toolbar/toolbar.component.scss (100%) rename src/app/layout/{blocks => components}/toolbar/toolbar.component.ts (98%) rename src/app/layout/{blocks => components}/toolbar/toolbar.module.ts (90%) create mode 100644 src/app/layout/horizontal/layout-1/layout-1.component.html create mode 100644 src/app/layout/horizontal/layout-1/layout-1.component.scss rename src/app/layout/{vertical/basic/basic.component.ts => horizontal/layout-1/layout-1.component.ts} (87%) create mode 100644 src/app/layout/horizontal/layout-1/layout-1.module.ts delete mode 100644 src/app/layout/vertical/basic/basic.component.html delete mode 100644 src/app/layout/vertical/basic/basic.component.scss delete mode 100644 src/app/layout/vertical/basic/basic.module.ts create mode 100644 src/app/layout/vertical/layout-1/layout-1.component.html create mode 100644 src/app/layout/vertical/layout-1/layout-1.component.scss create mode 100644 src/app/layout/vertical/layout-1/layout-1.component.ts create mode 100644 src/app/layout/vertical/layout-1/layout-1.module.ts create mode 100644 src/app/layout/vertical/layout-2/layout-2.component.html create mode 100644 src/app/layout/vertical/layout-2/layout-2.component.scss create mode 100644 src/app/layout/vertical/layout-2/layout-2.component.ts create mode 100644 src/app/layout/vertical/layout-2/layout-2.module.ts create mode 100644 src/app/layout/vertical/layout-3/layout-3.component.html create mode 100644 src/app/layout/vertical/layout-3/layout-3.component.scss create mode 100644 src/app/layout/vertical/layout-3/layout-3.component.ts create mode 100644 src/app/layout/vertical/layout-3/layout-3.module.ts diff --git a/.editorconfig b/.editorconfig index 6e87a003..ec967c61 100644 --- a/.editorconfig +++ b/.editorconfig @@ -1,13 +1,6 @@ -# Editor configuration, see http://editorconfig.org -root = true - [*] -charset = utf-8 -indent_style = space -indent_size = 2 -insert_final_newline = true -trim_trailing_whitespace = true - -[*.md] -max_line_length = off -trim_trailing_whitespace = false +charset=utf-8 +end_of_line=lf +insert_final_newline=false +indent_style=space +indent_size=4 diff --git a/src/@fuse/components/search-bar/search-bar.component.ts b/src/@fuse/components/search-bar/search-bar.component.ts index eb80bba9..8c7180d7 100644 --- a/src/@fuse/components/search-bar/search-bar.component.ts +++ b/src/@fuse/components/search-bar/search-bar.component.ts @@ -51,7 +51,7 @@ export class FuseSearchBarComponent implements OnInit, OnDestroy .pipe(takeUntil(this._unsubscribeAll)) .subscribe( (config) => { - this.toolbarColor = config.colorClasses.toolbar; + this.toolbarColor = config.layout.toolbar.background; } ); } diff --git a/src/@fuse/components/shortcuts/shortcuts.component.ts b/src/@fuse/components/shortcuts/shortcuts.component.ts index 5e001980..58e743a0 100644 --- a/src/@fuse/components/shortcuts/shortcuts.component.ts +++ b/src/@fuse/components/shortcuts/shortcuts.component.ts @@ -71,7 +71,7 @@ export class FuseShortcutsComponent implements OnInit, OnDestroy .pipe(takeUntil(this._unsubscribeAll)) .subscribe( (config) => { - this.toolbarColor = config.colorClasses.toolbar; + this.toolbarColor = config.layout.toolbar.background; } ); diff --git a/src/@fuse/components/theme-options/theme-options.component.html b/src/@fuse/components/theme-options/theme-options.component.html index 1e0f8ac7..ffe16bcb 100644 --- a/src/@fuse/components/theme-options/theme-options.component.html +++ b/src/@fuse/components/theme-options/theme-options.component.html @@ -12,102 +12,162 @@
-

Layout:

- - Vertical - Horizontal - None - +
-

Navigation:

- - Top - Left - Right - None - + + +
-

Navigation Fold (for vertical navigation):

- - Folded - + +

Vertical Layout Styles:

+ + Layout 1 + Layout 2 + Layout 3 + -

Toolbar:

- - Below - Above - None - + +

Horizontal Layout Styles:

+ + Layout 1 + Layout 2 + -

Footer:

- - Below - Above - None - -

Layout Mode:

- - Boxed - Fullwidth - +
- + +

Navigation Position:

-

Colors:

-
+ + + Left + Right + None + + + + + Top + None + + + + +

Navigation Fold:

+ + Folded + +
+ +
+ +
+ + +

Toolbar:

+ + Above + Below + Below Sticky + None + + +
+ +
+ + +

Footer:

+ + Above + Below + Below Sticky + None + + +
+ + +

Layout Mode:

+ + Boxed + Fullwidth + -
-

Toolbar Color

-
-
-

Navigation Bar Color

- + + +

Custom scrollbars:

+ + Enable custom scrollbars + + + + +

Colors:

+
+ +
+

Toolbar Color

+ +
+ +
+

Navigation Bar Color

+ +
+ +
+

Footer Color

+ +
+
-
-

Footer Color

- -
+ -
+

Router Animation:

+ + + + None + + + Slide up + + + Slide down + + + Slide right + + + Slide left + + + Fade in + + + - + -

Router Animation:

- - - - None - - - Slide up - - - Slide down - - - Slide right - - - Slide left - - - Fade in - - -
diff --git a/src/@fuse/components/theme-options/theme-options.component.ts b/src/@fuse/components/theme-options/theme-options.component.ts index 8eb0a39b..6e6ac9a9 100644 --- a/src/@fuse/components/theme-options/theme-options.component.ts +++ b/src/@fuse/components/theme-options/theme-options.component.ts @@ -1,5 +1,6 @@ import { Component, ElementRef, HostBinding, Input, OnDestroy, OnInit, Renderer2, ViewChild } from '@angular/core'; import { style, animate, AnimationBuilder, AnimationPlayer } from '@angular/animations'; +import { FormBuilder, FormGroup } from '@angular/forms'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; @@ -15,8 +16,9 @@ import { FuseNavigationService } from '@fuse/components/navigation/navigation.se }) export class FuseThemeOptionsComponent implements OnInit, OnDestroy { - @Input() - navigation; + fuseConfig: any; + fuseConfigForm: FormGroup; + player: AnimationPlayer; @ViewChild('openButton') openButton; @@ -27,16 +29,15 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy @ViewChild('overlay') overlay: ElementRef; - player: AnimationPlayer; - fuseConfig: any; - - @HostBinding('class.bar-closed') barClosed: boolean; + @HostBinding('class.bar-closed') + barClosed: boolean; // Private private _unsubscribeAll: Subject; constructor( private _animationBuilder: AnimationBuilder, + private _formBuilder: FormBuilder, private _fuseConfigService: FuseConfigService, private _fuseNavigationService: FuseNavigationService, private _renderer: Renderer2 @@ -66,16 +67,44 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy } ); + // Build the config form + // noinspection TypeScriptValidateTypes + this.fuseConfigForm = this._formBuilder.group({ + layout : this._formBuilder.group({ + style : this.fuseConfig.layout.style, + navigation: this._formBuilder.group({ + position : this.fuseConfig.layout.navigation.position, + folded : this.fuseConfig.layout.navigation.folded, + background: this.fuseConfig.layout.navigation.background + }), + toolbar : this._formBuilder.group({ + position : this.fuseConfig.layout.toolbar.position, + background: this.fuseConfig.layout.toolbar.background + }), + footer : this._formBuilder.group({ + position : this.fuseConfig.layout.footer.position, + background: this.fuseConfig.layout.footer.background + }), + mode : this.fuseConfig.layout.mode + }), + customScrollbars: this.fuseConfig.customScrollbars, + routerAnimation : this.fuseConfig.routerAnimation + }); + + // Subscribe to the form value changes + this.fuseConfigForm.valueChanges.subscribe((config) => { + + // Update the config + this._fuseConfigService.config = config; + }); + // Listen for the overlay's click event this._renderer.listen(this.overlay.nativeElement, 'click', () => { this.closeBar(); }); - // Get the nav model and add customize nav item - // that opens the bar programmatically - const nav: any = this.navigation; - - nav.push({ + // Add customize nav item that opens the bar programmatically + const customFunctionNavItem = { 'id' : 'custom-function', 'title' : 'Custom Function', 'type' : 'group', @@ -90,7 +119,9 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy } } ] - }); + }; + + this._fuseNavigationService.addNavigationItem(customFunctionNavItem, 'end'); } /** @@ -101,6 +132,9 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy // Unsubscribe from all subscriptions this._unsubscribeAll.next(); this._unsubscribeAll.complete(); + + // Remove the custom function menu + this._fuseNavigationService.removeNavigationItem('custom-function'); } // ----------------------------------------------------------------------------------------------------- @@ -110,9 +144,50 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy /** * On config change */ - onConfigChange(): void + onConfigChange(layoutChanged = false): void { this._fuseConfigService.config = this.fuseConfig; + + // If the layout changed, reset the settings + if ( layoutChanged ) + { + this.resetConfig(); + } + } + + /** + * Reset the config correctly + */ + resetConfig(): void + { + // Check the layout style and reset the + // configuration properly so we don't end + // up with options that don't work with + // selected layout style + switch ( this.fuseConfig.layout.style ) + { + // Vertical + + // Layout 1 + case 'vertical-layout-1': + { + this._fuseConfigService.config = { + layout: { + style : 'vertical-layout-1', + navigation: { + position: 'left' + } + } + }; + + break; + } + + default : + { + break; + } + } } /** diff --git a/src/@fuse/components/theme-options/theme-options.module.ts b/src/@fuse/components/theme-options/theme-options.module.ts index 5aa58c8d..d49050cb 100644 --- a/src/@fuse/components/theme-options/theme-options.module.ts +++ b/src/@fuse/components/theme-options/theme-options.module.ts @@ -1,6 +1,6 @@ import { NgModule } from '@angular/core'; import { CommonModule } from '@angular/common'; -import { FormsModule } from '@angular/forms'; +import { FormsModule, ReactiveFormsModule } from '@angular/forms'; import { FlexLayoutModule } from '@angular/flex-layout'; import { MatButtonModule, MatDividerModule, MatFormFieldModule, MatIconModule, MatOptionModule, MatRadioModule, MatSelectModule, MatSlideToggleModule } from '@angular/material'; @@ -14,6 +14,7 @@ import { FuseThemeOptionsComponent } from '@fuse/components/theme-options/theme- imports : [ CommonModule, FormsModule, + ReactiveFormsModule, FlexLayoutModule, diff --git a/src/@fuse/scss/partials/_global.scss b/src/@fuse/scss/partials/_global.scss index f7b93621..fad46620 100644 --- a/src/@fuse/scss/partials/_global.scss +++ b/src/@fuse/scss/partials/_global.scss @@ -1,6 +1,12 @@ +html, body { - - > mat-sidenav-container { - height: 100%; - } -} + display: flex; + flex: 1 0 auto; + width: 100%; + height: 100%; + max-height: 100%; + min-height: 100%; + margin: 0; + padding: 0; + overflow: hidden; +} \ No newline at end of file diff --git a/src/@fuse/types/fuse-config.ts b/src/@fuse/types/fuse-config.ts new file mode 100644 index 00000000..5cdf067a --- /dev/null +++ b/src/@fuse/types/fuse-config.ts @@ -0,0 +1,22 @@ +export interface FuseConfig +{ + layout: { + style: string, + navigation: { + position: 'left' | 'right' | 'top' | 'none', + folded: boolean, + background: string + }, + toolbar: { + position: 'above' | 'above-sticky' | 'below' | 'below-sticky' | 'none', + background: string + } + footer: { + position: 'above' | 'below' | 'below-sticky' | 'none', + background: string + }, + mode: 'fullwidth' | 'boxed' + }; + customScrollbars: boolean; + routerAnimation: string; +} diff --git a/src/@fuse/types/index.ts b/src/@fuse/types/index.ts new file mode 100644 index 00000000..f47ab6aa --- /dev/null +++ b/src/@fuse/types/index.ts @@ -0,0 +1 @@ +export * from './fuse-config'; diff --git a/src/app/app.component.html b/src/app/app.component.html index 1281ba0b..1e6ab5c9 100644 --- a/src/app/app.component.html +++ b/src/app/app.component.html @@ -1 +1,14 @@ - + + + + + + + + + + + + + + diff --git a/src/app/app.component.scss b/src/app/app.component.scss index e69de29b..189729a0 100644 --- a/src/app/app.component.scss +++ b/src/app/app.component.scss @@ -0,0 +1,6 @@ +:host { + display: flex; + flex: 1 1 auto; + width: 100%; + min-width: 0; +} \ No newline at end of file diff --git a/src/app/app.component.ts b/src/app/app.component.ts index 4deed6b7..2c15072b 100644 --- a/src/app/app.component.ts +++ b/src/app/app.component.ts @@ -1,9 +1,12 @@ -import { Component } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; import { TranslateService } from '@ngx-translate/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; +import { FuseConfigService } from '@fuse/services/config.service'; +import { FuseNavigationService } from '@fuse/components/navigation/navigation.service'; import { FuseSplashScreenService } from '@fuse/services/splash-screen.service'; import { FuseTranslationLoaderService } from '@fuse/services/translation-loader.service'; -import { FuseNavigationService } from '@fuse/components/navigation/navigation.service'; import { navigation } from 'app/navigation/navigation'; import { locale as navigationEnglish } from 'app/navigation/i18n/en'; @@ -14,28 +17,40 @@ import { locale as navigationTurkish } from 'app/navigation/i18n/tr'; templateUrl: './app.component.html', styleUrls : ['./app.component.scss'] }) -export class AppComponent +export class AppComponent implements OnInit, OnDestroy { navigation: any; + fuseConfig: any; + + // Private + private _unsubscribeAll: Subject; /** * Constructor * + * @param {FuseConfigService} _fuseConfigService * @param {FuseNavigationService} _fuseNavigationService * @param {FuseSplashScreenService} _fuseSplashScreenService * @param {FuseTranslationLoaderService} _fuseTranslationLoaderService * @param {TranslateService} _translateService */ constructor( + private _fuseConfigService: FuseConfigService, private _fuseNavigationService: FuseNavigationService, private _fuseSplashScreenService: FuseSplashScreenService, private _fuseTranslationLoaderService: FuseTranslationLoaderService, private _translateService: TranslateService ) { - // Navigation + // Get default navigation this.navigation = navigation; + // Register the navigation to the service + this._fuseNavigationService.register('main', this.navigation); + + // Set the main navigation as our current navigation + this._fuseNavigationService.setCurrentNavigation('main'); + // Add languages this._translateService.addLangs(['en', 'tr']); @@ -47,5 +62,35 @@ export class AppComponent // Use a language this._translateService.use('en'); + + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + // Subscribe to config changes + this._fuseConfigService.config + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe((config) => { + this.fuseConfig = config; + }); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } } diff --git a/src/app/fuse-config/index.ts b/src/app/fuse-config/index.ts index 7bb7e6bb..8b1c2af2 100644 --- a/src/app/fuse-config/index.ts +++ b/src/app/fuse-config/index.ts @@ -1,3 +1,5 @@ +import { FuseConfig } from '@fuse/types'; + /** * Default Fuse Configuration * @@ -5,23 +7,24 @@ * basis. See `app/main/pages/authentication/login/login.component.ts` constructor method to learn more * about changing these options per component basis. */ -export const fuseConfig = { + +export const fuseConfig: FuseConfig = { layout : { - style : 'vertical-basic', + style : 'vertical-layout-1', navigation: { - position: 'left', - folded : false + position : 'left', + folded : false, + background: 'mat-fuse-dark-700-bg' }, - // navigation : 'left', // 'right', 'left', 'top', 'none' - // navigationFolded: false, // true, false - toolbar : 'below', // 'above', 'below', 'none' - footer : 'below', // 'above', 'below', 'none' - mode : 'fullwidth' // 'boxed', 'fullwidth' - }, - colorClasses : { - toolbar: 'mat-white-500-bg', - navbar : 'mat-fuse-dark-700-bg', - footer : 'mat-fuse-dark-900-bg' + toolbar : { + position : 'below', + background: 'mat-white-500-bg' + }, + footer : { + position : 'below', + background: 'mat-fuse-dark-900-bg' + }, + mode : 'fullwidth' }, customScrollbars: true, routerAnimation : 'fadeIn' // fadeIn, slideUp, slideDown, slideRight, slideLeft, none diff --git a/src/app/layout/blocks/content/content.component.scss b/src/app/layout/blocks/content/content.component.scss deleted file mode 100644 index 64b48f72..00000000 --- a/src/app/layout/blocks/content/content.component.scss +++ /dev/null @@ -1,3 +0,0 @@ -:host { - z-index: 1; -} \ No newline at end of file diff --git a/src/app/layout/components/content/content.component.scss b/src/app/layout/components/content/content.component.scss new file mode 100644 index 00000000..32e80fa3 --- /dev/null +++ b/src/app/layout/components/content/content.component.scss @@ -0,0 +1,11 @@ +content { + display: flex; + flex-direction: column; + flex: 1 1 auto; + z-index: 1; + + > *:not(router-outlet) { + display: flex; + flex: 1 1 auto; + } +} \ No newline at end of file diff --git a/src/app/layout/blocks/content/content.component.ts b/src/app/layout/components/content/content.component.ts similarity index 91% rename from src/app/layout/blocks/content/content.component.ts rename to src/app/layout/components/content/content.component.ts index 481247a5..86fedeaf 100644 --- a/src/app/layout/blocks/content/content.component.ts +++ b/src/app/layout/components/content/content.component.ts @@ -1,4 +1,4 @@ -import { Component, HostBinding, OnDestroy, OnInit } from '@angular/core'; +import { Component, HostBinding, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { ActivatedRoute, NavigationEnd, Router } from '@angular/router'; import { Subject } from 'rxjs'; import { filter, map } from 'rxjs/operators'; @@ -8,10 +8,11 @@ import { fuseAnimations } from '@fuse/animations'; import { FuseConfigService } from '@fuse/services/config.service'; @Component({ - selector : 'content', - templateUrl: './content.component.html', - styleUrls : ['./content.component.scss'], - animations : fuseAnimations + selector : 'content', + templateUrl : './content.component.html', + styleUrls : ['./content.component.scss'], + encapsulation: ViewEncapsulation.None, + animations : fuseAnimations }) export class ContentComponent implements OnInit, OnDestroy { diff --git a/src/app/layout/blocks/content/content.module.ts b/src/app/layout/components/content/content.module.ts similarity index 81% rename from src/app/layout/blocks/content/content.module.ts rename to src/app/layout/components/content/content.module.ts index 5b2c42d7..410b821c 100644 --- a/src/app/layout/blocks/content/content.module.ts +++ b/src/app/layout/components/content/content.module.ts @@ -3,7 +3,7 @@ import { RouterModule } from '@angular/router'; import { FuseSharedModule } from '@fuse/shared.module'; -import { ContentComponent } from 'app/layout/blocks/content/content.component'; +import { ContentComponent } from 'app/layout/components/content/content.component'; @NgModule({ declarations: [ diff --git a/src/app/layout/blocks/footer/footer.component.html b/src/app/layout/components/footer/footer.component.html similarity index 100% rename from src/app/layout/blocks/footer/footer.component.html rename to src/app/layout/components/footer/footer.component.html diff --git a/src/app/layout/blocks/footer/footer.component.scss b/src/app/layout/components/footer/footer.component.scss similarity index 94% rename from src/app/layout/blocks/footer/footer.component.scss rename to src/app/layout/components/footer/footer.component.scss index 54033040..d684b80b 100644 --- a/src/app/layout/blocks/footer/footer.component.scss +++ b/src/app/layout/components/footer/footer.component.scss @@ -1,6 +1,6 @@ :host { display: flex; - flex: 0 1 auto; + flex: 0 0 auto; z-index: 3; .mat-toolbar { diff --git a/src/app/layout/blocks/footer/footer.component.ts b/src/app/layout/components/footer/footer.component.ts similarity index 100% rename from src/app/layout/blocks/footer/footer.component.ts rename to src/app/layout/components/footer/footer.component.ts diff --git a/src/app/layout/blocks/footer/footer.module.ts b/src/app/layout/components/footer/footer.module.ts similarity index 85% rename from src/app/layout/blocks/footer/footer.module.ts rename to src/app/layout/components/footer/footer.module.ts index 058b7aad..d0d6b7de 100644 --- a/src/app/layout/blocks/footer/footer.module.ts +++ b/src/app/layout/components/footer/footer.module.ts @@ -3,7 +3,7 @@ import { MatButtonModule, MatIconModule, MatToolbarModule } from '@angular/mater import { FuseSharedModule } from '@fuse/shared.module'; -import { FooterComponent } from 'app/layout/blocks/footer/footer.component'; +import { FooterComponent } from 'app/layout/components/footer/footer.component'; @NgModule({ declarations: [ diff --git a/src/app/layout/blocks/navbar/navbar.component.html b/src/app/layout/components/navbar/navbar.component.html similarity index 100% rename from src/app/layout/blocks/navbar/navbar.component.html rename to src/app/layout/components/navbar/navbar.component.html diff --git a/src/app/layout/blocks/navbar/navbar.component.scss b/src/app/layout/components/navbar/navbar.component.scss similarity index 100% rename from src/app/layout/blocks/navbar/navbar.component.scss rename to src/app/layout/components/navbar/navbar.component.scss diff --git a/src/app/layout/blocks/navbar/navbar.component.ts b/src/app/layout/components/navbar/navbar.component.ts similarity index 93% rename from src/app/layout/blocks/navbar/navbar.component.ts rename to src/app/layout/components/navbar/navbar.component.ts index 0ef3d7a3..c611f7c9 100644 --- a/src/app/layout/blocks/navbar/navbar.component.ts +++ b/src/app/layout/components/navbar/navbar.component.ts @@ -3,12 +3,10 @@ import { NavigationEnd, Router } from '@angular/router'; import { Subject } from 'rxjs'; import { filter, takeUntil } from 'rxjs/operators'; +import { FuseNavigationService } from '@fuse/components/navigation/navigation.service'; import { FusePerfectScrollbarDirective } from '@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive'; import { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service'; -import { navigation } from 'app/navigation/navigation'; -import { FuseNavigationService } from '@fuse/components/navigation/navigation.service'; - @Component({ selector : 'navbar', templateUrl : './navbar.component.html', @@ -43,7 +41,6 @@ export class NavbarComponent implements OnInit, OnDestroy { // Set the defaults this.layout = 'vertical'; - this.navigation = navigation; // Set the private defaults this._unsubscribeAll = new Subject(); @@ -94,6 +91,13 @@ export class NavbarComponent implements OnInit, OnDestroy } } ); + + // Get current navigation + this._fuseNavigationService.onNavigationChanged + .pipe(filter(value => value !== null)) + .subscribe(() => { + this.navigation = this._fuseNavigationService.getCurrentNavigation(); + }); } /** diff --git a/src/app/layout/blocks/navbar/navbar.module.ts b/src/app/layout/components/navbar/navbar.module.ts similarity index 86% rename from src/app/layout/blocks/navbar/navbar.module.ts rename to src/app/layout/components/navbar/navbar.module.ts index 03d2e2a7..acb91738 100644 --- a/src/app/layout/blocks/navbar/navbar.module.ts +++ b/src/app/layout/components/navbar/navbar.module.ts @@ -4,7 +4,7 @@ import { MatButtonModule, MatIconModule } from '@angular/material'; import { FuseNavigationModule } from '@fuse/components'; import { FuseSharedModule } from '@fuse/shared.module'; -import { NavbarComponent } from 'app/layout/blocks/navbar/navbar.component'; +import { NavbarComponent } from 'app/layout/components/navbar/navbar.component'; @NgModule({ declarations: [ diff --git a/src/app/layout/blocks/quick-panel/quick-panel.component.html b/src/app/layout/components/quick-panel/quick-panel.component.html similarity index 100% rename from src/app/layout/blocks/quick-panel/quick-panel.component.html rename to src/app/layout/components/quick-panel/quick-panel.component.html diff --git a/src/app/layout/blocks/quick-panel/quick-panel.component.scss b/src/app/layout/components/quick-panel/quick-panel.component.scss similarity index 100% rename from src/app/layout/blocks/quick-panel/quick-panel.component.scss rename to src/app/layout/components/quick-panel/quick-panel.component.scss diff --git a/src/app/layout/blocks/quick-panel/quick-panel.component.ts b/src/app/layout/components/quick-panel/quick-panel.component.ts similarity index 100% rename from src/app/layout/blocks/quick-panel/quick-panel.component.ts rename to src/app/layout/components/quick-panel/quick-panel.component.ts diff --git a/src/app/layout/blocks/quick-panel/quick-panel.module.ts b/src/app/layout/components/quick-panel/quick-panel.module.ts similarity index 83% rename from src/app/layout/blocks/quick-panel/quick-panel.module.ts rename to src/app/layout/components/quick-panel/quick-panel.module.ts index 0d4062cc..48009f2e 100644 --- a/src/app/layout/blocks/quick-panel/quick-panel.module.ts +++ b/src/app/layout/components/quick-panel/quick-panel.module.ts @@ -3,7 +3,7 @@ import { MatDividerModule, MatListModule, MatSlideToggleModule } from '@angular/ import { FuseSharedModule } from '@fuse/shared.module'; -import { QuickPanelComponent } from 'app/layout/blocks/quick-panel/quick-panel.component'; +import { QuickPanelComponent } from 'app/layout/components/quick-panel/quick-panel.component'; @NgModule({ declarations: [ diff --git a/src/app/layout/blocks/toolbar/toolbar.component.html b/src/app/layout/components/toolbar/toolbar.component.html similarity index 96% rename from src/app/layout/blocks/toolbar/toolbar.component.html rename to src/app/layout/components/toolbar/toolbar.component.html index d1d3cf8e..d8f7e2b6 100644 --- a/src/app/layout/blocks/toolbar/toolbar.component.html +++ b/src/app/layout/components/toolbar/toolbar.component.html @@ -8,7 +8,7 @@ @@ -92,7 +92,7 @@ diff --git a/src/app/layout/blocks/toolbar/toolbar.component.scss b/src/app/layout/components/toolbar/toolbar.component.scss similarity index 100% rename from src/app/layout/blocks/toolbar/toolbar.component.scss rename to src/app/layout/components/toolbar/toolbar.component.scss diff --git a/src/app/layout/blocks/toolbar/toolbar.component.ts b/src/app/layout/components/toolbar/toolbar.component.ts similarity index 98% rename from src/app/layout/blocks/toolbar/toolbar.component.ts rename to src/app/layout/components/toolbar/toolbar.component.ts index 34ab33fc..b2fdf441 100644 --- a/src/app/layout/blocks/toolbar/toolbar.component.ts +++ b/src/app/layout/components/toolbar/toolbar.component.ts @@ -146,11 +146,11 @@ export class ToolbarComponent implements OnInit, OnDestroy // ----------------------------------------------------------------------------------------------------- /** - * Toggle sidebar opened + * Toggle sidebar open * * @param key */ - toggleSidebarOpened(key): void + toggleSidebarOpen(key): void { this._fuseSidebarService.getSidebar(key).toggleOpen(); } diff --git a/src/app/layout/blocks/toolbar/toolbar.module.ts b/src/app/layout/components/toolbar/toolbar.module.ts similarity index 90% rename from src/app/layout/blocks/toolbar/toolbar.module.ts rename to src/app/layout/components/toolbar/toolbar.module.ts index 4217e99a..17e36e0c 100644 --- a/src/app/layout/blocks/toolbar/toolbar.module.ts +++ b/src/app/layout/components/toolbar/toolbar.module.ts @@ -5,7 +5,7 @@ import { MatButtonModule, MatIconModule, MatMenuModule, MatProgressBarModule, Ma import { FuseSearchBarModule, FuseShortcutsModule } from '@fuse/components'; import { FuseSharedModule } from '@fuse/shared.module'; -import { ToolbarComponent } from 'app/layout/blocks/toolbar/toolbar.component'; +import { ToolbarComponent } from 'app/layout/components/toolbar/toolbar.component'; @NgModule({ declarations: [ diff --git a/src/app/layout/horizontal/layout-1/layout-1.component.html b/src/app/layout/horizontal/layout-1/layout-1.component.html new file mode 100644 index 00000000..1294d2da --- /dev/null +++ b/src/app/layout/horizontal/layout-1/layout-1.component.html @@ -0,0 +1,91 @@ +
+ + + + + + + + + + + +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + + + + + + + +
+
+ + +
+ + + +
+
+ + +
+ + + + + + + +
+ + + +
+
+ + +
+ + + + + + + + \ No newline at end of file diff --git a/src/app/layout/horizontal/layout-1/layout-1.component.scss b/src/app/layout/horizontal/layout-1/layout-1.component.scss new file mode 100644 index 00000000..1d854f63 --- /dev/null +++ b/src/app/layout/horizontal/layout-1/layout-1.component.scss @@ -0,0 +1,131 @@ +@import "src/@fuse/scss/fuse"; + +horizontal-layout-1 { + display: flex; + flex: 1 1 auto; + width: 100%; + + #main { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + width: 100%; + z-index: 1; + + // Container 1 + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + width: 100%; + + // Container 2 + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + min-width: 0; + + // Container 3 (Scrollable) + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + transform: translateZ(0); + + &.container-scroll { + overflow-x: hidden; + overflow-y: auto; + + // Content component + content { + flex: 1 0 auto; + + > *:not(router-outlet) { + flex: 1 0 auto; + } + } + } + } + } + } + } +} + +vertical-layout-111 { + display: flex; + flex-direction: column; + width: 100%; + height: 100%; + + /* > .mat-sidenav-container { + display: flex; + flex: 1; + + > .mat-sidenav-content, + > .mat-drawer-content { + display: flex; + flex: 1; + overflow: hidden; + height: 100vh;*/ + + @include media-breakpoint-down('sm') { + height: auto !important; + } + + #main-content { + display: flex; + flex: 1; + flex-direction: column; + overflow: hidden; + background: #FAFAFA; + + #wrapper { + display: flex; + position: relative; + flex: 1; + overflow: hidden; + + .content-wrapper { + display: flex; + flex-direction: column; + flex: 1; + overflow: hidden; + + content { + position: relative; + display: flex; + flex: 1; + flex-direction: row; + width: 100%; + overflow: hidden; + + > *:not(router-outlet):not(.ps__scrollbar-x-rail):not(.ps__scrollbar-y-rail) { + display: flex; + flex: 1; + width: 100%; + min-width: 100%; + } + + > *.ng-animating { + + .mat-tab-body { + height: 100vh; + } + } + } + } + //} + //} + } + } + + &[fuse-layout-mode="boxed"] { + max-width: 1200px; + margin: 0 auto; + @include mat-elevation(8); + } +} diff --git a/src/app/layout/vertical/basic/basic.component.ts b/src/app/layout/horizontal/layout-1/layout-1.component.ts similarity index 87% rename from src/app/layout/vertical/basic/basic.component.ts rename to src/app/layout/horizontal/layout-1/layout-1.component.ts index ad498b0e..9b2868c0 100644 --- a/src/app/layout/vertical/basic/basic.component.ts +++ b/src/app/layout/horizontal/layout-1/layout-1.component.ts @@ -6,12 +6,12 @@ import { FuseConfigService } from '@fuse/services/config.service'; import { navigation } from 'app/navigation/navigation'; @Component({ - selector : 'vertical-nav-basic-layout', - templateUrl : './basic.component.html', - styleUrls : ['./basic.component.scss'], + selector : 'horizontal-layout-1', + templateUrl : './layout-1.component.html', + styleUrls : ['./layout-1.component.scss'], encapsulation: ViewEncapsulation.None }) -export class VerticalNavBasicLayoutComponent implements OnInit, OnDestroy +export class HorizontalLayout1Component implements OnInit, OnDestroy { fuseConfig: any; navigation: any; diff --git a/src/app/layout/horizontal/layout-1/layout-1.module.ts b/src/app/layout/horizontal/layout-1/layout-1.module.ts new file mode 100644 index 00000000..ee92e4b6 --- /dev/null +++ b/src/app/layout/horizontal/layout-1/layout-1.module.ts @@ -0,0 +1,38 @@ +import { NgModule } from '@angular/core'; +import { MatSidenavModule } from '@angular/material'; + +import { FuseSidebarModule, FuseThemeOptionsModule } from '@fuse/components'; +import { FuseSharedModule } from '@fuse/shared.module'; + +import { ContentModule } from 'app/layout/components/content/content.module'; +import { FooterModule } from 'app/layout/components/footer/footer.module'; +import { NavbarModule } from 'app/layout/components/navbar/navbar.module'; +import { QuickPanelModule } from 'app/layout/components/quick-panel/quick-panel.module'; +import { ToolbarModule } from 'app/layout/components/toolbar/toolbar.module'; + +import { HorizontalLayout1Component } from 'app/layout/horizontal/layout-1/layout-1.component'; + +@NgModule({ + declarations: [ + HorizontalLayout1Component + ], + imports : [ + MatSidenavModule, + + FuseSharedModule, + FuseSidebarModule, + FuseThemeOptionsModule, + + ContentModule, + FooterModule, + NavbarModule, + QuickPanelModule, + ToolbarModule + ], + exports : [ + HorizontalLayout1Component + ] +}) +export class HorizontalLayout1Module +{ +} diff --git a/src/app/layout/layout.module.ts b/src/app/layout/layout.module.ts index 0d168275..0030580c 100644 --- a/src/app/layout/layout.module.ts +++ b/src/app/layout/layout.module.ts @@ -1,13 +1,19 @@ import { NgModule } from '@angular/core'; -import { VerticalNavBasicLayoutModule } from 'app/layout/vertical/basic/basic.module'; +import { VerticalLayout1Module } from 'app/layout/vertical/layout-1/layout-1.module'; +import { VerticalLayout2Module } from 'app/layout/vertical/layout-2/layout-2.module'; +import { VerticalLayout3Module } from 'app/layout/vertical/layout-3/layout-3.module'; @NgModule({ imports: [ - VerticalNavBasicLayoutModule + VerticalLayout1Module, + VerticalLayout2Module, + VerticalLayout3Module ], exports: [ - VerticalNavBasicLayoutModule + VerticalLayout1Module, + VerticalLayout2Module, + VerticalLayout3Module ] }) export class LayoutModule diff --git a/src/app/layout/vertical/basic/basic.component.html b/src/app/layout/vertical/basic/basic.component.html deleted file mode 100644 index a12d2561..00000000 --- a/src/app/layout/vertical/basic/basic.component.html +++ /dev/null @@ -1,77 +0,0 @@ - - -
- - - - - - - - - - - - -
- - - - - - - -
- - - - - - - - - - - -
-
- - -
- - - - - - - -
- - - -
-
- - -
- - - - - - - -
- - \ No newline at end of file diff --git a/src/app/layout/vertical/basic/basic.component.scss b/src/app/layout/vertical/basic/basic.component.scss deleted file mode 100644 index 3220c433..00000000 --- a/src/app/layout/vertical/basic/basic.component.scss +++ /dev/null @@ -1,75 +0,0 @@ -@import "src/@fuse/scss/fuse"; - -vertical-nav-basic-layout { - display: flex; - flex-direction: column; - width: 100%; - height: 100%; - - > .mat-sidenav-container { - display: flex; - flex: 1; - - > .mat-sidenav-content, - > .mat-drawer-content { - display: flex; - flex: 1; - overflow: hidden; - height: 100vh; - - @include media-breakpoint-down('sm') { - height: auto !important; - } - - #main-content { - display: flex; - flex: 1; - flex-direction: column; - overflow: hidden; - - #wrapper { - display: flex; - position: relative; - flex: 1; - overflow: hidden; - - .content-wrapper { - display: flex; - flex-direction: column; - flex: 1; - overflow: hidden; - - content { - position: relative; - display: flex; - flex: 1; - flex-direction: row; - width: 100%; - overflow: hidden; - - > *:not(router-outlet):not(.ps__scrollbar-x-rail):not(.ps__scrollbar-y-rail) { - display: flex; - flex: 1; - width: 100%; - min-width: 100%; - } - - > *.ng-animating { - - .mat-tab-body { - height: 100vh; - } - } - } - } - } - } - } - } - - &[fuse-layout-mode="boxed"] { - max-width: 1200px; - margin: 0 auto; - @include mat-elevation(8); - } -} diff --git a/src/app/layout/vertical/basic/basic.module.ts b/src/app/layout/vertical/basic/basic.module.ts deleted file mode 100644 index 1f7a8949..00000000 --- a/src/app/layout/vertical/basic/basic.module.ts +++ /dev/null @@ -1,38 +0,0 @@ -import { NgModule } from '@angular/core'; -import { MatSidenavModule } from '@angular/material'; - -import { FuseSidebarModule, FuseThemeOptionsModule } from '@fuse/components'; -import { FuseSharedModule } from '@fuse/shared.module'; - -import { ContentModule } from 'app/layout/blocks/content/content.module'; -import { FooterModule } from 'app/layout/blocks/footer/footer.module'; -import { NavbarModule } from 'app/layout/blocks/navbar/navbar.module'; -import { QuickPanelModule } from 'app/layout/blocks/quick-panel/quick-panel.module'; -import { ToolbarModule } from 'app/layout/blocks/toolbar/toolbar.module'; - -import { VerticalNavBasicLayoutComponent } from 'app/layout/vertical/basic/basic.component'; - -@NgModule({ - declarations: [ - VerticalNavBasicLayoutComponent - ], - imports : [ - MatSidenavModule, - - FuseSharedModule, - FuseSidebarModule, - FuseThemeOptionsModule, - - ContentModule, - FooterModule, - NavbarModule, - QuickPanelModule, - ToolbarModule - ], - exports : [ - VerticalNavBasicLayoutComponent - ] -}) -export class VerticalNavBasicLayoutModule -{ -} diff --git a/src/app/layout/vertical/layout-1/layout-1.component.html b/src/app/layout/vertical/layout-1/layout-1.component.html new file mode 100644 index 00000000..5492fe03 --- /dev/null +++ b/src/app/layout/vertical/layout-1/layout-1.component.html @@ -0,0 +1,83 @@ +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + + + + + + + +
+
+ + +
+ + + +
+
+ + +
+ + + + + + + +
+ + + +
+
+ + +
+ + + + + + + + \ No newline at end of file diff --git a/src/app/layout/vertical/layout-1/layout-1.component.scss b/src/app/layout/vertical/layout-1/layout-1.component.scss new file mode 100644 index 00000000..b0990b8a --- /dev/null +++ b/src/app/layout/vertical/layout-1/layout-1.component.scss @@ -0,0 +1,117 @@ +@import "src/@fuse/scss/fuse"; + +vertical-layout-1 { + display: flex; + flex: 1 1 auto; + width: 100%; + + #main { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + width: 100%; + z-index: 1; + + // Container 1 + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + width: 100%; + + // Container 2 + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + min-width: 0; + + // Container 3 (Scrollable) + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + transform: translateZ(0); + } + } + } + } +} + +vertical-layout-111 { + display: flex; + flex-direction: column; + width: 100%; + height: 100%; + + /* > .mat-sidenav-container { + display: flex; + flex: 1; + + > .mat-sidenav-content, + > .mat-drawer-content { + display: flex; + flex: 1; + overflow: hidden; + height: 100vh;*/ + + @include media-breakpoint-down('sm') { + height: auto !important; + } + + #main-content { + display: flex; + flex: 1; + flex-direction: column; + overflow: hidden; + background: #FAFAFA; + + #wrapper { + display: flex; + position: relative; + flex: 1; + overflow: hidden; + + .content-wrapper { + display: flex; + flex-direction: column; + flex: 1; + overflow: hidden; + + content { + position: relative; + display: flex; + flex: 1; + flex-direction: row; + width: 100%; + overflow: hidden; + + > *:not(router-outlet):not(.ps__scrollbar-x-rail):not(.ps__scrollbar-y-rail) { + display: flex; + flex: 1; + width: 100%; + min-width: 100%; + } + + > *.ng-animating { + + .mat-tab-body { + height: 100vh; + } + } + } + } + //} + //} + } + } + + &[fuse-layout-mode="boxed"] { + max-width: 1200px; + margin: 0 auto; + @include mat-elevation(8); + } +} diff --git a/src/app/layout/vertical/layout-1/layout-1.component.ts b/src/app/layout/vertical/layout-1/layout-1.component.ts new file mode 100644 index 00000000..07c58e02 --- /dev/null +++ b/src/app/layout/vertical/layout-1/layout-1.component.ts @@ -0,0 +1,64 @@ +import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; + +import { FuseConfigService } from '@fuse/services/config.service'; +import { navigation } from 'app/navigation/navigation'; + +@Component({ + selector : 'vertical-layout-1', + templateUrl : './layout-1.component.html', + styleUrls : ['./layout-1.component.scss'], + encapsulation: ViewEncapsulation.None +}) +export class VerticalLayout1Component implements OnInit, OnDestroy +{ + fuseConfig: any; + navigation: any; + + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + */ + constructor( + private _fuseConfigService: FuseConfigService + ) + { + // Set the defaults + this.navigation = navigation; + + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + // Subscribe to config changes + this._fuseConfigService.config + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe((config) => { + this.fuseConfig = config; + }); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } +} diff --git a/src/app/layout/vertical/layout-1/layout-1.module.ts b/src/app/layout/vertical/layout-1/layout-1.module.ts new file mode 100644 index 00000000..b6e77784 --- /dev/null +++ b/src/app/layout/vertical/layout-1/layout-1.module.ts @@ -0,0 +1,35 @@ +import { NgModule } from '@angular/core'; + +import { FuseSidebarModule, FuseThemeOptionsModule } from '@fuse/components'; +import { FuseSharedModule } from '@fuse/shared.module'; + +import { ContentModule } from 'app/layout/components/content/content.module'; +import { FooterModule } from 'app/layout/components/footer/footer.module'; +import { NavbarModule } from 'app/layout/components/navbar/navbar.module'; +import { QuickPanelModule } from 'app/layout/components/quick-panel/quick-panel.module'; +import { ToolbarModule } from 'app/layout/components/toolbar/toolbar.module'; + +import { VerticalLayout1Component } from 'app/layout/vertical/layout-1/layout-1.component'; + +@NgModule({ + declarations: [ + VerticalLayout1Component + ], + imports : [ + FuseSharedModule, + FuseSidebarModule, + FuseThemeOptionsModule, + + ContentModule, + FooterModule, + NavbarModule, + QuickPanelModule, + ToolbarModule + ], + exports : [ + VerticalLayout1Component + ] +}) +export class VerticalLayout1Module +{ +} diff --git a/src/app/layout/vertical/layout-2/layout-2.component.html b/src/app/layout/vertical/layout-2/layout-2.component.html new file mode 100644 index 00000000..b95d2d4a --- /dev/null +++ b/src/app/layout/vertical/layout-2/layout-2.component.html @@ -0,0 +1,83 @@ +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + + + + + + + +
+
+ + +
+ + + +
+
+ + +
+ + + + + + + +
+ + + +
+
+ + +
+ + + + + + + + \ No newline at end of file diff --git a/src/app/layout/vertical/layout-2/layout-2.component.scss b/src/app/layout/vertical/layout-2/layout-2.component.scss new file mode 100644 index 00000000..d1496150 --- /dev/null +++ b/src/app/layout/vertical/layout-2/layout-2.component.scss @@ -0,0 +1,53 @@ +@import "src/@fuse/scss/fuse"; + +vertical-layout-2 { + display: flex; + flex: 1 1 auto; + width: 100%; + + #main { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + width: 100%; + z-index: 1; + + // Container 1 + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + width: 100%; + + // Container 2 + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + min-width: 0; + + // Container 3 (Scrollable) + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + transform: translateZ(0); + overflow-x: hidden; + overflow-y: auto; + + // Content component + content { + flex: 1 0 auto; + + > *:not(router-outlet) { + flex: 1 0 auto; + } + } + } + } + } + } +} diff --git a/src/app/layout/vertical/layout-2/layout-2.component.ts b/src/app/layout/vertical/layout-2/layout-2.component.ts new file mode 100644 index 00000000..82fb5d8a --- /dev/null +++ b/src/app/layout/vertical/layout-2/layout-2.component.ts @@ -0,0 +1,64 @@ +import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; + +import { FuseConfigService } from '@fuse/services/config.service'; +import { navigation } from 'app/navigation/navigation'; + +@Component({ + selector : 'vertical-layout-2', + templateUrl : './layout-2.component.html', + styleUrls : ['./layout-2.component.scss'], + encapsulation: ViewEncapsulation.None +}) +export class VerticalLayout2Component implements OnInit, OnDestroy +{ + fuseConfig: any; + navigation: any; + + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + */ + constructor( + private _fuseConfigService: FuseConfigService + ) + { + // Set the defaults + this.navigation = navigation; + + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + // Subscribe to config changes + this._fuseConfigService.config + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe((config) => { + this.fuseConfig = config; + }); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } +} diff --git a/src/app/layout/vertical/layout-2/layout-2.module.ts b/src/app/layout/vertical/layout-2/layout-2.module.ts new file mode 100644 index 00000000..30b96fc8 --- /dev/null +++ b/src/app/layout/vertical/layout-2/layout-2.module.ts @@ -0,0 +1,35 @@ +import { NgModule } from '@angular/core'; + +import { FuseSidebarModule, FuseThemeOptionsModule } from '@fuse/components'; +import { FuseSharedModule } from '@fuse/shared.module'; + +import { ContentModule } from 'app/layout/components/content/content.module'; +import { FooterModule } from 'app/layout/components/footer/footer.module'; +import { NavbarModule } from 'app/layout/components/navbar/navbar.module'; +import { QuickPanelModule } from 'app/layout/components/quick-panel/quick-panel.module'; +import { ToolbarModule } from 'app/layout/components/toolbar/toolbar.module'; + +import { VerticalLayout2Component } from 'app/layout/vertical/layout-2/layout-2.component'; + +@NgModule({ + declarations: [ + VerticalLayout2Component + ], + imports : [ + FuseSharedModule, + FuseSidebarModule, + FuseThemeOptionsModule, + + ContentModule, + FooterModule, + NavbarModule, + QuickPanelModule, + ToolbarModule + ], + exports : [ + VerticalLayout2Component + ] +}) +export class VerticalLayout2Module +{ +} diff --git a/src/app/layout/vertical/layout-3/layout-3.component.html b/src/app/layout/vertical/layout-3/layout-3.component.html new file mode 100644 index 00000000..4a823b85 --- /dev/null +++ b/src/app/layout/vertical/layout-3/layout-3.component.html @@ -0,0 +1,83 @@ +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + + + + + + + +
+
+ + +
+ + + + + + + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + + + + + + \ No newline at end of file diff --git a/src/app/layout/vertical/layout-3/layout-3.component.scss b/src/app/layout/vertical/layout-3/layout-3.component.scss new file mode 100644 index 00000000..a6d52354 --- /dev/null +++ b/src/app/layout/vertical/layout-3/layout-3.component.scss @@ -0,0 +1,45 @@ +@import "src/@fuse/scss/fuse"; + +vertical-layout-3 { + display: flex; + flex: 1 1 auto; + width: 100%; + + #main { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + width: 100%; + z-index: 1; + + // Container 1 (Scrollable) + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + width: 100%; + overflow-x: hidden; + overflow-y: auto; + transform: translateZ(0); + + // Container 2 + > .container { + position: relative; + display: flex; + flex: 1 0 auto; + width: 100%; + + // Container 3 + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + min-width: 0; + } + } + } + } +} diff --git a/src/app/layout/vertical/layout-3/layout-3.component.ts b/src/app/layout/vertical/layout-3/layout-3.component.ts new file mode 100644 index 00000000..d99091b4 --- /dev/null +++ b/src/app/layout/vertical/layout-3/layout-3.component.ts @@ -0,0 +1,64 @@ +import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; +import { Subject } from 'rxjs'; +import { takeUntil } from 'rxjs/operators'; + +import { FuseConfigService } from '@fuse/services/config.service'; +import { navigation } from 'app/navigation/navigation'; + +@Component({ + selector : 'vertical-layout-3', + templateUrl : './layout-3.component.html', + styleUrls : ['./layout-3.component.scss'], + encapsulation: ViewEncapsulation.None +}) +export class VerticalLayout3Component implements OnInit, OnDestroy +{ + fuseConfig: any; + navigation: any; + + // Private + private _unsubscribeAll: Subject; + + /** + * Constructor + * + * @param {FuseConfigService} _fuseConfigService + */ + constructor( + private _fuseConfigService: FuseConfigService + ) + { + // Set the defaults + this.navigation = navigation; + + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + // Subscribe to config changes + this._fuseConfigService.config + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe((config) => { + this.fuseConfig = config; + }); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + } +} diff --git a/src/app/layout/vertical/layout-3/layout-3.module.ts b/src/app/layout/vertical/layout-3/layout-3.module.ts new file mode 100644 index 00000000..b2bd25cf --- /dev/null +++ b/src/app/layout/vertical/layout-3/layout-3.module.ts @@ -0,0 +1,35 @@ +import { NgModule } from '@angular/core'; + +import { FuseSidebarModule, FuseThemeOptionsModule } from '@fuse/components'; +import { FuseSharedModule } from '@fuse/shared.module'; + +import { ContentModule } from 'app/layout/components/content/content.module'; +import { FooterModule } from 'app/layout/components/footer/footer.module'; +import { NavbarModule } from 'app/layout/components/navbar/navbar.module'; +import { QuickPanelModule } from 'app/layout/components/quick-panel/quick-panel.module'; +import { ToolbarModule } from 'app/layout/components/toolbar/toolbar.module'; + +import { VerticalLayout3Component } from 'app/layout/vertical/layout-3/layout-3.component'; + +@NgModule({ + declarations: [ + VerticalLayout3Component + ], + imports : [ + FuseSharedModule, + FuseSidebarModule, + FuseThemeOptionsModule, + + ContentModule, + FooterModule, + NavbarModule, + QuickPanelModule, + ToolbarModule + ], + exports : [ + VerticalLayout3Component + ] +}) +export class VerticalLayout3Module +{ +} diff --git a/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.html b/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.html index 52281b63..803bdda8 100644 --- a/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.html +++ b/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.html @@ -1,4 +1,4 @@ -
+
@@ -9,7 +9,7 @@
-

Fullwidth with page scroll

+

Fullwidth with container scroll

diff --git a/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts b/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts index 7128f849..7e1616e6 100644 --- a/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts +++ b/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts @@ -1,16 +1,86 @@ -import { Component } from '@angular/core'; +import { Component, OnDestroy, OnInit } from '@angular/core'; +import { takeUntil } from 'rxjs/operators'; +import { Subject } from 'rxjs'; + +import { FuseConfigService } from '@fuse/services/config.service'; +import { FuseMatchMediaService } from '@fuse/services/match-media.service'; @Component({ selector : 'carded-fullwidth', templateUrl: './fullwidth.component.html', styleUrls : ['./fullwidth.component.scss'] }) -export class CardedFullWidthComponent +export class CardedFullWidthComponent implements OnInit, OnDestroy { + // Private + private _unsubscribeAll: Subject; + /** * Constructor + * + * @param {FuseConfigService} _fuseConfigService + * @param {FuseMatchMediaService} _fuseMatchMediaService */ - constructor() + constructor( + private _fuseConfigService: FuseConfigService, + private _fuseMatchMediaService: FuseMatchMediaService + ) { + // Configure the layout + this._fuseConfigService.config = { + layout: { + containerScroll: false + } + }; + + // Set the private defaults + this._unsubscribeAll = new Subject(); + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + // Enable the containerScroll on small screen + // devices to get more screen real estate + this._fuseMatchMediaService.onMediaChange + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe((alias) => { + + // If 'xs' + if ( alias === 'xs' ) + { + // Set the containerScroll to true + this._fuseConfigService.config = { + layout: { + containerScroll: true + } + }; + } + else + { + // Set the containerScroll to false (route default) + this._fuseConfigService.config = { + layout: { + containerScroll: false + } + }; + } + }); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Unsubscribe from all subscriptions + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); } } diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.html b/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.html index 3246adca..575e5515 100644 --- a/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.html +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.html @@ -40,7 +40,7 @@ menu -

Left sidenav with tabs and page scroll

+

Left sidenav with tabs and container scroll

diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.html b/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.html index fb85cfe5..faa84817 100644 --- a/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.html +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.html @@ -32,7 +32,7 @@
-

Left sidenav with page scroll

+

Left sidenav with container scroll

diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.html b/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.html index 376eff20..056ae1cf 100644 --- a/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.html +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.html @@ -19,7 +19,7 @@ menu -

Right sidenav with tabs and page scroll

+

Right sidenav with tabs and container scroll

diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.html b/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.html index aac6936a..7e080983 100644 --- a/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.html +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.html @@ -11,7 +11,7 @@
-

Right sidenav with page scroll

+

Right sidenav with container scroll

diff --git a/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.html b/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.html index 7a991be9..bc6a8ff9 100644 --- a/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.html +++ b/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.html @@ -24,7 +24,7 @@
-

Left sidenav with page scroll

+

Left sidenav with container scroll

diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.html b/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.html index e1832c0b..e4454157 100644 --- a/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.html +++ b/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.html @@ -15,7 +15,7 @@
-

Right sidenav with page scroll

+

Right sidenav with container scroll

From 387077882b2272407bc71723021626585b575ebd Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Tue, 29 May 2018 15:07:13 +0300 Subject: [PATCH 21/80] Codebase improvements --- .../search-bar/search-bar.component.ts | 3 ++- .../components/shortcuts/shortcuts.component.ts | 17 +++++++++++------ 2 files changed, 13 insertions(+), 7 deletions(-) diff --git a/src/@fuse/components/search-bar/search-bar.component.ts b/src/@fuse/components/search-bar/search-bar.component.ts index 8c7180d7..aa75bee7 100644 --- a/src/@fuse/components/search-bar/search-bar.component.ts +++ b/src/@fuse/components/search-bar/search-bar.component.ts @@ -16,7 +16,7 @@ export class FuseSearchBarComponent implements OnInit, OnDestroy toolbarColor: string; @Output() - onInput: EventEmitter = new EventEmitter(); + onInput: EventEmitter; // Private private _unsubscribeAll: Subject; @@ -31,6 +31,7 @@ export class FuseSearchBarComponent implements OnInit, OnDestroy ) { // Set the defaults + this.onInput = new EventEmitter(); this.collapsed = true; // Set the private defaults diff --git a/src/@fuse/components/shortcuts/shortcuts.component.ts b/src/@fuse/components/shortcuts/shortcuts.component.ts index 58e743a0..9275ae1a 100644 --- a/src/@fuse/components/shortcuts/shortcuts.component.ts +++ b/src/@fuse/components/shortcuts/shortcuts.component.ts @@ -15,11 +15,11 @@ import { FuseConfigService } from '@fuse/services/config.service'; }) export class FuseShortcutsComponent implements OnInit, OnDestroy { - shortcutItems: any[] = []; + shortcutItems: any[]; navigationItems: any[]; filteredNavigationItems: any[]; - searching = false; - mobileShortcutsPanelActive = false; + searching: boolean; + mobileShortcutsPanelActive: boolean; toolbarColor: string; @Input() @@ -45,14 +45,19 @@ export class FuseShortcutsComponent implements OnInit, OnDestroy * @param {ObservableMedia} _observableMedia */ constructor( - private _renderer: Renderer2, private _cookieService: CookieService, + private _fuseConfigService: FuseConfigService, private _fuseMatchMediaService: FuseMatchMediaService, private _fuseNavigationService: FuseNavigationService, - private _fuseConfigService: FuseConfigService, - private _observableMedia: ObservableMedia + private _observableMedia: ObservableMedia, + private _renderer: Renderer2 ) { + // Set the defaults + this.shortcutItems = []; + this.searching = false; + this.mobileShortcutsPanelActive = false; + // Set the private defaults this._unsubscribeAll = new Subject(); } From 83c395b8664c4cf94d81f064dc8b06d78adac2d1 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Wed, 30 May 2018 11:49:30 +0300 Subject: [PATCH 22/80] (Sidebar) Make the sidebar invisible when it's not open Made the backdrop methods private --- .../components/sidebar/sidebar.component.ts | 208 ++++++++++++------ 1 file changed, 140 insertions(+), 68 deletions(-) diff --git a/src/@fuse/components/sidebar/sidebar.component.ts b/src/@fuse/components/sidebar/sidebar.component.ts index 5462686d..d44d1c77 100644 --- a/src/@fuse/components/sidebar/sidebar.component.ts +++ b/src/@fuse/components/sidebar/sidebar.component.ts @@ -1,7 +1,7 @@ import { Component, ElementRef, HostBinding, HostListener, Input, OnDestroy, OnInit, Renderer2, ViewEncapsulation } from '@angular/core'; import { animate, AnimationBuilder, AnimationPlayer, style } from '@angular/animations'; import { ObservableMedia } from '@angular/flex-layout'; -import { Subject, Subscription } from 'rxjs'; +import { Subject } from 'rxjs'; import { FuseSidebarService } from './sidebar.service'; import { FuseMatchMediaService } from '@fuse/services/match-media.service'; @@ -159,6 +159,9 @@ export class FuseSidebarComponent implements OnInit, OnDestroy // Register the sidebar this._fuseSidebarService.register(this.name, this); + // Setup visibility + this._setupVisibility(); + // Setup alignment this._setupAlignment(); @@ -224,6 +227,9 @@ export class FuseSidebarComponent implements OnInit, OnDestroy // Set the wasActive for the first time this._wasActive = false; + // Show the sidebar + this._showSidebar(); + // Act on every media change this._fuseMatchMediaService.onMediaChange .pipe(takeUntil(this._unsubscribeAll)) @@ -244,6 +250,9 @@ export class FuseSidebarComponent implements OnInit, OnDestroy // Set the lockedOpen status this.isLockedOpen = true; + // Show the sidebar + this._showSidebar(); + // Force the the opened status to true this.opened = true; @@ -255,7 +264,7 @@ export class FuseSidebarComponent implements OnInit, OnDestroy } // Hide the backdrop if any exists - this.hideBackdrop(); + this._hideBackdrop(); } // De-Activate the lockedOpen else @@ -268,6 +277,9 @@ export class FuseSidebarComponent implements OnInit, OnDestroy // Force the the opened status to close this.opened = false; + + // Hide the sidebar + this._hideSidebar(); } // Store the new active status @@ -275,6 +287,124 @@ export class FuseSidebarComponent implements OnInit, OnDestroy }); } + /** + * Setup the visibility of the sidebar + * + * @private + */ + private _setupVisibility(): void + { + // Remove the existing box-shadow + this._renderer.setStyle(this._elementRef.nativeElement, 'box-shadow', 'none'); + + // Make the sidebar invisible + this._renderer.setStyle(this._elementRef.nativeElement, 'visibility', 'hidden'); + } + + /** + * Show the backdrop + * + * @private + */ + private _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 + * + * @private + */ + private _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; + } + }); + } + + /** + * Change some properties of the sidebar + * and make it visible + * + * @private + */ + private _showSidebar(): void + { + // Remove the box-shadow style + this._renderer.removeStyle(this._elementRef.nativeElement, 'box-shadow'); + + // Make the sidebar invisible + this._renderer.removeStyle(this._elementRef.nativeElement, 'visibility'); + } + + /** + * Change some properties of the sidebar + * and make it invisible + * + * @private + */ + private _hideSidebar(delay = true): void + { + const delayAmount = delay ? 300 : 0; + + // Add a delay so close animation can play + setTimeout(() => { + + // Remove the box-shadow + this._renderer.setStyle(this._elementRef.nativeElement, 'box-shadow', 'none'); + + // Make the sidebar invisible + this._renderer.setStyle(this._elementRef.nativeElement, 'visibility', 'hidden'); + }, delayAmount); + } + // ----------------------------------------------------------------------------------------------------- // @ Public methods // ----------------------------------------------------------------------------------------------------- @@ -289,8 +419,11 @@ export class FuseSidebarComponent implements OnInit, OnDestroy return; } + // Show the sidebar + this._showSidebar(); + // Show the backdrop - this.showBackdrop(); + this._showBackdrop(); // Set the opened status this.opened = true; @@ -307,10 +440,13 @@ export class FuseSidebarComponent implements OnInit, OnDestroy } // Hide the backdrop - this.hideBackdrop(); + this._hideBackdrop(); // Set the opened status this.opened = false; + + // Hide the sidebar + this._hideSidebar(); } /** @@ -404,68 +540,4 @@ export class FuseSidebarComponent implements OnInit, OnDestroy 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; - } - }); - } } From b918fa4122bd76158d7822c29183d195cd1d70fc Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Wed, 30 May 2018 12:22:19 +0300 Subject: [PATCH 23/80] (Sidebar) Changed align to position since align is a native HTML attribute Added invisibleOverlay option --- .../components/sidebar/sidebar.component.scss | 8 +++- .../components/sidebar/sidebar.component.ts | 39 ++++++++++++------- 2 files changed, 31 insertions(+), 16 deletions(-) diff --git a/src/@fuse/components/sidebar/sidebar.component.scss b/src/@fuse/components/sidebar/sidebar.component.scss index 25b9b5ef..66a6b2cc 100644 --- a/src/@fuse/components/sidebar/sidebar.component.scss +++ b/src/@fuse/components/sidebar/sidebar.component.scss @@ -17,12 +17,12 @@ fuse-sidebar { box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.35); background: white; - &.left-aligned { + &.left-positioned { left: 0; transform: translateX(-100%); } - &.right-aligned { + &.right-positioned { right: 0; transform: translateX(100%); } @@ -58,4 +58,8 @@ fuse-sidebar { z-index: 3; background-color: rgba(0, 0, 0, 0.6); opacity: 0; + + &.fuse-sidebar-overlay-invisible { + background-color: transparent; + } } \ No newline at end of file diff --git a/src/@fuse/components/sidebar/sidebar.component.ts b/src/@fuse/components/sidebar/sidebar.component.ts index d44d1c77..bf398ac5 100644 --- a/src/@fuse/components/sidebar/sidebar.component.ts +++ b/src/@fuse/components/sidebar/sidebar.component.ts @@ -20,9 +20,9 @@ export class FuseSidebarComponent implements OnInit, OnDestroy @Input() name: string; - // Align + // Position @Input() - align: 'left' | 'right'; + position: 'left' | 'right'; // Open @HostBinding('class.open') @@ -40,6 +40,10 @@ export class FuseSidebarComponent implements OnInit, OnDestroy @HostBinding('class.unfolded') unfolded: boolean; + // Invisible overlay + @Input() + invisibleOverlay: boolean; + // Private private _folded: boolean; private _fuseConfig: any; @@ -70,9 +74,10 @@ export class FuseSidebarComponent implements OnInit, OnDestroy ) { // Set the defaults - this.opened = false; this.folded = false; - this.align = 'left'; + this.opened = false; + this.position = 'left'; + this.invisibleOverlay = false; // Set the private defaults this._unsubscribeAll = new Subject(); @@ -97,14 +102,14 @@ export class FuseSidebarComponent implements OnInit, OnDestroy this._folded = value; // Programmatically add/remove margin to the element - // that comes after or before based on the alignment + // that comes after or before based on the position let sibling, styleRule; const styleValue = '64px'; // Get the sibling and set the style rule - if ( this.align === 'left' ) + if ( this.position === 'left' ) { sibling = this._elementRef.nativeElement.nextElementSibling; styleRule = 'marginLeft'; @@ -162,8 +167,8 @@ export class FuseSidebarComponent implements OnInit, OnDestroy // Setup visibility this._setupVisibility(); - // Setup alignment - this._setupAlignment(); + // Setup position + this._setupPosition(); // Setup lockedOpen this._setupLockedOpen(); @@ -193,21 +198,21 @@ export class FuseSidebarComponent implements OnInit, OnDestroy // ----------------------------------------------------------------------------------------------------- /** - * Set the sidebar alignment + * Setup the sidebar position * * @private */ - private _setupAlignment(): void + private _setupPosition(): void { // Add the correct class name to the sidebar - // element depending on the align attribute - if ( this.align === 'right' ) + // element depending on the position attribute + if ( this.position === 'right' ) { - this._renderer.addClass(this._elementRef.nativeElement, 'right-aligned'); + this._renderer.addClass(this._elementRef.nativeElement, 'right-positioned'); } else { - this._renderer.addClass(this._elementRef.nativeElement, 'left-aligned'); + this._renderer.addClass(this._elementRef.nativeElement, 'left-positioned'); } } @@ -314,6 +319,12 @@ export class FuseSidebarComponent implements OnInit, OnDestroy // Add a class to the backdrop element this._backdrop.classList.add('fuse-sidebar-overlay'); + // Add a class depending on the invisibleOverlay option + if ( this.invisibleOverlay ) + { + this._backdrop.classList.add('fuse-sidebar-overlay-invisible'); + } + // Append the backdrop to the parent of the sidebar this._renderer.appendChild(this._elementRef.nativeElement.parentElement, this._backdrop); From 232b4de752596e7632b1cf15410ebff955c849e4 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Wed, 30 May 2018 12:23:09 +0300 Subject: [PATCH 24/80] Moved ThemeOptions to the Fuse Sidebar Replaced align with position on Fuse Sidebar components --- .../theme-options.component.html | 29 +-- .../theme-options.component.scss | 69 +------ .../theme-options/theme-options.component.ts | 171 ++++++++++-------- .../theme-options/theme-options.module.ts | 7 +- src/app/app.component.html | 10 + src/app/app.component.scss | 25 +++ src/app/app.component.ts | 18 ++ src/app/app.module.ts | 8 + .../vertical/layout-1/layout-1.component.html | 8 +- .../vertical/layout-1/layout-1.module.ts | 3 +- .../vertical/layout-2/layout-2.component.html | 8 +- .../vertical/layout-2/layout-2.module.ts | 3 +- .../vertical/layout-3/layout-3.component.html | 8 +- .../vertical/layout-3/layout-3.module.ts | 3 +- 14 files changed, 190 insertions(+), 180 deletions(-) diff --git a/src/@fuse/components/theme-options/theme-options.component.html b/src/@fuse/components/theme-options/theme-options.component.html index ffe16bcb..6928fbff 100644 --- a/src/@fuse/components/theme-options/theme-options.component.html +++ b/src/@fuse/components/theme-options/theme-options.component.html @@ -1,12 +1,6 @@ - +
-
- -
- - @@ -26,11 +20,11 @@
-

Vertical Layout Styles:

+

Scrollable Area:

- Layout 1 - Layout 2 - Layout 3 + Content + Wrapper + Body @@ -79,8 +73,15 @@

Toolbar:

Above + + Above Sticky + Below - Below Sticky + + Below Sticky + None @@ -170,4 +171,4 @@
-
+
\ No newline at end of file diff --git a/src/@fuse/components/theme-options/theme-options.component.scss b/src/@fuse/components/theme-options/theme-options.component.scss index 2e2c7c75..1fc3442c 100644 --- a/src/@fuse/components/theme-options/theme-options.component.scss +++ b/src/@fuse/components/theme-options/theme-options.component.scss @@ -10,33 +10,14 @@ } :host { - position: fixed; - display: block; - right: 0; - top: 160px; - z-index: 998; - - &.bar-closed .theme-options-panel { - display: none; - } + display: flex; .theme-options-panel { - position: absolute; - right: 0; - top: 0; - width: 360px; - transform: translate3d(100%, 0, 0); - z-index: 999; - max-height: calc(100vh - 200px); + display: flex; + flex: 1 0 auto; padding: 24px; overflow: auto; - @include media-breakpoint-down('xs') { - top: -120px; - max-height: calc(100vh - 100px); - width: 90vw; - } - .close-button { position: absolute; top: 8px; @@ -61,25 +42,6 @@ } } - .theme-options-panel-overlay { - position: fixed; - display: block; - background: rgba(0, 0, 0, 0); - top: 0; - right: 0; - left: 0; - bottom: 0; - z-index: 998; - - @include media-breakpoint-down('sm') { - background: rgba(0, 0, 0, 0.37); - } - - &.hidden { - display: none; - } - } - .mat-list .mat-list-item { font-size: 15px; } @@ -87,29 +49,4 @@ .mat-divider { margin: 16px; } - - .open-button { - position: absolute; - top: 0; - left: -48px; - width: 48px; - height: 48px; - line-height: 48px; - text-align: center; - cursor: pointer; - border-radius: 0; - margin: 0; - pointer-events: auto; - opacity: .75; - z-index: 998; - - mat-icon { - animation: rotating 3s linear infinite; - } - - &:hover { - opacity: 1; - } - } - } diff --git a/src/@fuse/components/theme-options/theme-options.component.ts b/src/@fuse/components/theme-options/theme-options.component.ts index 6e6ac9a9..aa61360a 100644 --- a/src/@fuse/components/theme-options/theme-options.component.ts +++ b/src/@fuse/components/theme-options/theme-options.component.ts @@ -1,5 +1,4 @@ -import { Component, ElementRef, HostBinding, Input, OnDestroy, OnInit, Renderer2, ViewChild } from '@angular/core'; -import { style, animate, AnimationBuilder, AnimationPlayer } from '@angular/animations'; +import { Component, HostBinding, OnDestroy, OnInit, Renderer2 } from '@angular/core'; import { FormBuilder, FormGroup } from '@angular/forms'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; @@ -7,6 +6,7 @@ import { takeUntil } from 'rxjs/operators'; import { fuseAnimations } from '@fuse/animations'; import { FuseConfigService } from '@fuse/services/config.service'; import { FuseNavigationService } from '@fuse/components/navigation/navigation.service'; +import { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service'; @Component({ selector : 'fuse-theme-options', @@ -18,16 +18,6 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy { fuseConfig: any; fuseConfigForm: FormGroup; - player: AnimationPlayer; - - @ViewChild('openButton') - openButton; - - @ViewChild('panel') - panel; - - @ViewChild('overlay') - overlay: ElementRef; @HostBinding('class.bar-closed') barClosed: boolean; @@ -35,11 +25,20 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy // Private private _unsubscribeAll: Subject; + /** + * Constructor + * + * @param {FormBuilder} _formBuilder + * @param {FuseConfigService} _fuseConfigService + * @param {FuseNavigationService} _fuseNavigationService + * @param {FuseSidebarService} _fuseSidebarService + * @param {Renderer2} _renderer + */ constructor( - private _animationBuilder: AnimationBuilder, private _formBuilder: FormBuilder, private _fuseConfigService: FuseConfigService, private _fuseNavigationService: FuseNavigationService, + private _fuseSidebarService: FuseSidebarService, private _renderer: Renderer2 ) { @@ -92,16 +91,23 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy }); // Subscribe to the form value changes - this.fuseConfigForm.valueChanges.subscribe((config) => { + this.fuseConfigForm.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe((config) => { - // Update the config - this._fuseConfigService.config = config; - }); + // Update the config + this._fuseConfigService.config = config; + }); - // Listen for the overlay's click event - this._renderer.listen(this.overlay.nativeElement, 'click', () => { - this.closeBar(); - }); + // Subscribe to the layout style value changes + const layoutControls: any = this.fuseConfigForm.controls.layout; + layoutControls.controls.style.valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe((layout) => { + + // Reset the config + this.resetConfig(layout); + }); // Add customize nav item that opens the bar programmatically const customFunctionNavItem = { @@ -115,7 +121,7 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy 'type' : 'item', 'icon' : 'settings', 'function': () => { - this.openBar(); + this._toggleSidebarOpen('themeOptionsPanel'); } } ] @@ -137,48 +143,93 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy this._fuseNavigationService.removeNavigationItem('custom-function'); } + // ----------------------------------------------------------------------------------------------------- + // @ Private methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Toggle sidebar open + * + * @param key + * @private + */ + private _toggleSidebarOpen(key): void + { + this._fuseSidebarService.getSidebar(key).toggleOpen(); + } + + // ----------------------------------------------------------------------------------------------------- // @ Public methods // ----------------------------------------------------------------------------------------------------- - /** - * On config change - */ - onConfigChange(layoutChanged = false): void - { - this._fuseConfigService.config = this.fuseConfig; - - // If the layout changed, reset the settings - if ( layoutChanged ) - { - this.resetConfig(); - } - } - /** * Reset the config correctly */ - resetConfig(): void + resetConfig(layout): void { + console.log(layout); + // Check the layout style and reset the // configuration properly so we don't end // up with options that don't work with // selected layout style - switch ( this.fuseConfig.layout.style ) + switch ( layout ) { // Vertical // Layout 1 case 'vertical-layout-1': { - this._fuseConfigService.config = { + // Reset the config form + this.fuseConfigForm.patchValue({ layout: { - style : 'vertical-layout-1', navigation: { - position: 'left' + folder: false + }, + toolbar : { + position: 'below' } } - }; + }); + + break; + } + + // Layout 2 + case 'vertical-layout-2': + { + console.log('resetting the options for vertical-layout-2...'); + + // Reset the config form + this.fuseConfigForm.patchValue({ + layout: { + navigation: { + folder: false + }, + toolbar : { + position: 'below' + } + } + }); + + break; + } + + // Layout 3 + case 'vertical-layout-3': + { + // Reset the config form + this.fuseConfigForm.patchValue({ + layout: { + navigation: { + folder: false + }, + toolbar : { + position: 'below' + } + } + }); break; } @@ -189,40 +240,4 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy } } } - - /** - * Open the bar - */ - openBar(): void - { - this.barClosed = false; - - this.player = - this._animationBuilder - .build([ - style({transform: 'translate3d(100%,0,0)'}), - animate('400ms ease', style({transform: 'translate3d(0,0,0)'})) - ]).create(this.panel.nativeElement); - - this.player.play(); - } - - /** - * Close the bar - */ - closeBar(): void - { - this.player = - this._animationBuilder - .build([ - style({transform: 'translate3d(0,0,0)'}), - animate('400ms ease', style({transform: 'translate3d(100%,0,0)'})) - ]).create(this.panel.nativeElement); - - this.player.play(); - - this.player.onDone(() => { - this.barClosed = true; - }); - } } diff --git a/src/@fuse/components/theme-options/theme-options.module.ts b/src/@fuse/components/theme-options/theme-options.module.ts index d49050cb..4a764bff 100644 --- a/src/@fuse/components/theme-options/theme-options.module.ts +++ b/src/@fuse/components/theme-options/theme-options.module.ts @@ -4,7 +4,10 @@ import { FormsModule, ReactiveFormsModule } from '@angular/forms'; import { FlexLayoutModule } from '@angular/flex-layout'; import { MatButtonModule, MatDividerModule, MatFormFieldModule, MatIconModule, MatOptionModule, MatRadioModule, MatSelectModule, MatSlideToggleModule } from '@angular/material'; +import { FuseDirectivesModule } from '@fuse/directives/directives'; +import { FuseSidebarModule } from '@fuse/components/sidebar/sidebar.module'; import { FuseMaterialColorPickerModule } from '@fuse/components/material-color-picker/material-color-picker.module'; + import { FuseThemeOptionsComponent } from '@fuse/components/theme-options/theme-options.component'; @NgModule({ @@ -27,7 +30,9 @@ import { FuseThemeOptionsComponent } from '@fuse/components/theme-options/theme- MatSelectModule, MatSlideToggleModule, - FuseMaterialColorPickerModule + FuseDirectivesModule, + FuseMaterialColorPickerModule, + FuseSidebarModule ], exports : [ FuseThemeOptionsComponent diff --git a/src/app/app.component.html b/src/app/app.component.html index 1e6ab5c9..871dc3d7 100644 --- a/src/app/app.component.html +++ b/src/app/app.component.html @@ -12,3 +12,13 @@ + + + + + + + \ No newline at end of file diff --git a/src/app/app.component.scss b/src/app/app.component.scss index 189729a0..292e233c 100644 --- a/src/app/app.component.scss +++ b/src/app/app.component.scss @@ -1,6 +1,31 @@ :host { + position: relative; display: flex; flex: 1 1 auto; width: 100%; min-width: 0; + + .theme-options-button { + position: absolute; + top: 160px; + right: 0; + width: 48px; + height: 48px; + line-height: 48px; + text-align: center; + cursor: pointer; + border-radius: 0; + margin: 0; + pointer-events: auto; + opacity: .75; + z-index: 998; + + mat-icon { + animation: rotating 3s linear infinite; + } + + &:hover { + opacity: 1; + } + } } \ No newline at end of file diff --git a/src/app/app.component.ts b/src/app/app.component.ts index 2c15072b..a27d185a 100644 --- a/src/app/app.component.ts +++ b/src/app/app.component.ts @@ -5,6 +5,7 @@ import { takeUntil } from 'rxjs/operators'; import { FuseConfigService } from '@fuse/services/config.service'; import { FuseNavigationService } from '@fuse/components/navigation/navigation.service'; +import { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service'; import { FuseSplashScreenService } from '@fuse/services/splash-screen.service'; import { FuseTranslationLoaderService } from '@fuse/services/translation-loader.service'; @@ -30,6 +31,7 @@ export class AppComponent implements OnInit, OnDestroy * * @param {FuseConfigService} _fuseConfigService * @param {FuseNavigationService} _fuseNavigationService + * @param {FuseSidebarService} _fuseSidebarService * @param {FuseSplashScreenService} _fuseSplashScreenService * @param {FuseTranslationLoaderService} _fuseTranslationLoaderService * @param {TranslateService} _translateService @@ -37,6 +39,7 @@ export class AppComponent implements OnInit, OnDestroy constructor( private _fuseConfigService: FuseConfigService, private _fuseNavigationService: FuseNavigationService, + private _fuseSidebarService: FuseSidebarService, private _fuseSplashScreenService: FuseSplashScreenService, private _fuseTranslationLoaderService: FuseTranslationLoaderService, private _translateService: TranslateService @@ -93,4 +96,19 @@ export class AppComponent implements OnInit, OnDestroy this._unsubscribeAll.next(); this._unsubscribeAll.complete(); } + + // ----------------------------------------------------------------------------------------------------- + // @ Private methods + // ----------------------------------------------------------------------------------------------------- + + /** + * Toggle sidebar open + * + * @param key + * @private + */ + private _toggleSidebarOpen(key): void + { + this._fuseSidebarService.getSidebar(key).toggleOpen(); + } } diff --git a/src/app/app.module.ts b/src/app/app.module.ts index b7cc2196..06374179 100644 --- a/src/app/app.module.ts +++ b/src/app/app.module.ts @@ -4,12 +4,14 @@ import { HttpClientModule } from '@angular/common/http'; import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; import { RouterModule, Routes } from '@angular/router'; import { MatMomentDateModule } from '@angular/material-moment-adapter'; +import { MatButtonModule, MatIconModule } from '@angular/material'; import { InMemoryWebApiModule } from 'angular-in-memory-web-api'; import { TranslateModule } from '@ngx-translate/core'; import 'hammerjs'; import { FuseModule } from '@fuse/fuse.module'; import { FuseSharedModule } from '@fuse/shared.module'; +import { FuseSidebarModule, FuseThemeOptionsModule } from '@fuse/components'; import { fuseConfig } from 'app/fuse-config'; @@ -68,9 +70,15 @@ const appRoutes: Routes = [ // Material moment date module MatMomentDateModule, + // Material + MatButtonModule, + MatIconModule, + // Fuse modules FuseModule.forRoot(fuseConfig), FuseSharedModule, + FuseSidebarModule, + FuseThemeOptionsModule, // App modules LayoutModule, diff --git a/src/app/layout/vertical/layout-1/layout-1.component.html b/src/app/layout/vertical/layout-1/layout-1.component.html index 5492fe03..b826ef61 100644 --- a/src/app/layout/vertical/layout-1/layout-1.component.html +++ b/src/app/layout/vertical/layout-1/layout-1.component.html @@ -55,7 +55,7 @@
- - + - - - \ No newline at end of file + \ No newline at end of file diff --git a/src/app/layout/vertical/layout-1/layout-1.module.ts b/src/app/layout/vertical/layout-1/layout-1.module.ts index b6e77784..ed5c7c96 100644 --- a/src/app/layout/vertical/layout-1/layout-1.module.ts +++ b/src/app/layout/vertical/layout-1/layout-1.module.ts @@ -1,6 +1,6 @@ import { NgModule } from '@angular/core'; -import { FuseSidebarModule, FuseThemeOptionsModule } from '@fuse/components'; +import { FuseSidebarModule } from '@fuse/components'; import { FuseSharedModule } from '@fuse/shared.module'; import { ContentModule } from 'app/layout/components/content/content.module'; @@ -18,7 +18,6 @@ import { VerticalLayout1Component } from 'app/layout/vertical/layout-1/layout-1. imports : [ FuseSharedModule, FuseSidebarModule, - FuseThemeOptionsModule, ContentModule, FooterModule, diff --git a/src/app/layout/vertical/layout-2/layout-2.component.html b/src/app/layout/vertical/layout-2/layout-2.component.html index b95d2d4a..22587f0a 100644 --- a/src/app/layout/vertical/layout-2/layout-2.component.html +++ b/src/app/layout/vertical/layout-2/layout-2.component.html @@ -55,7 +55,7 @@
- - + - - - \ No newline at end of file + \ No newline at end of file diff --git a/src/app/layout/vertical/layout-2/layout-2.module.ts b/src/app/layout/vertical/layout-2/layout-2.module.ts index 30b96fc8..26ed77d1 100644 --- a/src/app/layout/vertical/layout-2/layout-2.module.ts +++ b/src/app/layout/vertical/layout-2/layout-2.module.ts @@ -1,6 +1,6 @@ import { NgModule } from '@angular/core'; -import { FuseSidebarModule, FuseThemeOptionsModule } from '@fuse/components'; +import { FuseSidebarModule } from '@fuse/components'; import { FuseSharedModule } from '@fuse/shared.module'; import { ContentModule } from 'app/layout/components/content/content.module'; @@ -18,7 +18,6 @@ import { VerticalLayout2Component } from 'app/layout/vertical/layout-2/layout-2. imports : [ FuseSharedModule, FuseSidebarModule, - FuseThemeOptionsModule, ContentModule, FooterModule, diff --git a/src/app/layout/vertical/layout-3/layout-3.component.html b/src/app/layout/vertical/layout-3/layout-3.component.html index 4a823b85..422f2cbd 100644 --- a/src/app/layout/vertical/layout-3/layout-3.component.html +++ b/src/app/layout/vertical/layout-3/layout-3.component.html @@ -47,7 +47,7 @@ - - + - - - \ No newline at end of file + \ No newline at end of file diff --git a/src/app/layout/vertical/layout-3/layout-3.module.ts b/src/app/layout/vertical/layout-3/layout-3.module.ts index b2bd25cf..a0d16277 100644 --- a/src/app/layout/vertical/layout-3/layout-3.module.ts +++ b/src/app/layout/vertical/layout-3/layout-3.module.ts @@ -1,6 +1,6 @@ import { NgModule } from '@angular/core'; -import { FuseSidebarModule, FuseThemeOptionsModule } from '@fuse/components'; +import { FuseSidebarModule } from '@fuse/components'; import { FuseSharedModule } from '@fuse/shared.module'; import { ContentModule } from 'app/layout/components/content/content.module'; @@ -18,7 +18,6 @@ import { VerticalLayout3Component } from 'app/layout/vertical/layout-3/layout-3. imports : [ FuseSharedModule, FuseSidebarModule, - FuseThemeOptionsModule, ContentModule, FooterModule, From 1b94d8d14e67ff2a4387db5db230b279a4e3632c Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Wed, 30 May 2018 12:23:31 +0300 Subject: [PATCH 25/80] Config types --- src/@fuse/types/fuse-config.ts | 2 +- src/app/fuse-config/index.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/@fuse/types/fuse-config.ts b/src/@fuse/types/fuse-config.ts index 5cdf067a..29be0336 100644 --- a/src/@fuse/types/fuse-config.ts +++ b/src/@fuse/types/fuse-config.ts @@ -18,5 +18,5 @@ export interface FuseConfig mode: 'fullwidth' | 'boxed' }; customScrollbars: boolean; - routerAnimation: string; + routerAnimation: 'fadeIn' | 'slideUp' | 'slideDown' | 'slideRight' | 'slideLeft' | 'none'; } diff --git a/src/app/fuse-config/index.ts b/src/app/fuse-config/index.ts index 8b1c2af2..93dc6e53 100644 --- a/src/app/fuse-config/index.ts +++ b/src/app/fuse-config/index.ts @@ -27,5 +27,5 @@ export const fuseConfig: FuseConfig = { mode : 'fullwidth' }, customScrollbars: true, - routerAnimation : 'fadeIn' // fadeIn, slideUp, slideDown, slideRight, slideLeft, none + routerAnimation : 'fadeIn' }; From a29c4b01ad2015c8dc68aeedc1eeb1019e52c45d Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Wed, 30 May 2018 12:31:58 +0300 Subject: [PATCH 26/80] Update the readme --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 81eacd6e..88a5fc88 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ -# Fuse2 +# Fuse - Angular -Material Design Admin Template with Angular 6+ and Angular Material 2 +Material Design Admin Template with Angular 6+ and Angular Material ## The Community From f693298f3a0c26122a0d01b7f9673ac7461a114c Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Wed, 30 May 2018 19:48:59 +0300 Subject: [PATCH 27/80] Navigation interface --- .../nav-vertical-collapse.component.html | 36 +- .../nav-vertical-collapse.component.ts | 5 +- .../nav-group/nav-vertical-group.component.ts | 4 +- .../nav-item/nav-vertical-item.component.html | 25 +- .../nav-item/nav-vertical-item.component.ts | 4 +- src/@fuse/types/fuse-navigation.ts | 26 + src/@fuse/types/index.ts | 1 + src/app/navigation/navigation.ts | 1272 +++++++++-------- 8 files changed, 719 insertions(+), 654 deletions(-) create mode 100644 src/@fuse/types/fuse-navigation.ts diff --git a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html b/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html index ef09b5e9..dca833e8 100644 --- a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html +++ b/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html @@ -6,21 +6,37 @@ - + + + + + + + + + + + + + + + - - - - - - - + + diff --git a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.ts b/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.ts index ad046c1f..8ef02be0 100644 --- a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.ts +++ b/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.ts @@ -3,8 +3,9 @@ import { NavigationEnd, Router } from '@angular/router'; import { Subject } from 'rxjs'; import { filter, takeUntil } from 'rxjs/operators'; -import { FuseNavigationService } from '../../navigation.service'; +import { FuseNavigationItem } from '@fuse/types'; import { fuseAnimations } from '@fuse/animations'; +import { FuseNavigationService } from '@fuse/components/navigation/navigation.service'; @Component({ selector : 'fuse-nav-vertical-collapse', @@ -15,7 +16,7 @@ import { fuseAnimations } from '@fuse/animations'; export class FuseNavVerticalCollapseComponent implements OnInit, OnDestroy { @Input() - item: any; + item: FuseNavigationItem; @HostBinding('class') classes = 'nav-collapse nav-item'; diff --git a/src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.ts b/src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.ts index 8ec510e2..0959e39d 100644 --- a/src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.ts +++ b/src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.ts @@ -1,5 +1,7 @@ import { Component, HostBinding, Input } from '@angular/core'; +import { FuseNavigationItem } from '@fuse/types'; + @Component({ selector : 'fuse-nav-vertical-group', templateUrl: './nav-vertical-group.component.html', @@ -11,7 +13,7 @@ export class FuseNavVerticalGroupComponent classes = 'nav-group nav-item'; @Input() - item: any; + item: FuseNavigationItem; /** * Constructor diff --git a/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.html b/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.html index f4de0858..0363aaa6 100644 --- a/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.html +++ b/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.html @@ -1,21 +1,36 @@ - + [routerLinkActiveOptions]="{exact: item.exactMatch || false}" + [target]="item.openInNewTab ? '_blank' : '_self'" matRipple> + + + + + - + - + [routerLinkActiveOptions]="{exact: item.exactMatch || false}" + [target]="item.openInNewTab ? '_blank' : '_self'" matRipple> + + + + + diff --git a/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.ts b/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.ts index 481628c0..9fe5c36c 100644 --- a/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.ts +++ b/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.ts @@ -1,5 +1,7 @@ import { Component, HostBinding, Input } from '@angular/core'; +import { FuseNavigationItem } from '@fuse/types'; + @Component({ selector : 'fuse-nav-vertical-item', templateUrl: './nav-vertical-item.component.html', @@ -11,7 +13,7 @@ export class FuseNavVerticalItemComponent classes = 'nav-item'; @Input() - item: any; + item: FuseNavigationItem; /** * Constructor diff --git a/src/@fuse/types/fuse-navigation.ts b/src/@fuse/types/fuse-navigation.ts new file mode 100644 index 00000000..cb915e1e --- /dev/null +++ b/src/@fuse/types/fuse-navigation.ts @@ -0,0 +1,26 @@ +export interface FuseNavigationItem +{ + id: string; + title: string; + type: 'item' | 'group' | 'collapse'; + translate?: string; + icon?: string; + hidden?: boolean; + url?: string; + exactMatch?: boolean; + externalUrl?: boolean; + openInNewTab?: boolean; + function?: any; + badge?: { + title?: string; + translate?: string; + bg?: string; + fg?: string; + }; + children?: FuseNavigationItem[]; +} + +export interface FuseNavigation extends FuseNavigationItem +{ + children?: FuseNavigationItem[]; +} diff --git a/src/@fuse/types/index.ts b/src/@fuse/types/index.ts index f47ab6aa..50ed6d77 100644 --- a/src/@fuse/types/index.ts +++ b/src/@fuse/types/index.ts @@ -1 +1,2 @@ export * from './fuse-config'; +export * from './fuse-navigation'; diff --git a/src/app/navigation/navigation.ts b/src/app/navigation/navigation.ts index 63427768..bfd12d41 100644 --- a/src/app/navigation/navigation.ts +++ b/src/app/navigation/navigation.ts @@ -1,935 +1,937 @@ -export const navigation = [ +import { FuseNavigation } from '@fuse/types'; + +export const navigation: FuseNavigation[] = [ { - 'id' : 'applications', - 'title' : 'Applications', - 'translate': 'NAV.APPLICATIONS', - 'type' : 'group', - 'icon' : 'apps', - 'children' : [ + id : 'applications', + title : 'Applications', + translate: 'NAV.APPLICATIONS', + type : 'group', + icon : 'apps', + children : [ { - 'id' : 'dashboards', - 'title' : 'Dashboards', - 'translate': 'NAV.DASHBOARDS', - 'type' : 'collapse', - 'icon' : 'dashboard', - 'children' : [ + id : 'dashboards', + title : 'Dashboards', + translate: 'NAV.DASHBOARDS', + type : 'collapse', + icon : 'dashboard', + children : [ { - 'id' : 'analytics', - 'title': 'Analytics', - 'type' : 'item', - 'url' : '/apps/dashboards/analytics' + id : 'analytics', + title: 'Analytics', + type : 'item', + url : '/apps/dashboards/analytics' }, { - 'id' : 'project', - 'title': 'Project', - 'type' : 'item', - 'url' : '/apps/dashboards/project' + id : 'project', + title: 'Project', + type : 'item', + url : '/apps/dashboards/project' } ] }, { - 'id' : 'calendar', - 'title' : 'Calendar', - 'translate': 'NAV.CALENDAR', - 'type' : 'item', - 'icon' : 'today', - 'url' : '/apps/calendar' + id : 'calendar', + title : 'Calendar', + translate: 'NAV.CALENDAR', + type : 'item', + icon : 'today', + url : '/apps/calendar' }, { - 'id' : 'e-commerce', - 'title' : 'E-Commerce', - 'translate': 'NAV.ECOMMERCE', - 'type' : 'collapse', - 'icon' : 'shopping_cart', - 'children' : [ + id : 'e-commerce', + title : 'E-Commerce', + translate: 'NAV.ECOMMERCE', + type : 'collapse', + icon : 'shopping_cart', + children : [ { - 'id' : 'dashboard', - 'title': 'Dashboard', - 'type' : 'item', - 'url' : '/apps/e-commerce/dashboard' + id : 'dashboard', + title: 'Dashboard', + type : 'item', + url : '/apps/e-commerce/dashboard' }, { - 'id' : 'products', - 'title' : 'Products', - 'type' : 'item', - 'url' : '/apps/e-commerce/products', - 'exactMatch': true + id : 'products', + title : 'Products', + type : 'item', + url : '/apps/e-commerce/products', + exactMatch: true }, { - 'id' : 'productDetail', - 'title' : 'Product Detail', - 'type' : 'item', - 'url' : '/apps/e-commerce/products/1/printed-dress', - 'exactMatch': true + id : 'productDetail', + title : 'Product Detail', + type : 'item', + url : '/apps/e-commerce/products/1/printed-dress', + exactMatch: true }, { - 'id' : 'orders', - 'title' : 'Orders', - 'type' : 'item', - 'url' : '/apps/e-commerce/orders', - 'exactMatch': true + id : 'orders', + title : 'Orders', + type : 'item', + url : '/apps/e-commerce/orders', + exactMatch: true }, { - 'id' : 'orderDetail', - 'title' : 'Order Detail', - 'type' : 'item', - 'url' : '/apps/e-commerce/orders/1', - 'exactMatch': true + id : 'orderDetail', + title : 'Order Detail', + type : 'item', + url : '/apps/e-commerce/orders/1', + exactMatch: true } ] }, { - 'id' : 'academy', - 'title' : 'Academy', - 'translate': 'NAV.ACADEMY', - 'type' : 'item', - 'icon' : 'school', - 'url' : '/apps/academy' + id : 'academy', + title : 'Academy', + translate: 'NAV.ACADEMY', + type : 'item', + icon : 'school', + url : '/apps/academy' }, { - 'id' : 'mail', - 'title' : 'Mail', - 'translate': 'NAV.MAIL.TITLE', - 'type' : 'item', - 'icon' : 'email', - 'url' : '/apps/mail', - 'badge' : { - 'title' : 25, - 'translate': 'NAV.MAIL.BADGE', - 'bg' : '#F44336', - 'fg' : '#FFFFFF' + id : 'mail', + title : 'Mail', + translate: 'NAV.MAIL.TITLE', + type : 'item', + icon : 'email', + url : '/apps/mail', + badge : { + title : '25', + translate: 'NAV.MAIL.BADGE', + bg : '#F44336', + fg : '#FFFFFF' } }, { - 'id' : 'mail-ngrx', - 'title' : 'Mail Ngrx', - 'translate': 'NAV.MAIL_NGRX.TITLE', - 'type' : 'item', - 'icon' : 'email', - 'url' : '/apps/mail-ngrx', - 'badge' : { - 'title' : 13, - 'translate': 'NAV.MAIL_NGRX.BADGE', - 'bg' : '#EC0C8E', - 'fg' : '#FFFFFF' + id : 'mail-ngrx', + title : 'Mail Ngrx', + translate: 'NAV.MAIL_NGRX.TITLE', + type : 'item', + icon : 'email', + url : '/apps/mail-ngrx', + badge : { + title : '13', + translate: 'NAV.MAIL_NGRX.BADGE', + bg : '#EC0C8E', + fg : '#FFFFFF' } }, { - 'id' : 'chat', - 'title' : 'Chat', - 'translate': 'NAV.CHAT', - 'type' : 'item', - 'icon' : 'chat', - 'url' : '/apps/chat', - 'badge' : { - 'title': 13, - 'bg' : '#09d261', - 'fg' : '#FFFFFF' + id : 'chat', + title : 'Chat', + translate: 'NAV.CHAT', + type : 'item', + icon : 'chat', + url : '/apps/chat', + badge : { + title: '13', + bg : '#09d261', + fg : '#FFFFFF' } }, { - 'id' : 'file-manager', - 'title' : 'File Manager', - 'translate': 'NAV.FILE_MANAGER', - 'type' : 'item', - 'icon' : 'folder', - 'url' : '/apps/file-manager' + id : 'file-manager', + title : 'File Manager', + translate: 'NAV.FILE_MANAGER', + type : 'item', + icon : 'folder', + url : '/apps/file-manager' }, { - 'id' : 'contacts', - 'title' : 'Contacts', - 'translate': 'NAV.CONTACTS', - 'type' : 'item', - 'icon' : 'account_box', - 'url' : '/apps/contacts' + id : 'contacts', + title : 'Contacts', + translate: 'NAV.CONTACTS', + type : 'item', + icon : 'account_box', + url : '/apps/contacts' }, { - 'id' : 'to-do', - 'title' : 'To-Do', - 'translate': 'NAV.TODO', - 'type' : 'item', - 'icon' : 'check_box', - 'url' : '/apps/todo', - 'badge' : { - 'title': 3, - 'bg' : '#FF6F00', - 'fg' : '#FFFFFF' + id : 'to-do', + title : 'To-Do', + translate: 'NAV.TODO', + type : 'item', + icon : 'check_box', + url : '/apps/todo', + badge : { + title: '3', + bg : '#FF6F00', + fg : '#FFFFFF' } }, { - 'id' : 'scrumboard', - 'title' : 'Scrumboard', - 'translate': 'NAV.SCRUMBOARD', - 'type' : 'item', - 'icon' : 'assessment', - 'url' : '/apps/scrumboard' + id : 'scrumboard', + title : 'Scrumboard', + translate: 'NAV.SCRUMBOARD', + type : 'item', + icon : 'assessment', + url : '/apps/scrumboard' } ] }, { - 'id' : 'pages', - 'title' : 'Pages', - 'type' : 'group', - 'icon' : 'pages', - 'children': [ + id : 'pages', + title : 'Pages', + type : 'group', + icon : 'pages', + children: [ { - 'id' : 'authentication', - 'title' : 'Authentication', - 'type' : 'collapse', - 'icon' : 'lock', - 'badge' : { - 'title': 10, - 'bg' : '#525e8a', - 'fg' : '#FFFFFF' + id : 'authentication', + title : 'Authentication', + type : 'collapse', + icon : 'lock', + badge : { + title: '10', + bg : '#525e8a', + fg : '#FFFFFF' }, - 'children': [ + children: [ { - 'id' : 'login', - 'title': 'Login', - 'type' : 'item', - 'url' : '/pages/auth/login' + id : 'login', + title: 'Login', + type : 'item', + url : '/pages/auth/login' }, { - 'id' : 'login-v2', - 'title': 'Login v2', - 'type' : 'item', - 'url' : '/pages/auth/login-2' + id : 'login-v2', + title: 'Login v2', + type : 'item', + url : '/pages/auth/login-2' }, { - 'id' : 'register', - 'title': 'Register', - 'type' : 'item', - 'url' : '/pages/auth/register' + id : 'register', + title: 'Register', + type : 'item', + url : '/pages/auth/register' }, { - 'id' : 'register-v2', - 'title': 'Register v2', - 'type' : 'item', - 'url' : '/pages/auth/register-2' + id : 'register-v2', + title: 'Register v2', + type : 'item', + url : '/pages/auth/register-2' }, { - 'id' : 'forgot-password', - 'title': 'Forgot Password', - 'type' : 'item', - 'url' : '/pages/auth/forgot-password' + id : 'forgot-password', + title: 'Forgot Password', + type : 'item', + url : '/pages/auth/forgot-password' }, { - 'id' : 'forgot-password-v2', - 'title': 'Forgot Password v2', - 'type' : 'item', - 'url' : '/pages/auth/forgot-password-2' + id : 'forgot-password-v2', + title: 'Forgot Password v2', + type : 'item', + url : '/pages/auth/forgot-password-2' }, { - 'id' : 'reset-password', - 'title': 'Reset Password', - 'type' : 'item', - 'url' : '/pages/auth/reset-password' + id : 'reset-password', + title: 'Reset Password', + type : 'item', + url : '/pages/auth/reset-password' }, { - 'id' : 'reset-password-v2', - 'title': 'Reset Password v2', - 'type' : 'item', - 'url' : '/pages/auth/reset-password-2' + id : 'reset-password-v2', + title: 'Reset Password v2', + type : 'item', + url : '/pages/auth/reset-password-2' }, { - 'id' : 'lock-screen', - 'title': 'Lock Screen', - 'type' : 'item', - 'url' : '/pages/auth/lock' + id : 'lock-screen', + title: 'Lock Screen', + type : 'item', + url : '/pages/auth/lock' }, { - 'id' : 'mail-confirmation', - 'title': 'Mail Confirmation', - 'type' : 'item', - 'url' : '/pages/auth/mail-confirm' + id : 'mail-confirmation', + title: 'Mail Confirmation', + type : 'item', + url : '/pages/auth/mail-confirm' } ] }, { - 'id' : 'coming-soon', - 'title': 'Coming Soon', - 'type' : 'item', - 'icon' : 'alarm', - 'url' : '/pages/coming-soon' + id : 'coming-soon', + title: 'Coming Soon', + type : 'item', + icon : 'alarm', + url : '/pages/coming-soon' }, { - 'id' : 'errors', - 'title' : 'Errors', - 'type' : 'collapse', - 'icon' : 'error', - 'children': [ + id : 'errors', + title : 'Errors', + type : 'collapse', + icon : 'error', + children: [ { - 'id' : '404', - 'title': '404', - 'type' : 'item', - 'url' : '/pages/errors/error-404' + id : '404', + title: '404', + type : 'item', + url : '/pages/errors/error-404' }, { - 'id' : '500', - 'title': '500', - 'type' : 'item', - 'url' : '/pages/errors/error-500' + id : '500', + title: '500', + type : 'item', + url : '/pages/errors/error-500' } ] }, { - 'id' : 'invoice', - 'title' : 'Invoice', - 'type' : 'collapse', - 'icon' : 'receipt', - 'children': [ + id : 'invoice', + title : 'Invoice', + type : 'collapse', + icon : 'receipt', + children: [ { - 'id' : 'modern', - 'title': 'Modern', - 'type' : 'item', - 'url' : '/pages/invoices/modern' + id : 'modern', + title: 'Modern', + type : 'item', + url : '/pages/invoices/modern' }, { - 'id' : 'compact', - 'title': 'Compact', - 'type' : 'item', - 'url' : '/pages/invoices/compact' + id : 'compact', + title: 'Compact', + type : 'item', + url : '/pages/invoices/compact' } ] }, { - 'id' : 'maintenance', - 'title': 'Maintenance', - 'type' : 'item', - 'icon' : 'build', - 'url' : '/pages/maintenance' + id : 'maintenance', + title: 'Maintenance', + type : 'item', + icon : 'build', + url : '/pages/maintenance' }, { - 'id' : 'pricing', - 'title' : 'Pricing', - 'type' : 'collapse', - 'icon' : 'attach_money', - 'children': [ + id : 'pricing', + title : 'Pricing', + type : 'collapse', + icon : 'attach_money', + children: [ { - 'id' : 'style-1', - 'title': 'Style 1', - 'type' : 'item', - 'url' : '/pages/pricing/style-1' + id : 'style-1', + title: 'Style 1', + type : 'item', + url : '/pages/pricing/style-1' }, { - 'id' : 'style-2', - 'title': 'Style 2', - 'type' : 'item', - 'url' : '/pages/pricing/style-2' + id : 'style-2', + title: 'Style 2', + type : 'item', + url : '/pages/pricing/style-2' }, { - 'id' : 'style-3', - 'title': 'Style 3', - 'type' : 'item', - 'url' : '/pages/pricing/style-3' + id : 'style-3', + title: 'Style 3', + type : 'item', + url : '/pages/pricing/style-3' } ] }, { - 'id' : 'profile', - 'title': 'Profile', - 'type' : 'item', - 'icon' : 'person', - 'url' : '/pages/profile' + id : 'profile', + title: 'Profile', + type : 'item', + icon : 'person', + url : '/pages/profile' }, { - 'id' : 'search', - 'title': 'Search', - 'type' : 'item', - 'icon' : 'search', - 'url' : '/pages/search' + id : 'search', + title: 'Search', + type : 'item', + icon : 'search', + url : '/pages/search' }, { - 'id' : 'faq', - 'title': 'Faq', - 'type' : 'item', - 'icon' : 'help', - 'url' : '/pages/faq' + id : 'faq', + title: 'Faq', + type : 'item', + icon : 'help', + url : '/pages/faq' }, { - 'id' : 'knowledge-base', - 'title': 'Knowledge Base', - 'type' : 'item', - 'icon' : 'import_contacts', - 'url' : '/pages/knowledge-base' + id : 'knowledge-base', + title: 'Knowledge Base', + type : 'item', + icon : 'import_contacts', + url : '/pages/knowledge-base' } ] }, { - 'id' : 'user-interface', - 'title' : 'User Interface', - 'type' : 'group', - 'icon' : 'web', - 'children': [ + id : 'user-interface', + title : 'User Interface', + type : 'group', + icon : 'web', + children: [ { - 'id' : 'forms', - 'title': 'Forms', - 'type' : 'item', - 'icon' : 'web_asset', - 'url' : '/ui/forms' + id : 'forms', + title: 'Forms', + type : 'item', + icon : 'web_asset', + url : '/ui/forms' }, { - 'id' : 'icons', - 'title': 'Icons', - 'type' : 'item', - 'icon' : 'photo', - 'url' : '/ui/icons' + id : 'icons', + title: 'Icons', + type : 'item', + icon : 'photo', + url : '/ui/icons' }, { - 'id' : 'typography', - 'title': 'Typography', - 'type' : 'item', - 'icon' : 'text_fields', - 'url' : '/ui/typography' + id : 'typography', + title: 'Typography', + type : 'item', + icon : 'text_fields', + url : '/ui/typography' }, { - 'id' : 'helper-classes', - 'title': 'Helper Classes', - 'type' : 'item', - 'icon' : 'help', - 'url' : '/ui/helper-classes' + id : 'helper-classes', + title: 'Helper Classes', + type : 'item', + icon : 'help', + url : '/ui/helper-classes' }, { - 'id' : 'page-layouts', - 'title' : 'Page Layouts', - 'type' : 'collapse', - 'icon' : 'view_quilt', - 'children': [ + id : 'page-layouts', + title : 'Page Layouts', + type : 'collapse', + icon : 'view_quilt', + children: [ { - 'id' : 'carded', - 'title' : 'Carded', - 'type' : 'collapse', - 'badge' : { - 'title': 10, - 'bg' : '#525e8a', - 'fg' : '#FFFFFF' + id : 'carded', + title : 'Carded', + type : 'collapse', + badge : { + title: '10', + bg : '#525e8a', + fg : '#FFFFFF' }, - 'children': [ + children: [ { - 'id' : 'full-width', - 'title': 'Full Width', - 'type' : 'item', - 'url' : '/ui/page-layouts/carded/full-width' + id : 'full-width', + title: 'Full Width', + type : 'item', + url : '/ui/page-layouts/carded/full-width' }, { - 'id' : 'full-width-2', - 'title': 'Full Width 2', - 'type' : 'item', - 'url' : '/ui/page-layouts/carded/full-width-2' + id : 'full-width-2', + title: 'Full Width 2', + type : 'item', + url : '/ui/page-layouts/carded/full-width-2' }, { - 'id' : 'left-sidenav', - 'title': 'Left Sidenav', - 'type' : 'item', - 'url' : '/ui/page-layouts/carded/left-sidenav' + id : 'left-sidenav', + title: 'Left Sidenav', + type : 'item', + url : '/ui/page-layouts/carded/left-sidenav' }, { - 'id' : 'left-sidenav-tabbed', - 'title': 'Left Sidenav Tabbed', - 'type' : 'item', - 'url' : '/ui/page-layouts/carded/left-sidenav-tabbed' + id : 'left-sidenav-tabbed', + title: 'Left Sidenav Tabbed', + type : 'item', + url : '/ui/page-layouts/carded/left-sidenav-tabbed' }, { - 'id' : 'left-sidenav-2', - 'title': 'Left Sidenav 2', - 'type' : 'item', - 'url' : '/ui/page-layouts/carded/left-sidenav-2' + id : 'left-sidenav-2', + title: 'Left Sidenav 2', + type : 'item', + url : '/ui/page-layouts/carded/left-sidenav-2' }, { - 'id' : 'left-sidenav-2-tabbed', - 'title': 'Left Sidenav 2 Tabbed', - 'type' : 'item', - 'url' : '/ui/page-layouts/carded/left-sidenav-2-tabbed' + id : 'left-sidenav-2-tabbed', + title: 'Left Sidenav 2 Tabbed', + type : 'item', + url : '/ui/page-layouts/carded/left-sidenav-2-tabbed' }, { - 'id' : 'right-sidenav', - 'title': 'Right Sidenav', - 'type' : 'item', - 'url' : '/ui/page-layouts/carded/right-sidenav' + id : 'right-sidenav', + title: 'Right Sidenav', + type : 'item', + url : '/ui/page-layouts/carded/right-sidenav' }, { - 'id' : 'right-sidenav-tabbed', - 'title': 'Right Sidenav Tabbed', - 'type' : 'item', - 'url' : '/ui/page-layouts/carded/right-sidenav-tabbed' + id : 'right-sidenav-tabbed', + title: 'Right Sidenav Tabbed', + type : 'item', + url : '/ui/page-layouts/carded/right-sidenav-tabbed' }, { - 'id' : 'right-sidenav-2', - 'title': 'Right Sidenav 2', - 'type' : 'item', - 'url' : '/ui/page-layouts/carded/right-sidenav-2' + id : 'right-sidenav-2', + title: 'Right Sidenav 2', + type : 'item', + url : '/ui/page-layouts/carded/right-sidenav-2' }, { - 'id' : 'right-sidenav-2-tabbed', - 'title': 'Right Sidenav 2 Tabbed', - 'type' : 'item', - 'url' : '/ui/page-layouts/carded/right-sidenav-2-tabbed' + id : 'right-sidenav-2-tabbed', + title: 'Right Sidenav 2 Tabbed', + type : 'item', + url : '/ui/page-layouts/carded/right-sidenav-2-tabbed' } ] }, { - 'id' : 'simple', - 'title' : 'Simple', - 'type' : 'collapse', - 'badge' : { - 'title': 8, - 'bg' : '#525e8a', - 'fg' : '#FFFFFF' + id : 'simple', + title : 'Simple', + type : 'collapse', + badge : { + title: '8', + bg : '#525e8a', + fg : '#FFFFFF' }, - 'children': [ + children: [ { - 'id' : 'full-width', - 'title': 'Full Width', - 'type' : 'item', - 'url' : '/ui/page-layouts/simple/full-width' + id : 'full-width', + title: 'Full Width', + type : 'item', + url : '/ui/page-layouts/simple/full-width' }, { - 'id' : 'left-sidenav', - 'title': 'Left Sidenav', - 'type' : 'item', - 'url' : '/ui/page-layouts/simple/left-sidenav' + id : 'left-sidenav', + title: 'Left Sidenav', + type : 'item', + url : '/ui/page-layouts/simple/left-sidenav' }, { - 'id' : 'left-sidenav-2', - 'title': 'Left Sidenav 2', - 'type' : 'item', - 'url' : '/ui/page-layouts/simple/left-sidenav-2' + id : 'left-sidenav-2', + title: 'Left Sidenav 2', + type : 'item', + url : '/ui/page-layouts/simple/left-sidenav-2' }, { - 'id' : 'left-sidenav-3', - 'title': 'Left Sidenav 3', - 'type' : 'item', - 'url' : '/ui/page-layouts/simple/left-sidenav-3' + id : 'left-sidenav-3', + title: 'Left Sidenav 3', + type : 'item', + url : '/ui/page-layouts/simple/left-sidenav-3' }, { - 'id' : 'right-sidenav', - 'title': 'Right Sidenav', - 'type' : 'item', - 'url' : '/ui/page-layouts/simple/right-sidenav' + id : 'right-sidenav', + title: 'Right Sidenav', + type : 'item', + url : '/ui/page-layouts/simple/right-sidenav' }, { - 'id' : 'right-sidenav-2', - 'title': 'Right Sidenav 2', - 'type' : 'item', - 'url' : '/ui/page-layouts/simple/right-sidenav-2' + id : 'right-sidenav-2', + title: 'Right Sidenav 2', + type : 'item', + url : '/ui/page-layouts/simple/right-sidenav-2' }, { - 'id' : 'right-sidenav-3', - 'title': 'Right Sidenav 3', - 'type' : 'item', - 'url' : '/ui/page-layouts/simple/right-sidenav-3' + id : 'right-sidenav-3', + title: 'Right Sidenav 3', + type : 'item', + url : '/ui/page-layouts/simple/right-sidenav-3' }, { - 'id' : 'tabbed', - 'title': 'Tabbed', - 'type' : 'item', - 'url' : '/ui/page-layouts/simple/tabbed' + id : 'tabbed', + title: 'Tabbed', + type : 'item', + url : '/ui/page-layouts/simple/tabbed' } ] }, { - 'id' : 'blank', - 'title': 'Blank', - 'type' : 'item', - 'url' : '/ui/page-layouts/blank' + id : 'blank', + title: 'Blank', + type : 'item', + url : '/ui/page-layouts/blank' } ] }, { - 'id' : 'colors', - 'title': 'Colors', - 'type' : 'item', - 'icon' : 'color_lens', - 'url' : '/ui/colors' + id : 'colors', + title: 'Colors', + type : 'item', + icon : 'color_lens', + url : '/ui/colors' } ] }, { - 'id' : 'services', - 'title' : 'Services', - 'type' : 'group', - 'icon' : 'settings', - 'children': [ + id : 'services', + title : 'Services', + type : 'group', + icon : 'settings', + children: [ { - 'id' : 'config', - 'title': 'Config', - 'type' : 'item', - 'icon' : 'settings', - 'url' : '/services/config' + id : 'config', + title: 'Config', + type : 'item', + icon : 'settings', + url : '/services/config' }, { - 'id' : 'splash-screen', - 'title': 'Splash Screen', - 'type' : 'item', - 'icon' : 'settings', - 'url' : '/services/splash-screen' + id : 'splash-screen', + title: 'Splash Screen', + type : 'item', + icon : 'settings', + url : '/services/splash-screen' } ] }, { - 'id' : 'components', - 'title' : 'Components', - 'type' : 'group', - 'icon' : 'settings_input_component', - 'children': [ + id : 'components', + title : 'Components', + type : 'group', + icon : 'settings_input_component', + children: [ { - 'id' : 'angular-material-elements', - 'title' : 'Angular Material Elements', - 'type' : 'collapse', - 'icon' : 'layers', - 'children': [ + id : 'angular-material-elements', + title : 'Angular Material Elements', + type : 'collapse', + icon : 'layers', + children: [ { - 'id' : 'form-controls', - 'title' : 'Form Controls', - 'type' : 'group', - 'children': [ + id : 'form-controls', + title : 'Form Controls', + type : 'group', + children: [ { - 'id' : 'autocomplete', - 'title': 'Autocomplete', - 'type' : 'item', - 'url' : '/components/angular-material/autocomplete' + id : 'autocomplete', + title: 'Autocomplete', + type : 'item', + url : '/components/angular-material/autocomplete' }, { - 'id' : 'checkbox', - 'title': 'Checkbox', - 'type' : 'item', - 'url' : '/components/angular-material/checkbox' + id : 'checkbox', + title: 'Checkbox', + type : 'item', + url : '/components/angular-material/checkbox' }, { - 'id' : 'datepicker', - 'title': 'Datepicker', - 'type' : 'item', - 'url' : '/components/angular-material/datepicker' + id : 'datepicker', + title: 'Datepicker', + type : 'item', + url : '/components/angular-material/datepicker' }, { - 'id' : 'form-field', - 'title': 'Form field', - 'type' : 'item', - 'url' : '/components/angular-material/form-field' + id : 'form-field', + title: 'Form field', + type : 'item', + url : '/components/angular-material/form-field' }, { - 'id' : 'input', - 'title': 'Input', - 'type' : 'item', - 'url' : '/components/angular-material/input' + id : 'input', + title: 'Input', + type : 'item', + url : '/components/angular-material/input' }, { - 'id' : 'radio-button', - 'title': 'Radio button', - 'type' : 'item', - 'url' : '/components/angular-material/radio-button' + id : 'radio-button', + title: 'Radio button', + type : 'item', + url : '/components/angular-material/radio-button' }, { - 'id' : 'select', - 'title': 'Select', - 'type' : 'item', - 'url' : '/components/angular-material/select' + id : 'select', + title: 'Select', + type : 'item', + url : '/components/angular-material/select' }, { - 'id' : 'slider', - 'title': 'Slider', - 'type' : 'item', - 'url' : '/components/angular-material/slider' + id : 'slider', + title: 'Slider', + type : 'item', + url : '/components/angular-material/slider' }, { - 'id' : 'slide-toggle', - 'title': 'Slide toggle', - 'type' : 'item', - 'url' : '/components/angular-material/slide-toggle' + id : 'slide-toggle', + title: 'Slide toggle', + type : 'item', + url : '/components/angular-material/slide-toggle' } ] }, { - 'id' : 'navigation', - 'title' : 'Navigation', - 'type' : 'group', - 'children': [ + id : 'navigation', + title : 'Navigation', + type : 'group', + children: [ { - 'id' : 'menu', - 'title': 'Menu', - 'type' : 'item', - 'url' : '/components/angular-material/menu' + id : 'menu', + title: 'Menu', + type : 'item', + url : '/components/angular-material/menu' }, { - 'id' : 'sidenav', - 'title': 'Sidenav', - 'type' : 'item', - 'url' : '/components/angular-material/sidenav' + id : 'sidenav', + title: 'Sidenav', + type : 'item', + url : '/components/angular-material/sidenav' }, { - 'id' : 'toolbar', - 'title': 'Toolbar', - 'type' : 'item', - 'url' : '/components/angular-material/toolbar' + id : 'toolbar', + title: 'Toolbar', + type : 'item', + url : '/components/angular-material/toolbar' } ] }, { - 'id' : 'layout', - 'title' : 'Layout', - 'type' : 'group', - 'children': [ + id : 'layout', + title : 'Layout', + type : 'group', + children: [ { - 'id' : 'badge', - 'title': 'Badge', - 'type' : 'item', - 'url' : '/components/angular-material/badge' + id : 'badge', + title: 'badge', + type : 'item', + url : '/components/angular-material/badge' }, { - 'id' : 'bottom-sheet', - 'title': 'Bottom Sheet', - 'type' : 'item', - 'url' : '/components/angular-material/bottom-sheet' + id : 'bottom-sheet', + title: 'Bottom Sheet', + type : 'item', + url : '/components/angular-material/bottom-sheet' }, { - 'id' : 'card', - 'title': 'Card', - 'type' : 'item', - 'url' : '/components/angular-material/card' + id : 'card', + title: 'Card', + type : 'item', + url : '/components/angular-material/card' }, { - 'id' : 'divider', - 'title': 'Divider', - 'type' : 'item', - 'url' : '/components/angular-material/divider' + id : 'divider', + title: 'Divider', + type : 'item', + url : '/components/angular-material/divider' }, { - 'id' : 'elevation', - 'title': 'Elevation', - 'type' : 'item', - 'url' : '/components/angular-material/elevation' + id : 'elevation', + title: 'Elevation', + type : 'item', + url : '/components/angular-material/elevation' }, { - 'id' : 'expansion-panel', - 'title': 'Expansion Panel', - 'type' : 'item', - 'url' : '/components/angular-material/expansion-panel' + id : 'expansion-panel', + title: 'Expansion Panel', + type : 'item', + url : '/components/angular-material/expansion-panel' }, { - 'id' : 'grid-list', - 'title': 'Grid list', - 'type' : 'item', - 'url' : '/components/angular-material/grid-list' + id : 'grid-list', + title: 'Grid list', + type : 'item', + url : '/components/angular-material/grid-list' }, { - 'id' : 'list', - 'title': 'List', - 'type' : 'item', - 'url' : '/components/angular-material/list' + id : 'list', + title: 'List', + type : 'item', + url : '/components/angular-material/list' }, { - 'id' : 'stepper', - 'title': 'Stepper', - 'type' : 'item', - 'url' : '/components/angular-material/stepper' + id : 'stepper', + title: 'Stepper', + type : 'item', + url : '/components/angular-material/stepper' }, { - 'id' : 'tabs', - 'title': 'Tabs', - 'type' : 'item', - 'url' : '/components/angular-material/tabs' + id : 'tabs', + title: 'Tabs', + type : 'item', + url : '/components/angular-material/tabs' } ] }, { - 'id' : 'buttons-indicators', - 'title' : 'Buttons & Indicators', - 'type' : 'group', - 'children': [ + id : 'buttons-indicators', + title : 'Buttons & Indicators', + type : 'group', + children: [ { - 'id' : 'button', - 'title': 'Button', - 'type' : 'item', - 'url' : '/components/angular-material/button' + id : 'button', + title: 'Button', + type : 'item', + url : '/components/angular-material/button' }, { - 'id' : 'button-toggle', - 'title': 'Button toggle', - 'type' : 'item', - 'url' : '/components/angular-material/button-toggle' + id : 'button-toggle', + title: 'Button toggle', + type : 'item', + url : '/components/angular-material/button-toggle' }, { - 'id' : 'chips', - 'title': 'Chips', - 'type' : 'item', - 'url' : '/components/angular-material/chips' + id : 'chips', + title: 'Chips', + type : 'item', + url : '/components/angular-material/chips' }, { - 'id' : 'icon', - 'title': 'Icon', - 'type' : 'item', - 'url' : '/components/angular-material/icon' + id : 'icon', + title: 'icon', + type : 'item', + url : '/components/angular-material/icon' }, { - 'id' : 'progress-spinner', - 'title': 'Progress spinner', - 'type' : 'item', - 'url' : '/components/angular-material/progress-spinner' + id : 'progress-spinner', + title: 'Progress spinner', + type : 'item', + url : '/components/angular-material/progress-spinner' }, { - 'id' : 'progress-bar', - 'title': 'Progress bar', - 'type' : 'item', - 'url' : '/components/angular-material/progress-bar' + id : 'progress-bar', + title: 'Progress bar', + type : 'item', + url : '/components/angular-material/progress-bar' } ] }, { - 'id' : 'popups-modals', - 'title' : 'Popups & Modals', - 'type' : 'group', - 'children': [ + id : 'popups-modals', + title : 'Popups & Modals', + type : 'group', + children: [ { - 'id' : 'dialog', - 'title': 'Dialog', - 'type' : 'item', - 'url' : '/components/angular-material/dialog' + id : 'dialog', + title: 'Dialog', + type : 'item', + url : '/components/angular-material/dialog' }, { - 'id' : 'snackbar', - 'title': 'Snackbar', - 'type' : 'item', - 'url' : '/components/angular-material/snackbar' + id : 'snackbar', + title: 'Snackbar', + type : 'item', + url : '/components/angular-material/snackbar' }, { - 'id' : 'tooltip', - 'title': 'Tooltip', - 'type' : 'item', - 'url' : '/components/angular-material/tooltip' + id : 'tooltip', + title: 'Tooltip', + type : 'item', + url : '/components/angular-material/tooltip' } ] }, { - 'id' : 'data-table', - 'title' : 'Data table', - 'type' : 'group', - 'children': [ + id : 'data-table', + title : 'Data table', + type : 'group', + children: [ { - 'id' : 'paginator', - 'title': 'Paginator', - 'type' : 'item', - 'url' : '/components/angular-material/paginator' + id : 'paginator', + title: 'Paginator', + type : 'item', + url : '/components/angular-material/paginator' }, { - 'id' : 'sort-header', - 'title': 'Sort header', - 'type' : 'item', - 'url' : '/components/angular-material/sort-header' + id : 'sort-header', + title: 'Sort header', + type : 'item', + url : '/components/angular-material/sort-header' }, { - 'id' : 'table', - 'title': 'Table', - 'type' : 'item', - 'url' : '/components/angular-material/table' + id : 'table', + title: 'Table', + type : 'item', + url : '/components/angular-material/table' } ] }, { - 'id' : 'tree', - 'title': 'Tree', - 'type' : 'item', - 'url' : '/components/angular-material/tree' + id : 'tree', + title: 'Tree', + type : 'item', + url : '/components/angular-material/tree' } ] }, { - 'id' : 'cards', - 'title': 'Cards', - 'type' : 'item', - 'icon' : 'settings_input_component', - 'url' : '/components/cards' + id : 'cards', + title: 'Cards', + type : 'item', + icon : 'settings_input_component', + url : '/components/cards' }, { - 'id' : 'countdown', - 'title': 'Countdown', - 'type' : 'item', - 'icon' : 'settings_input_component', - 'url' : '/components/countdown' + id : 'countdown', + title: 'Countdown', + type : 'item', + icon : 'settings_input_component', + url : '/components/countdown' }, { - 'id' : 'highlight', - 'title': 'Highlight', - 'type' : 'item', - 'icon' : 'settings_input_component', - 'url' : '/components/highlight' + id : 'highlight', + title: 'Highlight', + type : 'item', + icon : 'settings_input_component', + url : '/components/highlight' }, { - 'id' : 'material-color-picker', - 'title': 'Material Color Picker', - 'type' : 'item', - 'icon' : 'settings_input_component', - 'url' : '/components/material-color-picker' + id : 'material-color-picker', + title: 'Material Color Picker', + type : 'item', + icon : 'settings_input_component', + url : '/components/material-color-picker' }, { - 'id' : 'multi-language', - 'title': 'Multi Language', - 'type' : 'item', - 'icon' : 'settings_input_component', - 'url' : '/components/multi-language' + id : 'multi-language', + title: 'Multi Language', + type : 'item', + icon : 'settings_input_component', + url : '/components/multi-language' }, { - 'id' : 'navigation', - 'title': 'Navigation', - 'type' : 'item', - 'icon' : 'settings_input_component', - 'url' : '/components/navigation' + id : 'navigation', + title: 'Navigation', + type : 'item', + icon : 'settings_input_component', + url : '/components/navigation' }, { - 'id' : 'search-bar', - 'title': 'Search Bar', - 'type' : 'item', - 'icon' : 'settings_input_component', - 'url' : '/components/search-bar' + id : 'search-bar', + title: 'Search Bar', + type : 'item', + icon : 'settings_input_component', + url : '/components/search-bar' }, { - 'id' : 'sidebar', - 'title': 'Sidebar', - 'type' : 'item', - 'icon' : 'settings_input_component', - 'url' : '/components/sidebar' + id : 'sidebar', + title: 'Sidebar', + type : 'item', + icon : 'settings_input_component', + url : '/components/sidebar' }, { - 'id' : 'shortcuts', - 'title': 'Shortcuts', - 'type' : 'item', - 'icon' : 'settings_input_component', - 'url' : '/components/shortcuts' + id : 'shortcuts', + title: 'Shortcuts', + type : 'item', + icon : 'settings_input_component', + url : '/components/shortcuts' }, { - 'id' : 'widget', - 'title': 'Widget', - 'type' : 'item', - 'icon' : 'settings_input_component', - 'url' : '/components/widget' + id : 'widget', + title: 'Widget', + type : 'item', + icon : 'settings_input_component', + url : '/components/widget' } ] }, { - 'id' : '3rd-party-components', - 'title' : '3rd Party components', - 'type' : 'group', - 'icon' : 'settings_input_component', - 'children': [ + id : '3rd-party-components', + title : '3rd Party components', + type : 'group', + icon : 'settings_input_component', + children: [ { - 'id' : 'datatables', - 'title' : 'Datatables', - 'type' : 'collapse', - 'icon' : 'border_all', - 'children': [ + id : 'datatables', + title : 'Datatables', + type : 'collapse', + icon : 'border_all', + children: [ { - 'id' : 'ngxdatatable', - 'title': 'ngx-datatable', - 'type' : 'item', - 'url' : '/components-third-party/datatables/ngx-datatable' + id : 'ngxdatatable', + title: 'ngx-datatable', + type : 'item', + url : '/components-third-party/datatables/ngx-datatable' } ] }, { - 'id' : 'google-maps', - 'title': 'Google Maps', - 'type' : 'item', - 'icon' : 'place', - 'url' : '/components-third-party/google-maps' + id : 'google-maps', + title: 'Google Maps', + type : 'item', + icon : 'place', + url : '/components-third-party/google-maps' } ] } From 420d8d1a1b1fe2ab81d9e9444adc76369688f99b Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Wed, 6 Jun 2018 21:19:43 +0300 Subject: [PATCH 28/80] Navigation icon colors --- .../vertical/nav-collapse/nav-vertical-collapse.component.html | 2 +- .../vertical/nav-item/nav-vertical-item.component.html | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html b/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html index dca833e8..acc4d0c6 100644 --- a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html +++ b/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html @@ -41,7 +41,7 @@ - {{item.icon}} + {{item.icon}} {{item.title}} diff --git a/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.html b/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.html index 0363aaa6..927f3cb3 100644 --- a/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.html +++ b/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.html @@ -35,7 +35,7 @@ - {{item.icon}} + {{item.icon}} {{item.title}} From 5c1f2ad1e3f87b3446ff5903f809616822bc33a4 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Wed, 6 Jun 2018 21:20:04 +0300 Subject: [PATCH 29/80] New layout system & new layouts (wip) --- .../components/sidebar/sidebar.component.ts | 2 +- .../theme-options.component.html | 354 +++++++++++++----- .../theme-options.component.scss | 86 +++-- .../theme-options/theme-options.component.ts | 262 +++++++------ src/@fuse/directives/directives.ts | 3 + .../fuse-inner-scroll.directive.ts | 61 +++ .../fuse-perfect-scrollbar.directive.ts | 45 ++- src/@fuse/scss/partials/_page-layouts.scss | 141 ++++--- src/@fuse/services/config.service.ts | 32 ++ src/@fuse/types/fuse-config.ts | 15 +- src/app/app.component.html | 19 +- src/app/app.component.scss | 7 + src/app/fuse-config/index.ts | 19 +- .../components/content/content.component.scss | 9 +- .../components/toolbar/toolbar.component.ts | 4 +- src/app/layout/layout.module.ts | 19 +- .../body-scroll/body-scroll.component.html | 115 ++++++ .../body-scroll/body-scroll.component.scss} | 6 +- .../body-scroll.component.ts} | 8 +- .../body-scroll/body-scroll.module.ts} | 11 +- .../content-scroll.component.html | 115 ++++++ .../content-scroll.component.scss | 61 +++ .../content-scroll.component.ts} | 8 +- .../content-scroll.module.ts} | 11 +- .../vertical/layout-1/layout-1.component.html | 81 ---- .../vertical/layout-1/layout-1.component.scss | 117 ------ .../vertical/layout-2/layout-2.component.html | 130 ++++--- .../vertical/layout-2/layout-2.component.scss | 35 +- .../vertical/layout-2/layout-2.module.ts | 3 + .../vertical/layout-3/layout-3.component.html | 81 ---- .../full-width-1.component.html} | 2 +- .../full-width-1.component.scss} | 0 .../full-width-1/full-width-1.component.ts | 16 + .../full-width-2.component.html} | 4 +- .../full-width-2.component.scss} | 0 .../full-width-2.component.ts} | 4 +- .../full-width-tabbed-1.component.html | 115 ++++++ .../full-width-tabbed-1.component.scss} | 0 .../full-width-tabbed-1.component.ts | 16 + .../full-width-tabbed-2.component.html | 115 ++++++ .../full-width-tabbed-2.component.scss} | 0 .../full-width-tabbed-2.component.ts | 16 + .../carded/fullwidth/fullwidth.component.ts | 86 ----- .../left-sidenav-1.component.html} | 6 +- .../left-sidenav-1.component.scss} | 0 .../left-sidenav-1.component.ts | 17 + .../left-sidenav-2-tabbed.component.ts | 17 - .../left-sidenav-2.component.html | 4 +- .../left-sidenav-tabbed-1.component.html} | 28 +- .../left-sidenav-tabbed-1.component.scss} | 0 .../left-sidenav-tabbed-1.component.ts | 17 + .../left-sidenav-tabbed-2.component.html} | 6 +- .../left-sidenav-tabbed-2.component.scss} | 0 .../left-sidenav-tabbed-2.component.ts | 17 + .../left-sidenav-tabbed.component.ts | 17 - .../left-sidenav/left-sidenav.component.ts | 17 - .../right-sidenav-1.component.html} | 6 +- .../right-sidenav-1.component.scss} | 0 .../right-sidenav-1.component.ts | 17 + .../right-sidenav-2-tabbed.component.ts | 17 - .../right-sidenav-2.component.html | 4 +- .../right-sidenav-tabbed-1.component.html} | 26 +- .../right-sidenav-tabbed-1.component.scss} | 0 .../right-sidenav-tabbed-1.component.ts | 17 + .../right-sidenav-tabbed-2.component.html} | 4 +- .../right-sidenav-tabbed-2.component.scss} | 0 .../right-sidenav-tabbed-2.component.ts | 17 + .../right-sidenav-tabbed.component.ts | 17 - .../right-sidenav/right-sidenav.component.ts | 17 - .../ui/page-layouts/page-layouts.module.ts | 102 ++--- .../full-width-1.component.html} | 2 +- .../full-width-1.component.scss} | 0 .../full-width-1/full-width-1.component.ts | 16 + .../simple/fullwidth/fullwidth.component.ts | 16 - .../left-sidenav-1.component.html} | 6 +- .../left-sidenav-1.component.scss} | 0 .../left-sidenav-1.component.ts | 17 + .../left-sidenav-2.component.html | 12 +- .../left-sidenav-3.component.html | 4 +- .../left-sidenav/left-sidenav.component.ts | 17 - .../right-sidenav-1.component.html} | 0 .../right-sidenav-1.component.scss | 0 .../right-sidenav-1.component.ts | 17 + .../right-sidenav-2.component.html | 12 +- .../right-sidenav-3.component.html | 2 +- .../right-sidenav/right-sidenav.component.ts | 17 - .../tabbed-1.component.html} | 0 .../simple/tabbed-1/tabbed-1.component.scss | 0 .../simple/tabbed-1/tabbed-1.component.ts | 17 + .../simple/tabbed/tabbed.component.ts | 17 - src/app/navigation/navigation.ts | 94 +++-- src/index.html | 2 +- 92 files changed, 1793 insertions(+), 1099 deletions(-) create mode 100644 src/@fuse/directives/fuse-inner-scroll/fuse-inner-scroll.directive.ts create mode 100644 src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.html rename src/app/layout/vertical/{layout-3/layout-3.component.scss => layout-1/body-scroll/body-scroll.component.scss} (93%) rename src/app/layout/vertical/layout-1/{layout-1.component.ts => body-scroll/body-scroll.component.ts} (86%) rename src/app/layout/vertical/{layout-3/layout-3.module.ts => layout-1/body-scroll/body-scroll.module.ts} (71%) create mode 100644 src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.html create mode 100644 src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.scss rename src/app/layout/vertical/{layout-3/layout-3.component.ts => layout-1/content-scroll/content-scroll.component.ts} (86%) rename src/app/layout/vertical/layout-1/{layout-1.module.ts => content-scroll/content-scroll.module.ts} (70%) delete mode 100644 src/app/layout/vertical/layout-1/layout-1.component.html delete mode 100644 src/app/layout/vertical/layout-1/layout-1.component.scss delete mode 100644 src/app/layout/vertical/layout-3/layout-3.component.html rename src/app/main/ui/page-layouts/carded/{fullwidth-2/fullwidth-2.component.html => full-width-1/full-width-1.component.html} (94%) rename src/app/main/ui/page-layouts/carded/{fullwidth-2/fullwidth-2.component.scss => full-width-1/full-width-1.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/carded/full-width-1/full-width-1.component.ts rename src/app/main/ui/page-layouts/carded/{fullwidth/fullwidth.component.html => full-width-2/full-width-2.component.html} (88%) rename src/app/main/ui/page-layouts/carded/{fullwidth/fullwidth.component.scss => full-width-2/full-width-2.component.scss} (100%) rename src/app/main/ui/page-layouts/carded/{fullwidth-2/fullwidth-2.component.ts => full-width-2/full-width-2.component.ts} (67%) create mode 100644 src/app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component.html rename src/app/main/ui/page-layouts/carded/{left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.scss => full-width-tabbed-1/full-width-tabbed-1.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component.ts create mode 100644 src/app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component.html rename src/app/main/ui/page-layouts/carded/{left-sidenav-tabbed/left-sidenav-tabbed.component.scss => full-width-tabbed-2/full-width-tabbed-2.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component.ts delete mode 100644 src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts rename src/app/main/ui/page-layouts/carded/{left-sidenav/left-sidenav.component.html => left-sidenav-1/left-sidenav-1.component.html} (90%) rename src/app/main/ui/page-layouts/carded/{left-sidenav/left-sidenav.component.scss => left-sidenav-1/left-sidenav-1.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/carded/left-sidenav-1/left-sidenav-1.component.ts delete mode 100644 src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.ts rename src/app/main/ui/page-layouts/carded/{left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.html => left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.html} (82%) rename src/app/main/ui/page-layouts/carded/{right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.scss => left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.ts rename src/app/main/ui/page-layouts/carded/{left-sidenav-tabbed/left-sidenav-tabbed.component.html => left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.html} (97%) rename src/app/main/ui/page-layouts/carded/{right-sidenav-tabbed/right-sidenav-tabbed.component.scss => left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.ts delete mode 100644 src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.ts delete mode 100644 src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.ts rename src/app/main/ui/page-layouts/carded/{right-sidenav/right-sidenav.component.html => right-sidenav-1/right-sidenav-1.component.html} (90%) rename src/app/main/ui/page-layouts/carded/{right-sidenav/right-sidenav.component.scss => right-sidenav-1/right-sidenav-1.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/carded/right-sidenav-1/right-sidenav-1.component.ts delete mode 100644 src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.ts rename src/app/main/ui/page-layouts/carded/{right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.html => right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.html} (82%) rename src/app/main/ui/page-layouts/{simple/fullwidth/fullwidth.component.scss => carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.ts rename src/app/main/ui/page-layouts/carded/{right-sidenav-tabbed/right-sidenav-tabbed.component.html => right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.html} (97%) rename src/app/main/ui/page-layouts/{simple/left-sidenav/left-sidenav.component.scss => carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.ts delete mode 100644 src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.ts delete mode 100644 src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.ts rename src/app/main/ui/page-layouts/simple/{fullwidth/fullwidth.component.html => full-width-1/full-width-1.component.html} (92%) rename src/app/main/ui/page-layouts/simple/{right-sidenav/right-sidenav.component.scss => full-width-1/full-width-1.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/simple/full-width-1/full-width-1.component.ts delete mode 100644 src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.ts rename src/app/main/ui/page-layouts/simple/{left-sidenav/left-sidenav.component.html => left-sidenav-1/left-sidenav-1.component.html} (86%) rename src/app/main/ui/page-layouts/simple/{tabbed/tabbed.component.scss => left-sidenav-1/left-sidenav-1.component.scss} (100%) create mode 100644 src/app/main/ui/page-layouts/simple/left-sidenav-1/left-sidenav-1.component.ts delete mode 100644 src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.ts rename src/app/main/ui/page-layouts/simple/{right-sidenav/right-sidenav.component.html => right-sidenav-1/right-sidenav-1.component.html} (100%) create mode 100644 src/app/main/ui/page-layouts/simple/right-sidenav-1/right-sidenav-1.component.scss create mode 100644 src/app/main/ui/page-layouts/simple/right-sidenav-1/right-sidenav-1.component.ts delete mode 100644 src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.ts rename src/app/main/ui/page-layouts/simple/{tabbed/tabbed.component.html => tabbed-1/tabbed-1.component.html} (100%) create mode 100644 src/app/main/ui/page-layouts/simple/tabbed-1/tabbed-1.component.scss create mode 100644 src/app/main/ui/page-layouts/simple/tabbed-1/tabbed-1.component.ts delete mode 100644 src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.ts diff --git a/src/@fuse/components/sidebar/sidebar.component.ts b/src/@fuse/components/sidebar/sidebar.component.ts index bf398ac5..e698a9e2 100644 --- a/src/@fuse/components/sidebar/sidebar.component.ts +++ b/src/@fuse/components/sidebar/sidebar.component.ts @@ -263,7 +263,7 @@ export class FuseSidebarComponent implements OnInit, OnDestroy // Read the folded setting from the config // and fold the sidebar if it's true - if ( this._fuseConfig.layout.navigation.folded ) + if ( this._fuseConfig.layout.navbar.folded ) { this.fold(); } diff --git a/src/@fuse/components/theme-options/theme-options.component.html b/src/@fuse/components/theme-options/theme-options.component.html index 6928fbff..74fa994a 100644 --- a/src/@fuse/components/theme-options/theme-options.component.html +++ b/src/@fuse/components/theme-options/theme-options.component.html @@ -1,124 +1,282 @@ -
+
- +
-
+ Theme Options -
+ - - +
+ +

Layout Styles

+ + + + Vertical Layout #1 - Content Scroll + + + Vertical Layout #1 - Body Scroll + + + Vertical Layout #2 + + Horizontal Layout #1 + Horizontal Layout #2 - --> -
- -

Scrollable Area:

- - Content - Wrapper - Body - + + - -

Horizontal Layout Styles:

- - Layout 1 - Layout 2 - + + + +
-
+

Layout Width

+ + Fullwidth + Boxed + - -

Navigation Position:

+
- - - Left - Right - None - + +
- - - Top - None - +

Navbar

- - -

Navigation Fold:

- + + Hide + + + Folded -
-
+

Position:

+ + Left + Right + -
+
-

Toolbar:

- - Above - - Above Sticky - - Below - - Below Sticky - - None - +
-
+

Toolbar

-
+ + Hide + + +

Position:

+ + Above + Below Static + Below Sticky + Below Fixed + + +
-

Footer:

- - Above - Below - Below Sticky - None - +
-
+

Footer

- -

Layout Mode:

- - Boxed - Fullwidth - + + Hide + -
+

Position:

+ + Above + Below Static + Below Sticky + Below Fixed + - +
-

Custom scrollbars:

- + + + + + + +
+ +

Layout Width

+ + Fullwidth + Boxed + + +
+ + +
+ +

Navbar

+ + + Hide + + + + Folded + + +

Position:

+ + Left + Right + + +
+ + +
+ +

Toolbar

+ + + Hide + + +

Position:

+ + Above Static + Above Sticky + Above Fixed + Below + + +
+ + +
+ +

Footer

+ + + Hide + + +

Position:

+ + Above Static + Above Sticky + Above Fixed + Below + + +
+ +
+ + + + + +
+ +

Layout Width

+ + Fullwidth + Boxed + + +
+ + +
+ +

Navbar

+ + + Hide + + + + Folded + + +

Position:

+ + Left + Right + + +
+ + +
+ +

Toolbar

+ + + Hide + + +

Position:

+ + Above Static + Above Sticky + Above Fixed + + +
+ + +
+ +

Footer

+ + + Hide + + +

Position:

+ + Above Static + Above Sticky + Above Fixed + + +
+ +
+ + + +
+ + +
+ +

Custom scrollbars

+ + Enable custom scrollbars - +
+ + +
+ +

Colors

-

Colors:

@@ -128,9 +286,9 @@
-

Navigation Bar Color

+

Navbar Color

+ [(selectedClass)]="fuseConfig.layout.navbar.background">
@@ -141,9 +299,13 @@
- +
+ + +
+ +

Router Animation

-

Router Animation:

@@ -167,8 +329,8 @@ - +
-
+ -
\ No newline at end of file +
diff --git a/src/@fuse/components/theme-options/theme-options.component.scss b/src/@fuse/components/theme-options/theme-options.component.scss index 1fc3442c..6c083492 100644 --- a/src/@fuse/components/theme-options/theme-options.component.scss +++ b/src/@fuse/components/theme-options/theme-options.component.scss @@ -14,39 +14,69 @@ .theme-options-panel { display: flex; + flex-direction: column; flex: 1 0 auto; - padding: 24px; + padding: 40px 24px 24px 24px; overflow: auto; - .close-button { - position: absolute; - top: 8px; - right: 8px; + .header { + display: flex; + flex: 0 1 auto; + margin-bottom: 32px; + align-items: center; + justify-content: space-between; + + .title { + font-size: 20px; + font-weight: 500; + padding-left: 4px; + } } - h3 { - font-size: 14px; - font-weight: 500; - color: rgba(0, 0, 0, 0.54); + form { + display: flex; + flex: 1 1 auto; + flex-direction: column; + + .group { + display: flex; + flex: 1 0 auto; + flex-direction: column; + position: relative; + border: 1px solid rgba(0, 0, 0, 0.12); + border-radius: 2px; + padding: 28px 16px 8px 16px; + margin: 16px 0; + + h2 { + position: absolute; + top: -11px; + left: 8px; + margin: 0; + padding: 0 8px; + font-size: 16px; + font-weight: 500; + background: white; + color: rgba(0, 0, 0, 0.54); + } + + h3 { + font-size: 14px; + font-weight: 500; + color: rgba(0, 0, 0, 0.54); + margin: 24px 0 16px 0; + padding: 0; + + &:first-of-type { + margin-top: 0; + } + } + } + + .colors { + display: block !important; + width: 100%; + } } - - .mat-divider { - display: block !important; - width: 100%; - margin: 24px 0 16px 0; - } - - .colors { - display: block !important; - width: 100%; - } - } - - .mat-list .mat-list-item { - font-size: 15px; - } - - .mat-divider { - margin: 16px; } } diff --git a/src/@fuse/components/theme-options/theme-options.component.ts b/src/@fuse/components/theme-options/theme-options.component.ts index aa61360a..c5230167 100644 --- a/src/@fuse/components/theme-options/theme-options.component.ts +++ b/src/@fuse/components/theme-options/theme-options.component.ts @@ -1,5 +1,5 @@ import { Component, HostBinding, OnDestroy, OnInit, Renderer2 } from '@angular/core'; -import { FormBuilder, FormGroup } from '@angular/forms'; +import { FormBuilder, FormControl, FormGroup } from '@angular/forms'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; @@ -17,7 +17,7 @@ import { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service'; export class FuseThemeOptionsComponent implements OnInit, OnDestroy { fuseConfig: any; - fuseConfigForm: FormGroup; + form: FormGroup; @HostBinding('class.bar-closed') barClosed: boolean; @@ -58,40 +58,59 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy */ ngOnInit(): void { + // Build the config form + // noinspection TypeScriptValidateTypes + this.form = this._formBuilder.group({ + layout : this._formBuilder.group({ + style : new FormControl(), + width : new FormControl(), + navbar : this._formBuilder.group({ + hidden : new FormControl(), + position : new FormControl(), + folded : new FormControl(), + background: new FormControl() + }), + toolbar: this._formBuilder.group({ + hidden : new FormControl(), + position : new FormControl(), + background: new FormControl() + }), + footer : this._formBuilder.group({ + hidden : new FormControl(), + position : new FormControl(), + background: new FormControl() + }) + }), + customScrollbars: new FormControl(), + routerAnimation : new FormControl() + }); + // Subscribe to the config changes this._fuseConfigService.config .pipe(takeUntil(this._unsubscribeAll)) .subscribe((config) => { - this.fuseConfig = config; - } - ); - // Build the config form - // noinspection TypeScriptValidateTypes - this.fuseConfigForm = this._formBuilder.group({ - layout : this._formBuilder.group({ - style : this.fuseConfig.layout.style, - navigation: this._formBuilder.group({ - position : this.fuseConfig.layout.navigation.position, - folded : this.fuseConfig.layout.navigation.folded, - background: this.fuseConfig.layout.navigation.background - }), - toolbar : this._formBuilder.group({ - position : this.fuseConfig.layout.toolbar.position, - background: this.fuseConfig.layout.toolbar.background - }), - footer : this._formBuilder.group({ - position : this.fuseConfig.layout.footer.position, - background: this.fuseConfig.layout.footer.background - }), - mode : this.fuseConfig.layout.mode - }), - customScrollbars: this.fuseConfig.customScrollbars, - routerAnimation : this.fuseConfig.routerAnimation - }); + // Update the stored config + this.fuseConfig = config; + + // Set the config form values without emitting an event + // so that we don't end up with an infinite loop + this.form.setValue(config, {emitEvent: false}); + }); + + // Subscribe to the specific form value changes (layout.style) + this.form.get('layout.style').valueChanges + .pipe(takeUntil(this._unsubscribeAll)) + .subscribe((value) => { + + // Reset the form values based on the + // selected layout style + this._resetFormValues(value); + + }); // Subscribe to the form value changes - this.fuseConfigForm.valueChanges + this.form.valueChanges .pipe(takeUntil(this._unsubscribeAll)) .subscribe((config) => { @@ -99,16 +118,6 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy this._fuseConfigService.config = config; }); - // Subscribe to the layout style value changes - const layoutControls: any = this.fuseConfigForm.controls.layout; - layoutControls.controls.style.valueChanges - .pipe(takeUntil(this._unsubscribeAll)) - .subscribe((layout) => { - - // Reset the config - this.resetConfig(layout); - }); - // Add customize nav item that opens the bar programmatically const customFunctionNavItem = { 'id' : 'custom-function', @@ -147,6 +156,103 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy // @ Private methods // ----------------------------------------------------------------------------------------------------- + /** + * Reset the form values based on the + * selected layout style + * + * @param value + * @private + */ + private _resetFormValues(value): void + { + switch ( value ) + { + // Vertical Layout #1 - Content scroll + case 'vertical-layout-1-content-scroll': + { + this.form.patchValue({ + layout: { + width : 'fullwidth', + navbar : { + hidden : false, + position : 'left', + folded : false, + background: 'mat-fuse-dark-700-bg' + }, + toolbar: { + hidden : false, + position : 'below-static', + background: 'mat-white-500-bg' + }, + footer : { + hidden : false, + position : 'below-static', + background: 'mat-fuse-dark-900-bg' + } + } + }); + + break; + } + + // Vertical Layout #1 - Body scroll + case 'vertical-layout-1-body-scroll': + { + this.form.patchValue({ + layout: { + width : 'fullwidth', + navbar : { + hidden : false, + position : 'left', + folded : false, + background: 'mat-fuse-dark-700-bg' + }, + toolbar: { + hidden : false, + position : 'below', + background: 'mat-white-500-bg' + }, + footer : { + hidden : false, + position : 'below', + background: 'mat-fuse-dark-900-bg' + } + } + }); + + break; + } + + // Vertical Layout #2 + case 'vertical-layout-2': + { + this.form.patchValue({ + layout: { + width : 'fullwidth', + navbar : { + hidden : false, + position : 'left', + folded : false, + background: 'mat-fuse-dark-700-bg' + }, + toolbar: { + hidden : false, + position : 'above-static', + background: 'mat-white-500-bg' + }, + footer : { + hidden : false, + position : 'above-static', + background: 'mat-fuse-dark-900-bg' + } + } + }); + + break; + } + } + } + /** * Toggle sidebar open * @@ -158,86 +264,8 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy this._fuseSidebarService.getSidebar(key).toggleOpen(); } - // ----------------------------------------------------------------------------------------------------- // @ Public methods // ----------------------------------------------------------------------------------------------------- - /** - * Reset the config correctly - */ - resetConfig(layout): void - { - console.log(layout); - - // Check the layout style and reset the - // configuration properly so we don't end - // up with options that don't work with - // selected layout style - switch ( layout ) - { - // Vertical - - // Layout 1 - case 'vertical-layout-1': - { - // Reset the config form - this.fuseConfigForm.patchValue({ - layout: { - navigation: { - folder: false - }, - toolbar : { - position: 'below' - } - } - }); - - break; - } - - // Layout 2 - case 'vertical-layout-2': - { - console.log('resetting the options for vertical-layout-2...'); - - // Reset the config form - this.fuseConfigForm.patchValue({ - layout: { - navigation: { - folder: false - }, - toolbar : { - position: 'below' - } - } - }); - - break; - } - - // Layout 3 - case 'vertical-layout-3': - { - // Reset the config form - this.fuseConfigForm.patchValue({ - layout: { - navigation: { - folder: false - }, - toolbar : { - position: 'below' - } - } - }); - - break; - } - - default : - { - break; - } - } - } } diff --git a/src/@fuse/directives/directives.ts b/src/@fuse/directives/directives.ts index 91c92607..d327ff71 100644 --- a/src/@fuse/directives/directives.ts +++ b/src/@fuse/directives/directives.ts @@ -1,12 +1,14 @@ import { NgModule } from '@angular/core'; import { FuseIfOnDomDirective } from '@fuse/directives/fuse-if-on-dom/fuse-if-on-dom.directive'; +import { FuseInnerScrollDirective } from '@fuse/directives/fuse-inner-scroll/fuse-inner-scroll.directive'; import { FusePerfectScrollbarDirective } from '@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive'; import { FuseMatSidenavHelperDirective, FuseMatSidenavTogglerDirective } from '@fuse/directives/fuse-mat-sidenav/fuse-mat-sidenav.directive'; @NgModule({ declarations: [ FuseIfOnDomDirective, + FuseInnerScrollDirective, FuseMatSidenavHelperDirective, FuseMatSidenavTogglerDirective, FusePerfectScrollbarDirective @@ -14,6 +16,7 @@ import { FuseMatSidenavHelperDirective, FuseMatSidenavTogglerDirective } from '@ imports : [], exports : [ FuseIfOnDomDirective, + FuseInnerScrollDirective, FuseMatSidenavHelperDirective, FuseMatSidenavTogglerDirective, FusePerfectScrollbarDirective diff --git a/src/@fuse/directives/fuse-inner-scroll/fuse-inner-scroll.directive.ts b/src/@fuse/directives/fuse-inner-scroll/fuse-inner-scroll.directive.ts new file mode 100644 index 00000000..17fb6bf5 --- /dev/null +++ b/src/@fuse/directives/fuse-inner-scroll/fuse-inner-scroll.directive.ts @@ -0,0 +1,61 @@ +import { Directive, ElementRef, OnDestroy, OnInit, Renderer2 } from '@angular/core'; + +@Directive({ + selector: '.inner-scroll' +}) +export class FuseInnerScrollDirective implements OnInit, OnDestroy +{ + // Private + private _parent: any; + private _grandParent: any; + + /** + * Constructor + */ + constructor( + private _elementRef: ElementRef, + private _renderer: Renderer2 + ) + { + } + + // ----------------------------------------------------------------------------------------------------- + // @ Lifecycle hooks + // ----------------------------------------------------------------------------------------------------- + + /** + * On init + */ + ngOnInit(): void + { + // Get the parent + this._parent = this._renderer.parentNode(this._elementRef.nativeElement); + + // Return, if there is no parent + if ( !this._parent ) + { + return; + } + + // Get the grand parent + this._grandParent = this._renderer.parentNode(this._parent); + + // Add the inner-scroll class + this._renderer.addClass(this._grandParent, 'inner-scroll'); + } + + /** + * On destroy + */ + ngOnDestroy(): void + { + // Return, if there is no parent + if ( !this._parent ) + { + return; + } + + // Remove the inner-scroll class + this._renderer.removeClass(this._grandParent, 'inner-scroll'); + } +} diff --git a/src/@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive.ts b/src/@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive.ts index 135e65c8..06bc53a9 100644 --- a/src/@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive.ts +++ b/src/@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive.ts @@ -1,8 +1,8 @@ import { AfterViewInit, Directive, ElementRef, HostListener, Input, OnDestroy } from '@angular/core'; +import { NavigationEnd, Router } from '@angular/router'; import { Platform } from '@angular/cdk/platform'; import { Subject } from 'rxjs'; -import { takeUntil } from 'rxjs/operators'; - +import { filter, takeUntil } from 'rxjs/operators'; import PerfectScrollbar from 'perfect-scrollbar'; import { FuseConfigService } from '@fuse/services/config.service'; @@ -18,6 +18,7 @@ export class FusePerfectScrollbarDirective implements AfterViewInit, OnDestroy // Private private _enabled: boolean | ''; + private _updateOnNavigationEnd: boolean | ''; private _unsubscribeAll: Subject; /** @@ -26,11 +27,13 @@ export class FusePerfectScrollbarDirective implements AfterViewInit, OnDestroy * @param {ElementRef} elementRef * @param {FuseConfigService} _fuseConfigService * @param {Platform} _platform + * @param {Router} _router */ constructor( public elementRef: ElementRef, private _fuseConfigService: FuseConfigService, - private _platform: Platform + private _platform: Platform, + private _router: Router ) { // Set the defaults @@ -39,6 +42,7 @@ export class FusePerfectScrollbarDirective implements AfterViewInit, OnDestroy // Set the private defaults this._enabled = false; + this._updateOnNavigationEnd = false; this._unsubscribeAll = new Subject(); } @@ -88,6 +92,27 @@ export class FusePerfectScrollbarDirective implements AfterViewInit, OnDestroy return this._enabled; } + /** + * Update on navigation end + * + * @param value + */ + @Input() + set updateOnNavigationEnd(value) + { + if ( value === '' ) + { + value = true; + } + + this._updateOnNavigationEnd = value; + } + + get updateOnNavigationEnd(): boolean | '' + { + return this._updateOnNavigationEnd; + } + // ----------------------------------------------------------------------------------------------------- // @ Lifecycle hooks // ----------------------------------------------------------------------------------------------------- @@ -106,7 +131,19 @@ export class FusePerfectScrollbarDirective implements AfterViewInit, OnDestroy } ); - // this._init(); + // If updateOnNavigationEnd attribute is provided, + // scroll to the top on every NavigationEnd + if ( this.updateOnNavigationEnd ) + { + this._router.events + .pipe( + takeUntil(this._unsubscribeAll), + filter(event => event instanceof NavigationEnd) + ) + .subscribe(() => { + this.scrollToTop(); + }); + } } /** diff --git a/src/@fuse/scss/partials/_page-layouts.scss b/src/@fuse/scss/partials/_page-layouts.scss index d811517a..9dc38efe 100644 --- a/src/@fuse/scss/partials/_page-layouts.scss +++ b/src/@fuse/scss/partials/_page-layouts.scss @@ -10,9 +10,6 @@ $header-height-sm: 100px !default; $carded-header-height-without-toolbar: $carded-header-height - $carded-toolbar-height; $carded-header-height-without-toolbar-sm: $carded-header-height-sm - $carded-toolbar-height; -// Top bg image -$top-bg-image: url('assets/images/backgrounds/header-bg.png'); - .page-layout { position: relative; overflow-x: hidden; @@ -34,8 +31,6 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); right: 0; left: 0; height: $carded-header-height; - background-image: $top-bg-image; - background-size: cover; @include media-breakpoint-down('sm') { height: $carded-header-height-sm; @@ -45,12 +40,20 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); // Fullwidth &.fullwidth { - // Single scroll - &.single-scroll { + // Inner scroll + &.inner-scroll { + flex: 1 1 auto; > .center { - flex: 1 0 auto; - max-height: none; + flex: 1 1 auto; + + .content-card { + flex: 1 1 auto; + + > .content { + flex: 1 1 auto; + } + } } } @@ -58,7 +61,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); > .center { display: flex; flex-direction: column; - flex: 1; + flex: 1 0 auto; position: relative; z-index: 2; padding: 0 32px; @@ -82,7 +85,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); .content-card { display: flex; flex-direction: column; - flex: 1; + flex: 1 0 auto; overflow: hidden; @include mat-elevation(7); @@ -98,28 +101,65 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); > .content { display: flex; - flex: 1; + flex: 1 0 auto; overflow: auto; } } } + + // Tabbed + &.tabbed { + + .center { + width: 100%; + min-width: 0; + + .header { + flex: 1 1 auto; + } + + .content-card { + + .content { + + .mat-tab-group { + overflow: hidden; + + .mat-tab-header { + + .mat-tab-label { + height: 64px; + } + } + + .mat-tab-body { + overflow: hidden; + + .mat-tab-body-content { + overflow: hidden; + + .tab-content { + position: relative; + width: 100%; + height: 100%; + overflow: auto; + } + } + } + } + } + } + } + } } // Left sidenav - Right sidenav &.left-sidenav, &.right-sidenav { - // Single scroll - &.single-scroll { - - > mat-sidenav-container { - flex: 1 0 auto; - } - } - > mat-sidenav-container { display: flex; - flex: 1; + flex: 1 1 auto; background: none; z-index: 2; width: 100%; @@ -127,7 +167,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); .sidenav { display: flex; flex-direction: column; - flex: 1; + flex: 1 1 auto; width: 240px; min-width: 240px; max-width: 240px; @@ -162,7 +202,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); > .mat-sidenav-content, > .mat-drawer-content { display: flex; - flex: 1; + flex: 1 1 auto; height: auto; overflow: visible; @@ -170,7 +210,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); .center { display: flex; flex-direction: column; - flex: 1; + flex: 1 1 auto; position: relative; z-index: 3; margin-left: 32px; @@ -192,7 +232,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); .content-card { display: flex; flex-direction: column; - flex: 1; + flex: 1 1 auto; overflow: hidden; @include mat-elevation(7); @@ -200,7 +240,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); display: flex; justify-content: flex-start; align-items: center; - flex: 1; + flex: 1 1 auto; border-bottom: 1px solid rgba(0, 0, 0, 0.12); height: $carded-toolbar-height; min-height: $carded-toolbar-height; @@ -215,7 +255,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); .content { display: flex; - flex: 1; + flex: 1 1 auto; overflow: auto; } } @@ -223,6 +263,30 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); } } + // Inner scroll + &.inner-scroll { + flex: 1 1 auto; + + > mat-sidenav-container { + + > .mat-sidenav-content, + > .mat-drawer-content { + + > .center { + flex: 1 1 auto; + + .content-card { + flex: 1 1 auto; + + > .content { + flex: 1 1 auto; + } + } + } + } + } + } + // Tabbed &.tabbed { @@ -242,7 +306,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); } .header { - flex: 1; + flex: 1 1 auto; } .content-card { @@ -336,12 +400,6 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); width: 100%; min-width: 100%; - // Top bg - > .header { - background-image: $top-bg-image; - background-size: cover; - } - // Fullwidth &.fullwidth { overflow: auto; @@ -363,7 +421,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); &.right-sidenav { // Single scroll - &.single-scroll { + /*&.single-scroll { > mat-sidenav-container { flex: 1 0 auto; @@ -374,13 +432,13 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); max-height: none; } } - } + }*/ // Inner Sidenav &.inner-sidenav { > mat-sidenav-container { - flex: 1; + flex: 1 1 auto; .sidenav { @@ -395,7 +453,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); height: auto; .center { - flex: 1; + flex: 1 1 auto; min-height: 100%; @include mat-elevation(0); @@ -411,7 +469,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); > mat-sidenav-container { display: flex; flex-direction: column; - flex: 1; + flex: 1 1 auto; background: none; z-index: 2; width: 100%; @@ -439,7 +497,7 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); > .mat-sidenav-content, > .mat-drawer-content { display: flex; - flex: 1; + flex: 1 1 auto; height: auto; overflow: visible; max-height: 100%; @@ -448,13 +506,12 @@ $top-bg-image: url('assets/images/backgrounds/header-bg.png'); height: $header-height; min-height: $header-height; max-height: $header-height; - background-image: $top-bg-image; } .center { display: flex; flex-direction: column; - flex: 1; + flex: 1 1 auto; overflow: auto; @include mat-elevation(7); diff --git a/src/@fuse/services/config.service.ts b/src/@fuse/services/config.service.ts index e753f337..fd8fea4b 100644 --- a/src/@fuse/services/config.service.ts +++ b/src/@fuse/services/config.service.ts @@ -107,6 +107,38 @@ export class FuseConfigService // @ Public methods // ----------------------------------------------------------------------------------------------------- + /** + * Set config + * + * @param value + * @param {{emitEvent: boolean}} opts + */ + setConfig(value, opts = {emitEvent: true}): void + { + // Get the value from the behavior subject + let config = this._configSubject.getValue(); + + // Merge the new config + config = _.merge({}, config, value); + + // If emitEvent option is true... + if ( opts.emitEvent === true ) + { + // Notify the observers + this._configSubject.next(config); + } + } + + /** + * Get config + * + * @returns {Observable} + */ + getConfig(): Observable + { + return this._configSubject.asObservable(); + } + /** * Reset to the default config */ diff --git a/src/@fuse/types/fuse-config.ts b/src/@fuse/types/fuse-config.ts index 29be0336..9458a935 100644 --- a/src/@fuse/types/fuse-config.ts +++ b/src/@fuse/types/fuse-config.ts @@ -2,20 +2,23 @@ export interface FuseConfig { layout: { style: string, - navigation: { - position: 'left' | 'right' | 'top' | 'none', + width: 'fullwidth' | 'boxed', + navbar: { + hidden: boolean, folded: boolean, + position: 'left' | 'right' | 'top', background: string }, toolbar: { - position: 'above' | 'above-sticky' | 'below' | 'below-sticky' | 'none', + hidden: boolean, + position: 'above' | 'above-static' | 'above-sticky' | 'above-fixed' | 'below' | 'below-static' | 'below-sticky' | 'below-fixed', background: string } footer: { - position: 'above' | 'below' | 'below-sticky' | 'none', + hidden: boolean, + position: 'above' | 'above-static' | 'above-sticky' | 'above-fixed' | 'below' | 'below-static' | 'below-sticky' | 'below-fixed', background: string - }, - mode: 'fullwidth' | 'boxed' + } }; customScrollbars: boolean; routerAnimation: 'fadeIn' | 'slideUp' | 'slideDown' | 'slideRight' | 'slideLeft' | 'none'; diff --git a/src/app/app.component.html b/src/app/app.component.html index 871dc3d7..669f1e7c 100644 --- a/src/app/app.component.html +++ b/src/app/app.component.html @@ -1,6 +1,11 @@ - - - + + + + + + + + @@ -8,9 +13,9 @@ - - - + + + @@ -19,6 +24,6 @@ settings - + \ No newline at end of file diff --git a/src/app/app.component.scss b/src/app/app.component.scss index 292e233c..42a78d3d 100644 --- a/src/app/app.component.scss +++ b/src/app/app.component.scss @@ -3,6 +3,7 @@ display: flex; flex: 1 1 auto; width: 100%; + height: 100%; min-width: 0; .theme-options-button { @@ -28,4 +29,10 @@ opacity: 1; } } + + .theme-options-sidebar { + width: 360px; + min-width: 360px; + max-width: 360px; + } } \ No newline at end of file diff --git a/src/app/fuse-config/index.ts b/src/app/fuse-config/index.ts index 93dc6e53..96ad2856 100644 --- a/src/app/fuse-config/index.ts +++ b/src/app/fuse-config/index.ts @@ -10,21 +10,24 @@ import { FuseConfig } from '@fuse/types'; export const fuseConfig: FuseConfig = { layout : { - style : 'vertical-layout-1', - navigation: { + style : 'vertical-layout-1-content-scroll', + width : 'fullwidth', + navbar : { + hidden : false, position : 'left', folded : false, background: 'mat-fuse-dark-700-bg' }, - toolbar : { - position : 'below', + toolbar : { + hidden : false, + position : 'below-static', background: 'mat-white-500-bg' }, - footer : { - position : 'below', + footer : { + hidden : false, + position : 'below-static', background: 'mat-fuse-dark-900-bg' - }, - mode : 'fullwidth' + } }, customScrollbars: true, routerAnimation : 'fadeIn' diff --git a/src/app/layout/components/content/content.component.scss b/src/app/layout/components/content/content.component.scss index 32e80fa3..33f85511 100644 --- a/src/app/layout/components/content/content.component.scss +++ b/src/app/layout/components/content/content.component.scss @@ -1,11 +1,12 @@ content { - display: flex; - flex-direction: column; - flex: 1 1 auto; + display:flex; z-index: 1; + flex: 1 0 auto; > *:not(router-outlet) { display: flex; - flex: 1 1 auto; + flex: 1 0 auto; + width: 100%; + min-width: 100%; } } \ No newline at end of file diff --git a/src/app/layout/components/toolbar/toolbar.component.ts b/src/app/layout/components/toolbar/toolbar.component.ts index b2fdf441..ac21c3de 100644 --- a/src/app/layout/components/toolbar/toolbar.component.ts +++ b/src/app/layout/components/toolbar/toolbar.component.ts @@ -123,8 +123,8 @@ export class ToolbarComponent implements OnInit, OnDestroy this._fuseConfigService.config .pipe(takeUntil(this._unsubscribeAll)) .subscribe((settings) => { - this.horizontalNav = settings.layout.navigation.position === 'top'; - this.noNav = settings.layout.navigation.position === 'none'; + this.horizontalNav = settings.layout.navbar.position === 'top'; + this.noNav = settings.layout.navbar.position === 'none'; }); // Set the selected language from default languages diff --git a/src/app/layout/layout.module.ts b/src/app/layout/layout.module.ts index 0030580c..008361c7 100644 --- a/src/app/layout/layout.module.ts +++ b/src/app/layout/layout.module.ts @@ -1,19 +1,22 @@ import { NgModule } from '@angular/core'; -import { VerticalLayout1Module } from 'app/layout/vertical/layout-1/layout-1.module'; +import { VerticalLayout1BodyScrollModule } from 'app/layout/vertical/layout-1/body-scroll/body-scroll.module'; +import { VerticalLayout1ContentScrollModule } from 'app/layout/vertical/layout-1/content-scroll/content-scroll.module'; + import { VerticalLayout2Module } from 'app/layout/vertical/layout-2/layout-2.module'; -import { VerticalLayout3Module } from 'app/layout/vertical/layout-3/layout-3.module'; @NgModule({ imports: [ - VerticalLayout1Module, - VerticalLayout2Module, - VerticalLayout3Module + VerticalLayout1BodyScrollModule, + VerticalLayout1ContentScrollModule, + + VerticalLayout2Module ], exports: [ - VerticalLayout1Module, - VerticalLayout2Module, - VerticalLayout3Module + VerticalLayout1BodyScrollModule, + VerticalLayout1ContentScrollModule, + + VerticalLayout2Module ] }) export class LayoutModule diff --git a/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.html b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.html new file mode 100644 index 00000000..aea612bd --- /dev/null +++ b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.html @@ -0,0 +1,115 @@ +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + + + + + + + + + + + +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + + + + + + + + + + + + +
+
+ + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/src/app/layout/vertical/layout-3/layout-3.component.scss b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.scss similarity index 93% rename from src/app/layout/vertical/layout-3/layout-3.component.scss rename to src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.scss index a6d52354..fbe43795 100644 --- a/src/app/layout/vertical/layout-3/layout-3.component.scss +++ b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.scss @@ -1,9 +1,10 @@ @import "src/@fuse/scss/fuse"; -vertical-layout-3 { +vertical-layout-1-body-scroll { display: flex; flex: 1 1 auto; width: 100%; + height: 100%; #main { position: relative; @@ -11,6 +12,7 @@ vertical-layout-3 { flex: 1 1 auto; flex-direction: column; width: 100%; + height: 100%; z-index: 1; // Container 1 (Scrollable) @@ -42,4 +44,4 @@ vertical-layout-3 { } } } -} +} \ No newline at end of file diff --git a/src/app/layout/vertical/layout-1/layout-1.component.ts b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.ts similarity index 86% rename from src/app/layout/vertical/layout-1/layout-1.component.ts rename to src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.ts index 07c58e02..54892576 100644 --- a/src/app/layout/vertical/layout-1/layout-1.component.ts +++ b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.ts @@ -6,12 +6,12 @@ import { FuseConfigService } from '@fuse/services/config.service'; import { navigation } from 'app/navigation/navigation'; @Component({ - selector : 'vertical-layout-1', - templateUrl : './layout-1.component.html', - styleUrls : ['./layout-1.component.scss'], + selector : 'vertical-layout-1-body-scroll', + templateUrl : './body-scroll.component.html', + styleUrls : ['./body-scroll.component.scss'], encapsulation: ViewEncapsulation.None }) -export class VerticalLayout1Component implements OnInit, OnDestroy +export class VerticalLayout1BodyScrollComponent implements OnInit, OnDestroy { fuseConfig: any; navigation: any; diff --git a/src/app/layout/vertical/layout-3/layout-3.module.ts b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.module.ts similarity index 71% rename from src/app/layout/vertical/layout-3/layout-3.module.ts rename to src/app/layout/vertical/layout-1/body-scroll/body-scroll.module.ts index a0d16277..e942d517 100644 --- a/src/app/layout/vertical/layout-3/layout-3.module.ts +++ b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.module.ts @@ -1,4 +1,5 @@ import { NgModule } from '@angular/core'; +import { RouterModule } from '@angular/router'; import { FuseSidebarModule } from '@fuse/components'; import { FuseSharedModule } from '@fuse/shared.module'; @@ -9,13 +10,15 @@ import { NavbarModule } from 'app/layout/components/navbar/navbar.module'; import { QuickPanelModule } from 'app/layout/components/quick-panel/quick-panel.module'; import { ToolbarModule } from 'app/layout/components/toolbar/toolbar.module'; -import { VerticalLayout3Component } from 'app/layout/vertical/layout-3/layout-3.component'; +import { VerticalLayout1BodyScrollComponent } from 'app/layout/vertical/layout-1/body-scroll/body-scroll.component'; @NgModule({ declarations: [ - VerticalLayout3Component + VerticalLayout1BodyScrollComponent ], imports : [ + RouterModule, + FuseSharedModule, FuseSidebarModule, @@ -26,9 +29,9 @@ import { VerticalLayout3Component } from 'app/layout/vertical/layout-3/layout-3. ToolbarModule ], exports : [ - VerticalLayout3Component + VerticalLayout1BodyScrollComponent ] }) -export class VerticalLayout3Module +export class VerticalLayout1BodyScrollModule { } diff --git a/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.html b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.html new file mode 100644 index 00000000..9d1217cf --- /dev/null +++ b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.html @@ -0,0 +1,115 @@ +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + + + + + + + + + + + +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + +
+ + + + + + + + + + + + + + + + + + +
+
+ + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.scss b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.scss new file mode 100644 index 00000000..0af78cae --- /dev/null +++ b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.scss @@ -0,0 +1,61 @@ +@import "src/@fuse/scss/fuse"; + +vertical-layout-1-content-scroll { + display: flex; + flex: 1 1 auto; + width: 100%; + height: 100%; + + #main { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + width: 100%; + height: 100%; + z-index: 1; + + // Container 1 + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + width: 100%; + min-height: 0; + min-width: 0; + + // Container 2 + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + min-width: 0; + + // Container 3 (Scrollable) + > .container { + position: relative; + display: flex; + flex: 1 1 auto; + flex-direction: column; + transform: translateZ(0); + overflow-x: hidden; + overflow-y: auto; + + // Content component + content { + + &.inner-scroll { + flex: 1 1 auto; + min-height: 0; + + > *:not(router-outlet) { + flex: 1 1 auto; + } + } + } + } + } + } + } +} \ No newline at end of file diff --git a/src/app/layout/vertical/layout-3/layout-3.component.ts b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.ts similarity index 86% rename from src/app/layout/vertical/layout-3/layout-3.component.ts rename to src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.ts index d99091b4..82c0d145 100644 --- a/src/app/layout/vertical/layout-3/layout-3.component.ts +++ b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.ts @@ -6,12 +6,12 @@ import { FuseConfigService } from '@fuse/services/config.service'; import { navigation } from 'app/navigation/navigation'; @Component({ - selector : 'vertical-layout-3', - templateUrl : './layout-3.component.html', - styleUrls : ['./layout-3.component.scss'], + selector : 'vertical-layout-1-content-scroll', + templateUrl : './content-scroll.component.html', + styleUrls : ['./content-scroll.component.scss'], encapsulation: ViewEncapsulation.None }) -export class VerticalLayout3Component implements OnInit, OnDestroy +export class VerticalLayout1ContentScrollComponent implements OnInit, OnDestroy { fuseConfig: any; navigation: any; diff --git a/src/app/layout/vertical/layout-1/layout-1.module.ts b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.module.ts similarity index 70% rename from src/app/layout/vertical/layout-1/layout-1.module.ts rename to src/app/layout/vertical/layout-1/content-scroll/content-scroll.module.ts index ed5c7c96..9ba7418b 100644 --- a/src/app/layout/vertical/layout-1/layout-1.module.ts +++ b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.module.ts @@ -1,4 +1,5 @@ import { NgModule } from '@angular/core'; +import { RouterModule } from '@angular/router'; import { FuseSidebarModule } from '@fuse/components'; import { FuseSharedModule } from '@fuse/shared.module'; @@ -9,13 +10,15 @@ import { NavbarModule } from 'app/layout/components/navbar/navbar.module'; import { QuickPanelModule } from 'app/layout/components/quick-panel/quick-panel.module'; import { ToolbarModule } from 'app/layout/components/toolbar/toolbar.module'; -import { VerticalLayout1Component } from 'app/layout/vertical/layout-1/layout-1.component'; +import { VerticalLayout1ContentScrollComponent } from 'app/layout/vertical/layout-1/content-scroll/content-scroll.component'; @NgModule({ declarations: [ - VerticalLayout1Component + VerticalLayout1ContentScrollComponent ], imports : [ + RouterModule, + FuseSharedModule, FuseSidebarModule, @@ -26,9 +29,9 @@ import { VerticalLayout1Component } from 'app/layout/vertical/layout-1/layout-1. ToolbarModule ], exports : [ - VerticalLayout1Component + VerticalLayout1ContentScrollComponent ] }) -export class VerticalLayout1Module +export class VerticalLayout1ContentScrollModule { } diff --git a/src/app/layout/vertical/layout-1/layout-1.component.html b/src/app/layout/vertical/layout-1/layout-1.component.html deleted file mode 100644 index b826ef61..00000000 --- a/src/app/layout/vertical/layout-1/layout-1.component.html +++ /dev/null @@ -1,81 +0,0 @@ -
- - - - - - - -
- - - - - - - -
- - - - - - - -
- - - - - - - - - - - - - -
-
- - -
- - - -
-
- - -
- - - - - - - -
- - - -
-
- - -
- - - - - - \ No newline at end of file diff --git a/src/app/layout/vertical/layout-1/layout-1.component.scss b/src/app/layout/vertical/layout-1/layout-1.component.scss deleted file mode 100644 index b0990b8a..00000000 --- a/src/app/layout/vertical/layout-1/layout-1.component.scss +++ /dev/null @@ -1,117 +0,0 @@ -@import "src/@fuse/scss/fuse"; - -vertical-layout-1 { - display: flex; - flex: 1 1 auto; - width: 100%; - - #main { - position: relative; - display: flex; - flex: 1 1 auto; - flex-direction: column; - width: 100%; - z-index: 1; - - // Container 1 - > .container { - position: relative; - display: flex; - flex: 1 1 auto; - width: 100%; - - // Container 2 - > .container { - position: relative; - display: flex; - flex: 1 1 auto; - flex-direction: column; - min-width: 0; - - // Container 3 (Scrollable) - > .container { - position: relative; - display: flex; - flex: 1 1 auto; - flex-direction: column; - transform: translateZ(0); - } - } - } - } -} - -vertical-layout-111 { - display: flex; - flex-direction: column; - width: 100%; - height: 100%; - - /* > .mat-sidenav-container { - display: flex; - flex: 1; - - > .mat-sidenav-content, - > .mat-drawer-content { - display: flex; - flex: 1; - overflow: hidden; - height: 100vh;*/ - - @include media-breakpoint-down('sm') { - height: auto !important; - } - - #main-content { - display: flex; - flex: 1; - flex-direction: column; - overflow: hidden; - background: #FAFAFA; - - #wrapper { - display: flex; - position: relative; - flex: 1; - overflow: hidden; - - .content-wrapper { - display: flex; - flex-direction: column; - flex: 1; - overflow: hidden; - - content { - position: relative; - display: flex; - flex: 1; - flex-direction: row; - width: 100%; - overflow: hidden; - - > *:not(router-outlet):not(.ps__scrollbar-x-rail):not(.ps__scrollbar-y-rail) { - display: flex; - flex: 1; - width: 100%; - min-width: 100%; - } - - > *.ng-animating { - - .mat-tab-body { - height: 100vh; - } - } - } - } - //} - //} - } - } - - &[fuse-layout-mode="boxed"] { - max-width: 1200px; - margin: 0 auto; - @include mat-elevation(8); - } -} diff --git a/src/app/layout/vertical/layout-2/layout-2.component.html b/src/app/layout/vertical/layout-2/layout-2.component.html index 22587f0a..7b719f1f 100644 --- a/src/app/layout/vertical/layout-2/layout-2.component.html +++ b/src/app/layout/vertical/layout-2/layout-2.component.html @@ -1,76 +1,54 @@
- - - + + + - + -
+
- - - - - + + + + +
- - - + + + - + -
+ + + - - - - - - - - - - - - -
-
- - -
- - - -
+ + + - +
- - - - - + + + + +
- - -
+ + + - +
@@ -78,4 +56,46 @@ - \ No newline at end of file + + + + + + + + + + + + + +
+
+ + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/src/app/layout/vertical/layout-2/layout-2.component.scss b/src/app/layout/vertical/layout-2/layout-2.component.scss index d1496150..b863500e 100644 --- a/src/app/layout/vertical/layout-2/layout-2.component.scss +++ b/src/app/layout/vertical/layout-2/layout-2.component.scss @@ -4,6 +4,7 @@ vertical-layout-2 { display: flex; flex: 1 1 auto; width: 100%; + height: 100%; #main { position: relative; @@ -11,43 +12,37 @@ vertical-layout-2 { flex: 1 1 auto; flex-direction: column; width: 100%; + height: 100%; z-index: 1; - // Container 1 + // Container 1 (Scrollable) > .container { position: relative; display: flex; flex: 1 1 auto; + flex-direction: column; width: 100%; + overflow-x: hidden; + overflow-y: auto; + transform: translateZ(0); // Container 2 > .container { position: relative; display: flex; - flex: 1 1 auto; - flex-direction: column; + flex: 1 0 auto; + width: 100%; min-width: 0; + padding: 32px; - // Container 3 (Scrollable) - > .container { - position: relative; - display: flex; + // Content component + > content { flex: 1 1 auto; - flex-direction: column; - transform: translateZ(0); - overflow-x: hidden; - overflow-y: auto; + min-width: 0; - // Content component - content { - flex: 1 0 auto; - - > *:not(router-outlet) { - flex: 1 0 auto; - } - } + @include mat-elevation(3); } } } } -} +} \ No newline at end of file diff --git a/src/app/layout/vertical/layout-2/layout-2.module.ts b/src/app/layout/vertical/layout-2/layout-2.module.ts index 26ed77d1..64c7540f 100644 --- a/src/app/layout/vertical/layout-2/layout-2.module.ts +++ b/src/app/layout/vertical/layout-2/layout-2.module.ts @@ -1,4 +1,5 @@ import { NgModule } from '@angular/core'; +import { RouterModule } from '@angular/router'; import { FuseSidebarModule } from '@fuse/components'; import { FuseSharedModule } from '@fuse/shared.module'; @@ -16,6 +17,8 @@ import { VerticalLayout2Component } from 'app/layout/vertical/layout-2/layout-2. VerticalLayout2Component ], imports : [ + RouterModule, + FuseSharedModule, FuseSidebarModule, diff --git a/src/app/layout/vertical/layout-3/layout-3.component.html b/src/app/layout/vertical/layout-3/layout-3.component.html deleted file mode 100644 index 422f2cbd..00000000 --- a/src/app/layout/vertical/layout-3/layout-3.component.html +++ /dev/null @@ -1,81 +0,0 @@ -
- - - - - - - -
- - - - - - - -
- - - - - - - -
- - - - - - - - - - - - - -
-
- - -
- - - - - - - -
- - - -
-
- - -
- - - -
-
- - -
- - - - - - \ No newline at end of file diff --git a/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.html b/src/app/main/ui/page-layouts/carded/full-width-1/full-width-1.component.html similarity index 94% rename from src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.html rename to src/app/main/ui/page-layouts/carded/full-width-1/full-width-1.component.html index 803bdda8..5e08db5f 100644 --- a/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.html +++ b/src/app/main/ui/page-layouts/carded/full-width-1/full-width-1.component.html @@ -9,7 +9,7 @@
-

Fullwidth with container scroll

+

Full width with content scroll

diff --git a/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.scss b/src/app/main/ui/page-layouts/carded/full-width-1/full-width-1.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.scss rename to src/app/main/ui/page-layouts/carded/full-width-1/full-width-1.component.scss diff --git a/src/app/main/ui/page-layouts/carded/full-width-1/full-width-1.component.ts b/src/app/main/ui/page-layouts/carded/full-width-1/full-width-1.component.ts new file mode 100644 index 00000000..5a3e0daf --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/full-width-1/full-width-1.component.ts @@ -0,0 +1,16 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'carded-fullwidth-1', + templateUrl: './full-width-1.component.html', + styleUrls : ['./full-width-1.component.scss'] +}) +export class CardedFullWidth1Component +{ + /** + * Constructor + */ + constructor() + { + } +} diff --git a/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.html b/src/app/main/ui/page-layouts/carded/full-width-2/full-width-2.component.html similarity index 88% rename from src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.html rename to src/app/main/ui/page-layouts/carded/full-width-2/full-width-2.component.html index f228732b..a9a45f3a 100644 --- a/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.html +++ b/src/app/main/ui/page-layouts/carded/full-width-2/full-width-2.component.html @@ -1,4 +1,4 @@ -
+
@@ -9,7 +9,7 @@
-

Fullwidth with content scroll

+

Full width with inner scroll

diff --git a/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.scss b/src/app/main/ui/page-layouts/carded/full-width-2/full-width-2.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.scss rename to src/app/main/ui/page-layouts/carded/full-width-2/full-width-2.component.scss diff --git a/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.ts b/src/app/main/ui/page-layouts/carded/full-width-2/full-width-2.component.ts similarity index 67% rename from src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.ts rename to src/app/main/ui/page-layouts/carded/full-width-2/full-width-2.component.ts index f05d08d6..fa38a5db 100644 --- a/src/app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component.ts +++ b/src/app/main/ui/page-layouts/carded/full-width-2/full-width-2.component.ts @@ -2,8 +2,8 @@ import { Component } from '@angular/core'; @Component({ selector : 'carded-fullwidth-2', - templateUrl: './fullwidth-2.component.html', - styleUrls : ['./fullwidth-2.component.scss'] + templateUrl: './full-width-2.component.html', + styleUrls : ['./full-width-2.component.scss'] }) export class CardedFullWidth2Component { diff --git a/src/app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component.html b/src/app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component.html new file mode 100644 index 00000000..b5f75269 --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component.html @@ -0,0 +1,115 @@ +
+ + +
+ + + +
+ + +
+

Full width with tabs and content scroll

+
+ + + +
+ + +
+ + + + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ +
+ +
+ + +
+ + +
+ + +
diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.scss b/src/app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.scss rename to src/app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component.scss diff --git a/src/app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component.ts b/src/app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component.ts new file mode 100644 index 00000000..2da39a05 --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component.ts @@ -0,0 +1,16 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'carded-fullwidth-tabbed-1', + templateUrl: './full-width-tabbed-1.component.html', + styleUrls : ['./full-width-tabbed-1.component.scss'] +}) +export class CardedFullWidthTabbed1Component +{ + /** + * Constructor + */ + constructor() + { + } +} diff --git a/src/app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component.html b/src/app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component.html new file mode 100644 index 00000000..0c008df2 --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component.html @@ -0,0 +1,115 @@ +
+ + +
+ + + +
+ + +
+

Full width with tabs and inner scroll

+
+ + + +
+ + +
+ + + + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ + +
+ + + +
+
+ +
+ +
+ + +
+ + +
+ + +
diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.scss b/src/app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.scss rename to src/app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component.scss diff --git a/src/app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component.ts b/src/app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component.ts new file mode 100644 index 00000000..dc746bb4 --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component.ts @@ -0,0 +1,16 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'carded-fullwidth-tabbed-2', + templateUrl: './full-width-tabbed-2.component.html', + styleUrls : ['./full-width-tabbed-2.component.scss'] +}) +export class CardedFullWidthTabbed2Component +{ + /** + * Constructor + */ + constructor() + { + } +} diff --git a/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts b/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts deleted file mode 100644 index 7e1616e6..00000000 --- a/src/app/main/ui/page-layouts/carded/fullwidth/fullwidth.component.ts +++ /dev/null @@ -1,86 +0,0 @@ -import { Component, OnDestroy, OnInit } from '@angular/core'; -import { takeUntil } from 'rxjs/operators'; -import { Subject } from 'rxjs'; - -import { FuseConfigService } from '@fuse/services/config.service'; -import { FuseMatchMediaService } from '@fuse/services/match-media.service'; - -@Component({ - selector : 'carded-fullwidth', - templateUrl: './fullwidth.component.html', - styleUrls : ['./fullwidth.component.scss'] -}) -export class CardedFullWidthComponent implements OnInit, OnDestroy -{ - // Private - private _unsubscribeAll: Subject; - - /** - * Constructor - * - * @param {FuseConfigService} _fuseConfigService - * @param {FuseMatchMediaService} _fuseMatchMediaService - */ - constructor( - private _fuseConfigService: FuseConfigService, - private _fuseMatchMediaService: FuseMatchMediaService - ) - { - // Configure the layout - this._fuseConfigService.config = { - layout: { - containerScroll: false - } - }; - - // Set the private defaults - this._unsubscribeAll = new Subject(); - } - - // ----------------------------------------------------------------------------------------------------- - // @ Lifecycle hooks - // ----------------------------------------------------------------------------------------------------- - - /** - * On init - */ - ngOnInit(): void - { - // Enable the containerScroll on small screen - // devices to get more screen real estate - this._fuseMatchMediaService.onMediaChange - .pipe(takeUntil(this._unsubscribeAll)) - .subscribe((alias) => { - - // If 'xs' - if ( alias === 'xs' ) - { - // Set the containerScroll to true - this._fuseConfigService.config = { - layout: { - containerScroll: true - } - }; - } - else - { - // Set the containerScroll to false (route default) - this._fuseConfigService.config = { - layout: { - containerScroll: false - } - }; - } - }); - } - - /** - * On destroy - */ - ngOnDestroy(): void - { - // Unsubscribe from all subscriptions - this._unsubscribeAll.next(); - this._unsubscribeAll.complete(); - } -} diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.html b/src/app/main/ui/page-layouts/carded/left-sidenav-1/left-sidenav-1.component.html similarity index 90% rename from src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.html rename to src/app/main/ui/page-layouts/carded/left-sidenav-1/left-sidenav-1.component.html index 7a7a65f1..b982e7c0 100644 --- a/src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.html +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-1/left-sidenav-1.component.html @@ -1,4 +1,4 @@ -
+
@@ -17,7 +17,7 @@ -
+
@@ -52,7 +52,7 @@ -
+
diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.scss b/src/app/main/ui/page-layouts/carded/left-sidenav-1/left-sidenav-1.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.scss rename to src/app/main/ui/page-layouts/carded/left-sidenav-1/left-sidenav-1.component.scss diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-1/left-sidenav-1.component.ts b/src/app/main/ui/page-layouts/carded/left-sidenav-1/left-sidenav-1.component.ts new file mode 100644 index 00000000..1b1d69b9 --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-1/left-sidenav-1.component.ts @@ -0,0 +1,17 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'carded-left-sidenav-1', + templateUrl: './left-sidenav-1.component.html', + styleUrls : ['./left-sidenav-1.component.scss'] +}) +export class CardedLeftSidenav1Component +{ + /** + * Constructor + */ + constructor() + { + } + +} diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.ts b/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.ts deleted file mode 100644 index e715bb04..00000000 --- a/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector : 'carded-left-sidenav-2-tabbed', - templateUrl: './left-sidenav-2-tabbed.component.html', - styleUrls : ['./left-sidenav-2-tabbed.component.scss'] -}) -export class CardedLeftSidenav2TabbedComponent -{ - /** - * Constructor - */ - constructor() - { - } - -} diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.html b/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.html index faa84817..5f828a44 100644 --- a/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.html +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component.html @@ -1,4 +1,4 @@ -
+
@@ -32,7 +32,7 @@
-

Left sidenav with container scroll

+

Left sidenav with inner scroll

diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.html b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.html similarity index 82% rename from src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.html rename to src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.html index 575e5515..37159c86 100644 --- a/src/app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component.html +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.html @@ -1,4 +1,4 @@ -
+
@@ -17,7 +17,7 @@ -
+
@@ -40,7 +40,7 @@ menu -

Left sidenav with tabs and container scroll

+

Left sidenav with tabs and content scroll

@@ -56,7 +56,7 @@ -
+
@@ -64,7 +64,7 @@ -
+
@@ -72,7 +72,7 @@ -
+
@@ -80,7 +80,7 @@ -
+
@@ -88,7 +88,7 @@ -
+
@@ -96,7 +96,7 @@ -
+
@@ -104,7 +104,7 @@ -
+
@@ -112,7 +112,7 @@ -
+
@@ -120,7 +120,7 @@ -
+
@@ -128,7 +128,7 @@ -
+
@@ -148,4 +148,4 @@ -
\ No newline at end of file +
diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.scss b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.scss rename to src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.scss diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.ts b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.ts new file mode 100644 index 00000000..eee50265 --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-1/left-sidenav-tabbed-1.component.ts @@ -0,0 +1,17 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'carded-left-sidenav-tabbed-1', + templateUrl: './left-sidenav-tabbed-1.component.html', + styleUrls : ['./left-sidenav-tabbed-1.component.scss'] +}) +export class CardedLeftSidenavTabbed1Component +{ + /** + * Constructor + */ + constructor() + { + } + +} diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.html b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.html similarity index 97% rename from src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.html rename to src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.html index fd214075..03e69569 100644 --- a/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.html +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.html @@ -1,4 +1,4 @@ -
+
@@ -40,7 +40,7 @@ menu -

Left sidenav with tabs and content scroll

+

Left sidenav with tabs and inner scroll

@@ -148,4 +148,4 @@ -
+
\ No newline at end of file diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.scss b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.scss rename to src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.scss diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.ts b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.ts new file mode 100644 index 00000000..b3cb2bfe --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed-2/left-sidenav-tabbed-2.component.ts @@ -0,0 +1,17 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'carded-left-sidenav-tabbed-2', + templateUrl: './left-sidenav-tabbed-2.component.html', + styleUrls : ['./left-sidenav-tabbed-2.component.scss'] +}) +export class CardedLeftSidenavTabbed2Component +{ + /** + * Constructor + */ + constructor() + { + } + +} diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.ts b/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.ts deleted file mode 100644 index e1cc2130..00000000 --- a/src/app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector : 'carded-left-sidenav-tabbed', - templateUrl: './left-sidenav-tabbed.component.html', - styleUrls : ['./left-sidenav-tabbed.component.scss'] -}) -export class CardedLeftSidenavTabbedComponent -{ - /** - * Constructor - */ - constructor() - { - } - -} diff --git a/src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.ts b/src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.ts deleted file mode 100644 index babe06ef..00000000 --- a/src/app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector : 'carded-left-sidenav', - templateUrl: './left-sidenav.component.html', - styleUrls : ['./left-sidenav.component.scss'] -}) -export class CardedLeftSidenavComponent -{ - /** - * Constructor - */ - constructor() - { - } - -} diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.html b/src/app/main/ui/page-layouts/carded/right-sidenav-1/right-sidenav-1.component.html similarity index 90% rename from src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.html rename to src/app/main/ui/page-layouts/carded/right-sidenav-1/right-sidenav-1.component.html index 1e0d37d9..f6bf47f2 100644 --- a/src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.html +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-1/right-sidenav-1.component.html @@ -1,4 +1,4 @@ -
+
@@ -31,7 +31,7 @@ -
+
@@ -55,7 +55,7 @@ -
+
diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.scss b/src/app/main/ui/page-layouts/carded/right-sidenav-1/right-sidenav-1.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.scss rename to src/app/main/ui/page-layouts/carded/right-sidenav-1/right-sidenav-1.component.scss diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-1/right-sidenav-1.component.ts b/src/app/main/ui/page-layouts/carded/right-sidenav-1/right-sidenav-1.component.ts new file mode 100644 index 00000000..7ce474ea --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-1/right-sidenav-1.component.ts @@ -0,0 +1,17 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'carded-right-sidenav-1', + templateUrl: './right-sidenav-1.component.html', + styleUrls : ['./right-sidenav-1.component.scss'] +}) +export class CardedRightSidenav1Component +{ + /** + * Constructor + */ + constructor() + { + } + +} diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.ts b/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.ts deleted file mode 100644 index 83585df2..00000000 --- a/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector : 'carded-right-sidenav-2-tabbed', - templateUrl: './right-sidenav-2-tabbed.component.html', - styleUrls : ['./right-sidenav-2-tabbed.component.scss'] -}) -export class CardedRightSidenav2TabbedComponent -{ - /** - * Constructor - */ - constructor() - { - } - -} diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.html b/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.html index 7e080983..35e5cf2b 100644 --- a/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.html +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component.html @@ -1,4 +1,4 @@ -
+
@@ -11,7 +11,7 @@
-

Right sidenav with container scroll

+

Right sidenav with inner scroll

diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.html b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.html similarity index 82% rename from src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.html rename to src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.html index 056ae1cf..5fe94776 100644 --- a/src/app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component.html +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.html @@ -1,4 +1,4 @@ -
+
@@ -19,7 +19,7 @@ menu -

Right sidenav with tabs and container scroll

+

Right sidenav with tabs and content scroll

@@ -35,7 +35,7 @@ -
+
@@ -43,7 +43,7 @@ -
+
@@ -51,7 +51,7 @@ -
+
@@ -59,7 +59,7 @@ -
+
@@ -67,7 +67,7 @@ -
+
@@ -75,7 +75,7 @@ -
+
@@ -83,7 +83,7 @@ -
+
@@ -91,7 +91,7 @@ -
+
@@ -99,7 +99,7 @@ -
+
@@ -107,7 +107,7 @@ -
+
@@ -136,7 +136,7 @@ -
+
diff --git a/src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.scss b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.scss rename to src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.scss diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.ts b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.ts new file mode 100644 index 00000000..40ae7782 --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component.ts @@ -0,0 +1,17 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'carded-right-sidenav-tabbed-1', + templateUrl: './right-sidenav-tabbed-1.component.html', + styleUrls : ['./right-sidenav-tabbed-1.component.scss'] +}) +export class CardedRightSidenavTabbed1Component +{ + /** + * Constructor + */ + constructor() + { + } + +} diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.html b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.html similarity index 97% rename from src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.html rename to src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.html index 3364858d..d56483ae 100644 --- a/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.html +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.html @@ -1,4 +1,4 @@ -
+
@@ -19,7 +19,7 @@ menu -

Right sidenav with tabs and content scroll

+

Right sidenav with tabs and inner scroll

diff --git a/src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.scss b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.scss rename to src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.scss diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.ts b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.ts new file mode 100644 index 00000000..33f58358 --- /dev/null +++ b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component.ts @@ -0,0 +1,17 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'carded-right-sidenav-tabbed-2', + templateUrl: './right-sidenav-tabbed-2.component.html', + styleUrls : ['./right-sidenav-tabbed-2.component.scss'] +}) +export class CardedRightSidenavTabbed2Component +{ + /** + * Constructor + */ + constructor() + { + } + +} diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.ts b/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.ts deleted file mode 100644 index 2e5dedfe..00000000 --- a/src/app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector : 'carded-right-sidenav-tabbed', - templateUrl: './right-sidenav-tabbed.component.html', - styleUrls : ['./right-sidenav-tabbed.component.scss'] -}) -export class CardedRightSidenavTabbedComponent -{ - /** - * Constructor - */ - constructor() - { - } - -} diff --git a/src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.ts b/src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.ts deleted file mode 100644 index 7ea8b054..00000000 --- a/src/app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector : 'carded-right-sidenav', - templateUrl: './right-sidenav.component.html', - styleUrls : ['./right-sidenav.component.scss'] -}) -export class CardedRightSidenavComponent -{ - /** - * Constructor - */ - constructor() - { - } - -} diff --git a/src/app/main/ui/page-layouts/page-layouts.module.ts b/src/app/main/ui/page-layouts/page-layouts.module.ts index 45041b57..89295b23 100644 --- a/src/app/main/ui/page-layouts/page-layouts.module.ts +++ b/src/app/main/ui/page-layouts/page-layouts.module.ts @@ -5,74 +5,84 @@ import { MatButtonModule, MatIconModule, MatSidenavModule, MatTabsModule } from import { FuseSharedModule } from '@fuse/shared.module'; import { FuseDemoModule } from '@fuse/components/demo/demo.module'; -import { CardedFullWidthComponent } from 'app/main/ui/page-layouts/carded/fullwidth/fullwidth.component'; -import { CardedFullWidth2Component } from 'app/main/ui/page-layouts/carded/fullwidth-2/fullwidth-2.component'; -import { CardedLeftSidenavComponent } from 'app/main/ui/page-layouts/carded/left-sidenav/left-sidenav.component'; -import { CardedLeftSidenavTabbedComponent } from 'app/main/ui/page-layouts/carded/left-sidenav-tabbed/left-sidenav-tabbed.component'; +import { CardedFullWidth1Component } from 'app/main/ui/page-layouts/carded/full-width-1/full-width-1.component'; +import { CardedFullWidth2Component } from 'app/main/ui/page-layouts/carded/full-width-2/full-width-2.component'; +import { CardedFullWidthTabbed1Component } from 'app/main/ui/page-layouts/carded/full-width-tabbed-1/full-width-tabbed-1.component'; +import { CardedFullWidthTabbed2Component } from 'app/main/ui/page-layouts/carded/full-width-tabbed-2/full-width-tabbed-2.component'; +import { CardedLeftSidenav1Component } from 'app/main/ui/page-layouts/carded/left-sidenav-1/left-sidenav-1.component'; import { CardedLeftSidenav2Component } from 'app/main/ui/page-layouts/carded/left-sidenav-2/left-sidenav-2.component'; -import { CardedLeftSidenav2TabbedComponent } from 'app/main/ui/page-layouts/carded/left-sidenav-2-tabbed/left-sidenav-2-tabbed.component'; -import { CardedRightSidenavComponent } from 'app/main/ui/page-layouts/carded/right-sidenav/right-sidenav.component'; -import { CardedRightSidenavTabbedComponent } from 'app/main/ui/page-layouts/carded/right-sidenav-tabbed/right-sidenav-tabbed.component'; +import { CardedLeftSidenavTabbed1Component } from 'app/main/ui/page-layouts/carded/left-sidenav-tabbed-1/left-sidenav-tabbed-1.component'; +import { CardedLeftSidenavTabbed2Component } from 'app/main/ui/page-layouts/carded/left-sidenav-tabbed-2/left-sidenav-tabbed-2.component'; +import { CardedRightSidenav1Component } from 'app/main/ui/page-layouts/carded/right-sidenav-1/right-sidenav-1.component'; import { CardedRightSidenav2Component } from 'app/main/ui/page-layouts/carded/right-sidenav-2/right-sidenav-2.component'; -import { CardedRightSidenav2TabbedComponent } from 'app/main/ui/page-layouts/carded/right-sidenav-2-tabbed/right-sidenav-2-tabbed.component'; -import { SimpleFullWidthComponent } from 'app/main/ui/page-layouts/simple/fullwidth/fullwidth.component'; -import { SimpleLeftSidenavComponent } from 'app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component'; +import { CardedRightSidenavTabbed1Component } from 'app/main/ui/page-layouts/carded/right-sidenav-tabbed-1/right-sidenav-tabbed-1.component'; +import { CardedRightSidenavTabbed2Component } from 'app/main/ui/page-layouts/carded/right-sidenav-tabbed-2/right-sidenav-tabbed-2.component'; +import { SimpleFullWidth1Component } from 'app/main/ui/page-layouts/simple/full-width-1/full-width-1.component'; +import { SimpleLeftSidenav1Component } from 'app/main/ui/page-layouts/simple/left-sidenav-1/left-sidenav-1.component'; import { SimpleLeftSidenav2Component } from 'app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component'; import { SimpleLeftSidenav3Component } from 'app/main/ui/page-layouts/simple/left-sidenav-3/left-sidenav-3.component'; -import { SimpleRightSidenavComponent } from 'app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component'; +import { SimpleRightSidenav1Component } from 'app/main/ui/page-layouts/simple/right-sidenav-1/right-sidenav-1.component'; import { SimpleRightSidenav2Component } from 'app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component'; import { SimpleRightSidenav3Component } from 'app/main/ui/page-layouts/simple/right-sidenav-3/right-sidenav-3.component'; -import { TabbedComponent } from 'app/main/ui/page-layouts/simple/tabbed/tabbed.component'; +import { Tabbed1Component } from 'app/main/ui/page-layouts/simple/tabbed-1/tabbed-1.component'; import { BlankComponent } from 'app/main/ui/page-layouts/blank/blank.component'; const routes: Routes = [ { - path : 'page-layouts/carded/full-width', - component: CardedFullWidthComponent + path : 'page-layouts/carded/full-width-1', + component: CardedFullWidth1Component }, { path : 'page-layouts/carded/full-width-2', component: CardedFullWidth2Component }, { - path : 'page-layouts/carded/left-sidenav', - component: CardedLeftSidenavComponent + path : 'page-layouts/carded/full-width-tabbed-1', + component: CardedFullWidthTabbed1Component }, { - path : 'page-layouts/carded/left-sidenav-tabbed', - component: CardedLeftSidenavTabbedComponent + path : 'page-layouts/carded/full-width-tabbed-2', + component: CardedFullWidthTabbed2Component + }, + { + path : 'page-layouts/carded/left-sidenav-1', + component: CardedLeftSidenav1Component + }, + { + path : 'page-layouts/carded/left-sidenav-tabbed-1', + component: CardedLeftSidenavTabbed1Component }, { path : 'page-layouts/carded/left-sidenav-2', component: CardedLeftSidenav2Component }, { - path : 'page-layouts/carded/left-sidenav-2-tabbed', - component: CardedLeftSidenav2TabbedComponent + path : 'page-layouts/carded/left-sidenav-tabbed-2', + component: CardedLeftSidenavTabbed2Component }, { - path : 'page-layouts/carded/right-sidenav', - component: CardedRightSidenavComponent + path : 'page-layouts/carded/right-sidenav-1', + component: CardedRightSidenav1Component }, { - path : 'page-layouts/carded/right-sidenav-tabbed', - component: CardedRightSidenavTabbedComponent + path : 'page-layouts/carded/right-sidenav-tabbed-1', + component: CardedRightSidenavTabbed1Component }, { path : 'page-layouts/carded/right-sidenav-2', component: CardedRightSidenav2Component }, { - path : 'page-layouts/carded/right-sidenav-2-tabbed', - component: CardedRightSidenav2TabbedComponent + path : 'page-layouts/carded/right-sidenav-tabbed-2', + component: CardedRightSidenavTabbed2Component }, { - path : 'page-layouts/simple/full-width', - component: SimpleFullWidthComponent + path : 'page-layouts/simple/full-width-1', + component: SimpleFullWidth1Component }, { - path : 'page-layouts/simple/left-sidenav', - component: SimpleLeftSidenavComponent + path : 'page-layouts/simple/left-sidenav-1', + component: SimpleLeftSidenav1Component }, { path : 'page-layouts/simple/left-sidenav-2', @@ -83,8 +93,8 @@ const routes: Routes = [ component: SimpleLeftSidenav3Component }, { - path : 'page-layouts/simple/right-sidenav', - component: SimpleRightSidenavComponent + path : 'page-layouts/simple/right-sidenav-1', + component: SimpleRightSidenav1Component }, { path : 'page-layouts/simple/right-sidenav-2', @@ -95,8 +105,8 @@ const routes: Routes = [ component: SimpleRightSidenav3Component }, { - path : 'page-layouts/simple/tabbed', - component: TabbedComponent + path : 'page-layouts/simple/tabbed-1', + component: Tabbed1Component }, { path : 'page-layouts/blank', @@ -106,24 +116,26 @@ const routes: Routes = [ @NgModule({ declarations: [ - CardedFullWidthComponent, + CardedFullWidth1Component, CardedFullWidth2Component, - CardedLeftSidenavComponent, - CardedLeftSidenavTabbedComponent, + CardedFullWidthTabbed1Component, + CardedFullWidthTabbed2Component, + CardedLeftSidenav1Component, CardedLeftSidenav2Component, - CardedLeftSidenav2TabbedComponent, - CardedRightSidenavComponent, - CardedRightSidenavTabbedComponent, + CardedLeftSidenavTabbed1Component, + CardedLeftSidenavTabbed2Component, + CardedRightSidenav1Component, CardedRightSidenav2Component, - CardedRightSidenav2TabbedComponent, - SimpleFullWidthComponent, - SimpleLeftSidenavComponent, + CardedRightSidenavTabbed1Component, + CardedRightSidenavTabbed2Component, + SimpleFullWidth1Component, + SimpleLeftSidenav1Component, SimpleLeftSidenav2Component, SimpleLeftSidenav3Component, - SimpleRightSidenavComponent, + SimpleRightSidenav1Component, SimpleRightSidenav2Component, SimpleRightSidenav3Component, - TabbedComponent, + Tabbed1Component, BlankComponent ], imports : [ diff --git a/src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.html b/src/app/main/ui/page-layouts/simple/full-width-1/full-width-1.component.html similarity index 92% rename from src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.html rename to src/app/main/ui/page-layouts/simple/full-width-1/full-width-1.component.html index 857770c3..b4270e75 100644 --- a/src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.html +++ b/src/app/main/ui/page-layouts/simple/full-width-1/full-width-1.component.html @@ -2,7 +2,7 @@
-

Fullwidth

+

Full width

diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.scss b/src/app/main/ui/page-layouts/simple/full-width-1/full-width-1.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.scss rename to src/app/main/ui/page-layouts/simple/full-width-1/full-width-1.component.scss diff --git a/src/app/main/ui/page-layouts/simple/full-width-1/full-width-1.component.ts b/src/app/main/ui/page-layouts/simple/full-width-1/full-width-1.component.ts new file mode 100644 index 00000000..74e45bb1 --- /dev/null +++ b/src/app/main/ui/page-layouts/simple/full-width-1/full-width-1.component.ts @@ -0,0 +1,16 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'simple-fullwidth-1', + templateUrl: './full-width-1.component.html', + styleUrls : ['./full-width-1.component.scss'] +}) +export class SimpleFullWidth1Component +{ + /** + * Constructor + */ + constructor() + { + } +} diff --git a/src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.ts b/src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.ts deleted file mode 100644 index d0c7414d..00000000 --- a/src/app/main/ui/page-layouts/simple/fullwidth/fullwidth.component.ts +++ /dev/null @@ -1,16 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector : 'simple-fullwidth', - templateUrl: './fullwidth.component.html', - styleUrls : ['./fullwidth.component.scss'] -}) -export class SimpleFullWidthComponent -{ - /** - * Constructor - */ - constructor() - { - } -} diff --git a/src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.html b/src/app/main/ui/page-layouts/simple/left-sidenav-1/left-sidenav-1.component.html similarity index 86% rename from src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.html rename to src/app/main/ui/page-layouts/simple/left-sidenav-1/left-sidenav-1.component.html index 4020d025..15f928df 100644 --- a/src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.html +++ b/src/app/main/ui/page-layouts/simple/left-sidenav-1/left-sidenav-1.component.html @@ -1,4 +1,4 @@ -
+
@@ -6,7 +6,7 @@ -
+
@@ -16,7 +16,7 @@ -
+
diff --git a/src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.scss b/src/app/main/ui/page-layouts/simple/left-sidenav-1/left-sidenav-1.component.scss similarity index 100% rename from src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.scss rename to src/app/main/ui/page-layouts/simple/left-sidenav-1/left-sidenav-1.component.scss diff --git a/src/app/main/ui/page-layouts/simple/left-sidenav-1/left-sidenav-1.component.ts b/src/app/main/ui/page-layouts/simple/left-sidenav-1/left-sidenav-1.component.ts new file mode 100644 index 00000000..5a1a9bfe --- /dev/null +++ b/src/app/main/ui/page-layouts/simple/left-sidenav-1/left-sidenav-1.component.ts @@ -0,0 +1,17 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'simple-left-sidenav-1', + templateUrl: './left-sidenav-1.component.html', + styleUrls : ['./left-sidenav-1.component.scss'] +}) +export class SimpleLeftSidenav1Component +{ + /** + * Constructor + */ + constructor() + { + } + +} diff --git a/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.html b/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.html index bc6a8ff9..5c4b6a07 100644 --- a/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.html +++ b/src/app/main/ui/page-layouts/simple/left-sidenav-2/left-sidenav-2.component.html @@ -1,12 +1,16 @@ -
+
- - +
+ + + +
@@ -24,7 +28,7 @@
-

Left sidenav with container scroll

+

Left sidenav with inner scroll

diff --git a/src/app/main/ui/page-layouts/simple/left-sidenav-3/left-sidenav-3.component.html b/src/app/main/ui/page-layouts/simple/left-sidenav-3/left-sidenav-3.component.html index d2afe5d2..23434a82 100644 --- a/src/app/main/ui/page-layouts/simple/left-sidenav-3/left-sidenav-3.component.html +++ b/src/app/main/ui/page-layouts/simple/left-sidenav-3/left-sidenav-3.component.html @@ -1,4 +1,4 @@ -
+
@@ -10,7 +10,7 @@
-

Left inner sidenav with content scroll

+

Left inner sidenav with inner scroll

diff --git a/src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.ts b/src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.ts deleted file mode 100644 index 682b638a..00000000 --- a/src/app/main/ui/page-layouts/simple/left-sidenav/left-sidenav.component.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector : 'simple-left-sidenav', - templateUrl: './left-sidenav.component.html', - styleUrls : ['./left-sidenav.component.scss'] -}) -export class SimpleLeftSidenavComponent -{ - /** - * Constructor - */ - constructor() - { - } - -} diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.html b/src/app/main/ui/page-layouts/simple/right-sidenav-1/right-sidenav-1.component.html similarity index 100% rename from src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.html rename to src/app/main/ui/page-layouts/simple/right-sidenav-1/right-sidenav-1.component.html diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav-1/right-sidenav-1.component.scss b/src/app/main/ui/page-layouts/simple/right-sidenav-1/right-sidenav-1.component.scss new file mode 100644 index 00000000..e69de29b diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav-1/right-sidenav-1.component.ts b/src/app/main/ui/page-layouts/simple/right-sidenav-1/right-sidenav-1.component.ts new file mode 100644 index 00000000..c022174f --- /dev/null +++ b/src/app/main/ui/page-layouts/simple/right-sidenav-1/right-sidenav-1.component.ts @@ -0,0 +1,17 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'simple-right-sidenav-1', + templateUrl: './right-sidenav-1.component.html', + styleUrls : ['./right-sidenav-1.component.scss'] +}) +export class SimpleRightSidenav1Component +{ + /** + * Constructor + */ + constructor() + { + } + +} diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.html b/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.html index e4454157..ddc677d5 100644 --- a/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.html +++ b/src/app/main/ui/page-layouts/simple/right-sidenav-2/right-sidenav-2.component.html @@ -1,4 +1,4 @@ -
+
@@ -15,7 +15,7 @@
-

Right sidenav with container scroll

+

Right sidenav with inner scroll

@@ -33,10 +33,14 @@ - - +
+ + + +
diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav-3/right-sidenav-3.component.html b/src/app/main/ui/page-layouts/simple/right-sidenav-3/right-sidenav-3.component.html index 07c94ab6..47d8d815 100644 --- a/src/app/main/ui/page-layouts/simple/right-sidenav-3/right-sidenav-3.component.html +++ b/src/app/main/ui/page-layouts/simple/right-sidenav-3/right-sidenav-3.component.html @@ -1,4 +1,4 @@ -
+
diff --git a/src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.ts b/src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.ts deleted file mode 100644 index bd3ab81d..00000000 --- a/src/app/main/ui/page-layouts/simple/right-sidenav/right-sidenav.component.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector : 'simple-right-sidenav', - templateUrl: './right-sidenav.component.html', - styleUrls : ['./right-sidenav.component.scss'] -}) -export class SimpleRightSidenavComponent -{ - /** - * Constructor - */ - constructor() - { - } - -} diff --git a/src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.html b/src/app/main/ui/page-layouts/simple/tabbed-1/tabbed-1.component.html similarity index 100% rename from src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.html rename to src/app/main/ui/page-layouts/simple/tabbed-1/tabbed-1.component.html diff --git a/src/app/main/ui/page-layouts/simple/tabbed-1/tabbed-1.component.scss b/src/app/main/ui/page-layouts/simple/tabbed-1/tabbed-1.component.scss new file mode 100644 index 00000000..e69de29b diff --git a/src/app/main/ui/page-layouts/simple/tabbed-1/tabbed-1.component.ts b/src/app/main/ui/page-layouts/simple/tabbed-1/tabbed-1.component.ts new file mode 100644 index 00000000..f5039dde --- /dev/null +++ b/src/app/main/ui/page-layouts/simple/tabbed-1/tabbed-1.component.ts @@ -0,0 +1,17 @@ +import { Component } from '@angular/core'; + +@Component({ + selector : 'tabbed-1', + templateUrl: './tabbed-1.component.html', + styleUrls : ['./tabbed-1.component.scss'] +}) +export class Tabbed1Component +{ + /** + * Constructor + */ + constructor() + { + } + +} diff --git a/src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.ts b/src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.ts deleted file mode 100644 index 6e01380f..00000000 --- a/src/app/main/ui/page-layouts/simple/tabbed/tabbed.component.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { Component } from '@angular/core'; - -@Component({ - selector : 'tabbed', - templateUrl: './tabbed.component.html', - styleUrls : ['./tabbed.component.scss'] -}) -export class TabbedComponent -{ - /** - * Constructor - */ - constructor() - { - } - -} diff --git a/src/app/navigation/navigation.ts b/src/app/navigation/navigation.ts index bfd12d41..2ff178f0 100644 --- a/src/app/navigation/navigation.ts +++ b/src/app/navigation/navigation.ts @@ -402,70 +402,82 @@ export const navigation: FuseNavigation[] = [ title : 'Carded', type : 'collapse', badge : { - title: '10', + title: '12', bg : '#525e8a', fg : '#FFFFFF' }, children: [ { - id : 'full-width', - title: 'Full Width', + id : 'full-width-1', + title: 'Full Width #1', type : 'item', - url : '/ui/page-layouts/carded/full-width' + url : '/ui/page-layouts/carded/full-width-1' }, { id : 'full-width-2', - title: 'Full Width 2', + title: 'Full Width #2', type : 'item', url : '/ui/page-layouts/carded/full-width-2' }, { - id : 'left-sidenav', - title: 'Left Sidenav', + id : 'full-width-tabbed-1', + title: 'Full Width Tabbed #1', type : 'item', - url : '/ui/page-layouts/carded/left-sidenav' + url : '/ui/page-layouts/carded/full-width-tabbed-1' }, { - id : 'left-sidenav-tabbed', - title: 'Left Sidenav Tabbed', + id : 'full-width-tabbed-2', + title: 'Full Width Tabbed #2', type : 'item', - url : '/ui/page-layouts/carded/left-sidenav-tabbed' + url : '/ui/page-layouts/carded/full-width-tabbed-2' + }, + { + id : 'left-sidenav-1', + title: 'Left Sidenav #1', + type : 'item', + url : '/ui/page-layouts/carded/left-sidenav-1' }, { id : 'left-sidenav-2', - title: 'Left Sidenav 2', + title: 'Left Sidenav #2', type : 'item', url : '/ui/page-layouts/carded/left-sidenav-2' }, { - id : 'left-sidenav-2-tabbed', - title: 'Left Sidenav 2 Tabbed', + id : 'left-sidenav-tabbed-1', + title: 'Left Sidenav Tabbed #1', type : 'item', - url : '/ui/page-layouts/carded/left-sidenav-2-tabbed' + url : '/ui/page-layouts/carded/left-sidenav-tabbed-1' }, { - id : 'right-sidenav', - title: 'Right Sidenav', + id : 'left-sidenav-tabbed-2', + title: 'Left Sidenav Tabbed #2', type : 'item', - url : '/ui/page-layouts/carded/right-sidenav' + url : '/ui/page-layouts/carded/left-sidenav-tabbed-2' }, { - id : 'right-sidenav-tabbed', - title: 'Right Sidenav Tabbed', + id : 'right-sidenav-1', + title: 'Right Sidenav #1', type : 'item', - url : '/ui/page-layouts/carded/right-sidenav-tabbed' + url : '/ui/page-layouts/carded/right-sidenav-1' }, { id : 'right-sidenav-2', - title: 'Right Sidenav 2', + title: 'Right Sidenav #2', type : 'item', url : '/ui/page-layouts/carded/right-sidenav-2' }, { - id : 'right-sidenav-2-tabbed', - title: 'Right Sidenav 2 Tabbed', + id : 'right-sidenav-tabbed-1', + title: 'Right Sidenav Tabbed #1', type : 'item', - url : '/ui/page-layouts/carded/right-sidenav-2-tabbed' + url : '/ui/page-layouts/carded/right-sidenav-tabbed-1' + }, + { + id : 'right-sidenav-tabbed-2', + title: 'Right Sidenav Tabbed #2', + type : 'item', + url : '/ui/page-layouts/carded/right-sidenav-tabbed-2' } ] }, @@ -480,52 +492,52 @@ export const navigation: FuseNavigation[] = [ }, children: [ { - id : 'full-width', - title: 'Full Width', + id : 'full-width-1', + title: 'Full Width #1', type : 'item', - url : '/ui/page-layouts/simple/full-width' + url : '/ui/page-layouts/simple/full-width-1' }, { - id : 'left-sidenav', - title: 'Left Sidenav', + id : 'left-sidenav-1', + title: 'Left Sidenav #1', type : 'item', - url : '/ui/page-layouts/simple/left-sidenav' + url : '/ui/page-layouts/simple/left-sidenav-1' }, { id : 'left-sidenav-2', - title: 'Left Sidenav 2', + title: 'Left Sidenav #2', type : 'item', url : '/ui/page-layouts/simple/left-sidenav-2' }, { id : 'left-sidenav-3', - title: 'Left Sidenav 3', + title: 'Left Sidenav #3', type : 'item', url : '/ui/page-layouts/simple/left-sidenav-3' }, { - id : 'right-sidenav', - title: 'Right Sidenav', + id : 'right-sidenav-1', + title: 'Right Sidenav #1', type : 'item', - url : '/ui/page-layouts/simple/right-sidenav' + url : '/ui/page-layouts/simple/right-sidenav-1' }, { id : 'right-sidenav-2', - title: 'Right Sidenav 2', + title: 'Right Sidenav #2', type : 'item', url : '/ui/page-layouts/simple/right-sidenav-2' }, { id : 'right-sidenav-3', - title: 'Right Sidenav 3', + title: 'Right Sidenav #3', type : 'item', url : '/ui/page-layouts/simple/right-sidenav-3' }, { - id : 'tabbed', - title: 'Tabbed', + id : 'tabbed-1', + title: 'Tabbed #1', type : 'item', - url : '/ui/page-layouts/simple/tabbed' + url : '/ui/page-layouts/simple/tabbed-1' } ] }, diff --git a/src/index.html b/src/index.html index 534f3c25..be771e3b 100644 --- a/src/index.html +++ b/src/index.html @@ -181,7 +181,7 @@ - + From ea15a8b832765a3ed1483cbacbf4af867ed9df82 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Thu, 7 Jun 2018 19:10:44 +0300 Subject: [PATCH 30/80] Re-added the accidentally deleted Angular Material Examples module --- ...nent.html => angular-material-examples.component.html} | 0 ...nent.scss => angular-material-examples.component.scss} | 0 ...omponent.ts => angular-material-examples.component.ts} | 6 +++--- ...rial.module.ts => angular-material-examples.module.ts} | 8 ++++---- src/app/main/components/components.module.ts | 6 +++++- src/app/navigation/navigation.ts | 2 +- 6 files changed, 13 insertions(+), 9 deletions(-) rename src/app/main/components/angular-material/{angular-material.component.html => angular-material-examples.component.html} (100%) rename src/app/main/components/angular-material/{angular-material.component.scss => angular-material-examples.component.scss} (100%) rename src/app/main/components/angular-material/{angular-material.component.ts => angular-material-examples.component.ts} (86%) rename src/app/main/components/angular-material/{angular-material.module.ts => angular-material-examples.module.ts} (79%) diff --git a/src/app/main/components/angular-material/angular-material.component.html b/src/app/main/components/angular-material/angular-material-examples.component.html similarity index 100% rename from src/app/main/components/angular-material/angular-material.component.html rename to src/app/main/components/angular-material/angular-material-examples.component.html diff --git a/src/app/main/components/angular-material/angular-material.component.scss b/src/app/main/components/angular-material/angular-material-examples.component.scss similarity index 100% rename from src/app/main/components/angular-material/angular-material.component.scss rename to src/app/main/components/angular-material/angular-material-examples.component.scss diff --git a/src/app/main/components/angular-material/angular-material.component.ts b/src/app/main/components/angular-material/angular-material-examples.component.ts similarity index 86% rename from src/app/main/components/angular-material/angular-material.component.ts rename to src/app/main/components/angular-material/angular-material-examples.component.ts index 4e56c1f2..d8d34a26 100644 --- a/src/app/main/components/angular-material/angular-material.component.ts +++ b/src/app/main/components/angular-material/angular-material-examples.component.ts @@ -7,10 +7,10 @@ import { COMPONENT_MAP } from 'app/main/components/angular-material/example-comp @Component({ selector : 'angular-material', - templateUrl: './angular-material.component.html', - styleUrls : ['./angular-material.component.scss'] + templateUrl: './angular-material-examples.component.html', + styleUrls : ['./angular-material-examples.component.scss'] }) -export class AngularMaterialComponent implements OnInit, OnDestroy +export class AngularMaterialExamplesComponent implements OnInit, OnDestroy { id: string; title: string; diff --git a/src/app/main/components/angular-material/angular-material.module.ts b/src/app/main/components/angular-material/angular-material-examples.module.ts similarity index 79% rename from src/app/main/components/angular-material/angular-material.module.ts rename to src/app/main/components/angular-material/angular-material-examples.module.ts index c82a0729..3da6959e 100644 --- a/src/app/main/components/angular-material/angular-material.module.ts +++ b/src/app/main/components/angular-material/angular-material-examples.module.ts @@ -7,7 +7,7 @@ import { FuseWidgetModule } from '@fuse/components/widget/widget.module'; import { MaterialModule } from 'app/main/components/angular-material/material.module'; import { EXAMPLE_LIST } from 'app/main/components/angular-material/example-components'; -import { AngularMaterialComponent } from 'app/main/components/angular-material/angular-material.component'; +import { AngularMaterialExamplesComponent } from 'app/main/components/angular-material/angular-material-examples.component'; import { ExampleViewerComponent } from 'app/main/components/angular-material/example-viewer/example-viewer'; const routes: Routes = [ @@ -16,7 +16,7 @@ const routes: Routes = [ children: [ { path : ':id', - component: AngularMaterialComponent + component: AngularMaterialExamplesComponent } ] } @@ -25,7 +25,7 @@ const routes: Routes = [ @NgModule({ declarations : [ [...EXAMPLE_LIST], - AngularMaterialComponent, + AngularMaterialExamplesComponent, ExampleViewerComponent ], imports : [ @@ -39,7 +39,7 @@ const routes: Routes = [ ], entryComponents: EXAMPLE_LIST, }) -export class AngularMaterialModule +export class AngularMaterialExamplesModule { } diff --git a/src/app/main/components/components.module.ts b/src/app/main/components/components.module.ts index 0a53c9a7..9e4e3717 100644 --- a/src/app/main/components/components.module.ts +++ b/src/app/main/components/components.module.ts @@ -5,6 +5,8 @@ import { NgxChartsModule } from '@swimlane/ngx-charts'; import { FuseSharedModule } from '@fuse/shared.module'; +import { AngularMaterialExamplesModule } from 'app/main/components/angular-material/angular-material-examples.module'; + import { FuseCountdownModule, FuseHighlightModule, FuseMaterialColorPickerModule, FuseWidgetModule } from '@fuse/components'; import { CardsDocsComponent } from 'app/main/components/cards/cards.component'; import { CountdownDocsComponent } from 'app/main/components/countdown/countdown.component'; @@ -93,7 +95,9 @@ const routes = [ FuseCountdownModule, FuseHighlightModule, FuseMaterialColorPickerModule, - FuseWidgetModule + FuseWidgetModule, + + AngularMaterialExamplesModule ] }) export class ComponentsModule diff --git a/src/app/navigation/navigation.ts b/src/app/navigation/navigation.ts index 2ff178f0..a08e7590 100644 --- a/src/app/navigation/navigation.ts +++ b/src/app/navigation/navigation.ts @@ -685,7 +685,7 @@ export const navigation: FuseNavigation[] = [ children: [ { id : 'badge', - title: 'badge', + title: 'Badge', type : 'item', url : '/components/angular-material/badge' }, From 97f864bb767566f9d24cae9c57ddcc1ef5a2a14c Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Thu, 7 Jun 2018 19:11:06 +0300 Subject: [PATCH 31/80] Small fix in navigation docs --- src/app/main/components/navigation/navigation.component.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/app/main/components/navigation/navigation.component.html b/src/app/main/components/navigation/navigation.component.html index aae875dd..25f6d333 100644 --- a/src/app/main/components/navigation/navigation.component.html +++ b/src/app/main/components/navigation/navigation.component.html @@ -99,7 +99,7 @@ 'children' : [ { 'title': 'ngx-datatable', - 'type' : 'nav-item', + 'type' : 'item', 'url' : '/components/datatables/ngx-datatable' } ] From ba35ebae948966cfa3e4118728b53647d0cb7e4a Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Thu, 7 Jun 2018 19:11:21 +0300 Subject: [PATCH 32/80] Fix: Images in Angular Material cards --- src/@fuse/scss/partials/_angular-material-fix.scss | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/@fuse/scss/partials/_angular-material-fix.scss b/src/@fuse/scss/partials/_angular-material-fix.scss index b56e66f8..cca511e7 100644 --- a/src/@fuse/scss/partials/_angular-material-fix.scss +++ b/src/@fuse/scss/partials/_angular-material-fix.scss @@ -84,4 +84,9 @@ mat-chip { min-width: 0 !important; min-height: 0 !important; } +} + +// Fix: Mat-card-image requires a bigger width than 100% +.mat-card-image { + max-width: none !important; } \ No newline at end of file From a39021188eca4d5ea3700a818fafe37fd622773a Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Thu, 7 Jun 2018 20:49:29 +0300 Subject: [PATCH 33/80] Renamed 'collapse' to 'collapsable' in navigation types Renamed navigation component files Small fix in shortcuts ('nav-item' to 'item') --- .../collapsable.component.html} | 11 +++++----- .../collapsable.component.scss} | 0 .../collapsable.component.ts} | 10 ++++----- .../item.component.html} | 0 .../item.component.scss} | 0 .../item.component.ts} | 4 ++-- .../navigation/navigation.component.html | 6 ++--- .../navigation/navigation.module.ts | 14 ++++++------ .../collapsable.component.html} | 5 +++-- .../collapsable.component.scss} | 0 .../collapsable.component.ts} | 10 ++++----- .../group.component.html} | 3 ++- .../group.component.scss} | 0 .../group.component.ts} | 4 ++-- .../item.component.html} | 0 .../item.component.scss} | 0 .../item.component.ts} | 4 ++-- .../shortcuts/shortcuts.component.ts | 8 +++---- src/@fuse/scss/partials/_navigation.scss | 16 +++++++------- src/@fuse/types/fuse-navigation.ts | 2 +- src/app/navigation/navigation.ts | 22 +++++++++---------- 21 files changed, 61 insertions(+), 58 deletions(-) rename src/@fuse/components/navigation/horizontal/{nav-collapse/nav-horizontal-collapse.component.html => collapsable/collapsable.component.html} (78%) rename src/@fuse/components/navigation/horizontal/{nav-collapse/nav-horizontal-collapse.component.scss => collapsable/collapsable.component.scss} (100%) rename src/@fuse/components/navigation/horizontal/{nav-collapse/nav-horizontal-collapse.component.ts => collapsable/collapsable.component.ts} (86%) rename src/@fuse/components/navigation/horizontal/{nav-item/nav-horizontal-item.component.html => item/item.component.html} (100%) rename src/@fuse/components/navigation/horizontal/{nav-item/nav-horizontal-item.component.scss => item/item.component.scss} (100%) rename src/@fuse/components/navigation/horizontal/{nav-item/nav-horizontal-item.component.ts => item/item.component.ts} (73%) rename src/@fuse/components/navigation/vertical/{nav-collapse/nav-vertical-collapse.component.html => collapsable/collapsable.component.html} (91%) rename src/@fuse/components/navigation/vertical/{nav-collapse/nav-vertical-collapse.component.scss => collapsable/collapsable.component.scss} (100%) rename src/@fuse/components/navigation/vertical/{nav-collapse/nav-vertical-collapse.component.ts => collapsable/collapsable.component.ts} (95%) rename src/@fuse/components/navigation/vertical/{nav-group/nav-vertical-group.component.html => group/group.component.html} (75%) rename src/@fuse/components/navigation/vertical/{nav-group/nav-vertical-group.component.scss => group/group.component.scss} (100%) rename src/@fuse/components/navigation/vertical/{nav-group/nav-vertical-group.component.ts => group/group.component.ts} (77%) rename src/@fuse/components/navigation/vertical/{nav-item/nav-vertical-item.component.html => item/item.component.html} (100%) rename src/@fuse/components/navigation/vertical/{nav-item/nav-vertical-item.component.scss => item/item.component.scss} (100%) rename src/@fuse/components/navigation/vertical/{nav-item/nav-vertical-item.component.ts => item/item.component.ts} (77%) diff --git a/src/@fuse/components/navigation/horizontal/nav-collapse/nav-horizontal-collapse.component.html b/src/@fuse/components/navigation/horizontal/collapsable/collapsable.component.html similarity index 78% rename from src/@fuse/components/navigation/horizontal/nav-collapse/nav-horizontal-collapse.component.html rename to src/@fuse/components/navigation/horizontal/collapsable/collapsable.component.html index da55085f..28a5e64b 100644 --- a/src/@fuse/components/navigation/horizontal/nav-collapse/nav-horizontal-collapse.component.html +++ b/src/@fuse/components/navigation/horizontal/collapsable/collapsable.component.html @@ -31,18 +31,19 @@ [ngStyle]="{'background-color': item.badge.bg,'color': item.badge.fg}"> {{item.badge.title}} - keyboard_arrow_right + keyboard_arrow_right
-
+
- - + +
diff --git a/src/@fuse/components/navigation/horizontal/nav-collapse/nav-horizontal-collapse.component.scss b/src/@fuse/components/navigation/horizontal/collapsable/collapsable.component.scss similarity index 100% rename from src/@fuse/components/navigation/horizontal/nav-collapse/nav-horizontal-collapse.component.scss rename to src/@fuse/components/navigation/horizontal/collapsable/collapsable.component.scss diff --git a/src/@fuse/components/navigation/horizontal/nav-collapse/nav-horizontal-collapse.component.ts b/src/@fuse/components/navigation/horizontal/collapsable/collapsable.component.ts similarity index 86% rename from src/@fuse/components/navigation/horizontal/nav-collapse/nav-horizontal-collapse.component.ts rename to src/@fuse/components/navigation/horizontal/collapsable/collapsable.component.ts index f0fe6903..4b5cdb9a 100644 --- a/src/@fuse/components/navigation/horizontal/nav-collapse/nav-horizontal-collapse.component.ts +++ b/src/@fuse/components/navigation/horizontal/collapsable/collapsable.component.ts @@ -6,18 +6,18 @@ import { fuseAnimations } from '@fuse/animations'; import { FuseConfigService } from '@fuse/services/config.service'; @Component({ - selector : 'fuse-nav-horizontal-collapse', - templateUrl: './nav-horizontal-collapse.component.html', - styleUrls : ['./nav-horizontal-collapse.component.scss'], + selector : 'fuse-nav-horizontal-collapsable', + templateUrl: './collapsable.component.html', + styleUrls : ['./collapsable.component.scss'], animations : fuseAnimations }) -export class FuseNavHorizontalCollapseComponent implements OnInit, OnDestroy +export class FuseNavHorizontalCollapsableComponent implements OnInit, OnDestroy { fuseConfig: any; isOpen = false; @HostBinding('class') - classes = 'nav-item nav-collapse'; + classes = 'nav-collapsable nav-item'; @Input() item: any; diff --git a/src/@fuse/components/navigation/horizontal/nav-item/nav-horizontal-item.component.html b/src/@fuse/components/navigation/horizontal/item/item.component.html similarity index 100% rename from src/@fuse/components/navigation/horizontal/nav-item/nav-horizontal-item.component.html rename to src/@fuse/components/navigation/horizontal/item/item.component.html diff --git a/src/@fuse/components/navigation/horizontal/nav-item/nav-horizontal-item.component.scss b/src/@fuse/components/navigation/horizontal/item/item.component.scss similarity index 100% rename from src/@fuse/components/navigation/horizontal/nav-item/nav-horizontal-item.component.scss rename to src/@fuse/components/navigation/horizontal/item/item.component.scss diff --git a/src/@fuse/components/navigation/horizontal/nav-item/nav-horizontal-item.component.ts b/src/@fuse/components/navigation/horizontal/item/item.component.ts similarity index 73% rename from src/@fuse/components/navigation/horizontal/nav-item/nav-horizontal-item.component.ts rename to src/@fuse/components/navigation/horizontal/item/item.component.ts index 58e3dab5..ade234a4 100644 --- a/src/@fuse/components/navigation/horizontal/nav-item/nav-horizontal-item.component.ts +++ b/src/@fuse/components/navigation/horizontal/item/item.component.ts @@ -2,8 +2,8 @@ import { Component, HostBinding, Input } from '@angular/core'; @Component({ selector : 'fuse-nav-horizontal-item', - templateUrl: './nav-horizontal-item.component.html', - styleUrls : ['./nav-horizontal-item.component.scss'] + templateUrl: './item.component.html', + styleUrls : ['./item.component.scss'] }) export class FuseNavHorizontalItemComponent { diff --git a/src/@fuse/components/navigation/navigation.component.html b/src/@fuse/components/navigation/navigation.component.html index 10ecaf89..79459998 100644 --- a/src/@fuse/components/navigation/navigation.component.html +++ b/src/@fuse/components/navigation/navigation.component.html @@ -7,7 +7,7 @@ - + @@ -20,8 +20,8 @@ - - + + diff --git a/src/@fuse/components/navigation/navigation.module.ts b/src/@fuse/components/navigation/navigation.module.ts index 12519314..577a1186 100644 --- a/src/@fuse/components/navigation/navigation.module.ts +++ b/src/@fuse/components/navigation/navigation.module.ts @@ -6,11 +6,11 @@ import { MatIconModule, MatRippleModule } from '@angular/material'; import { TranslateModule } from '@ngx-translate/core'; import { FuseNavigationComponent } from './navigation.component'; -import { FuseNavVerticalItemComponent } from './vertical/nav-item/nav-vertical-item.component'; -import { FuseNavVerticalCollapseComponent } from './vertical/nav-collapse/nav-vertical-collapse.component'; -import { FuseNavVerticalGroupComponent } from './vertical/nav-group/nav-vertical-group.component'; -import { FuseNavHorizontalItemComponent } from './horizontal/nav-item/nav-horizontal-item.component'; -import { FuseNavHorizontalCollapseComponent } from './horizontal/nav-collapse/nav-horizontal-collapse.component'; +import { FuseNavVerticalItemComponent } from './vertical/item/item.component'; +import { FuseNavVerticalCollapsableComponent } from './vertical/collapsable/collapsable.component'; +import { FuseNavVerticalGroupComponent } from './vertical/group/group.component'; +import { FuseNavHorizontalItemComponent } from './horizontal/item/item.component'; +import { FuseNavHorizontalCollapsableComponent } from './horizontal/collapsable/collapsable.component'; @NgModule({ imports : [ @@ -29,9 +29,9 @@ import { FuseNavHorizontalCollapseComponent } from './horizontal/nav-collapse/na FuseNavigationComponent, FuseNavVerticalGroupComponent, FuseNavVerticalItemComponent, - FuseNavVerticalCollapseComponent, + FuseNavVerticalCollapsableComponent, FuseNavHorizontalItemComponent, - FuseNavHorizontalCollapseComponent + FuseNavHorizontalCollapsableComponent ] }) export class FuseNavigationModule diff --git a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html b/src/@fuse/components/navigation/vertical/collapsable/collapsable.component.html similarity index 91% rename from src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html rename to src/@fuse/components/navigation/vertical/collapsable/collapsable.component.html index acc4d0c6..f85fbd4d 100644 --- a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.html +++ b/src/@fuse/components/navigation/vertical/collapsable/collapsable.component.html @@ -47,13 +47,14 @@ [ngStyle]="{'background-color': item.badge.bg,'color': item.badge.fg}"> {{item.badge.title}} - keyboard_arrow_right + keyboard_arrow_right
- +
diff --git a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.scss b/src/@fuse/components/navigation/vertical/collapsable/collapsable.component.scss similarity index 100% rename from src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.scss rename to src/@fuse/components/navigation/vertical/collapsable/collapsable.component.scss diff --git a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.ts b/src/@fuse/components/navigation/vertical/collapsable/collapsable.component.ts similarity index 95% rename from src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.ts rename to src/@fuse/components/navigation/vertical/collapsable/collapsable.component.ts index 8ef02be0..fbda7a18 100644 --- a/src/@fuse/components/navigation/vertical/nav-collapse/nav-vertical-collapse.component.ts +++ b/src/@fuse/components/navigation/vertical/collapsable/collapsable.component.ts @@ -8,18 +8,18 @@ import { fuseAnimations } from '@fuse/animations'; import { FuseNavigationService } from '@fuse/components/navigation/navigation.service'; @Component({ - selector : 'fuse-nav-vertical-collapse', - templateUrl: './nav-vertical-collapse.component.html', - styleUrls : ['./nav-vertical-collapse.component.scss'], + selector : 'fuse-nav-vertical-collapsable', + templateUrl: './collapsable.component.html', + styleUrls : ['./collapsable.component.scss'], animations : fuseAnimations }) -export class FuseNavVerticalCollapseComponent implements OnInit, OnDestroy +export class FuseNavVerticalCollapsableComponent implements OnInit, OnDestroy { @Input() item: FuseNavigationItem; @HostBinding('class') - classes = 'nav-collapse nav-item'; + classes = 'nav-collapsable nav-item'; @HostBinding('class.open') public isOpen = false; diff --git a/src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.html b/src/@fuse/components/navigation/vertical/group/group.component.html similarity index 75% rename from src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.html rename to src/@fuse/components/navigation/vertical/group/group.component.html index 0747455c..26820b81 100644 --- a/src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.html +++ b/src/@fuse/components/navigation/vertical/group/group.component.html @@ -7,7 +7,8 @@
- +
diff --git a/src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.scss b/src/@fuse/components/navigation/vertical/group/group.component.scss similarity index 100% rename from src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.scss rename to src/@fuse/components/navigation/vertical/group/group.component.scss diff --git a/src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.ts b/src/@fuse/components/navigation/vertical/group/group.component.ts similarity index 77% rename from src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.ts rename to src/@fuse/components/navigation/vertical/group/group.component.ts index 0959e39d..d43e223e 100644 --- a/src/@fuse/components/navigation/vertical/nav-group/nav-vertical-group.component.ts +++ b/src/@fuse/components/navigation/vertical/group/group.component.ts @@ -4,8 +4,8 @@ import { FuseNavigationItem } from '@fuse/types'; @Component({ selector : 'fuse-nav-vertical-group', - templateUrl: './nav-vertical-group.component.html', - styleUrls : ['./nav-vertical-group.component.scss'] + templateUrl: './group.component.html', + styleUrls : ['./group.component.scss'] }) export class FuseNavVerticalGroupComponent { diff --git a/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.html b/src/@fuse/components/navigation/vertical/item/item.component.html similarity index 100% rename from src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.html rename to src/@fuse/components/navigation/vertical/item/item.component.html diff --git a/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.scss b/src/@fuse/components/navigation/vertical/item/item.component.scss similarity index 100% rename from src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.scss rename to src/@fuse/components/navigation/vertical/item/item.component.scss diff --git a/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.ts b/src/@fuse/components/navigation/vertical/item/item.component.ts similarity index 77% rename from src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.ts rename to src/@fuse/components/navigation/vertical/item/item.component.ts index 9fe5c36c..c807e381 100644 --- a/src/@fuse/components/navigation/vertical/nav-item/nav-vertical-item.component.ts +++ b/src/@fuse/components/navigation/vertical/item/item.component.ts @@ -4,8 +4,8 @@ import { FuseNavigationItem } from '@fuse/types'; @Component({ selector : 'fuse-nav-vertical-item', - templateUrl: './nav-vertical-item.component.html', - styleUrls : ['./nav-vertical-item.component.scss'] + templateUrl: './item.component.html', + styleUrls : ['./item.component.scss'] }) export class FuseNavVerticalItemComponent { diff --git a/src/@fuse/components/shortcuts/shortcuts.component.ts b/src/@fuse/components/shortcuts/shortcuts.component.ts index 9275ae1a..14c45833 100644 --- a/src/@fuse/components/shortcuts/shortcuts.component.ts +++ b/src/@fuse/components/shortcuts/shortcuts.component.ts @@ -95,25 +95,25 @@ export class FuseShortcutsComponent implements OnInit, OnDestroy this.shortcutItems = [ { 'title': 'Calendar', - 'type' : 'nav-item', + 'type' : 'item', 'icon' : 'today', 'url' : '/apps/calendar' }, { 'title': 'Mail', - 'type' : 'nav-item', + 'type' : 'item', 'icon' : 'email', 'url' : '/apps/mail' }, { 'title': 'Contacts', - 'type' : 'nav-item', + 'type' : 'item', 'icon' : 'account_box', 'url' : '/apps/contacts' }, { 'title': 'To-Do', - 'type' : 'nav-item', + 'type' : 'item', 'icon' : 'check_box', 'url' : '/apps/todo' } diff --git a/src/@fuse/scss/partials/_navigation.scss b/src/@fuse/scss/partials/_navigation.scss index a007e38b..4e52dc95 100644 --- a/src/@fuse/scss/partials/_navigation.scss +++ b/src/@fuse/scss/partials/_navigation.scss @@ -58,7 +58,7 @@ transition: opacity 0.2s ease-in-out 0.1s; margin-left: 8px; - + .collapse-arrow { + + .collapsable-arrow { margin-left: 8px; } } @@ -93,7 +93,7 @@ } .nav-link-icon, - .collapse-arrow { + .collapsable-arrow { font-size: 16px; width: 16px; height: 16px; @@ -103,7 +103,7 @@ } } - &.nav-collapse { + &.nav-collapsable { display: block; > .children { @@ -135,7 +135,7 @@ > .nav-item { - &.nav-collapse { + &.nav-collapsable { background: transparent; transition: background 200ms ease-in-out; @@ -149,7 +149,7 @@ > .group-items { - > .nav-collapse { + > .nav-collapsable { background: transparent; transition: background 200ms ease-in-out; @@ -176,7 +176,7 @@ .nav-item { - &.nav-collapse { + &.nav-collapsable { position: relative; .children { @@ -205,13 +205,13 @@ height: 56px; } - &.nav-collapse { + &.nav-collapsable { position: relative; > .nav-link { height: 56px; - .collapse-arrow { + .collapsable-arrow { display: none; } } diff --git a/src/@fuse/types/fuse-navigation.ts b/src/@fuse/types/fuse-navigation.ts index cb915e1e..823d633f 100644 --- a/src/@fuse/types/fuse-navigation.ts +++ b/src/@fuse/types/fuse-navigation.ts @@ -2,7 +2,7 @@ export interface FuseNavigationItem { id: string; title: string; - type: 'item' | 'group' | 'collapse'; + type: 'item' | 'group' | 'collapsable'; translate?: string; icon?: string; hidden?: boolean; diff --git a/src/app/navigation/navigation.ts b/src/app/navigation/navigation.ts index a08e7590..0cfa6601 100644 --- a/src/app/navigation/navigation.ts +++ b/src/app/navigation/navigation.ts @@ -12,7 +12,7 @@ export const navigation: FuseNavigation[] = [ id : 'dashboards', title : 'Dashboards', translate: 'NAV.DASHBOARDS', - type : 'collapse', + type : 'collapsable', icon : 'dashboard', children : [ { @@ -41,7 +41,7 @@ export const navigation: FuseNavigation[] = [ id : 'e-commerce', title : 'E-Commerce', translate: 'NAV.ECOMMERCE', - type : 'collapse', + type : 'collapsable', icon : 'shopping_cart', children : [ { @@ -177,7 +177,7 @@ export const navigation: FuseNavigation[] = [ { id : 'authentication', title : 'Authentication', - type : 'collapse', + type : 'collapsable', icon : 'lock', badge : { title: '10', @@ -257,7 +257,7 @@ export const navigation: FuseNavigation[] = [ { id : 'errors', title : 'Errors', - type : 'collapse', + type : 'collapsable', icon : 'error', children: [ { @@ -277,7 +277,7 @@ export const navigation: FuseNavigation[] = [ { id : 'invoice', title : 'Invoice', - type : 'collapse', + type : 'collapsable', icon : 'receipt', children: [ { @@ -304,7 +304,7 @@ export const navigation: FuseNavigation[] = [ { id : 'pricing', title : 'Pricing', - type : 'collapse', + type : 'collapsable', icon : 'attach_money', children: [ { @@ -394,13 +394,13 @@ export const navigation: FuseNavigation[] = [ { id : 'page-layouts', title : 'Page Layouts', - type : 'collapse', + type : 'collapsable', icon : 'view_quilt', children: [ { id : 'carded', title : 'Carded', - type : 'collapse', + type : 'collapsable', badge : { title: '12', bg : '#525e8a', @@ -484,7 +484,7 @@ export const navigation: FuseNavigation[] = [ { id : 'simple', title : 'Simple', - type : 'collapse', + type : 'collapsable', badge : { title: '8', bg : '#525e8a', @@ -589,7 +589,7 @@ export const navigation: FuseNavigation[] = [ { id : 'angular-material-elements', title : 'Angular Material Elements', - type : 'collapse', + type : 'collapsable', icon : 'layers', children: [ { @@ -927,7 +927,7 @@ export const navigation: FuseNavigation[] = [ { id : 'datatables', title : 'Datatables', - type : 'collapse', + type : 'collapsable', icon : 'border_all', children: [ { From 90fe94a41722c478aecb0c468f1a8e0d57c9ea3b Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Thu, 7 Jun 2018 21:12:12 +0300 Subject: [PATCH 34/80] Added horizontal layout to the new layout system Added boxed layout width --- .../theme-options.component.html | 83 +++++++++++-- .../theme-options/theme-options.component.ts | 28 +++++ src/@fuse/types/fuse-config.ts | 4 +- src/app/app.component.html | 2 +- .../layout-1/layout-1.component.html | 109 ++++++++++-------- .../layout-1/layout-1.component.scss | 101 +++------------- src/app/layout/layout.module.ts | 10 +- .../body-scroll/body-scroll.component.html | 2 +- .../body-scroll/body-scroll.component.scss | 7 ++ .../content-scroll.component.html | 2 +- .../content-scroll.component.scss | 7 ++ .../vertical/layout-2/layout-2.component.html | 2 +- .../vertical/layout-2/layout-2.component.scss | 7 ++ 13 files changed, 213 insertions(+), 151 deletions(-) diff --git a/src/@fuse/components/theme-options/theme-options.component.html b/src/@fuse/components/theme-options/theme-options.component.html index 74fa994a..8f521bfe 100644 --- a/src/@fuse/components/theme-options/theme-options.component.html +++ b/src/@fuse/components/theme-options/theme-options.component.html @@ -27,8 +27,9 @@ Vertical Layout #2 - Horizontal Layout #1 - Horizontal Layout #2 + + Horizontal Layout #1 + @@ -38,7 +39,7 @@ -
+

Layout Width

@@ -82,7 +83,6 @@ Above Below Static - Below Sticky Below Fixed @@ -101,7 +101,6 @@ Above Below Static - Below Sticky Below Fixed @@ -113,7 +112,7 @@ -
+

Layout Width

@@ -156,7 +155,6 @@

Position:

Above Static - Above Sticky Above Fixed Below @@ -175,7 +173,6 @@

Position:

Above Static - Above Sticky Above Fixed Below @@ -188,7 +185,7 @@ -
+

Layout Width

@@ -231,7 +228,6 @@

Position:

Above Static - Above Sticky Above Fixed @@ -249,7 +245,6 @@

Position:

Above Static - Above Sticky Above Fixed @@ -257,6 +252,72 @@ + + + + +
+ +

Layout Width

+ + Fullwidth + Boxed + + +
+ + +
+ +

Navbar

+ + + Hide + + +

Position:

+ + Top + + +
+ + +
+ +

Toolbar

+ + + Hide + + +

Position:

+ + Above + Below + + +
+ + +
+ +

Footer

+ + + Hide + + +

Position:

+ + Above Fixed + Above Static + + +
+ +
+
diff --git a/src/@fuse/components/theme-options/theme-options.component.ts b/src/@fuse/components/theme-options/theme-options.component.ts index c5230167..c801768f 100644 --- a/src/@fuse/components/theme-options/theme-options.component.ts +++ b/src/@fuse/components/theme-options/theme-options.component.ts @@ -250,6 +250,34 @@ export class FuseThemeOptionsComponent implements OnInit, OnDestroy break; } + + // Horizontal Layout #1 + case 'horizontal-layout-1': + { + this.form.patchValue({ + layout: { + width : 'fullwidth', + navbar : { + hidden : false, + position : 'top', + folded : false, + background: 'mat-fuse-dark-700-bg' + }, + toolbar: { + hidden : false, + position : 'above', + background: 'mat-white-500-bg' + }, + footer : { + hidden : false, + position : 'above-fixed', + background: 'mat-fuse-dark-900-bg' + } + } + }); + + break; + } } } diff --git a/src/@fuse/types/fuse-config.ts b/src/@fuse/types/fuse-config.ts index 9458a935..2172caac 100644 --- a/src/@fuse/types/fuse-config.ts +++ b/src/@fuse/types/fuse-config.ts @@ -11,12 +11,12 @@ export interface FuseConfig }, toolbar: { hidden: boolean, - position: 'above' | 'above-static' | 'above-sticky' | 'above-fixed' | 'below' | 'below-static' | 'below-sticky' | 'below-fixed', + position: 'above' | 'above-static' | 'above-fixed' | 'below' | 'below-static' | 'below-fixed', background: string } footer: { hidden: boolean, - position: 'above' | 'above-static' | 'above-sticky' | 'above-fixed' | 'below' | 'below-static' | 'below-sticky' | 'below-fixed', + position: 'above' | 'above-static' | 'above-fixed' | 'below' | 'below-static' | 'below-fixed', background: string } }; diff --git a/src/app/app.component.html b/src/app/app.component.html index 669f1e7c..2048afa4 100644 --- a/src/app/app.component.html +++ b/src/app/app.component.html @@ -15,7 +15,7 @@ - + diff --git a/src/app/layout/horizontal/layout-1/layout-1.component.html b/src/app/layout/horizontal/layout-1/layout-1.component.html index 1294d2da..1585d402 100644 --- a/src/app/layout/horizontal/layout-1/layout-1.component.html +++ b/src/app/layout/horizontal/layout-1/layout-1.component.html @@ -1,91 +1,100 @@ -
+
- - + + - + + + + + + + + +
- - - + + +
- - - - - - -
- - - - - - +
- -
+ +
- - -
-
- -
- - - - - -
- -
+ +
- + - \ No newline at end of file + + + + + + + + + + + +
+
+ + + + + + + + + + + + + + + + diff --git a/src/app/layout/horizontal/layout-1/layout-1.component.scss b/src/app/layout/horizontal/layout-1/layout-1.component.scss index 1d854f63..bb3a3b3b 100644 --- a/src/app/layout/horizontal/layout-1/layout-1.component.scss +++ b/src/app/layout/horizontal/layout-1/layout-1.component.scss @@ -4,6 +4,7 @@ horizontal-layout-1 { display: flex; flex: 1 1 auto; width: 100%; + height: 100%; #main { position: relative; @@ -11,14 +12,24 @@ horizontal-layout-1 { flex: 1 1 auto; flex-direction: column; width: 100%; + height: 100%; z-index: 1; + // Boxed + &.boxed { + max-width: 1200px; + margin: 0 auto; + @include mat-elevation(8); + } + // Container 1 > .container { position: relative; display: flex; flex: 1 1 auto; width: 100%; + min-height: 0; + min-width: 0; // Container 2 > .container { @@ -35,17 +46,18 @@ horizontal-layout-1 { flex: 1 1 auto; flex-direction: column; transform: translateZ(0); + overflow-x: hidden; + overflow-y: auto; - &.container-scroll { - overflow-x: hidden; - overflow-y: auto; + // Content component + content { - // Content component - content { - flex: 1 0 auto; + &.inner-scroll { + flex: 1 1 auto; + min-height: 0; > *:not(router-outlet) { - flex: 1 0 auto; + flex: 1 1 auto; } } } @@ -54,78 +66,3 @@ horizontal-layout-1 { } } } - -vertical-layout-111 { - display: flex; - flex-direction: column; - width: 100%; - height: 100%; - - /* > .mat-sidenav-container { - display: flex; - flex: 1; - - > .mat-sidenav-content, - > .mat-drawer-content { - display: flex; - flex: 1; - overflow: hidden; - height: 100vh;*/ - - @include media-breakpoint-down('sm') { - height: auto !important; - } - - #main-content { - display: flex; - flex: 1; - flex-direction: column; - overflow: hidden; - background: #FAFAFA; - - #wrapper { - display: flex; - position: relative; - flex: 1; - overflow: hidden; - - .content-wrapper { - display: flex; - flex-direction: column; - flex: 1; - overflow: hidden; - - content { - position: relative; - display: flex; - flex: 1; - flex-direction: row; - width: 100%; - overflow: hidden; - - > *:not(router-outlet):not(.ps__scrollbar-x-rail):not(.ps__scrollbar-y-rail) { - display: flex; - flex: 1; - width: 100%; - min-width: 100%; - } - - > *.ng-animating { - - .mat-tab-body { - height: 100vh; - } - } - } - } - //} - //} - } - } - - &[fuse-layout-mode="boxed"] { - max-width: 1200px; - margin: 0 auto; - @include mat-elevation(8); - } -} diff --git a/src/app/layout/layout.module.ts b/src/app/layout/layout.module.ts index 008361c7..42cd08a8 100644 --- a/src/app/layout/layout.module.ts +++ b/src/app/layout/layout.module.ts @@ -5,18 +5,24 @@ import { VerticalLayout1ContentScrollModule } from 'app/layout/vertical/layout-1 import { VerticalLayout2Module } from 'app/layout/vertical/layout-2/layout-2.module'; +import { HorizontalLayout1Module } from 'app/layout/horizontal/layout-1/layout-1.module'; + @NgModule({ imports: [ VerticalLayout1BodyScrollModule, VerticalLayout1ContentScrollModule, - VerticalLayout2Module + VerticalLayout2Module, + + HorizontalLayout1Module ], exports: [ VerticalLayout1BodyScrollModule, VerticalLayout1ContentScrollModule, - VerticalLayout2Module + VerticalLayout2Module, + + HorizontalLayout1Module ] }) export class LayoutModule diff --git a/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.html b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.html index aea612bd..fb79bfec 100644 --- a/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.html +++ b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.html @@ -1,4 +1,4 @@ -
+
diff --git a/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.scss b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.scss index fbe43795..951fe8d1 100644 --- a/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.scss +++ b/src/app/layout/vertical/layout-1/body-scroll/body-scroll.component.scss @@ -15,6 +15,13 @@ vertical-layout-1-body-scroll { height: 100%; z-index: 1; + // Boxed + &.boxed { + max-width: 1200px; + margin: 0 auto; + @include mat-elevation(8); + } + // Container 1 (Scrollable) > .container { position: relative; diff --git a/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.html b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.html index 9d1217cf..b0dc5ea4 100644 --- a/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.html +++ b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.html @@ -1,4 +1,4 @@ -
+
diff --git a/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.scss b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.scss index 0af78cae..db1a6bcf 100644 --- a/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.scss +++ b/src/app/layout/vertical/layout-1/content-scroll/content-scroll.component.scss @@ -15,6 +15,13 @@ vertical-layout-1-content-scroll { height: 100%; z-index: 1; + // Boxed + &.boxed { + max-width: 1200px; + margin: 0 auto; + @include mat-elevation(8); + } + // Container 1 > .container { position: relative; diff --git a/src/app/layout/vertical/layout-2/layout-2.component.html b/src/app/layout/vertical/layout-2/layout-2.component.html index 7b719f1f..ddb30b83 100644 --- a/src/app/layout/vertical/layout-2/layout-2.component.html +++ b/src/app/layout/vertical/layout-2/layout-2.component.html @@ -1,4 +1,4 @@ -
+
diff --git a/src/app/layout/vertical/layout-2/layout-2.component.scss b/src/app/layout/vertical/layout-2/layout-2.component.scss index b863500e..cf112512 100644 --- a/src/app/layout/vertical/layout-2/layout-2.component.scss +++ b/src/app/layout/vertical/layout-2/layout-2.component.scss @@ -15,6 +15,13 @@ vertical-layout-2 { height: 100%; z-index: 1; + // Boxed + &.boxed { + max-width: 1200px; + margin: 0 auto; + @include mat-elevation(8); + } + // Container 1 (Scrollable) > .container { position: relative; From 5ed04c3925b04d6060e18d518d773c37aba9f930 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Thu, 7 Jun 2018 21:20:09 +0300 Subject: [PATCH 35/80] Collapsable arrow class name fix --- .../vertical/collapsable/collapsable.component.scss | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/src/@fuse/components/navigation/vertical/collapsable/collapsable.component.scss b/src/@fuse/components/navigation/vertical/collapsable/collapsable.component.scss index 6fa59f1f..17eb6a38 100644 --- a/src/@fuse/components/navigation/vertical/collapsable/collapsable.component.scss +++ b/src/@fuse/components/navigation/vertical/collapsable/collapsable.component.scss @@ -20,7 +20,7 @@ .nav-link { - .collapse-arrow { + .collapsable-arrow { transition: transform .3s ease-in-out, opacity .25s ease-in-out .1s; transform: rotate(0); } @@ -34,13 +34,9 @@ > .nav-link { - .collapse-arrow { + .collapsable-arrow { transform: rotate(90deg); } } - - > .children { - } - } } From bd79830cb4fefc1e20b1a3a4e7076fe2357c5c6c Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Sat, 9 Jun 2018 14:26:00 +0300 Subject: [PATCH 36/80] Fixed: Toolbar background color issues --- .../components/search-bar/search-bar.component.html | 2 +- .../components/search-bar/search-bar.component.ts | 11 ++++------- .../components/shortcuts/shortcuts.component.html | 2 +- .../components/shortcuts/shortcuts.component.ts | 13 ------------- .../components/toolbar/toolbar.component.html | 2 +- .../components/search-bar/search-bar.component.html | 4 ++-- 6 files changed, 9 insertions(+), 25 deletions(-) diff --git a/src/@fuse/components/search-bar/search-bar.component.html b/src/@fuse/components/search-bar/search-bar.component.html index f64e9d09..a79f270f 100644 --- a/src/@fuse/components/search-bar/search-bar.component.html +++ b/src/@fuse/components/search-bar/search-bar.component.html @@ -1,6 +1,6 @@