UNPKG

ad-custom-lib

Version:

This is an UI custom library based on Adminlte library with purpose for personal use, if you need a full template of Primeng please visit https://github.com/mledour/angular-admin-lte

257 lines 22.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, ViewChild } from '@angular/core'; import { Title } from '@angular/platform-browser'; import { NavigationEnd, NavigationStart, Router } from '@angular/router'; import { removeSubscriptions } from '../../helpers'; import { RoutingService } from '../../services/routing.service'; import { FooterService } from '../footer/footer.service'; import { HeaderService } from '../header/header.service'; import { LayoutStore } from '../layout.store'; import { SidebarRightService } from '../sidebar-right/sidebar-right.service'; export class ContentComponent { /** * \@method constructor * @param {?} layoutStore * @param {?} routingService * @param {?} titleService * @param {?} elementRef * @param {?} changeDetectorRef * @param {?} sidebarRightService * @param {?} headerService * @param {?} footerService * @param {?} router */ constructor(layoutStore, routingService, titleService, elementRef, changeDetectorRef, sidebarRightService, headerService, footerService, router) { this.layoutStore = layoutStore; this.routingService = routingService; this.titleService = titleService; this.elementRef = elementRef; this.changeDetectorRef = changeDetectorRef; this.sidebarRightService = sidebarRightService; this.headerService = headerService; this.footerService = footerService; this.router = router; this.subscriptions = []; } /** * \@method ngOnInit * @return {?} */ ngOnInit() { this.titleTag = this.titleService.getTitle(); this.subscriptions.push(this.routingService.onChange.subscribe((/** * @param {?} value * @return {?} */ (value) => { if (value && value[value.length - 1]) { this.titleService.setTitle(this.getTitle(value[value.length - 1].data['title'])); this.header = value[value.length - 1].data['title']; this.description = value[value.length - 1].data['description']; } this.changeDetectorRef.markForCheck(); }))); this.subscriptions.push(this.router.events.subscribe((/** * @param {?} routeEvent * @return {?} */ (routeEvent) => { if (routeEvent instanceof NavigationStart) { this.navigationEnd = false; } if (routeEvent instanceof NavigationEnd) { this.navigationEnd = true; this.setContentMinHeight(); } }))); this.subscriptions.push(this.layoutStore.sidebarLeftElementHeight.subscribe((/** * @param {?} value * @return {?} */ (value) => { this.sidebarLeftHeight = value; this.setContentMinHeight(); }))); this.subscriptions.push(this.layoutStore.layout.subscribe((/** * @param {?} value * @return {?} */ (value) => { this.layout = value; this.setContentMinHeight(); }))); this.subscriptions.push(this.layoutStore.windowInnerHeight.subscribe((/** * @param {?} value * @return {?} */ (value) => { this.windowInnerHeight = value; this.setContentMinHeight(); }))); this.heightStyle = this.windowInnerHeight; } /** * \@method ngOnDestroy * @return {?} */ ngOnDestroy() { this.subscriptions = removeSubscriptions(this.subscriptions); } /** * [scrollHeight description] * \@method scrollHeight * @return {?} [description] */ get scrollHeight() { return this.contentInnerElement.nativeElement.scrollHeight; } /** * [getTitle description] * \@method getTitle * @private * @param {?} title [description] * @return {?} [description] */ getTitle(title) { return title ? `${title} - ${this.titleTag}` : this.titleTag; } /** * [setMinHeight description] * \@method setMinHeight * @private * @return {?} */ setContentMinHeight() { if (this.navigationEnd) { /** @type {?} */ let heightStyle; /** @type {?} */ const headerFooterOffsetHeight = this.headerService.offsetHeight + this.footerService.offsetHeight; if (this.layout === 'fixed') { heightStyle = this.windowInnerHeight - this.footerService.offsetHeight; } else { /** @type {?} */ const sidebarRight = this.sidebarRightService.scrollHeight ? this.sidebarRightService.scrollHeight - this.headerService.offsetHeight : 0; heightStyle = Math.max(this.windowInnerHeight - headerFooterOffsetHeight, this.sidebarLeftHeight - this.headerService.offsetHeight, sidebarRight); } if (heightStyle && heightStyle !== this.heightStyle) { if (this.scrollHeight > heightStyle) { heightStyle = null; } this.heightStyle = heightStyle; this.changeDetectorRef.detectChanges(); } } } } ContentComponent.decorators = [ { type: Component, args: [{ selector: 'mk-layout-content', template: "<div class=\"content-wrapper\" [style.min-height.px]=\"heightStyle\">\r\n <div #contentInnerElement class=\"content-inner\">\r\n <ng-content select=\"[mk-layout-content-before-header]\"></ng-content>\r\n <!-- <section class=\"content-header\">\r\n <h1 *ngIf=\"header || description\">\r\n {{header}}\r\n <small *ngIf=\"description\">{{description}}</small>\r\n </h1>\r\n <mk-breadcrumbs></mk-breadcrumbs>\r\n </section> -->\r\n <ng-content select=\"[mk-layout-content-after-header]\"></ng-content>\r\n <section class=\"content\">\r\n <ng-content></ng-content>\r\n </section>\r\n </div>\r\n</div>", changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block}.content-wrapper{position:relative}"] }] } ]; /** @nocollapse */ ContentComponent.ctorParameters = () => [ { type: LayoutStore }, { type: RoutingService }, { type: Title }, { type: ElementRef }, { type: ChangeDetectorRef }, { type: SidebarRightService }, { type: HeaderService }, { type: FooterService }, { type: Router } ]; ContentComponent.propDecorators = { contentInnerElement: [{ type: ViewChild, args: ['contentInnerElement', { static: true },] }] }; if (false) { /** @type {?} */ ContentComponent.prototype.description; /** @type {?} */ ContentComponent.prototype.header; /** @type {?} */ ContentComponent.prototype.heightStyle; /** @type {?} */ ContentComponent.prototype.sidebarLeftHeight; /** @type {?} */ ContentComponent.prototype.windowInnerHeight; /** * @type {?} * @private */ ContentComponent.prototype.layout; /** * @type {?} * @private */ ContentComponent.prototype.titleTag; /** * @type {?} * @private */ ContentComponent.prototype.navigationEnd; /** * @type {?} * @private */ ContentComponent.prototype.subscriptions; /** * @type {?} * @private */ ContentComponent.prototype.contentInnerElement; /** * @type {?} * @private */ ContentComponent.prototype.layoutStore; /** * @type {?} * @private */ ContentComponent.prototype.routingService; /** * @type {?} * @private */ ContentComponent.prototype.titleService; /** * @type {?} * @private */ ContentComponent.prototype.elementRef; /** * @type {?} * @private */ ContentComponent.prototype.changeDetectorRef; /** * @type {?} * @private */ ContentComponent.prototype.sidebarRightService; /** * @type {?} * @private */ ContentComponent.prototype.headerService; /** * @type {?} * @private */ ContentComponent.prototype.footerService; /** * @type {?} * @private */ ContentComponent.prototype.router; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"content.component.js","sourceRoot":"ng://ad-custom-lib/","sources":["lib/layout/content/content.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, OnDestroy, OnInit, ViewChild\r\n} from '@angular/core';\r\nimport { Title } from '@angular/platform-browser';\r\nimport { Event as RouterEvent, NavigationEnd, NavigationStart, Router } from '@angular/router';\r\n\r\nimport { removeSubscriptions } from '../../helpers';\r\nimport { RoutingService } from '../../services/routing.service';\r\nimport { FooterService } from '../footer/footer.service';\r\nimport { HeaderService } from '../header/header.service';\r\nimport { LayoutStore } from '../layout.store';\r\nimport { SidebarRightService } from '../sidebar-right/sidebar-right.service';\r\n\r\n@Component({\r\n    selector: 'mk-layout-content',\r\n    templateUrl: './content.component.html',\r\n    styleUrls: ['./content.component.css'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class ContentComponent implements OnInit, OnDestroy {\r\n    public description: string;\r\n    public header: string;\r\n    public heightStyle: number;\r\n    public sidebarLeftHeight: number;\r\n    public windowInnerHeight: number;\r\n\r\n    private layout: string;\r\n    private titleTag: string;\r\n    private navigationEnd: boolean;\r\n    private subscriptions = [];\r\n\r\n    @ViewChild('contentInnerElement', { static: true }) private contentInnerElement: ElementRef;\r\n\r\n    /**\r\n     * @method constructor\r\n     * @param layoutStore\r\n     * @param routingService\r\n     * @param titleService\r\n     * @param elementRef\r\n     * @param changeDetectorRef\r\n     * @param sidebarRightService\r\n     * @param headerService\r\n     * @param footerService\r\n     * @param router\r\n     */\r\n    constructor(\r\n        private layoutStore: LayoutStore,\r\n        private routingService: RoutingService,\r\n        private titleService: Title,\r\n        private elementRef: ElementRef,\r\n        private changeDetectorRef: ChangeDetectorRef,\r\n        private sidebarRightService: SidebarRightService,\r\n        private headerService: HeaderService,\r\n        private footerService: FooterService,\r\n        private router: Router\r\n    ) { }\r\n\r\n    /**\r\n     * @method ngOnInit\r\n     */\r\n    ngOnInit() {\r\n        this.titleTag = this.titleService.getTitle();\r\n\r\n        this.subscriptions.push(this.routingService.onChange.subscribe((value: any) => {\r\n            if (value && value[value.length - 1]) {\r\n                this.titleService.setTitle(this.getTitle(value[value.length - 1].data['title']));\r\n                this.header = value[value.length - 1].data['title'];\r\n                this.description = value[value.length - 1].data['description'];\r\n            }\r\n            this.changeDetectorRef.markForCheck();\r\n        }));\r\n\r\n        this.subscriptions.push(this.router.events.subscribe((routeEvent: RouterEvent) => {\r\n            if (routeEvent instanceof NavigationStart) {\r\n                this.navigationEnd = false;\r\n            }\r\n            if (routeEvent instanceof NavigationEnd) {\r\n                this.navigationEnd = true;\r\n                this.setContentMinHeight();\r\n            }\r\n        }));\r\n\r\n        this.subscriptions.push(this.layoutStore.sidebarLeftElementHeight.subscribe((value: number) => {\r\n            this.sidebarLeftHeight = value;\r\n            this.setContentMinHeight();\r\n        }));\r\n\r\n        this.subscriptions.push(this.layoutStore.layout.subscribe((value: string) => {\r\n            this.layout = value;\r\n            this.setContentMinHeight();\r\n        }));\r\n\r\n        this.subscriptions.push(this.layoutStore.windowInnerHeight.subscribe((value: number) => {\r\n            this.windowInnerHeight = value;\r\n            this.setContentMinHeight();\r\n        }));\r\n        this.heightStyle = this.windowInnerHeight;\r\n    }\r\n\r\n    /**\r\n     * @method ngOnDestroy\r\n     */\r\n    ngOnDestroy() {\r\n        this.subscriptions = removeSubscriptions(this.subscriptions);\r\n    }\r\n\r\n    /**\r\n     * [scrollHeight description]\r\n     * @method scrollHeight\r\n     * @return [description]\r\n     */\r\n    public get scrollHeight(): number {\r\n        return this.contentInnerElement.nativeElement.scrollHeight;\r\n    }\r\n\r\n    /**\r\n     * [getTitle description]\r\n     * @method getTitle\r\n     * @param title [description]\r\n     * @return [description]\r\n     */\r\n    private getTitle(title: string): string {\r\n        return title ? `${title} - ${this.titleTag}` : this.titleTag;\r\n    }\r\n\r\n    /**\r\n     * [setMinHeight description]\r\n     * @method setMinHeight\r\n     */\r\n    private setContentMinHeight(): void {\r\n        if (this.navigationEnd) {\r\n            let heightStyle;\r\n\r\n            const headerFooterOffsetHeight = this.headerService.offsetHeight + this.footerService.offsetHeight;\r\n\r\n            if (this.layout === 'fixed') {\r\n                heightStyle = this.windowInnerHeight - this.footerService.offsetHeight;\r\n            } else {\r\n                const sidebarRight =\r\n                    this.sidebarRightService.scrollHeight ?\r\n                        this.sidebarRightService.scrollHeight - this.headerService.offsetHeight : 0;\r\n\r\n                heightStyle = Math.max(\r\n                    this.windowInnerHeight - headerFooterOffsetHeight,\r\n                    this.sidebarLeftHeight - this.headerService.offsetHeight,\r\n                    sidebarRight\r\n                );\r\n            }\r\n\r\n            if (heightStyle && heightStyle !== this.heightStyle) {\r\n                if (this.scrollHeight > heightStyle) {\r\n                    heightStyle = null;\r\n                }\r\n                this.heightStyle = heightStyle;\r\n                this.changeDetectorRef.detectChanges();\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}