UNPKG

@stratio/egeo

Version:
258 lines 20.5 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'; var StHeaderMenuOptionComponent = /** @class */ (function () { function StHeaderMenuOptionComponent(elementRef, router, cd) { var _this = this; 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 {?} */ function (event) { return _this._onRouterEvent(event); })); this._actualPath = this.router.url; } Object.defineProperty(StHeaderMenuOptionComponent.prototype, "isCurrentRoute", { get: /** * @return {?} */ function () { return StHeaderUtils.isRouteActive(this._option, this.router.url); }, enumerable: true, configurable: true }); Object.defineProperty(StHeaderMenuOptionComponent.prototype, "option", { get: /** * @return {?} */ function () { return this._option; }, set: /** * @param {?} _option * @return {?} */ function (_option) { this._option = _option; this.hasSubmenu = _option.subMenus && _option.subMenus.length > 0; this.qaId = this._getQaId(); this.submenuList = this._getSubmenuList(); this.cd.markForCheck(); }, enumerable: true, configurable: true }); /** * @return {?} */ StHeaderMenuOptionComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.isActive = false; this._subscription.unsubscribe(); }; /** * @return {?} */ StHeaderMenuOptionComponent.prototype.onMenuClick = /** * @return {?} */ function () { 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 {?} */ StHeaderMenuOptionComponent.prototype.changeOption = /** * @param {?} selected * @return {?} */ function (selected) { this.isActive = false; this.cd.markForCheck(); this.selectMenu.emit(selected.selection); }; /** * @param {?} event * @return {?} */ StHeaderMenuOptionComponent.prototype.onClickOutside = /** * @param {?} event * @return {?} */ function (event) { /** @type {?} */ var isMyComponent = this.isActive && this.menu.nativeElement.contains(event.target); if (!isMyComponent && this.isActive) { this.isActive = false; this.cd.markForCheck(); } }; /** * @private * @param {?} event * @return {?} */ StHeaderMenuOptionComponent.prototype._onRouterEvent = /** * @private * @param {?} event * @return {?} */ function (event) { if (event instanceof NavigationEnd) { this._actualPath = event.urlAfterRedirects; this.submenuList = this._getSubmenuList(); this.cd.markForCheck(); } }; /** * @private * @return {?} */ StHeaderMenuOptionComponent.prototype._getQaId = /** * @private * @return {?} */ function () { if (!this._option) { return null; } /** @type {?} */ var id = this.elementRef.nativeElement.id + "-" + this._option.label.toLowerCase(); id.replace(/\s+/ig, '_'); return id; }; /** * @private * @return {?} */ StHeaderMenuOptionComponent.prototype._getSubmenuList = /** * @private * @return {?} */ function () { var _this = this; return this._option && this.hasSubmenu ? this._option.subMenus.map((/** * @param {?} _ * @return {?} */ function (_) { 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 = function () { return [ { 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'],] }] }; return StHeaderMenuOptionComponent; }()); export { StHeaderMenuOptionComponent }; 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"]}