UNPKG

@stratio/egeo

Version:
224 lines 19 kB
/** * @fileoverview added by tsickle * Generated from: lib/st-header/menu-option/menu-option.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, HostBinding, HostListener, Input, Output, ViewChild } from '@angular/core'; import { NavigationEnd, Router } from '@angular/router'; import { StHeaderMenuOption } from '../st-header.model'; import { StDropDownVisualMode } from './../../st-dropdown-menu/st-dropdown-menu.interface'; import { StHeaderUtils } from '../st-header.utils'; export class StHeaderMenuOptionComponent { /** * @param {?} elementRef * @param {?} router * @param {?} cd */ constructor(elementRef, router, cd) { this.elementRef = elementRef; this.router = router; this.cd = cd; this.selectMenu = new EventEmitter(); this.visualMode = StDropDownVisualMode.MENU_LIST; this._actualPath = ''; this._subscription = this.router.events.subscribe((/** * @param {?} event * @return {?} */ (event) => this._onRouterEvent(event))); this._actualPath = this.router.url; } /** * @return {?} */ get isCurrentRoute() { return StHeaderUtils.isRouteActive(this._option, this.router.url); } /** * @return {?} */ get option() { return this._option; } /** * @param {?} _option * @return {?} */ set option(_option) { this._option = _option; this.hasSubmenu = _option.subMenus && _option.subMenus.length > 0; this.qaId = this._getQaId(); this.submenuList = this._getSubmenuList(); this.cd.markForCheck(); } /** * @return {?} */ ngOnDestroy() { this.isActive = false; this._subscription.unsubscribe(); } /** * @return {?} */ onMenuClick() { if (this.hasSubmenu) { this.isActive = !this.isActive; this.cd.markForCheck(); } else { this.selectMenu.emit({ link: this._option.link, external: this._option.external, openInNewPage: this._option.openInNewPage }); } } /** * @param {?} selected * @return {?} */ changeOption(selected) { this.isActive = false; this.cd.markForCheck(); this.selectMenu.emit(selected.selection); } /** * @param {?} event * @return {?} */ onClickOutside(event) { /** @type {?} */ const isMyComponent = this.isActive && this.menu.nativeElement.contains(event.target); if (!isMyComponent && this.isActive) { this.isActive = false; this.cd.markForCheck(); } } /** * @private * @param {?} event * @return {?} */ _onRouterEvent(event) { if (event instanceof NavigationEnd) { this._actualPath = event.urlAfterRedirects; this.submenuList = this._getSubmenuList(); this.cd.markForCheck(); } } /** * @private * @return {?} */ _getQaId() { if (!this._option) { return null; } /** @type {?} */ let id = `${this.elementRef.nativeElement.id}-${this._option.label.toLowerCase()}`; id.replace(/\s+/ig, '_'); return id; } /** * @private * @return {?} */ _getSubmenuList() { return this._option && this.hasSubmenu ? this._option.subMenus.map((/** * @param {?} _ * @return {?} */ _ => ({ label: _.label, value: _.link, selected: this._actualPath === _.link, selection: (/** @type {?} */ ({ link: _.link, external: _.external, openInNewPage: _.openInNewPage })) }))) : []; } } StHeaderMenuOptionComponent.decorators = [ { type: Component, args: [{ selector: 'st-header-menu-option', 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\n<st-dropdown-menu [items]=\"submenuList\"\n [visualMode]=\"visualMode\"\n [active]=\"isActive && hasSubmenu\"\n [placement]=\"'bottom-start'\"\n [offset]=\"{x: 0, y: 10}\"\n (change)=\"changeOption($event)\">\n <div class=\"st-header-menu-option\" #menu\n [attr.id]=\"qaId\"\n (click)=\"onMenuClick()\">\n <a class=\"st-header-menu-option-name\">\n <i *ngIf=\"option.icon\"\n class=\"st-header-menu-option-icon\"\n [ngClass]=\"option.icon\"\n [title]=\"option.label\"></i>\n <div *ngIf=\"showMenuName\" class=\"st-header-menu-option-label\">{{option.label}}</div>\n </a>\n <i *ngIf=\"hasSubmenu\" class=\"icon-arrow2_down st-header-menu-option-arrow\"></i>\n </div>\n</st-dropdown-menu>\n", changeDetection: ChangeDetectionStrategy.OnPush, styles: ["@charset \"UTF-8\";:host{display:flex;justify-content:center;flex-direction:column;height:100%;padding:0 10px}:host.active{background:#566574}:host.active .st-header-menu-option,:host.active .st-header-menu-option:hover{color:#fff}"] }] } ]; /** @nocollapse */ StHeaderMenuOptionComponent.ctorParameters = () => [ { type: ElementRef }, { type: Router }, { type: ChangeDetectorRef } ]; StHeaderMenuOptionComponent.propDecorators = { showMenuName: [{ type: Input }], selectMenu: [{ type: Output }], menu: [{ type: ViewChild, args: ['menu', { static: false },] }], isCurrentRoute: [{ type: HostBinding, args: ['class.active',] }], option: [{ type: Input }], onClickOutside: [{ type: HostListener, args: ['document:click', ['$event'],] }] }; if (false) { /** @type {?} */ StHeaderMenuOptionComponent.prototype.showMenuName; /** @type {?} */ StHeaderMenuOptionComponent.prototype.selectMenu; /** @type {?} */ StHeaderMenuOptionComponent.prototype.menu; /** @type {?} */ StHeaderMenuOptionComponent.prototype.isActive; /** @type {?} */ StHeaderMenuOptionComponent.prototype.visualMode; /** @type {?} */ StHeaderMenuOptionComponent.prototype.hasSubmenu; /** @type {?} */ StHeaderMenuOptionComponent.prototype.qaId; /** @type {?} */ StHeaderMenuOptionComponent.prototype.submenuList; /** * @type {?} * @private */ StHeaderMenuOptionComponent.prototype._subscription; /** * @type {?} * @private */ StHeaderMenuOptionComponent.prototype._actualPath; /** * @type {?} * @private */ StHeaderMenuOptionComponent.prototype._option; /** * @type {?} * @private */ StHeaderMenuOptionComponent.prototype.elementRef; /** * @type {?} * @private */ StHeaderMenuOptionComponent.prototype.router; /** * @type {?} * @private */ StHeaderMenuOptionComponent.prototype.cd; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-option.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-header/menu-option/menu-option.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   ChangeDetectionStrategy,\n   ChangeDetectorRef,\n   Component,\n   ElementRef,\n   EventEmitter,\n   HostBinding,\n   HostListener,\n   Input,\n   OnDestroy,\n   Output,\n   ViewChild\n} from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { Subscription } from 'rxjs';\n\nimport { StHeaderMenuItem, StHeaderMenuOption, StHeaderSelection } from '../st-header.model';\nimport { StDropDownVisualMode } from './../../st-dropdown-menu/st-dropdown-menu.interface';\nimport { StHeaderUtils } from '../st-header.utils';\n\n@Component({\n   selector: 'st-header-menu-option',\n   templateUrl: './menu-option.html',\n   styleUrls: ['./menu-option.scss'],\n   changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class StHeaderMenuOptionComponent implements OnDestroy {\n\n   @Input() showMenuName: boolean;\n\n   @Output() selectMenu: EventEmitter<StHeaderSelection> = new EventEmitter<StHeaderSelection>();\n\n   @ViewChild('menu', { static: false }) menu: ElementRef;\n\n   @HostBinding('class.active')\n   public get isCurrentRoute(): boolean {\n      return StHeaderUtils.isRouteActive(this._option, this.router.url);\n   }\n\n   public isActive: boolean;\n   public visualMode: StDropDownVisualMode = StDropDownVisualMode.MENU_LIST;\n   public hasSubmenu: boolean;\n   public qaId: string;\n   public submenuList: StHeaderMenuItem[];\n\n   private _subscription: Subscription;\n   private _actualPath: string = '';\n   private _option: StHeaderMenuOption;\n\n   @Input()\n   get option(): StHeaderMenuOption {\n      return this._option;\n   }\n\n   set option(_option: StHeaderMenuOption) {\n      this._option = _option;\n      this.hasSubmenu = _option.subMenus && _option.subMenus.length > 0;\n      this.qaId = this._getQaId();\n      this.submenuList = this._getSubmenuList();\n      this.cd.markForCheck();\n   }\n\n   constructor(private elementRef: ElementRef, private router: Router, private cd: ChangeDetectorRef) {\n      this._subscription = this.router.events.subscribe((event) => this._onRouterEvent(event));\n      this._actualPath = this.router.url;\n   }\n\n   public ngOnDestroy(): void {\n      this.isActive = false;\n      this._subscription.unsubscribe();\n   }\n\n   public onMenuClick(): void {\n      if (this.hasSubmenu) {\n         this.isActive = !this.isActive;\n         this.cd.markForCheck();\n      } else {\n         this.selectMenu.emit({\n            link: this._option.link,\n            external: this._option.external,\n            openInNewPage: this._option.openInNewPage\n         });\n      }\n   }\n\n   public changeOption(selected: StHeaderMenuItem): void {\n      this.isActive = false;\n      this.cd.markForCheck();\n      this.selectMenu.emit(selected.selection);\n   }\n\n   @HostListener('document:click', ['$event'])\n   onClickOutside(event: Event): void {\n      const isMyComponent: boolean = this.isActive && this.menu.nativeElement.contains(event.target);\n      if (!isMyComponent && this.isActive) {\n         this.isActive = false;\n         this.cd.markForCheck();\n      }\n   }\n\n   private _onRouterEvent(event: any): void {\n      if (event instanceof NavigationEnd) {\n         this._actualPath = event.urlAfterRedirects;\n         this.submenuList = this._getSubmenuList();\n         this.cd.markForCheck();\n      }\n   }\n\n\n   private _getQaId(): string {\n      if (!this._option) {\n         return null;\n      }\n      let id: string = `${this.elementRef.nativeElement.id}-${this._option.label.toLowerCase()}`;\n      id.replace(/\\s+/ig, '_');\n      return id;\n   }\n\n\n   private _getSubmenuList(): StHeaderMenuItem[] {\n      return this._option && this.hasSubmenu ? this._option.subMenus.map(_ => ({\n         label: _.label,\n         value: _.link,\n         selected: this._actualPath === _.link,\n         selection: {\n            link: _.link,\n            external: _.external,\n            openInNewPage: _.openInNewPage\n         } as StHeaderSelection\n      })) : [];\n   }\n\n\n}\n"]}