@stratio/egeo
Version:
222 lines • 16.9 kB
JavaScript
/**
* @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, Component, Input, ElementRef, Output, EventEmitter, HostListener, ViewChild, ChangeDetectorRef } from '@angular/core';
import { Router, NavigationEnd } from '@angular/router';
import { StHeaderMenuOption } from '../st-header.model';
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.isActive = false;
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, "qaId", {
get: /**
* @return {?}
*/
function () {
/** @type {?} */
var id = this.elementRef.nativeElement.id + "-" + this.option.label.toLowerCase();
id.replace(/\s+/ig, '_');
return id;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StHeaderMenuOptionComponent.prototype, "hasSubmenu", {
get: /**
* @return {?}
*/
function () {
return this.option.subMenus && this.option.subMenus.length > 0;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StHeaderMenuOptionComponent.prototype, "submenuList", {
get: /**
* @return {?}
*/
function () {
var _this = this;
return 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
}))
}); })) : [];
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
StHeaderMenuOptionComponent.prototype.isRouteActive = /**
* @return {?}
*/
function () {
return this.router.url.indexOf(this.option.link) > -1;
};
/**
* @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;
}
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.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;
}
};
/**
* @private
* @param {?} event
* @return {?}
*/
StHeaderMenuOptionComponent.prototype.onRouterEvent = /**
* @private
* @param {?} event
* @return {?}
*/
function (event) {
if (event instanceof NavigationEnd) {
this.actualPath = event.urlAfterRedirects;
this.cd.markForCheck();
}
};
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\" (change)=\"changeOption($event)\" [active]=\"isActive && hasSubmenu\" [placement]=\"'bottom-start'\" [offset]=\"{x: 0, y: 5}\">\n <div class=\"sth-header-menu-option\" [attr.id]=\"qaId\" [ngClass]=\"{active: isRouteActive()}\" #menu (click)=\"onMenuClick()\">\n <a class=\"sth-header-menu-option-name\">\n <i [ngClass]=\"option.icon\" class=\"sth-header-menu-option-icon\" [title]=\"option.label\"></i>\n <div *ngIf=\"showMenuName\" class=\"sth-header-menu-option-label\">{{option.label}}</div>\n </a>\n <i *ngIf=\"hasSubmenu\" class=\"icon-arrow2_down sth-header-menu-option-arrow\"></i>\n </div>\n</st-dropdown-menu>\n",
changeDetection: ChangeDetectionStrategy.OnPush
}] }
];
/** @nocollapse */
StHeaderMenuOptionComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: Router },
{ type: ChangeDetectorRef }
]; };
StHeaderMenuOptionComponent.propDecorators = {
option: [{ type: Input }],
showMenuName: [{ type: Input }],
selectMenu: [{ type: Output }],
menu: [{ type: ViewChild, args: ['menu', { static: false },] }],
onClickOutside: [{ type: HostListener, args: ['document:click', ['$event'],] }]
};
return StHeaderMenuOptionComponent;
}());
export { StHeaderMenuOptionComponent };
if (false) {
/** @type {?} */
StHeaderMenuOptionComponent.prototype.option;
/** @type {?} */
StHeaderMenuOptionComponent.prototype.showMenuName;
/** @type {?} */
StHeaderMenuOptionComponent.prototype.selectMenu;
/** @type {?} */
StHeaderMenuOptionComponent.prototype.menu;
/** @type {?} */
StHeaderMenuOptionComponent.prototype.isActive;
/**
* @type {?}
* @private
*/
StHeaderMenuOptionComponent.prototype.subscription;
/**
* @type {?}
* @private
*/
StHeaderMenuOptionComponent.prototype.actualPath;
/**
* @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   Component,\n   Input,\n   OnDestroy,\n   ElementRef,\n   Output,\n   EventEmitter,\n   HostListener,\n   ViewChild,\n   ChangeDetectorRef\n} from '@angular/core';\nimport { Router, NavigationEnd } from '@angular/router';\nimport { Subscription } from 'rxjs';\n\nimport { StHeaderMenuOption, StHeaderSelection, StHeaderMenuItem } from '../st-header.model';\n\n@Component({\n   selector: 'st-header-menu-option',\n   templateUrl: './menu-option.html',\n   changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class StHeaderMenuOptionComponent implements OnDestroy {\n\n   @Input() option: StHeaderMenuOption;\n   @Input() showMenuName: boolean;\n\n   @Output() selectMenu: EventEmitter<StHeaderSelection> = new EventEmitter<StHeaderSelection>();\n\n   @ViewChild('menu', {static: false}) menu: ElementRef;\n   public isActive: boolean = false;\n\n   private subscription: Subscription;\n   private actualPath: string = '';\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 get qaId(): string {\n      let id: string = `${this.elementRef.nativeElement.id}-${this.option.label.toLowerCase()}`;\n      id.replace(/\\s+/ig, '_');\n      return id;\n   }\n\n   public get hasSubmenu(): boolean {\n      return this.option.subMenus && this.option.subMenus.length > 0;\n   }\n\n   public get submenuList(): StHeaderMenuItem[] {\n      return 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   public isRouteActive(): boolean {\n      return this.router.url.indexOf(this.option.link) > -1;\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      } 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.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      }\n   }\n\n   private onRouterEvent(event: any): void {\n      if (event instanceof NavigationEnd) {\n         this.actualPath = event.urlAfterRedirects;\n         this.cd.markForCheck();\n      }\n   }\n}\n"]}