UNPKG

@soushians/layout

Version:

184 lines (183 loc) 26.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Component, ElementRef, ViewChild, Input, HostBinding } from "@angular/core"; import { Router, NavigationEnd } from "@angular/router"; import { Store } from "@ngrx/store"; import { BehaviorSubject } from "rxjs"; import { TranslateService } from '@ngx-translate/core'; import { ConfigModel } from "@soushians/config"; import { getShowMainSidenav, getMainSideNavMode, getShowSecondSidebarStatus, getSecondSidebarMode, getLayoutMode, getLayoutToolbarMode, getFullscreenMode } from "../../reducers"; import { CloseSecondSidenavAction, ChangeSecondSidenavMode, CloseSidenavAction, ChangeSideNavMode } from "../../actions"; import { LayoutConfigurationService } from "../../services/layout-configuration.service"; import { UserFacadeService } from "@soushians/user"; import { trigger, state, transition, animate, style } from "@angular/animations"; var NgsLayoutMainComponent = /** @class */ (function () { function NgsLayoutMainComponent(store, router, configService, translateService, userFacadeService) { var _this = this; this.store = store; this.router = router; this.configService = configService; this.translateService = translateService; this.userFacadeService = userFacadeService; this.showSidebarMenu = new BehaviorSubject(true); this.width = 100; this._set_i18n_resource(); this.configService.config$.subscribe(function (config) { debugger; _this.theme = config.theme; _this.theme_A = config.theme == "theme_A"; _this.theme_B = config.theme == "theme_B"; }); this.store.dispatch(new ChangeSideNavMode("push")); this.user$ = this.store.select(function (s) { return (/** @type {?} */ (s)).user.user.data; }); this.displayName$ = this.userFacadeService.getDisplayName(); this.showMainSidenav = this.store.select(getShowMainSidenav); this.mainSidenavMode = this.store.select(getMainSideNavMode); this.toolbarAnimationState = this.store.select(getLayoutToolbarMode); this.isFullscreen$ = this.store.select(getFullscreenMode); this.mode$ = this.isFullscreen$.map(function (mode) { return (mode ? "invisible" : "visible"); }); //#region manage second sidebar this.store.dispatch(new ChangeSecondSidenavMode("push")); this.showSecondSidenav = this.store.select(getShowSecondSidebarStatus); this.secondSidenavMode = this.store.select(getSecondSidebarMode); //#endregion manage second sidebar this.layoutMode = this.store.select(getLayoutMode); this.router.events.filter(function (data) { return data instanceof NavigationEnd; }).subscribe(function (event) { /** @type {?} */ var hideSituations = [ (/** @type {?} */ (event)).urlAfterRedirects == "/auth/signin", (/** @type {?} */ (event)).urlAfterRedirects == "/auth/signup/register", (/** @type {?} */ (event)).urlAfterRedirects == "/auth/signup/verification", (/** @type {?} */ (event)).urlAfterRedirects == "/user/password/reset" ]; if (hideSituations.some(function (i) { return i; })) _this.showSidebarMenu.next(false); else _this.showSidebarMenu.next(true); }); } // ngAfterViewInit() { // this.store.dispatch(new ChangeLayout("with-margin")); // } /** * @return {?} */ NgsLayoutMainComponent.prototype.onSecondSidebarClosedStart = /** * @return {?} */ function () { this.store.dispatch(new CloseSecondSidenavAction()); }; /** * @return {?} */ NgsLayoutMainComponent.prototype.onSidebarClosedStart = /** * @return {?} */ function () { this.store.dispatch(new CloseSidenavAction()); }; /** * private methods */ /** * private methods * @return {?} */ NgsLayoutMainComponent.prototype._set_i18n_resource = /** * private methods * @return {?} */ function () { this.translateService.setTranslation('en', { __Signin: 'Signin', __Signup: 'Signup' }); this.translateService.setTranslation('fa', { Signin: 'ورود', Signup: 'ثبت نام' }); }; NgsLayoutMainComponent.decorators = [ { type: Component, args: [{ selector: "layout-main", template: "<div #mainSideNav [ngClass]=\"toolbarAnimationState | async\" [class.fullscreen]=\"isFullscreen$ | async\">\n <!-- <mat-progress-bar *ngIf='progressStatus$ | async' color=\"primary\" mode=\"query\"></mat-progress-bar> -->\n <layout-toolbar *ngIf=\"theme == 'theme_A'\" [user]=\"user$ | async\" [displayName]=\"displayName$ | async\" [showSidebarMenu]='showSidebarMenu | async' [app-config]=\"app_config\"></layout-toolbar>\n <layout-toolbar-b *ngIf=\"theme == 'theme_B'\" [user]=\"user$ | async\" [displayName]=\"displayName$ | async\" [showSidebarMenu]='showSidebarMenu | async' [app-config]=\"app_config\"></layout-toolbar-b>\n \n <mat-sidenav-container id=\"layout-sidnav\" [className]=\"layoutMode | async\">\n <mat-sidenav [mode]=\"mainSidenavMode | async\" [opened]='showMainSidenav | async' #sidebar (closedStart)=\"onSidebarClosedStart()\">\n <mat-nav-list>\n <ngs-layout-main-menu [authenticated]='showSidebarMenu' (closeSidebar)=\"sidebar.close()\" (click)=\"onSecondSidebarClosedStart()\"></ngs-layout-main-menu>\n </mat-nav-list>\n </mat-sidenav>\n <!-- <mat-sidenav [mode]=\"secondSidenavMode | async\" [opened]='showSecondSidenav | async' (closedStart)=\"onSecondSidebarClosedStart()\"\n position=\"end\" #second_sidebar class=\"second_sidebar\">\n <mat-nav-list fxLayout='column'>\n </mat-nav-list>\n </mat-sidenav> -->\n <div fxFlexLayout='column' id=\"app-main-container\" fxLayoutAlign='center center'>\n <div fxFlex='0 0 100'>\n <router-outlet></router-outlet>\n <footer [@mode]=\"mode$ | async\" ruleAnchor=\"layout_footer\">\n <router-outlet name=\"footer_A\"></router-outlet>\n <router-outlet name=\"footer_B\"></router-outlet>\n <app-footer [app-config]=\"app_config\"></app-footer>\n </footer>\n </div>\n </div>\n </mat-sidenav-container>\n</div>", styles: ["#purchase-fab-button{position:fixed;bottom:23px;left:31px}md-progress-bar{position:absolute!important}.with-margin #app-main-container{margin-top:25px;padding-right:25px;padding-left:25px}.second_sidebar{width:380px}.more-detail{margin:8px;box-sizing:border-box;padding:10px;text-align:center;width:96%;border:1px solid #dedede;outline:0;cursor:pointer;transition:.3s}.more-detail:hover{background:#eee}footer{border-top:1px solid #e5e5e5;margin-top:25px;background-color:#f1f1f1}"], animations: [ trigger("mode", [ state("visible", style({ transform: "scaleY(1) translateY(0)" })), state("invisible", style({ height: "0", transform: "scaleY(0) translateY(100%)" })), transition("visible => invisible", [animate("1000ms")]), transition("invisible => visible", [animate("1000ms")]) ]) ] },] }, ]; /** @nocollapse */ NgsLayoutMainComponent.ctorParameters = function () { return [ { type: Store }, { type: Router }, { type: LayoutConfigurationService }, { type: TranslateService }, { type: UserFacadeService } ]; }; NgsLayoutMainComponent.propDecorators = { app_config: [{ type: Input, args: ["app-config",] }], mainSideNav: [{ type: ViewChild, args: ["mainSideNav",] }], theme_A: [{ type: HostBinding, args: ["class.theme_A",] }], theme_B: [{ type: HostBinding, args: ["class.theme_B",] }] }; return NgsLayoutMainComponent; }()); export { NgsLayoutMainComponent }; if (false) { /** @type {?} */ NgsLayoutMainComponent.prototype.app_config; /** @type {?} */ NgsLayoutMainComponent.prototype.mode$; /** @type {?} */ NgsLayoutMainComponent.prototype.theme; /** @type {?} */ NgsLayoutMainComponent.prototype.user$; /** @type {?} */ NgsLayoutMainComponent.prototype.displayName$; /** @type {?} */ NgsLayoutMainComponent.prototype.isFullscreen$; /** @type {?} */ NgsLayoutMainComponent.prototype.progressStatus$; /** @type {?} */ NgsLayoutMainComponent.prototype.showSidebarMenu; /** @type {?} */ NgsLayoutMainComponent.prototype.showMainSidenav; /** @type {?} */ NgsLayoutMainComponent.prototype.mainSidenavMode; /** @type {?} */ NgsLayoutMainComponent.prototype.layoutMode; /** @type {?} */ NgsLayoutMainComponent.prototype.width; /** @type {?} */ NgsLayoutMainComponent.prototype.showSecondSidenav; /** @type {?} */ NgsLayoutMainComponent.prototype.secondSidenavMode; /** @type {?} */ NgsLayoutMainComponent.prototype.toolbarAnimationState; /** @type {?} */ NgsLayoutMainComponent.prototype.mainSideNav; /** @type {?} */ NgsLayoutMainComponent.prototype.theme_A; /** @type {?} */ NgsLayoutMainComponent.prototype.theme_B; /** @type {?} */ NgsLayoutMainComponent.prototype.store; /** @type {?} */ NgsLayoutMainComponent.prototype.router; /** @type {?} */ NgsLayoutMainComponent.prototype.configService; /** @type {?} */ NgsLayoutMainComponent.prototype.translateService; /** @type {?} */ NgsLayoutMainComponent.prototype.userFacadeService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.component.js","sourceRoot":"ng://@soushians/layout/","sources":["lib/dumb-components/main/main.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild, AfterViewInit, OnDestroy, Input, HostBinding } from \"@angular/core\";\r\nimport { Router, NavigationEnd } from \"@angular/router\";\r\nimport { Observable } from \"rxjs/Observable\";\r\n// import { BehaviorSubject } from \"rxjs/BehaviorSubject\";\r\nimport { Store } from \"@ngrx/store\";\r\nimport { SwPush } from \"@angular/service-worker\";\r\nimport { BehaviorSubject } from \"rxjs\";\r\nimport { MatSidenav, MatSidenavContainer } from \"@angular/material\";\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\nimport { ConfigModel, getAppConfig } from \"@soushians/config\";\r\nimport { UserModel } from \"@soushians/user\";\r\n\r\nimport {\r\n\tFeatureState,\r\n\tgetShowMainSidenav,\r\n\tgetMainSideNavMode,\r\n\tgetShowSecondSidebarStatus,\r\n\tgetSecondSidebarMode,\r\n\tgetLayoutMode,\r\n\tgetLayoutToolbarMode,\r\n\tgetFullscreenMode\r\n} from \"../../reducers\";\r\n\r\nimport {\r\n\tChangeToolbatToComfortableModeAction,\r\n\tCloseSecondSidenavAction,\r\n\tChangeSecondSidenavMode,\r\n\tOpenSecondSidenavAction,\r\n\tCloseSidenavAction,\r\n\tChangeSideNavMode,\r\n\tOpenSidenavAction,\r\n\tChangeLayout\r\n} from \"../../actions\";\r\nimport { LayoutConfigurationService } from \"../../services/layout-configuration.service\";\r\nimport { UserFacadeService } from \"@soushians/user\";\r\nimport { trigger, state, transition, animate, style } from \"@angular/animations\";\r\n\r\n@Component({\r\n\tselector: \"layout-main\",\r\n\ttemplate: `<div #mainSideNav [ngClass]=\"toolbarAnimationState | async\" [class.fullscreen]=\"isFullscreen$ | async\">\r\n  <!-- <mat-progress-bar *ngIf='progressStatus$ | async' color=\"primary\" mode=\"query\"></mat-progress-bar> -->\r\n  <layout-toolbar  *ngIf=\"theme == 'theme_A'\" [user]=\"user$ | async\" [displayName]=\"displayName$ | async\" [showSidebarMenu]='showSidebarMenu | async' [app-config]=\"app_config\"></layout-toolbar>\r\n  <layout-toolbar-b *ngIf=\"theme == 'theme_B'\" [user]=\"user$ | async\" [displayName]=\"displayName$ | async\" [showSidebarMenu]='showSidebarMenu | async' [app-config]=\"app_config\"></layout-toolbar-b>\r\n  \r\n  <mat-sidenav-container id=\"layout-sidnav\" [className]=\"layoutMode | async\">\r\n    <mat-sidenav [mode]=\"mainSidenavMode | async\" [opened]='showMainSidenav | async' #sidebar (closedStart)=\"onSidebarClosedStart()\">\r\n      <mat-nav-list>\r\n        <ngs-layout-main-menu [authenticated]='showSidebarMenu' (closeSidebar)=\"sidebar.close()\" (click)=\"onSecondSidebarClosedStart()\"></ngs-layout-main-menu>\r\n      </mat-nav-list>\r\n    </mat-sidenav>\r\n    <!-- <mat-sidenav [mode]=\"secondSidenavMode | async\" [opened]='showSecondSidenav | async' (closedStart)=\"onSecondSidebarClosedStart()\"\r\n      position=\"end\" #second_sidebar class=\"second_sidebar\">\r\n      <mat-nav-list fxLayout='column'>\r\n      </mat-nav-list>\r\n    </mat-sidenav> -->\r\n    <div fxFlexLayout='column' id=\"app-main-container\" fxLayoutAlign='center center'>\r\n      <div fxFlex='0 0 100'>\r\n        <router-outlet></router-outlet>\r\n        <footer [@mode]=\"mode$ | async\" ruleAnchor=\"layout_footer\">\r\n          <router-outlet name=\"footer_A\"></router-outlet>\r\n          <router-outlet name=\"footer_B\"></router-outlet>\r\n          <app-footer [app-config]=\"app_config\"></app-footer>\r\n        </footer>\r\n      </div>\r\n    </div>\r\n  </mat-sidenav-container>\r\n</div>`,\r\n\tstyles: [`#purchase-fab-button{position:fixed;bottom:23px;left:31px}md-progress-bar{position:absolute!important}.with-margin #app-main-container{margin-top:25px;padding-right:25px;padding-left:25px}.second_sidebar{width:380px}.more-detail{margin:8px;box-sizing:border-box;padding:10px;text-align:center;width:96%;border:1px solid #dedede;outline:0;cursor:pointer;transition:.3s}.more-detail:hover{background:#eee}footer{border-top:1px solid #e5e5e5;margin-top:25px;background-color:#f1f1f1}`],\r\n\tanimations: [\r\n\t\ttrigger(\"mode\", [\r\n\t\t\tstate(\"visible\", style({ transform: \"scaleY(1) translateY(0)\" })),\r\n\t\t\tstate(\"invisible\", style({ height: \"0\", transform: \"scaleY(0) translateY(100%)\" })),\r\n\t\t\ttransition(\"visible => invisible\", [animate(\"1000ms\")]),\r\n\t\t\ttransition(\"invisible => visible\", [animate(\"1000ms\")])\r\n\t\t])\r\n\t]\r\n})\r\nexport class NgsLayoutMainComponent {\r\n\t@Input(\"app-config\") app_config: ConfigModel<any>;\r\n\tmode$: Observable<\"visible\" | \"invisible\">;\r\n\ttheme: string;\r\n\tuser$: Observable<UserModel>;\r\n\tdisplayName$: Observable<string>;\r\n\tisFullscreen$: Observable<boolean>;\r\n\tprogressStatus$: Observable<boolean>;\r\n\tshowSidebarMenu = new BehaviorSubject(true);\r\n\t// user$: Observable<UserModel>;\r\n\tshowMainSidenav: Observable<boolean>;\r\n\tmainSidenavMode: Observable<\"side\" | \"over\" | \"push\">;\r\n\tlayoutMode: Observable<\"with-margin\" | \"without-margin\" | \"default\">;\r\n\twidth = 100;\r\n\tshowSecondSidenav: Observable<boolean>;\r\n\tsecondSidenavMode: Observable<\"side\" | \"over\" | \"push\">;\r\n\ttoolbarAnimationState: Observable<string>;\r\n\t@ViewChild(\"mainSideNav\") mainSideNav: ElementRef;\r\n\t@HostBinding(\"class.theme_A\") theme_A: boolean;\r\n\t@HostBinding(\"class.theme_B\") theme_B: boolean;\r\n\tconstructor(\r\n\t\tprivate store: Store<FeatureState>,\r\n\t\tprivate router: Router,\r\n\t\tprivate configService: LayoutConfigurationService,\r\n\t\tprivate translateService: TranslateService,\r\n\t\tprivate userFacadeService: UserFacadeService\r\n\t) {\r\n\t\tthis._set_i18n_resource();\r\n\t\tthis.configService.config$.subscribe((config) => {\r\n\t\t\tdebugger;\r\n\t\t\tthis.theme = config.theme;\r\n\t\t\tthis.theme_A = config.theme == \"theme_A\";\r\n\t\t\tthis.theme_B = config.theme == \"theme_B\";\r\n\t\t});\r\n\t\tthis.store.dispatch(new ChangeSideNavMode(\"push\"));\r\n\t\tthis.user$ = this.store.select((s) => (s as any).user.user.data);\r\n\t\tthis.displayName$ = this.userFacadeService.getDisplayName();\r\n\t\tthis.showMainSidenav = this.store.select(getShowMainSidenav);\r\n\t\tthis.mainSidenavMode = this.store.select(getMainSideNavMode);\r\n\t\tthis.toolbarAnimationState = this.store.select(getLayoutToolbarMode);\r\n\r\n\t\tthis.isFullscreen$ = this.store.select(getFullscreenMode);\r\n\t\tthis.mode$ = this.isFullscreen$.map((mode) => (mode ? \"invisible\" : \"visible\"));\r\n\r\n\t\t//#region manage second sidebar\r\n\t\tthis.store.dispatch(new ChangeSecondSidenavMode(\"push\"));\r\n\t\tthis.showSecondSidenav = this.store.select(getShowSecondSidebarStatus);\r\n\t\tthis.secondSidenavMode = this.store.select(getSecondSidebarMode);\r\n\t\t//#endregion manage second sidebar\r\n\r\n\t\tthis.layoutMode = this.store.select(getLayoutMode);\r\n\r\n\t\tthis.router.events.filter((data) => data instanceof NavigationEnd).subscribe((event) => {\r\n\t\t\tconst hideSituations = [\r\n\t\t\t\t(event as NavigationEnd).urlAfterRedirects == \"/auth/signin\",\r\n\t\t\t\t(event as NavigationEnd).urlAfterRedirects == \"/auth/signup/register\",\r\n\t\t\t\t(event as NavigationEnd).urlAfterRedirects == \"/auth/signup/verification\",\r\n\t\t\t\t(event as NavigationEnd).urlAfterRedirects == \"/user/password/reset\"\r\n\t\t\t];\r\n\t\t\tif (hideSituations.some((i) => i)) this.showSidebarMenu.next(false);\r\n\t\t\telse this.showSidebarMenu.next(true);\r\n\t\t});\r\n\t}\r\n\r\n\t// ngAfterViewInit() {\r\n\t// \tthis.store.dispatch(new ChangeLayout(\"with-margin\"));\r\n\t// }\r\n\r\n\tonSecondSidebarClosedStart() {\r\n\t\tthis.store.dispatch(new CloseSecondSidenavAction());\r\n\t}\r\n\r\n\tonSidebarClosedStart() {\r\n\t\tthis.store.dispatch(new CloseSidenavAction());\r\n\t}\r\n\r\n\t/**\r\n\t * private methods\r\n\t */\r\n\t_set_i18n_resource() {\r\n\t\tthis.translateService.setTranslation('en', {\r\n\t\t\t__Signin: 'Signin',\r\n\t\t\t__Signup: 'Signup'\r\n\t\t});\r\n\t\tthis.translateService.setTranslation('fa', {\r\n\t\t\tSignin: 'ورود',\r\n\t\t\tSignup: 'ثبت نام'\r\n\t\t});\r\n\t}\r\n}\r\n"]}