@uex/web-extensions
Version:
Uex extensions for Angular 6+ web projects
535 lines • 45.3 kB
JavaScript
/**
* @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"]}