UNPKG

@uex/web-extensions

Version:

Uex extensions for Angular 6+ web projects

535 lines 45.3 kB
/** * @fileoverview added by tsickle * Generated from: lib/modules/template/template.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, HostListener, ContentChildren, ContentChild, QueryList, ViewChild, EventEmitter, Input } from "@angular/core"; import { ActivatedRoute, PRIMARY_OUTLET } from "@angular/router"; import * as _ from "lodash"; import { DeviceDetectorService } from "ngx-device-detector"; import { ConfigService } from "../../config.service"; import { ActionBarComponent } from "./components/action-bar.component"; import { FormBarComponent } from "./components/form-bar.component"; import { TemplateSize, TemplateTheme } from "./template.enum"; import { LayoutRouterService } from "../layout/services/router.service"; /** @type {?} */ const ROUTE_DATA_BREADCRUMB = "$title"; export class TemplateComponent { /** * @param {?} _route * @param {?} _deviceService * @param {?} _config * @param {?} _layoutRouterService * @param {?} elementRef */ constructor(_route, _deviceService, _config, _layoutRouterService, elementRef) { this._route = _route; this._deviceService = _deviceService; this._config = _config; this._layoutRouterService = _layoutRouterService; this.elementRef = elementRef; this.type = "default"; this.size = TemplateSize.RESPONSIVE; this.onSizeChange = new EventEmitter(); this.onScroll = new EventEmitter(); this.breakPoints = [ "xs", "sm", "md", "lg", "xl" ]; this.sizes = { width: 0, height: 0, header_height: 0, offset_height: 0 }; this.scrollRef = { top: 0, left: 0 }; this.relative = false; this._device_info = this._deviceService.getDeviceInfo(); } /** * @private * @param {?} action_bars * @return {?} */ set _actionBars(action_bars) { setTimeout((/** * @return {?} */ () => (this.actionBars = action_bars.toArray())), 0); } /** * @private * @param {?} form_bar * @return {?} */ set _formBar(form_bar) { setTimeout((/** * @return {?} */ () => (this.formBar = form_bar)), 0); } /** * @return {?} */ _onResize() { this.resize(); } /** * @return {?} */ _onScroll() { this.scrollRef = { top: this._getScrollElement().scrollTop, left: this._getScrollElement().scrollLeft }; this.onScroll.emit(this.scrollRef); } /** * @return {?} */ ngOnInit() { this._layoutRouterService.registerTemplate(this); } /** * @return {?} */ ngOnDestroy() { this._layoutRouterService.unregisterTemplate(); } /** * @return {?} */ ngAfterViewInit() { setTimeout((/** * @return {?} */ () => { if (!this.title) { /** @type {?} */ const root = this._route.root; this.title = this._getActiveRoute(root).snapshot.data[ROUTE_DATA_BREADCRUMB]; } this.resize(); this._updateData(); }), 0); } /** * @return {?} */ ngOnChanges() { this._updateData(); } /** * @param {?} offset * @param {?=} smooth * @return {?} */ scrollTo(offset, smooth = false) { if (this.hasScroll()) { this._getScrollElement().scroll({ top: offset, behavior: smooth ? "smooth" : "auto" }); } } /** * @param {?} anchor * @param {?=} smooth * @return {?} */ scrollToAnchor(anchor, smooth = false) { if (this.hasScroll()) { if (anchor.indexOf("#") !== 0) { anchor = `#${anchor}`; } /** @type {?} */ const el = this.elementRef.nativeElement.querySelector(anchor); if (!el) { return; } this.scrollTo(((/** @type {?} */ (el))).offsetTop, smooth); } } /** * @param {?=} smooth * @return {?} */ scrollToTop(smooth = false) { if (this.hasScroll()) { this._getScrollElement().scroll({ top: 0, behavior: smooth ? "smooth" : "auto" }); } } /** * @param {?=} smooth * @return {?} */ scrollToBottom(smooth = false) { if (this.hasScroll()) { this._getScrollElement().scroll({ top: this._getScrollElement().scrollHeight, behavior: smooth ? "smooth" : "auto" }); } } /** * @return {?} */ resize() { this._setBreakPoint(); this._setSizes(); } /** * @param {?} size * @return {?} */ isBreakPoint(size) { return this.breakPoint == size; } /** * @param {?} size * @return {?} */ isBreakPointMin(size) { return (this.breakPoints.indexOf(size) <= this.breakPoints.indexOf(this.breakPoint)); } /** * @param {?} size * @return {?} */ isBreakPointMax(size) { return (this.breakPoints.indexOf(size) >= this.breakPoints.indexOf(this.breakPoint)); } /** * @param {?} path * @return {?} */ getConfig(path) { if (!this.type) { this.type = "default"; } if (this._config) { /** @type {?} */ const template_type = this._config.template[this.type] || this._config.template["1"] || this._config.template.default; if (!template_type) return null; switch (path) { case "background.color": return template_type.background.color; case "background.image": return template_type.background.image ? `url("${template_type.background.image}")` : null; default: return _.get(template_type, path); } } else { return null; } } /** * @param {?} theme_type * @return {?} */ isTheme(theme_type) { return this.getConfig("theme") == TemplateTheme[theme_type]; } /** * @return {?} */ hasFormBar() { // return this.has_form_bar; return this.formBar && this.formBar.content ? true : false; } /** * @return {?} */ hasActionBar() { return this.actionBars && this.actionBars.length > 0; } /** * @return {?} */ hasScroll() { if (this._wrapper) { /** @type {?} */ const el = this._getScrollElement(true); // const wrapper = this._wrapper.nativeElement.childNodes[0]; /** @type {?} */ const wrapper = this._wrapper.nativeElement; return wrapper.offsetHeight > el.offsetHeight; } return false; } /** * @private * @param {?=} use_body * @return {?} */ _getScrollElement(use_body = false) { /** @type {?} */ const is_safari = this._device_info.browser == "safari"; return this._config.layout.relative ? use_body || is_safari ? document.body : document.documentElement : this.elementRef.nativeElement; } /** * @private * @return {?} */ _setBreakPoint() { /** @type {?} */ const width = document.body.clientWidth; switch (true) { case width < 576: this.breakPoint = "xs"; break; case width >= 576 && width < 768: this.breakPoint = "sm"; break; case width >= 768 && width < 992: this.breakPoint = "md"; break; case width >= 992 && width < 1200: this.breakPoint = "lg"; break; case width > 1200: this.breakPoint = "xl"; break; } } /** * @private * @return {?} */ _setSizes() { setTimeout((/** * @return {?} */ () => { this.sizes.width = this._getScrollElement().clientWidth; this.sizes.height = this._getScrollElement().offsetHeight; this.sizes.header_height = this._header ? this._header.nativeElement.offsetHeight : 0; /** @type {?} */ let content_padding = 0; if (this._content) { /** @type {?} */ const content_styles = window.getComputedStyle(this._content.nativeElement); /** @type {?} */ const content_padding_top = parseFloat(content_styles.getPropertyValue("padding-top")); /** @type {?} */ const content_padding_bottom = parseFloat(content_styles.getPropertyValue("padding-bottom")); content_padding = content_padding_top + content_padding_bottom; } /** @type {?} */ const offset = this.sizes.height - this.sizes.header_height; this.sizes.offset_height = offset - content_padding; this.onSizeChange.emit(this.sizes); }), 100); } /** * @private * @return {?} */ _updateData() { if (_.isUndefined(this.show_header)) { /** @type {?} */ const show_header = this.getConfig("header"); this.show_header = _.isBoolean(show_header) ? show_header : true; } if (_.isUndefined(this.show_layout_header)) { /** @type {?} */ const show_layout_header = this.getConfig("layout.header"); this.show_layout_header = _.isBoolean(show_layout_header) ? show_layout_header : true; } if (_.isUndefined(this.show_layout_sidebar)) { /** @type {?} */ const show_layout_sidebar = this.getConfig("layout.sidebar"); this.show_layout_sidebar = _.isBoolean(show_layout_sidebar) ? show_layout_sidebar : true; } this._layoutRouterService.updateTemplate(); } /** * @private * @param {?} route * @return {?} */ _getActiveRoute(route) { // Fet the child routes /** @type {?} */ const children = route.children; /** @type {?} */ let current; // Return if there are no more children if (children.length === 0) { return route; } // Iterate over each children for (const child of children) { // Verify primary route if (child.outlet !== PRIMARY_OUTLET) { continue; } // Recursive current = this._getActiveRoute(child); } return current; } } TemplateComponent.decorators = [ { type: Component, args: [{ selector: "uex-template", template: "<div class=\"uex-template-bg\" [style.background-color]=\"getConfig('background.color')\" [style.background-image]=\"getConfig('background.image')\" *ngIf=\"!show_header\"></div>\r\n\r\n<div #wrapper class=\"uex-template-wrapper\">\r\n <div #header class=\"uex-template-header\" *ngIf=\"show_header\"\r\n\r\n [class.uex-template-header-theme-default]=\"isTheme('DEFAULT')\"\r\n [class.uex-template-header-theme-dark]=\"isTheme('DARK')\"\r\n [class.uex-template-header-theme-light]=\"isTheme('LIGHT')\"\r\n [class.uex-template-header-theme-blue]=\"isTheme('BLUE')\"\r\n\r\n [class.uex-template-header-with-form-bar]=\"hasFormBar()\"\r\n [class.uex-template-header-with-breadcrumbs]=\"breadcrumb?.visible\"\r\n\r\n [style.background-color]=\"getConfig('background.color')\"\r\n [style.background-image]=\"getConfig('background.image')\">\r\n <div class=\"row m-0\" [hidden]=\"!breadcrumb?.visible\">\r\n <div class=\"uex-template-breadcrumb col-12\">\r\n <uex-breadcrumb #breadcrumb></uex-breadcrumb>\r\n </div>\r\n </div>\r\n\r\n <div class=\"row m-0\">\r\n <div class=\"uex-template-header-side col-12\" [class.col-sm-6]=\"hasActionBar()\" *ngIf=\"title || hasActionBar()\">\r\n <div class=\"uex-template-title\" [title]=\"title ? title : ''\" *ngIf=\"title\">\r\n <h1>{{title}}</h1>\r\n </div>\r\n\r\n <div class=\"uex-template-subtitle\" [title]=\"subtitle ? subtitle : ''\" *ngIf=\"subtitle\">\r\n <h2>{{subtitle}}</h2>\r\n </div>\r\n </div>\r\n\r\n <div class=\"uex-template-header-side col-12 col-sm-6\" *ngIf=\"hasActionBar()\">\r\n <div class=\"uex-template-action-bar align-items-end text-right col-12\" [class.align-self-start]=\"actionBar.is_top\" [class.align-self-end]=\"actionBar.is_bottom\" [ngClass]=\"actionBar.cssClass\" *ngFor=\"let actionBar of actionBars\">\r\n <ng-template [uex-portal]=\"actionBar.content\"></ng-template>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"row m-0\">\r\n <div class=\"uex-template-header-bottom col-12 p-0\" *ngIf=\"hasFormBar()\" [hidden]=\"formBar?.hidden\">\r\n <div class=\"uex-template-form-bar\">\r\n <ng-template [uex-portal]=\"formBar?.content\"></ng-template>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div #content class=\"uex-template-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n</div>\r\n", host: { class: "uex-template", "[attr.title]": "null", "[attr.subtitle]": "null" } }] } ]; /** @nocollapse */ TemplateComponent.ctorParameters = () => [ { type: ActivatedRoute }, { type: DeviceDetectorService }, { type: ConfigService }, { type: LayoutRouterService }, { type: ElementRef } ]; TemplateComponent.propDecorators = { _actionBars: [{ type: ContentChildren, args: [ActionBarComponent, { descendants: true },] }], _formBar: [{ type: ContentChild, args: [FormBarComponent, { static: false },] }], _wrapper: [{ type: ViewChild, args: ["wrapper", { static: true },] }], _header: [{ type: ViewChild, args: ["header", { static: false },] }], _content: [{ type: ViewChild, args: ["content", { static: true },] }], title: [{ type: Input, args: ["title",] }], subtitle: [{ type: Input, args: ["subtitle",] }], type: [{ type: Input, args: ["type",] }], show_header: [{ type: Input, args: ["show-header",] }], show_layout_header: [{ type: Input, args: ["show-layout-header",] }], show_layout_sidebar: [{ type: Input, args: ["show-layout-sidebar",] }], size: [{ type: Input, args: ["size",] }], _onResize: [{ type: HostListener, args: ["window:resize",] }], _onScroll: [{ type: HostListener, args: ["scroll",] }] }; if (false) { /** * @type {?} * @private */ TemplateComponent.prototype._wrapper; /** * @type {?} * @private */ TemplateComponent.prototype._header; /** * @type {?} * @private */ TemplateComponent.prototype._content; /** @type {?} */ TemplateComponent.prototype.title; /** @type {?} */ TemplateComponent.prototype.subtitle; /** @type {?} */ TemplateComponent.prototype.type; /** @type {?} */ TemplateComponent.prototype.show_header; /** @type {?} */ TemplateComponent.prototype.show_layout_header; /** @type {?} */ TemplateComponent.prototype.show_layout_sidebar; /** @type {?} */ TemplateComponent.prototype.size; /** @type {?} */ TemplateComponent.prototype.formBar; /** @type {?} */ TemplateComponent.prototype.actionBars; /** @type {?} */ TemplateComponent.prototype.onSizeChange; /** @type {?} */ TemplateComponent.prototype.onScroll; /** @type {?} */ TemplateComponent.prototype.breakPoint; /** @type {?} */ TemplateComponent.prototype.breakPoints; /** @type {?} */ TemplateComponent.prototype.sizes; /** @type {?} */ TemplateComponent.prototype.scrollRef; /** @type {?} */ TemplateComponent.prototype.relative; /** * @type {?} * @private */ TemplateComponent.prototype._device_info; /** * @type {?} * @private */ TemplateComponent.prototype._route; /** * @type {?} * @private */ TemplateComponent.prototype._deviceService; /** * @type {?} * @private */ TemplateComponent.prototype._config; /** * @type {?} * @private */ TemplateComponent.prototype._layoutRouterService; /** @type {?} */ TemplateComponent.prototype.elementRef; } /** * @record */ export function TemplateScrollRef() { } if (false) { /** @type {?} */ TemplateScrollRef.prototype.top; /** @type {?} */ TemplateScrollRef.prototype.left; } /** * @record */ export function TemplateSizes() { } if (false) { /** @type {?} */ TemplateSizes.prototype.width; /** @type {?} */ TemplateSizes.prototype.height; /** @type {?} */ TemplateSizes.prototype.header_height; /** @type {?} */ TemplateSizes.prototype.offset_height; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template.component.js","sourceRoot":"ng://@uex/web-extensions/","sources":["lib/modules/template/template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  ContentChildren,\r\n  ContentChild,\r\n  QueryList,\r\n  ViewChild,\r\n  EventEmitter,\r\n  Input,\r\n  AfterViewInit\r\n} from \"@angular/core\";\r\nimport { ActivatedRoute, PRIMARY_OUTLET } from \"@angular/router\";\r\n\r\nimport * as _ from \"lodash\";\r\nimport { DeviceDetectorService, DeviceInfo } from \"ngx-device-detector\";\r\n\r\nimport { ConfigService } from \"../../config.service\";\r\n\r\nimport { ActionBarComponent } from \"./components/action-bar.component\";\r\nimport { FormBarComponent } from \"./components/form-bar.component\";\r\n\r\nimport { TemplateSize, TemplateTheme } from \"./template.enum\";\r\nimport { LayoutRouterService } from \"../layout/services/router.service\";\r\n\r\nconst ROUTE_DATA_BREADCRUMB = \"$title\";\r\n\r\n@Component({\r\n  selector: \"uex-template\",\r\n  templateUrl: \"./template.component.html\",\r\n  host: {\r\n    class: \"uex-template\",\r\n    \"[attr.title]\": \"null\",\r\n    \"[attr.subtitle]\": \"null\"\r\n  }\r\n})\r\nexport class TemplateComponent implements AfterViewInit {\r\n  @ContentChildren(ActionBarComponent, { descendants: true })\r\n  private set _actionBars(action_bars: QueryList<ActionBarComponent>) {\r\n    setTimeout(() => (this.actionBars = action_bars.toArray()), 0);\r\n  }\r\n  @ContentChild(FormBarComponent, { static: false }) private set _formBar(\r\n    form_bar: FormBarComponent\r\n  ) {\r\n    setTimeout(() => (this.formBar = form_bar), 0);\r\n  }\r\n\r\n  constructor(\r\n    private _route: ActivatedRoute,\r\n    private _deviceService: DeviceDetectorService,\r\n    private _config: ConfigService,\r\n    private _layoutRouterService: LayoutRouterService,\r\n    public elementRef: ElementRef\r\n  ) {}\r\n\r\n  @ViewChild(\"wrapper\", { static: true }) private _wrapper: ElementRef;\r\n  @ViewChild(\"header\", { static: false }) private _header: ElementRef;\r\n  @ViewChild(\"content\", { static: true }) private _content: ElementRef;\r\n\r\n  @Input(\"title\") title: string;\r\n  @Input(\"subtitle\") subtitle: string;\r\n  @Input(\"type\") type = \"default\";\r\n  @Input(\"show-header\") show_header: boolean;\r\n  @Input(\"show-layout-header\") show_layout_header: boolean;\r\n  @Input(\"show-layout-sidebar\") show_layout_sidebar: boolean;\r\n  @Input(\"size\") size: TemplateSize = TemplateSize.RESPONSIVE;\r\n\r\n  public formBar: FormBarComponent;\r\n  public actionBars: Array<ActionBarComponent>;\r\n\r\n  public onSizeChange: EventEmitter<TemplateSizes> = new EventEmitter();\r\n  public onScroll: EventEmitter<TemplateScrollRef> = new EventEmitter();\r\n\r\n  public breakPoint: TemplateBreakPoint;\r\n  public breakPoints: Array<TemplateBreakPoint> = [\r\n    \"xs\",\r\n    \"sm\",\r\n    \"md\",\r\n    \"lg\",\r\n    \"xl\"\r\n  ];\r\n\r\n  public sizes: TemplateSizes = {\r\n    width: 0,\r\n    height: 0,\r\n    header_height: 0,\r\n    offset_height: 0\r\n  };\r\n\r\n  public scrollRef: TemplateScrollRef = {\r\n    top: 0,\r\n    left: 0\r\n  };\r\n\r\n  public relative = false;\r\n\r\n  private _device_info: DeviceInfo = this._deviceService.getDeviceInfo();\r\n\r\n  @HostListener(\"window:resize\") public _onResize() {\r\n    this.resize();\r\n  }\r\n\r\n  @HostListener(\"scroll\") public _onScroll() {\r\n    this.scrollRef = {\r\n      top: this._getScrollElement().scrollTop,\r\n      left: this._getScrollElement().scrollLeft\r\n    };\r\n    this.onScroll.emit(this.scrollRef);\r\n  }\r\n\r\n  public ngOnInit() {\r\n    this._layoutRouterService.registerTemplate(this);\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    this._layoutRouterService.unregisterTemplate();\r\n  }\r\n\r\n  public ngAfterViewInit() {\r\n    setTimeout(() => {\r\n      if (!this.title) {\r\n        const root: ActivatedRoute = this._route.root;\r\n        this.title = this._getActiveRoute(root).snapshot.data[\r\n          ROUTE_DATA_BREADCRUMB\r\n        ];\r\n      }\r\n      this.resize();\r\n      this._updateData();\r\n    }, 0);\r\n  }\r\n\r\n  public ngOnChanges() {\r\n    this._updateData();\r\n  }\r\n\r\n  public scrollTo(offset: number, smooth: boolean = false) {\r\n    if (this.hasScroll()) {\r\n      this._getScrollElement().scroll({\r\n        top: offset,\r\n        behavior: smooth ? \"smooth\" : \"auto\"\r\n      });\r\n    }\r\n  }\r\n\r\n  public scrollToAnchor(anchor: string, smooth: boolean = false) {\r\n    if (this.hasScroll()) {\r\n      if (anchor.indexOf(\"#\") !== 0) {\r\n        anchor = `#${anchor}`;\r\n      }\r\n      const el = this.elementRef.nativeElement.querySelector(anchor);\r\n      if (!el) {\r\n        return;\r\n      }\r\n      this.scrollTo((<any>el).offsetTop, smooth);\r\n    }\r\n  }\r\n\r\n  public scrollToTop(smooth: boolean = false) {\r\n    if (this.hasScroll()) {\r\n      this._getScrollElement().scroll({\r\n        top: 0,\r\n        behavior: smooth ? \"smooth\" : \"auto\"\r\n      });\r\n    }\r\n  }\r\n\r\n  public scrollToBottom(smooth: boolean = false) {\r\n    if (this.hasScroll()) {\r\n      this._getScrollElement().scroll({\r\n        top: this._getScrollElement().scrollHeight,\r\n        behavior: smooth ? \"smooth\" : \"auto\"\r\n      });\r\n    }\r\n  }\r\n\r\n  public resize() {\r\n    this._setBreakPoint();\r\n    this._setSizes();\r\n  }\r\n\r\n  public isBreakPoint(size: TemplateBreakPoint): boolean {\r\n    return this.breakPoint == size;\r\n  }\r\n\r\n  public isBreakPointMin(size: TemplateBreakPoint): boolean {\r\n    return (\r\n      this.breakPoints.indexOf(size) <=\r\n      this.breakPoints.indexOf(this.breakPoint)\r\n    );\r\n  }\r\n\r\n  public isBreakPointMax(size: TemplateBreakPoint): boolean {\r\n    return (\r\n      this.breakPoints.indexOf(size) >=\r\n      this.breakPoints.indexOf(this.breakPoint)\r\n    );\r\n  }\r\n\r\n  public getConfig(path): any {\r\n    if (!this.type) {\r\n      this.type = \"default\";\r\n    }\r\n    if (this._config) {\r\n      const template_type =\r\n        this._config.template[this.type] ||\r\n        this._config.template[\"1\"] ||\r\n        this._config.template.default;\r\n\r\n      if (!template_type) return null;\r\n\r\n      switch (path) {\r\n        case \"background.color\":\r\n          return template_type.background.color;\r\n        case \"background.image\":\r\n          return template_type.background.image\r\n            ? `url(\"${template_type.background.image}\")`\r\n            : null;\r\n        default:\r\n          return _.get(template_type, path);\r\n      }\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n\r\n  public isTheme(theme_type: string): boolean {\r\n    return this.getConfig(\"theme\") == TemplateTheme[theme_type];\r\n  }\r\n\r\n  public hasFormBar(): boolean {\r\n    // return this.has_form_bar;\r\n    return this.formBar && this.formBar.content ? true : false;\r\n  }\r\n\r\n  public hasActionBar(): boolean {\r\n    return this.actionBars && this.actionBars.length > 0;\r\n  }\r\n\r\n  public hasScroll(): boolean {\r\n    if (this._wrapper) {\r\n      const el = this._getScrollElement(true);\r\n      // const wrapper = this._wrapper.nativeElement.childNodes[0];\r\n      const wrapper = this._wrapper.nativeElement;\r\n      return wrapper.offsetHeight > el.offsetHeight;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  private _getScrollElement(use_body: boolean = false): HTMLElement {\r\n    const is_safari = this._device_info.browser == \"safari\";\r\n    return this._config.layout.relative\r\n      ? use_body || is_safari\r\n        ? document.body\r\n        : document.documentElement\r\n      : this.elementRef.nativeElement;\r\n  }\r\n\r\n  private _setBreakPoint() {\r\n    const width = document.body.clientWidth;\r\n    switch (true) {\r\n      case width < 576:\r\n        this.breakPoint = \"xs\";\r\n        break;\r\n      case width >= 576 && width < 768:\r\n        this.breakPoint = \"sm\";\r\n        break;\r\n      case width >= 768 && width < 992:\r\n        this.breakPoint = \"md\";\r\n        break;\r\n      case width >= 992 && width < 1200:\r\n        this.breakPoint = \"lg\";\r\n        break;\r\n      case width > 1200:\r\n        this.breakPoint = \"xl\";\r\n        break;\r\n    }\r\n  }\r\n\r\n  private _setSizes() {\r\n    setTimeout(() => {\r\n      this.sizes.width = this._getScrollElement().clientWidth;\r\n      this.sizes.height = this._getScrollElement().offsetHeight;\r\n      this.sizes.header_height = this._header\r\n        ? this._header.nativeElement.offsetHeight\r\n        : 0;\r\n      let content_padding = 0;\r\n      if (this._content) {\r\n        const content_styles = window.getComputedStyle(\r\n          this._content.nativeElement\r\n        );\r\n        const content_padding_top = parseFloat(\r\n          content_styles.getPropertyValue(\"padding-top\")\r\n        );\r\n        const content_padding_bottom = parseFloat(\r\n          content_styles.getPropertyValue(\"padding-bottom\")\r\n        );\r\n        content_padding = content_padding_top + content_padding_bottom;\r\n      }\r\n      const offset = this.sizes.height - this.sizes.header_height;\r\n      this.sizes.offset_height = offset - content_padding;\r\n      this.onSizeChange.emit(this.sizes);\r\n    }, 100);\r\n  }\r\n\r\n  private _updateData() {\r\n    if (_.isUndefined(this.show_header)) {\r\n      const show_header = this.getConfig(\"header\");\r\n      this.show_header = _.isBoolean(show_header) ? show_header : true;\r\n    }\r\n    if (_.isUndefined(this.show_layout_header)) {\r\n      const show_layout_header = this.getConfig(\"layout.header\");\r\n      this.show_layout_header = _.isBoolean(show_layout_header)\r\n        ? show_layout_header\r\n        : true;\r\n    }\r\n    if (_.isUndefined(this.show_layout_sidebar)) {\r\n      const show_layout_sidebar = this.getConfig(\"layout.sidebar\");\r\n      this.show_layout_sidebar = _.isBoolean(show_layout_sidebar)\r\n        ? show_layout_sidebar\r\n        : true;\r\n    }\r\n\r\n    this._layoutRouterService.updateTemplate();\r\n  }\r\n\r\n  private _getActiveRoute(route: ActivatedRoute): ActivatedRoute {\r\n    // Fet the child routes\r\n    const children: ActivatedRoute[] = route.children;\r\n    let current: ActivatedRoute;\r\n\r\n    // Return if there are no more children\r\n    if (children.length === 0) {\r\n      return route;\r\n    }\r\n\r\n    // Iterate over each children\r\n    for (const child of children) {\r\n      // Verify primary route\r\n      if (child.outlet !== PRIMARY_OUTLET) {\r\n        continue;\r\n      }\r\n\r\n      // Recursive\r\n      current = this._getActiveRoute(child);\r\n    }\r\n\r\n    return current;\r\n  }\r\n}\r\n\r\nexport type TemplateBreakPoint = \"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\";\r\n\r\nexport interface TemplateScrollRef {\r\n  top: number;\r\n  left: number;\r\n}\r\n\r\nexport interface TemplateSizes {\r\n  width: number;\r\n  height: number;\r\n  header_height: number;\r\n  offset_height: number;\r\n}\r\n"]}