UNPKG

@stratio/egeo

Version:
513 lines 43.2 kB
/** * @fileoverview added by tsickle * Generated from: lib/st-select/st-select.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, forwardRef, HostBinding, Injector, Input, Output, ViewChild } from '@angular/core'; import { FormControl, NG_VALUE_ACCESSOR } from '@angular/forms'; import { cloneDeep as _cloneDeep, flatten as _flatten, has as _has } from 'lodash'; import { StCheckValidationsDirective } from './st-check-validations'; import { StDropDownMenuItem } from '../st-dropdown-menu/st-dropdown-menu.interface'; export class StSelectComponent { /** * @param {?} _selectElement * @param {?} _injector * @param {?} _cd */ constructor(_selectElement, _injector, _cd) { this._selectElement = _selectElement; this._injector = _injector; this._cd = _cd; this.placeholder = ''; this.name = ''; this.label = ''; this.tooltip = null; this.selected = undefined; this.itemsBeforeScroll = 8; this.enabledSearcher = false; this.isLoading = false; this.forceValidations = false; this.placeholderSearch = 'Search...'; this.keyBoardMove = false; this.expand = new EventEmitter(); this.select = new EventEmitter(); this.scrollAtBottom = new EventEmitter(); this.search = new EventEmitter(); this.expandedMenu = false; this.searchInput = new FormControl(); this.inputFormControl = new FormControl(); this._inputHTMLElement = undefined; this._isDisabled = false; this._options = []; } // TODO: MOVE THIS TO FORM-BASE /** * @param {?} errorMessage * @return {?} */ notifyError(errorMessage) { this.errorMessage = errorMessage; } /* ****** getters && setters ****** */ /** * @param {?} value * @return {?} */ set disabled(value) { this._isDisabled = value; this._cd.markForCheck(); } /** * @return {?} */ get disabled() { return this._isDisabled; } /** * @param {?} options * @return {?} */ set options(options) { this._options = _cloneDeep(options); /** @type {?} */ const selectedItem = this.findByProperty('selected', true); this.removeAllSelected(); if (selectedItem) { this.selected = selectedItem; } } /** * @return {?} */ get options() { return this._options; } /** * @return {?} */ get selectedValue() { return this.selected && this.selected.label ? this.selected.label : ''; } /** * @return {?} */ get disableValue() { return this._isDisabled === true ? '' : null; } /** * @return {?} */ get selectId() { /** @type {?} */ const select = this._selectElement.nativeElement; return select.getAttribute('id') !== null ? select.id : null; } /** * @return {?} */ get inputId() { return this.selectId !== null ? `${this.selectId}-input` : null; } /** * @return {?} */ get labelId() { return this.selectId !== null ? `${this.selectId}-label` : null; } /** * @return {?} */ get optionsId() { return this.selectId !== null ? `${this.selectId}-options` : null; } /** * @return {?} */ get inputName() { return this.name && this.name.length > 0 ? this.name : null; } /** * @return {?} */ get hasLabel() { return this.label !== undefined && this.label !== null && this.label.length > 0; } /** * @return {?} */ showError() { return this.errorMessage && this.errorMessage.length && (this.inputFormControl.touched || this.forceValidations) && !this._isDisabled; } /* ****** Control value accessor && validate methods ****** */ /** * @return {?} */ onSearch() { this.search.emit(this.searchInput.value); this._cd.markForCheck(); } /** * @param {?} event * @return {?} */ onSearchClick(event) { event.preventDefault(); event.stopPropagation(); } // Set the function to be called when the control receives a change event. /** * @param {?} fn * @return {?} */ registerOnChange(fn) { this.onChange = fn; } // Set the function to be called when the control receives a touch event. /** * @param {?} fn * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * @param {?} disabled * @return {?} */ setDisabledState(disabled) { this._isDisabled = disabled; this._cd.markForCheck(); } // Write a new value to the element. /** * @param {?} newValue * @return {?} */ writeValue(newValue) { if (!this.selected || this.selected.value !== newValue) { this.selected = this.findByProperty('value', newValue); this._cd.markForCheck(); } } /* ****** Component methods ****** */ /** * @return {?} */ ngAfterViewInit() { this._inputHTMLElement = this.inputElement.nativeElement; /** @type {?} */ const directive = this._injector.get(StCheckValidationsDirective, null); if (directive) { directive.registerOnChange(this.notifyError.bind(this)); } } /** * @return {?} */ onButtonClick() { if (!this._isDisabled) { this.toggleButton(); this.expandedMenu ? this._inputHTMLElement.focus() : this._inputHTMLElement.blur(); } } /** * @param {?} event * @return {?} */ onButtonKeyPress(event) { if (event.code === 'Enter') { this.toggleButton(); } } /** * @return {?} */ clearSearchInput() { this.searchInput.setValue(''); this.search.emit(''); } /** * @return {?} */ createResetButton() { return this.default !== undefined && ((!this.selected && this.inputFormControl.touched) || (this.selected && this.selected.value !== this.default)); } /** * @return {?} */ resetToDefault() { this.writeValue(this.default); this.select.emit(this.default); if (this.onChange) { this.onChange(this.default); } this._cd.markForCheck(); } /** * @return {?} */ onClickOutside() { this.expandedMenu = false; this.expand.emit(this.expandedMenu); // Notify expand change } /** * @param {?} option * @return {?} */ onChangeOption(option) { this.selected = option && option.value !== undefined ? option : undefined; /** @type {?} */ const value = option && option.value !== undefined ? option.value : undefined; if (this.onChange) { this.onChange(value); } if (this.onTouched) { this.onTouched(); } this.select.emit(value); if (value || (option && option.hasOwnProperty('value') && !option.value)) { this.onClickOutside(); } this._cd.markForCheck(); } /** * @return {?} */ onScrollAtBottom() { this.scrollAtBottom.emit(); } /* ****** Util component methods ****** */ // Search element by property in option list /** * @private * @param {?} propName * @param {?} propValue * @return {?} */ findByProperty(propName, propValue) { if (this.isStDropdownItemList(this.options)) { return this.options.find((/** * @param {?} item * @return {?} */ item => _has(item, propName) && item[propName] === propValue)); } else if (this.isStDropdownGroupList(this.options)) { return _flatten(this.options.map((/** * @param {?} group * @return {?} */ group => group.items))).find((/** * @param {?} item * @return {?} */ item => _has(item, propName) && item[propName] === propValue)); } } // Check if options are a instance of StDropDownMenuItem[] /** * @private * @param {?} items * @return {?} */ isStDropdownItemList(items) { return this.options && this.options.length > 0 && !_has(((/** @type {?} */ (items)))[0], 'items'); } // Check if options are a instance of StDropDownMenuGroup[] /** * @private * @param {?} items * @return {?} */ isStDropdownGroupList(items) { return this.options && this.options.length > 0 && _has(((/** @type {?} */ (items)))[0], 'items'); } /** * @private * @return {?} */ toggleButton() { this.expandedMenu = !this.expandedMenu; this.expand.emit(this.expandedMenu); // Notify expand change this._cd.markForCheck(); } // TODO: Remove when remove from StDropDownMenuItem model the selected property /** * @private * @return {?} */ removeAllSelected() { if (this.isStDropdownItemList(this.options)) { return this.options.forEach((/** * @param {?} item * @return {?} */ item => { if (item.selected) { delete item.selected; } })); } else if (this.isStDropdownGroupList(this.options)) { this.options.forEach((/** * @param {?} group * @return {?} */ group => group.items.forEach((/** * @param {?} item * @return {?} */ item => { if (item.selected) { delete item.selected; } })))); } } } StSelectComponent.decorators = [ { type: Component, args: [{ selector: 'st-select', 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<st-dropdown-menu\n class=\"st-select-menu\"\n [items]=\"options\"\n [attr.id]=\"optionsId\"\n [active]=\"expandedMenu\"\n [placement]=\"'bottom-start'\"\n [keyBoardMove]=\"keyBoardMove\"\n [selectedItem]=\"selected\"\n (change)=\"onChangeOption($event)\"\n (scrollAtBottom)=\"onScrollAtBottom()\"\n [isLoading]=\"isLoading\"\n [itemsBeforeScroll]=\"itemsBeforeScroll\"\n>\n <div (click)=\"onButtonClick()\" (keypress)=\"onButtonKeyPress($event)\" #button class=\"button-container\"\n (clickOutside)=\"onClickOutside()\">\n <div>\n <label *ngIf=\"hasLabel\" [ngClass]=\"{disabled: disabled, error: showError()}\"\n st-label\n for=\"inputId\"\n class=\"st-label\"\n [attr.title]=\"tooltip\"\n [attr.id]=\"labelId\"\n [attr.disabled]=\"disableValue\">{{label}}</label>\n <div class=\"input-container\">\n <input\n #input\n [formControl]=\"inputFormControl\"\n autocomplete=\"off\"\n aria-haspopup=\"true\"\n class=\"st-input\"\n type=\"text\"\n [readonly]=\"true\"\n [attr.aria-expanded]=\"expandedMenu\"\n [attr.disabled]=\"disableValue\"\n [attr.id]=\"inputId\"\n [attr.name]=\"inputName\"\n [placeholder]=\"placeholder\"\n [value]=\"selectedValue\"\n\n />\n <span *ngIf=\"createResetButton()\" class=\"st-form-control-reset-button\" (click)=\"resetToDefault()\"\n [style.opacity]=\"expandedMenu ? 1 : 0\">\n <i class=\"icon-reload2\"></i>\n </span>\n <i class=\"icon-arrow2_down arrow\" [attr.disabled]=\"disableValue\"></i>\n </div>\n </div>\n </div>\n <div dropdown-header *ngIf=\"enabledSearcher\"\n (click)=\"onSearchClick($event)\"\n class=\"search-input\">\n <input\n id=\"searchInput\"\n autocomplete=\"off\"\n aria-haspopup=\"true\"\n class=\"st-input\"\n type=\"text\"\n [attr.aria-expanded]=\"expandedMenu\"\n [attr.disabled]=\"disableValue\"\n [attr.id]=\"searchInput\"\n [placeholder]=\"placeholderSearch\"\n [formControl]=\"searchInput\"\n (focus)=\"enabledSearcher\"\n (input)=\"onSearch()\"\n />\n <i class=\"st-search-icon sth-search-icon icon-search\" tabindex=\"0\" *ngIf=\"!searchInput.value?.length\"></i>\n <i class=\"st-search-icon sth-search-icon icon-cross\" tabindex=\"0\" *ngIf=\"searchInput.value?.length\"\n (click)=\"clearSearchInput()\" (keyup.enter)=\"clearSearchInput()\"></i>\n </div>\n\n</st-dropdown-menu>\n\n<div class=\"st-input-error-layout\" *ngIf=\"showError()\">\n <span class=\"st-input-error-message\">{{errorMessage}}</span>\n</div>\n", host: { 'class': 'st-select' }, changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ () => StSelectComponent)), multi: true } ], styles: ["@charset \"UTF-8\";.button-container{position:relative}.arrow{position:absolute;right:8px;top:8px;padding:5px 5px 5px 9px;cursor:pointer}.st-select-menu{position:relative}.input-container{position:relative;display:inline-block;width:100%}.search-input{margin:15px}.st-search-icon{position:absolute;right:28px;top:28px;cursor:pointer}.st-search-icon:focus{outline:0}"] }] } ]; /** @nocollapse */ StSelectComponent.ctorParameters = () => [ { type: ElementRef }, { type: Injector }, { type: ChangeDetectorRef } ]; StSelectComponent.propDecorators = { placeholder: [{ type: Input }], name: [{ type: Input }], label: [{ type: Input }], tooltip: [{ type: Input }], errorMessage: [{ type: Input }], selected: [{ type: Input }], default: [{ type: Input }], itemsBeforeScroll: [{ type: Input }], enabledSearcher: [{ type: Input }], isLoading: [{ type: Input }], forceValidations: [{ type: Input }], placeholderSearch: [{ type: Input }], keyBoardMove: [{ type: Input }], expand: [{ type: Output }], select: [{ type: Output }], scrollAtBottom: [{ type: Output }], search: [{ type: Output }], inputElement: [{ type: ViewChild, args: ['input', { static: false },] }], buttonElement: [{ type: ViewChild, args: ['button', { static: false },] }], expandedMenu: [{ type: HostBinding, args: ['class.st-select-opened',] }], disabled: [{ type: Input }], options: [{ type: Input }] }; if (false) { /** @type {?} */ StSelectComponent.prototype.placeholder; /** @type {?} */ StSelectComponent.prototype.name; /** @type {?} */ StSelectComponent.prototype.label; /** @type {?} */ StSelectComponent.prototype.tooltip; /** @type {?} */ StSelectComponent.prototype.errorMessage; /** @type {?} */ StSelectComponent.prototype.selected; /** @type {?} */ StSelectComponent.prototype.default; /** @type {?} */ StSelectComponent.prototype.itemsBeforeScroll; /** @type {?} */ StSelectComponent.prototype.enabledSearcher; /** @type {?} */ StSelectComponent.prototype.isLoading; /** @type {?} */ StSelectComponent.prototype.forceValidations; /** @type {?} */ StSelectComponent.prototype.placeholderSearch; /** @type {?} */ StSelectComponent.prototype.keyBoardMove; /** @type {?} */ StSelectComponent.prototype.expand; /** @type {?} */ StSelectComponent.prototype.select; /** @type {?} */ StSelectComponent.prototype.scrollAtBottom; /** @type {?} */ StSelectComponent.prototype.search; /** @type {?} */ StSelectComponent.prototype.inputElement; /** @type {?} */ StSelectComponent.prototype.buttonElement; /** @type {?} */ StSelectComponent.prototype.expandedMenu; /** @type {?} */ StSelectComponent.prototype.searchInput; /** @type {?} */ StSelectComponent.prototype.inputFormControl; /** @type {?} */ StSelectComponent.prototype.onChange; /** @type {?} */ StSelectComponent.prototype.onTouched; /** * @type {?} * @private */ StSelectComponent.prototype._inputHTMLElement; /** * @type {?} * @private */ StSelectComponent.prototype._isDisabled; /** * @type {?} * @private */ StSelectComponent.prototype._options; /** * @type {?} * @private */ StSelectComponent.prototype._selectElement; /** * @type {?} * @private */ StSelectComponent.prototype._injector; /** * @type {?} * @private */ StSelectComponent.prototype._cd; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-select.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-select/st-select.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAUA,OAAO,EAEJ,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,WAAW,EACX,QAAQ,EACR,KAAK,EACL,MAAM,EACN,SAAS,EACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,WAAW,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACtF,OAAO,EAAE,SAAS,IAAI,UAAU,EAAE,OAAO,IAAI,QAAQ,EAAE,GAAG,IAAI,IAAI,EAAE,MAAM,QAAQ,CAAC;AAEnF,OAAO,EAAE,2BAA2B,EAAE,MAAM,wBAAwB,CAAC;AACrE,OAAO,EAAuB,kBAAkB,EAAE,MAAM,gDAAgD,CAAC;AAczG,MAAM,OAAO,iBAAiB;;;;;;IAuC3B,YAAoB,cAA0B,EAC1B,SAAmB,EACnB,GAAsB;QAFtB,mBAAc,GAAd,cAAc,CAAY;QAC1B,cAAS,GAAT,SAAS,CAAU;QACnB,QAAG,GAAH,GAAG,CAAmB;QAvCjC,gBAAW,GAAW,EAAE,CAAC;QACzB,SAAI,GAAW,EAAE,CAAC;QAClB,UAAK,GAAW,EAAE,CAAC;QACnB,YAAO,GAAkB,IAAI,CAAC;QAE9B,aAAQ,GAAuB,SAAS,CAAC;QAEzC,sBAAiB,GAAW,CAAC,CAAC;QAC9B,oBAAe,GAAY,KAAK,CAAC;QACjC,cAAS,GAAY,KAAK,CAAC;QAC3B,qBAAgB,GAAY,KAAK,CAAC;QAElC,sBAAiB,GAAY,WAAW,CAAC;QACzC,iBAAY,GAAY,KAAK,CAAC;QAE7B,WAAM,GAA0B,IAAI,YAAY,EAAW,CAAC;QAC5D,WAAM,GAAsB,IAAI,YAAY,EAAO,CAAC;QACpD,mBAAc,GAAsB,IAAI,YAAY,EAAO,CAAC;QAC5D,WAAM,GAAyB,IAAI,YAAY,EAAU,CAAC;QAO7D,iBAAY,GAAY,KAAK,CAAC;QAC9B,gBAAW,GAAgB,IAAI,WAAW,EAAE,CAAC;QAC7C,qBAAgB,GAAgB,IAAI,WAAW,EAAE,CAAC;QAKjD,sBAAiB,GAAiC,SAAS,CAAC;QAC5D,gBAAW,GAAY,KAAK,CAAC;QAC7B,aAAQ,GAAiD,EAAE,CAAC;IAMpE,CAAC;;;;;;IAGD,WAAW,CAAC,YAAoB;QAC7B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;IACpC,CAAC;;;;;;;;IAKD,IACI,QAAQ,CAAC,KAAc;QACxB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;;;;IAED,IAAI,QAAQ;QACT,OAAO,IAAI,CAAC,WAAW,CAAC;IAC3B,CAAC;;;;;IAED,IACI,OAAO,CAAC,OAAqD;QAC9D,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC;;cAC9B,YAAY,GAAmC,IAAI,CAAC,cAAc,CAAC,UAAU,EAAE,IAAI,CAAC;QAC1F,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,YAAY,EAAE;YACf,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC;SAC/B;IACJ,CAAC;;;;IAED,IAAI,OAAO;QACR,OAAO,IAAI,CAAC,QAAQ,CAAC;IACxB,CAAC;;;;IAED,IAAI,aAAa;QACd,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;IAC1E,CAAC;;;;IAED,IAAI,YAAY;QACb,OAAO,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IAChD,CAAC;;;;IAED,IAAI,QAAQ;;cACH,MAAM,GAAgB,IAAI,CAAC,cAAc,CAAC,aAAa;QAC7D,OAAO,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IAChE,CAAC;;;;IAED,IAAI,OAAO;QACR,OAAO,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;IACnE,CAAC;;;;IAED,IAAI,OAAO;QACR,OAAO,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;IACnE,CAAC;;;;IAED,IAAI,SAAS;QACV,OAAO,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;IACrE,CAAC;;;;IAED,IAAI,SAAS;QACV,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IAC/D,CAAC;;;;IAED,IAAI,QAAQ;QACT,OAAO,IAAI,CAAC,KAAK,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;IACnF,CAAC;;;;IAED,SAAS;QACN,OAAO,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC;IACzI,CAAC;;;;;;;IAMD,QAAQ;QACL,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QACzC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;;;;;IAED,aAAa,CAAC,KAAY;QACvB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;;;;;;IAGD,gBAAgB,CAAC,EAAoB;QAClC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACtB,CAAC;;;;;;IAGD,iBAAiB,CAAC,EAAc;QAC7B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACvB,CAAC;;;;;IAED,gBAAgB,CAAC,QAAiB;QAC/B,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC;QAC5B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;;;;;;IAGD,UAAU,CAAC,QAAa;QACrB,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,KAAK,QAAQ,EAAE;YACrD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;YACvD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;SAC1B;IACJ,CAAC;;;;;;;IAMD,eAAe;QACZ,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC;;cACnD,SAAS,GAAgC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,2BAA2B,EAAE,IAAI,CAAC;QACpG,IAAI,SAAS,EAAE;YACZ,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;SAC1D;IACJ,CAAC;;;;IAED,aAAa;QACV,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;SACrF;IACJ,CAAC;;;;;IAED,gBAAgB,CAAC,KAAoB;QAClC,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;YACzB,IAAI,CAAC,YAAY,EAAE,CAAC;SACtB;IACJ,CAAC;;;;IAED,gBAAgB;QACb,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACxB,CAAC;;;;IAED,iBAAiB;QACd,OAAO,IAAI,CAAC,OAAO,KAAK,SAAS,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,KAAK,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;IACvJ,CAAC;;;;IAED,cAAc;QACX,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC/B,IAAI,IAAI,CAAC,QAAQ,EAAE;YAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SAC9B;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;;;;IAED,cAAc;QACX,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,uBAAuB;IAC/D,CAAC;;;;;IAED,cAAc,CAAC,MAA0B;QACtC,IAAI,CAAC,QAAQ,GAAG,MAAM,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;;cACpE,KAAK,GAAQ,MAAM,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;QAClF,IAAI,IAAI,CAAC,QAAQ,EAAE;YAChB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACvB;QACD,IAAI,IAAI,CAAC,SAAS,EAAE;YACjB,IAAI,CAAC,SAAS,EAAE,CAAC;SACnB;QACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAExB,IAAI,KAAK,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;YACvE,IAAI,CAAC,cAAc,EAAE,CAAC;SACxB;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;;;;IAED,gBAAgB;QACb,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAC9B,CAAC;;;;;;;;;;;IAOO,cAAc,CAAC,QAA8B,EAAE,SAAc;QAClE,IAAI,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAC1C,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI;;;;YAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,SAAS,EAAC,CAAC;SACzF;aAAM,IAAI,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAClD,OAAO,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG;;;;YAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,EAAC,CAAC,CAAC,IAAI;;;;YAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,SAAS,EAAC,CAAC;SAC7H;IACJ,CAAC;;;;;;;IAGO,oBAAoB,CAAC,KAAmD;QAC7E,OAAO,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,mBAAA,KAAK,EAAyB,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;IACzG,CAAC;;;;;;;IAGO,qBAAqB,CAAC,KAAmD;QAC9E,OAAO,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,CAAC,mBAAA,KAAK,EAAyB,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;IACxG,CAAC;;;;;IAEO,YAAY;QACjB,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;QACvC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,uBAAuB;QAC5D,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;;;;;;IAGO,iBAAiB;QACtB,IAAI,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAC1C,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO;;;;YAAC,IAAI,CAAC,EAAE;gBAChC,IAAI,IAAI,CAAC,QAAQ,EAAE;oBAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;iBACvB;YACJ,CAAC,EAAC,CAAC;SACL;aAAM,IAAI,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAClD,IAAI,CAAC,OAAO,CAAC,OAAO;;;;YAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO;;;;YAAC,IAAI,CAAC,EAAE;gBACtD,IAAI,IAAI,CAAC,QAAQ,EAAE;oBAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;iBACvB;YACJ,CAAC,EAAC,EAAC,CAAC;SACN;IACJ,CAAC;;;YAnRH,SAAS,SAAC;gBACR,QAAQ,EAAE,WAAW;gBACrB,s0GAA+B;gBAE/B,IAAI,EAAE;oBACH,OAAO,EAAE,WAAW;iBACtB;gBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,SAAS,EAAE;oBACR,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,UAAU;;;wBAAC,GAAG,EAAE,CAAC,iBAAiB,EAAC,EAAE,KAAK,EAAE,IAAI,EAAE;iBAC/F;;aACH;;;;YA1BE,UAAU;YAIV,QAAQ;YANR,iBAAiB;;;0BA+BhB,KAAK;mBACL,KAAK;oBACL,KAAK;sBACL,KAAK;2BACL,KAAK;uBACL,KAAK;sBACL,KAAK;gCACL,KAAK;8BACL,KAAK;wBACL,KAAK;+BACL,KAAK;gCAEL,KAAK;2BACL,KAAK;qBAEL,MAAM;qBACN,MAAM;6BACN,MAAM;qBACN,MAAM;2BAEN,SAAS,SAAC,OAAO,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;4BAClC,SAAS,SAAC,QAAQ,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;2BAEnC,WAAW,SAAC,wBAAwB;uBA2BpC,KAAK;sBAUL,KAAK;;;;IA5DN,wCAAkC;;IAClC,iCAA2B;;IAC3B,kCAA4B;;IAC5B,oCAAuC;;IACvC,yCAA8B;;IAC9B,qCAAkD;;IAClD,oCAAsB;;IACtB,8CAAuC;;IACvC,4CAA0C;;IAC1C,sCAAoC;;IACpC,6CAA2C;;IAE3C,8CAAkD;;IAClD,yCAAuC;;IAEvC,mCAAsE;;IACtE,mCAA8D;;IAC9D,2CAAsE;;IACtE,mCAAoE;;IAEpE,yCAA8D;;IAC9D,0CAAgE;;IAEhE,yCAEqC;;IACrC,wCAAoD;;IACpD,6CAAyD;;IAEzD,qCAA2B;;IAC3B,sCAAsB;;;;;IAEtB,8CAAoE;;;;;IACpE,wCAAqC;;;;;IACrC,qCAAoE;;;;;IAGxD,2CAAkC;;;;;IAClC,sCAA2B;;;;;IAC3B,gCAA8B","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   AfterViewInit,\n   ChangeDetectionStrategy,\n   ChangeDetectorRef,\n   Component,\n   ElementRef,\n   EventEmitter,\n   forwardRef,\n   HostBinding,\n   Injector,\n   Input,\n   Output,\n   ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { cloneDeep as _cloneDeep, flatten as _flatten, has as _has } from 'lodash';\n\nimport { StCheckValidationsDirective } from './st-check-validations';\nimport { StDropDownMenuGroup, StDropDownMenuItem } from '../st-dropdown-menu/st-dropdown-menu.interface';\n\n@Component({\n   selector: 'st-select',\n   templateUrl: './st-select.html',\n   styleUrls: ['./st-select.scss'],\n   host: {\n      'class': 'st-select'\n   },\n   changeDetection: ChangeDetectionStrategy.OnPush,\n   providers: [\n      { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => StSelectComponent), multi: true }\n   ]\n})\nexport class StSelectComponent implements AfterViewInit, ControlValueAccessor {\n\n   @Input() placeholder: string = '';\n   @Input() name: string = '';\n   @Input() label: string = '';\n   @Input() tooltip: string | null = null;\n   @Input() errorMessage: string;\n   @Input() selected: StDropDownMenuItem = undefined;\n   @Input() default: any;\n   @Input() itemsBeforeScroll: number = 8;\n   @Input() enabledSearcher: boolean = false;\n   @Input() isLoading: boolean = false;\n   @Input() forceValidations: boolean = false;\n\n   @Input() placeholderSearch?: string = 'Search...';\n   @Input() keyBoardMove: boolean = false;\n\n   @Output() expand: EventEmitter<boolean> = new EventEmitter<boolean>();\n   @Output() select: EventEmitter<any> = new EventEmitter<any>();\n   @Output() scrollAtBottom: EventEmitter<any> = new EventEmitter<any>();\n   @Output() search: EventEmitter<string> = new EventEmitter<string>();\n\n   @ViewChild('input', {static: false}) inputElement: ElementRef;\n   @ViewChild('button', {static: false}) buttonElement: ElementRef;\n\n   @HostBinding('class.st-select-opened')\n\n   public expandedMenu: boolean = false;\n   public searchInput: FormControl = new FormControl();\n   public inputFormControl: FormControl = new FormControl();\n\n   onChange: (_: any) => void;\n   onTouched: () => void;\n\n   private _inputHTMLElement: HTMLInputElement | undefined = undefined;\n   private _isDisabled: boolean = false;\n   private _options: StDropDownMenuItem[] | StDropDownMenuGroup[] = [];\n\n\n   constructor(private _selectElement: ElementRef,\n               private _injector: Injector,\n               private _cd: ChangeDetectorRef) {\n   }\n\n   // TODO: MOVE THIS TO FORM-BASE\n   notifyError(errorMessage: string): void {\n      this.errorMessage = errorMessage;\n   }\n\n   /*\n    ****** getters && setters ******\n    */\n   @Input()\n   set disabled(value: boolean) {\n      this._isDisabled = value;\n      this._cd.markForCheck();\n   }\n\n   get disabled(): boolean {\n      return this._isDisabled;\n   }\n\n   @Input()\n   set options(options: StDropDownMenuItem[] | StDropDownMenuGroup[]) {\n      this._options = _cloneDeep(options);\n      const selectedItem: StDropDownMenuItem | undefined = this.findByProperty('selected', true);\n      this.removeAllSelected();\n      if (selectedItem) {\n         this.selected = selectedItem;\n      }\n   }\n\n   get options(): StDropDownMenuItem[] | StDropDownMenuGroup[] {\n      return this._options;\n   }\n\n   get selectedValue(): string {\n      return this.selected && this.selected.label ? this.selected.label : '';\n   }\n\n   get disableValue(): string | null {\n      return this._isDisabled === true ? '' : null;\n   }\n\n   get selectId(): string | null {\n      const select: HTMLElement = this._selectElement.nativeElement;\n      return select.getAttribute('id') !== null ? select.id : null;\n   }\n\n   get inputId(): string | null {\n      return this.selectId !== null ? `${this.selectId}-input` : null;\n   }\n\n   get labelId(): string | null {\n      return this.selectId !== null ? `${this.selectId}-label` : null;\n   }\n\n   get optionsId(): string | null {\n      return this.selectId !== null ? `${this.selectId}-options` : null;\n   }\n\n   get inputName(): string | null {\n      return this.name && this.name.length > 0 ? this.name : null;\n   }\n\n   get hasLabel(): boolean {\n      return this.label !== undefined && this.label !== null && this.label.length > 0;\n   }\n\n   showError(): boolean {\n      return this.errorMessage && this.errorMessage.length && (this.inputFormControl.touched || this.forceValidations) && !this._isDisabled;\n   }\n\n   /*\n    ****** Control value accessor && validate methods ******\n    */\n\n   onSearch(): void {\n      this.search.emit(this.searchInput.value);\n      this._cd.markForCheck();\n   }\n\n   onSearchClick(event: Event): void {\n      event.preventDefault();\n      event.stopPropagation();\n   }\n\n   // Set the function to be called when the control receives a change event.\n   registerOnChange(fn: (_: any) => void): void {\n      this.onChange = fn;\n   }\n\n   // Set the function to be called when the control receives a touch event.\n   registerOnTouched(fn: () => void): void {\n      this.onTouched = fn;\n   }\n\n   setDisabledState(disabled: boolean): void {\n      this._isDisabled = disabled;\n      this._cd.markForCheck();\n   }\n\n   // Write a new value to the element.\n   writeValue(newValue: any): void {\n      if (!this.selected || this.selected.value !== newValue) {\n         this.selected = this.findByProperty('value', newValue);\n         this._cd.markForCheck();\n      }\n   }\n\n   /*\n    ****** Component methods ******\n    */\n\n   ngAfterViewInit(): void {\n      this._inputHTMLElement = this.inputElement.nativeElement;\n      const directive: StCheckValidationsDirective = this._injector.get(StCheckValidationsDirective, null);\n      if (directive) {\n         directive.registerOnChange(this.notifyError.bind(this));\n      }\n   }\n\n   onButtonClick(): void {\n      if (!this._isDisabled) {\n         this.toggleButton();\n         this.expandedMenu ? this._inputHTMLElement.focus() : this._inputHTMLElement.blur();\n      }\n   }\n\n   onButtonKeyPress(event: KeyboardEvent): void {\n      if (event.code === 'Enter') {\n         this.toggleButton();\n      }\n   }\n\n   clearSearchInput(): void {\n      this.searchInput.setValue('');\n      this.search.emit('');\n   }\n\n   createResetButton(): boolean {\n      return this.default !== undefined && ((!this.selected && this.inputFormControl.touched) || (this.selected && this.selected.value !== this.default));\n   }\n\n   resetToDefault(): void {\n      this.writeValue(this.default);\n      this.select.emit(this.default);\n      if (this.onChange) {\n         this.onChange(this.default);\n      }\n      this._cd.markForCheck();\n   }\n\n   onClickOutside(): void {\n      this.expandedMenu = false;\n      this.expand.emit(this.expandedMenu); // Notify expand change\n   }\n\n   onChangeOption(option: StDropDownMenuItem): void {\n      this.selected = option && option.value !== undefined ? option : undefined;\n      const value: any = option && option.value !== undefined ? option.value : undefined;\n      if (this.onChange) {\n         this.onChange(value);\n      }\n      if (this.onTouched) {\n         this.onTouched();\n      }\n      this.select.emit(value);\n\n      if (value || (option && option.hasOwnProperty('value') && !option.value)) {\n         this.onClickOutside();\n      }\n      this._cd.markForCheck();\n   }\n\n   onScrollAtBottom(): void {\n      this.scrollAtBottom.emit();\n   }\n\n   /*\n    ****** Util component methods ******\n    */\n\n   // Search element by property in option list\n   private findByProperty(propName: 'value' | 'selected', propValue: any): StDropDownMenuItem | undefined {\n      if (this.isStDropdownItemList(this.options)) {\n         return this.options.find(item => _has(item, propName) && item[propName] === propValue);\n      } else if (this.isStDropdownGroupList(this.options)) {\n         return _flatten(this.options.map(group => group.items)).find(item => _has(item, propName) && item[propName] === propValue);\n      }\n   }\n\n   // Check if options are a instance of StDropDownMenuItem[]\n   private isStDropdownItemList(items: StDropDownMenuItem[] | StDropDownMenuGroup[]): items is StDropDownMenuItem[] {\n      return this.options && this.options.length > 0 && !_has((items as StDropDownMenuGroup[])[0], 'items');\n   }\n\n   // Check if options are a instance of StDropDownMenuGroup[]\n   private isStDropdownGroupList(items: StDropDownMenuItem[] | StDropDownMenuGroup[]): items is StDropDownMenuGroup[] {\n      return this.options && this.options.length > 0 && _has((items as StDropDownMenuGroup[])[0], 'items');\n   }\n\n   private toggleButton(): void {\n      this.expandedMenu = !this.expandedMenu;\n      this.expand.emit(this.expandedMenu); // Notify expand change\n      this._cd.markForCheck();\n   }\n\n   // TODO: Remove when remove from StDropDownMenuItem model the selected property\n   private removeAllSelected(): void {\n      if (this.isStDropdownItemList(this.options)) {\n         return this.options.forEach(item => {\n            if (item.selected) {\n               delete item.selected;\n            }\n         });\n      } else if (this.isStDropdownGroupList(this.options)) {\n         this.options.forEach(group => group.items.forEach(item => {\n            if (item.selected) {\n               delete item.selected;\n            }\n         }));\n      }\n   }\n}\n"]}