@stratio/egeo
Version:
241 lines • 16.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/st-menu/st-menu.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 { Component, Output, EventEmitter, Input, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core';
import { FormControl } from '@angular/forms';
import { StMenuPosition } from './st-menu.model';
/**
* \@description {Component} Menu
*
* This components shows a dropdown menu with nested submenus
*
* \@model
*
* [Menu model] {./st-menu.model.ts#StMenuModel}
* [Menu status] {./st-menu.model.ts#StMenuStatus}
* [Menu position] {./st-menu.model.ts#StMenuPosition}
*
* \@example
*
* {html}
*
* ```
* <st-menu
* qaTag="menu-example"
* [menuOptions]="options"
* [dynamicHeight]="true"
* (selectedOption)="onSelectMenuOption(event)">
* </st-menu>
* ```
* @template T
*/
export class StMenuComponent {
/**
* @param {?} _cd
*/
constructor(_cd) {
this._cd = _cd;
/**
* \@input {StMenuPosition} current menu position: left | right
*/
this.position = StMenuPosition.right;
/**
* \@input {string} search input custom label
*/
this.searchLabel = 'Search';
/**
* \@input {boolean} shows menu dropdown animation
*/
this.animate = true;
/**
* \@input {boolean} disable menu toggle
*/
this.disabled = false;
/**
* \@output {StMenuModel<T>} [selectedOption=''] Notify the selected menu option
*/
this.selectedOption = new EventEmitter();
/**
* \@output {string} [searchChange=''] Notify when the search input value changes
*/
this.searchChange = new EventEmitter();
this.showMenu = false;
}
/**
* @return {?}
*/
ngOnInit() {
if (this.search) {
this.searchFormControl = new FormControl('');
this._formControlSubscription = this.searchFormControl.valueChanges.subscribe((/**
* @param {?} value
* @return {?}
*/
value => {
this.searchChange.emit(value);
}));
}
}
/**
* @return {?}
*/
ngOnDestroy() {
if (this._formControlSubscription) {
this._formControlSubscription.unsubscribe();
}
}
/**
* Toggle menu activation
* @param {?} event
* @return {?}
*/
activateMenu(event) {
if (this.showMenu) {
this.hideMenu();
}
else {
setTimeout((/**
* @return {?}
*/
() => {
this.showMenu = true;
this._cd.markForCheck();
}));
}
}
/**
* Emits the selected menu option from childs
* @param {?} event
* @return {?}
*/
selectedMenuOption(event) {
this.selectedOption.emit(event);
this.hideMenu();
}
/**
* Hides the menu and reset the search input value if it's enabled
* @return {?}
*/
hideMenu() {
this.showMenu = false;
if (this.searchFormControl) {
this.searchFormControl.setValue('');
}
this._cd.markForCheck();
}
}
StMenuComponent.decorators = [
{ type: Component, args: [{
selector: 'st-menu',
template: "<div class=\"st-menu\" [ngClass]=\"{'st-menu--disabled': disabled}\">\n <div class=\"st-menu__action\">\n <div class=\"st-menu__link\"\n [ngClass]=\"{'st-menu__button--disabled': disabled}\"\n [id]=\"qaTag\"\n (click)=\"!disabled && activateMenu($event)\" >\n <ng-content></ng-content>\n </div>\n <div class=\"st-menu__options\"\n *ngIf=\"showMenu\"\n clickOutside\n (clickOutside)=\"hideMenu()\"\n [ngClass]=\"{'st-menu__options--left': position === 'left'}\">\n <st-menu-options\n [searchFormControl]=\"searchFormControl\"\n [searchLabel]=\"searchLabel\"\n [menuOptions]=\"menuOptions\"\n [animate]=\"animate\"\n [dynamicHeight]=\"dynamicHeight\"\n [activeOption]=\"activeOption\"\n [position]=\"position\"\n [marginTop]=\"marginTop\"\n [qaTag]=\"qaTag\"\n (selectedOption)=\"selectedMenuOption($event)\"></st-menu-options>\n </div>\n </div>\n</div>\n",
changeDetection: ChangeDetectionStrategy.OnPush,
styles: ["@charset \"UTF-8\";:host{display:inline-block}.st-menu__action{position:relative;display:inline-block}.st-menu__link{cursor:pointer;display:inline-block;position:relative}.st-menu__options{position:absolute;z-index:7500;-webkit-transform:translate3d(0,0,0);top:0;height:100%;margin-top:5px}.st-menu__options--left{right:0}.st-menu--disabled{cursor:not-allowed}.st-menu__button--disabled{pointer-events:none}"]
}] }
];
/** @nocollapse */
StMenuComponent.ctorParameters = () => [
{ type: ChangeDetectorRef }
];
StMenuComponent.propDecorators = {
qaTag: [{ type: Input }],
menuOptions: [{ type: Input }],
activeOption: [{ type: Input }],
position: [{ type: Input }],
search: [{ type: Input }],
searchLabel: [{ type: Input }],
dynamicHeight: [{ type: Input }],
marginTop: [{ type: Input }],
animate: [{ type: Input }],
disabled: [{ type: Input }],
selectedOption: [{ type: Output }],
searchChange: [{ type: Output }]
};
if (false) {
/**
* \@input {string} [qaTag=''] For set id for tests
* @type {?}
*/
StMenuComponent.prototype.qaTag;
/**
* \@input {StMenuModel<T>[]} list of menu items to show
* @type {?}
*/
StMenuComponent.prototype.menuOptions;
/**
* \@input {any} current selected option
* @type {?}
*/
StMenuComponent.prototype.activeOption;
/**
* \@input {StMenuPosition} current menu position: left | right
* @type {?}
*/
StMenuComponent.prototype.position;
/**
* \@input {boolean} show search input
* @type {?}
*/
StMenuComponent.prototype.search;
/**
* \@input {string} search input custom label
* @type {?}
*/
StMenuComponent.prototype.searchLabel;
/**
* \@input {boolean} Show menu in full height mode
* @type {?}
*/
StMenuComponent.prototype.dynamicHeight;
/**
* \@input {number} adjust menu options position
* @type {?}
*/
StMenuComponent.prototype.marginTop;
/**
* \@input {boolean} shows menu dropdown animation
* @type {?}
*/
StMenuComponent.prototype.animate;
/**
* \@input {boolean} disable menu toggle
* @type {?}
*/
StMenuComponent.prototype.disabled;
/**
* \@output {StMenuModel<T>} [selectedOption=''] Notify the selected menu option
* @type {?}
*/
StMenuComponent.prototype.selectedOption;
/**
* \@output {string} [searchChange=''] Notify when the search input value changes
* @type {?}
*/
StMenuComponent.prototype.searchChange;
/** @type {?} */
StMenuComponent.prototype.showMenu;
/** @type {?} */
StMenuComponent.prototype.searchFormControl;
/**
* @type {?}
* @private
*/
StMenuComponent.prototype._formControlSubscription;
/**
* @type {?}
* @private
*/
StMenuComponent.prototype._cd;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-menu.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-menu/st-menu.component.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAWA,OAAO,EACJ,SAAS,EAAU,MAAM,EAAE,YAAY,EAAE,KAAK,EAC9C,uBAAuB,EAAa,iBAAiB,EACvD,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAG7C,OAAO,EAAe,cAAc,EAAE,MAAM,iBAAiB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;AAgC9D,MAAM,OAAO,eAAe;;;;IAiCzB,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;;;;QAxBjC,aAAQ,GAAmB,cAAc,CAAC,KAAK,CAAC;;;;QAIhD,gBAAW,GAAW,QAAQ,CAAC;;;;QAM/B,YAAO,GAAY,IAAI,CAAC;;;;QAExB,aAAQ,GAAY,KAAK,CAAC;;;;QAGzB,mBAAc,GAAiC,IAAI,YAAY,EAAkB,CAAC;;;;QAElF,iBAAY,GAAyB,IAAI,YAAY,EAAU,CAAC;QAEnE,aAAQ,GAAY,KAAK,CAAC;IAKa,CAAC;;;;IAE/C,QAAQ;QACL,IAAI,IAAI,CAAC,MAAM,EAAE;YACd,IAAI,CAAC,iBAAiB,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;YAC7C,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,SAAS;;;;YAAC,KAAK,CAAC,EAAE;gBACnF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACjC,CAAC,EAAC,CAAC;SACL;IACJ,CAAC;;;;IAED,WAAW;QACR,IAAI,IAAI,CAAC,wBAAwB,EAAE;YAChC,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,CAAC;SAC9C;IACJ,CAAC;;;;;;IAMM,YAAY,CAAC,KAAY;QAC7B,IAAI,IAAI,CAAC,QAAQ,EAAE;YAChB,IAAI,CAAC,QAAQ,EAAE,CAAC;SAClB;aAAM;YACJ,UAAU;;;YAAC,GAAG,EAAE;gBACb,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC3B,CAAC,EAAC,CAAC;SACL;IACJ,CAAC;;;;;;IAMM,kBAAkB,CAAC,KAAqB;QAC5C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChC,IAAI,CAAC,QAAQ,EAAE,CAAC;IACnB,CAAC;;;;;IAKM,QAAQ;QACZ,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,IAAI,CAAC,iBAAiB,EAAE;YACzB,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;SACtC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;;;YAzFH,SAAS,SAAC;gBACR,QAAQ,EAAE,SAAS;gBACnB,k+BAAuC;gBAEvC,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aACjD;;;;YApCsC,iBAAiB;;;oBAwCpD,KAAK;0BAEL,KAAK;2BAEL,KAAK;uBAEL,KAAK;qBAEL,KAAK;0BAEL,KAAK;4BAEL,KAAK;wBAEL,KAAK;sBAEL,KAAK;uBAEL,KAAK;6BAGL,MAAM;2BAEN,MAAM;;;;;;;IAvBP,gCAAuB;;;;;IAEvB,sCAAuC;;;;;IAEvC,uCAA2B;;;;;IAE3B,mCAAyD;;;;;IAEzD,iCAAyB;;;;;IAEzB,sCAAwC;;;;;IAExC,wCAAgC;;;;;IAEhC,oCAA2B;;;;;IAE3B,kCAAiC;;;;;IAEjC,mCAAmC;;;;;IAGnC,yCAA4F;;;;;IAE5F,uCAA0E;;IAE1E,mCAAiC;;IACjC,4CAAsC;;;;;IAEtC,mDAA+C;;;;;IAEnC,8BAA8B","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 */\n\nimport {\n   Component, OnInit, Output, EventEmitter, Input, ElementRef,\n   ChangeDetectionStrategy, OnDestroy, ChangeDetectorRef\n} from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { StMenuModel, StMenuPosition } from './st-menu.model';\n\n/**\n * @description {Component} Menu\n *\n * This components shows a dropdown menu with nested submenus\n *\n *  @model\n *\n *   [Menu model] {./st-menu.model.ts#StMenuModel}\n *   [Menu status] {./st-menu.model.ts#StMenuStatus}\n *   [Menu position] {./st-menu.model.ts#StMenuPosition}\n *\n * @example\n *\n * {html}\n *\n * ```\n *    <st-menu\n *       qaTag=\"menu-example\"\n *       [menuOptions]=\"options\"\n *       [dynamicHeight]=\"true\"\n *       (selectedOption)=\"onSelectMenuOption(event)\">\n *    </st-menu>\n * ```\n */\n@Component({\n   selector: 'st-menu',\n   templateUrl: './st-menu.component.html',\n   styleUrls: ['./st-menu.component.scss'],\n   changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class StMenuComponent<T> implements OnDestroy, OnInit {\n\n   /** @input {string} [qaTag=''] For set id for tests */\n   @Input() qaTag: string;\n   /** @input {StMenuModel<T>[]} list of menu items to show */\n   @Input() menuOptions: StMenuModel<T>[];\n   /** @input {any} current selected option */\n   @Input() activeOption: any;\n   /** @input {StMenuPosition} current menu position: left | right */\n   @Input() position: StMenuPosition = StMenuPosition.right;\n   /** @input {boolean} show search input */\n   @Input() search: boolean;\n   /** @input {string} search input custom label */\n   @Input() searchLabel: string = 'Search';\n   /** @input {boolean} Show menu in full height mode */\n   @Input() dynamicHeight: boolean;\n   /** @input {number} adjust menu options position */\n   @Input() marginTop: number;\n   /** @input {boolean} shows menu dropdown animation */\n   @Input() animate: boolean = true;\n   /** @input {boolean} disable menu toggle */\n   @Input() disabled: boolean = false;\n\n   /** @output {StMenuModel<T>} [selectedOption=''] Notify the selected menu option */\n   @Output() selectedOption: EventEmitter<StMenuModel<T>> = new EventEmitter<StMenuModel<T>>();\n   /** @output {string} [searchChange=''] Notify when the search input value changes */\n   @Output() searchChange: EventEmitter<string> = new EventEmitter<string>();\n\n   public showMenu: boolean = false;\n   public searchFormControl: FormControl;\n\n   private _formControlSubscription: Subscription;\n\n   constructor(private _cd: ChangeDetectorRef) { }\n\n   ngOnInit(): void {\n      if (this.search) {\n         this.searchFormControl = new FormControl('');\n         this._formControlSubscription = this.searchFormControl.valueChanges.subscribe(value => {\n            this.searchChange.emit(value);\n         });\n      }\n   }\n\n   ngOnDestroy(): void {\n      if (this._formControlSubscription) {\n         this._formControlSubscription.unsubscribe();\n      }\n   }\n\n   /**\n    * Toggle menu activation\n    * @param event\n    */\n   public activateMenu(event: Event): void {\n      if (this.showMenu) {\n         this.hideMenu();\n      } else {\n         setTimeout(() => {\n            this.showMenu = true;\n            this._cd.markForCheck();\n         });\n      }\n   }\n\n   /**\n    * Emits the selected menu option from childs\n    * @param event: StMenuModel<T>\n    */\n   public selectedMenuOption(event: StMenuModel<T>): void {\n      this.selectedOption.emit(event);\n      this.hideMenu();\n   }\n\n   /**\n    * Hides the menu and reset the search input value if it's enabled\n    */\n   public hideMenu(): void {\n      this.showMenu = false;\n      if (this.searchFormControl) {\n         this.searchFormControl.setValue('');\n      }\n      this._cd.markForCheck();\n   }\n}\n"]}