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
JavaScript
/**
* @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"]}