UNPKG

@stratio/egeo

Version:
241 lines 16.6 kB
/** * @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"]}