@stratio/egeo
Version:
222 lines • 18 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/st-header/st-header.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/*
* © 2017 Stratio Big Data Inc., Sucursal en España.
*
* This software is licensed under the Apache License, Version 2.0.
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the terms of the License for more details.
*
* SPDX-License-Identifier: Apache-2.0.
*/
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild } from '@angular/core';
import { Router } from '@angular/router';
import { StWindowRefService } from '../utils/window-service';
/**
* \@description {Component} [Header]
*
* The header component is a main component of an application.
* This component must be on top and scroll with page, when scroll is in a calculated position,
* the header shrinks and fix to top.
*
* \@model
*
* [Header menu options] {./st-header.model.ts#StHeaderMenuOption}
* [Submenu options] {./st-header.model.ts#StHeaderSubMenuOption}
*
* \@example
*
* {html}
*
* ```
* <st-header [menu]="headerMenuSchema" id="header">
* <div class="st-header-logo">
* <!-- Logo as svg, image, etc. -->
* </div>
* <div class="st-header-user-menu">
* <!-- Right header menu, with user menu, notifications, etc -->
* </div>
*
* </st-header>
* ```
*/
export class StHeaderComponent {
/**
* @param {?} _router
* @param {?} _windowServiceRef
* @param {?} _el
* @param {?} _cd
*/
constructor(_router, _windowServiceRef, _el, _cd) {
this._router = _router;
this._windowServiceRef = _windowServiceRef;
this._el = _el;
this._cd = _cd;
/**
* \@Input {StHeaderMenuOption[]} [menu] Array with menu option to show
*/
this.menu = [];
/**
* \@Input {boolean} [navigateByDefault] True if we want menu to manage navigation, false if navigation will be managed from the outside
*/
this.navigateByDefault = true;
/**
* \@Output {StHeaderSelection} [selectMenu] Notify any menu option selection
*/
this.selectMenu = new EventEmitter();
this.showMenuNames = true;
this._headerSize = 0;
}
/**
* @return {?}
*/
ngAfterViewInit() {
this._headerSize = this.headerFixPart.nativeElement.getBoundingClientRect().width + this.userMenuElementWidth + 20;
setTimeout((/**
* @return {?}
*/
() => {
this.checkMenuLabelVisibility();
this._cd.markForCheck();
}));
}
/**
* @return {?}
*/
onResize() {
this.checkMenuLabelVisibility();
this._cd.markForCheck();
}
/**
* @return {?}
*/
get id() {
return this._el.nativeElement.id || 'st-header';
}
/**
* @param {?} selected
* @return {?}
*/
onSelectMenu(selected) {
if (this.navigateByDefault) {
if (selected.external) {
this._windowServiceRef.nativeWindow.open(selected.link, selected.openInNewPage ? '_blank' : '_self');
}
else {
this._router.navigate([selected.link]);
}
}
this.selectMenu.emit(selected);
}
/**
* @return {?}
*/
get menuContainerId() {
return `${this.id}-menu`;
}
/**
* @return {?}
*/
get userMenuElementWidth() {
/** @type {?} */
const userMenuContainer = this.userMenuContainer.nativeElement;
if (userMenuContainer.children && userMenuContainer.children.length > 0) {
return userMenuContainer.children[0].getBoundingClientRect().width;
}
else {
return userMenuContainer.getBoundingClientRect().width;
}
}
/**
* @private
* @return {?}
*/
checkMenuLabelVisibility() {
/** @type {?} */
const windowSize = this._windowServiceRef.nativeWindow.innerWidth;
/** @type {?} */
const canShowMenuNames = this._headerSize <= windowSize;
if (this.showMenuNames !== canShowMenuNames) {
this.showMenuNames = canShowMenuNames;
this._cd.markForCheck();
}
}
}
StHeaderComponent.decorators = [
{ type: Component, args: [{
selector: 'st-header',
template: "<!--\n\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\n\n This software is licensed under the Apache License, Version 2.0.\n This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n See the terms of the License for more details.\n\n SPDX-License-Identifier: Apache-2.0.\n\n-->\n<header class=\"st-header\" #headerDivElement>\n <div class=\"st-header-container container\">\n <div class=\"st-header-container-fix-part\" #headerFixPart>\n <ng-content select=\".st-header-logo\"></ng-content>\n <st-header-menu class=\"st-header-menu-component\"\n [menu]=\"menu\"\n [attr.id]=\"menuContainerId\"\n [showMenuNames]=\"showMenuNames\"\n (selectMenu)=\"onSelectMenu($event)\">\n </st-header-menu>\n </div>\n <div class=\"st-header-shortcut-buttons-container\" #userMenuContainerElement>\n <ng-content select=\".st-header-shortcut-buttons\"></ng-content>\n </div>\n <div class=\"st-header-user-menu-container\" #userMenuContainerElement>\n <ng-content select=\".st-header-user-menu\"></ng-content>\n </div>\n </div>\n</header>\n",
changeDetection: ChangeDetectionStrategy.OnPush
}] }
];
/** @nocollapse */
StHeaderComponent.ctorParameters = () => [
{ type: Router },
{ type: StWindowRefService },
{ type: ElementRef },
{ type: ChangeDetectorRef }
];
StHeaderComponent.propDecorators = {
menu: [{ type: Input }],
navigateByDefault: [{ type: Input }],
selectMenu: [{ type: Output }],
headerDivElement: [{ type: ViewChild, args: ['headerDivElement', { static: false },] }],
headerFixPart: [{ type: ViewChild, args: ['headerFixPart', { static: false },] }],
userMenuContainer: [{ type: ViewChild, args: ['userMenuContainerElement', { static: true },] }],
onResize: [{ type: HostListener, args: ['window:resize', [],] }]
};
if (false) {
/**
* \@Input {StHeaderMenuOption[]} [menu] Array with menu option to show
* @type {?}
*/
StHeaderComponent.prototype.menu;
/**
* \@Input {boolean} [navigateByDefault] True if we want menu to manage navigation, false if navigation will be managed from the outside
* @type {?}
*/
StHeaderComponent.prototype.navigateByDefault;
/**
* \@Output {StHeaderSelection} [selectMenu] Notify any menu option selection
* @type {?}
*/
StHeaderComponent.prototype.selectMenu;
/** @type {?} */
StHeaderComponent.prototype.headerDivElement;
/** @type {?} */
StHeaderComponent.prototype.headerFixPart;
/** @type {?} */
StHeaderComponent.prototype.userMenuContainer;
/** @type {?} */
StHeaderComponent.prototype.showMenuNames;
/**
* @type {?}
* @private
*/
StHeaderComponent.prototype._headerSize;
/**
* @type {?}
* @private
*/
StHeaderComponent.prototype._router;
/**
* @type {?}
* @private
*/
StHeaderComponent.prototype._windowServiceRef;
/**
* @type {?}
* @private
*/
StHeaderComponent.prototype._el;
/**
* @type {?}
* @private
*/
StHeaderComponent.prototype._cd;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-header.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-header/st-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * © 2017 Stratio Big Data Inc., Sucursal en España.\n *\n * This software is licensed under the Apache License, Version 2.0.\n * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n * See the terms of the License for more details.\n *\n * SPDX-License-Identifier: Apache-2.0.\n */\nimport {\n   AfterViewInit,\n   ChangeDetectionStrategy,\n   ChangeDetectorRef,\n   Component,\n   ElementRef,\n   EventEmitter,\n   HostListener,\n   Input,\n   Output,\n   ViewChild\n} from '@angular/core';\nimport { Router } from '@angular/router';\n\nimport { StHeaderMenuOption, StHeaderSelection } from './st-header.model';\nimport { StWindowRefService } from '../utils/window-service';\n\n\n/**\n * @description {Component} [Header]\n *\n * The header component is a main component of an application.\n * This component must be on top and scroll with page, when scroll is in a calculated position,\n * the header shrinks and fix to top.\n *\n * @model\n *\n *   [Header menu options] {./st-header.model.ts#StHeaderMenuOption}\n *   [Submenu options] {./st-header.model.ts#StHeaderSubMenuOption}\n *\n * @example\n *\n * {html}\n *\n * ```\n * <st-header [menu]=\"headerMenuSchema\" id=\"header\">\n *     <div class=\"st-header-logo\">\n *        <!-- Logo as svg, image, etc. -->\n *     </div>\n *     <div class=\"st-header-user-menu\">\n *        <!-- Right header menu, with user menu, notifications, etc -->\n *     </div>\n *\n *  </st-header>\n * ```\n */\n@Component({\n   selector: 'st-header',\n   templateUrl: './st-header.component.html',\n   changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class StHeaderComponent implements AfterViewInit {\n\n   /** @Input {StHeaderMenuOption[]} [menu] Array with menu option to show */\n   @Input() menu: StHeaderMenuOption[] = [];\n   /** @Input {boolean} [navigateByDefault] True if we want menu to manage navigation, false if navigation will be managed from the outside */\n   @Input() navigateByDefault: boolean = true;\n\n   /** @Output {StHeaderSelection} [selectMenu] Notify any menu option selection */\n   @Output() selectMenu: EventEmitter<StHeaderSelection> = new EventEmitter<StHeaderSelection>();\n\n   @ViewChild('headerDivElement', { static: false }) headerDivElement: ElementRef;\n   @ViewChild('headerFixPart', { static: false }) headerFixPart: ElementRef;\n   @ViewChild('userMenuContainerElement', { static: true }) userMenuContainer: ElementRef;\n\n   public showMenuNames: boolean = true;\n\n   private _headerSize: number = 0;\n\n   constructor(\n      private _router: Router,\n      private _windowServiceRef: StWindowRefService,\n      private _el: ElementRef,\n      private _cd: ChangeDetectorRef\n   ) { }\n\n   public ngAfterViewInit(): void {\n      this._headerSize = this.headerFixPart.nativeElement.getBoundingClientRect().width + this.userMenuElementWidth + 20;\n      setTimeout(() => {\n         this.checkMenuLabelVisibility();\n         this._cd.markForCheck();\n      });\n   }\n\n   @HostListener('window:resize', [])\n   onResize(): void {\n      this.checkMenuLabelVisibility();\n      this._cd.markForCheck();\n   }\n\n   public get id(): string {\n      return this._el.nativeElement.id || 'st-header';\n   }\n\n   public onSelectMenu(selected: StHeaderSelection): void {\n      if (this.navigateByDefault) {\n         if (selected.external) {\n            this._windowServiceRef.nativeWindow.open(selected.link, selected.openInNewPage ? '_blank' : '_self');\n         } else {\n            this._router.navigate([selected.link]);\n         }\n      }\n      this.selectMenu.emit(selected);\n   }\n\n   public get menuContainerId(): string {\n      return `${this.id}-menu`;\n   }\n\n   public get userMenuElementWidth(): number {\n      const userMenuContainer: HTMLElement = this.userMenuContainer.nativeElement;\n\n      if (userMenuContainer.children && userMenuContainer.children.length > 0) {\n         return userMenuContainer.children[0].getBoundingClientRect().width;\n      } else {\n         return userMenuContainer.getBoundingClientRect().width;\n      }\n   }\n\n   private checkMenuLabelVisibility(): void {\n      const windowSize: number = this._windowServiceRef.nativeWindow.innerWidth;\n      const canShowMenuNames = this._headerSize <= windowSize;\n      if (this.showMenuNames !== canShowMenuNames) {\n         this.showMenuNames = canShowMenuNames;\n         this._cd.markForCheck();\n      }\n   }\n}\n"]}