@stratio/egeo
Version:
677 lines • 49.4 kB
JavaScript
/**
* @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';
var StSelectComponent = /** @class */ (function () {
function StSelectComponent(_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
// TODO: MOVE THIS TO FORM-BASE
/**
* @param {?} errorMessage
* @return {?}
*/
StSelectComponent.prototype.notifyError =
// TODO: MOVE THIS TO FORM-BASE
/**
* @param {?} errorMessage
* @return {?}
*/
function (errorMessage) {
this.errorMessage = errorMessage;
};
Object.defineProperty(StSelectComponent.prototype, "disabled", {
get: /**
* @return {?}
*/
function () {
return this._isDisabled;
},
/*
****** getters && setters ******
*/
set: /*
****** getters && setters ******
*/
/**
* @param {?} value
* @return {?}
*/
function (value) {
this._isDisabled = value;
this._cd.markForCheck();
},
enumerable: true,
configurable: true
});
Object.defineProperty(StSelectComponent.prototype, "options", {
get: /**
* @return {?}
*/
function () {
return this._options;
},
set: /**
* @param {?} options
* @return {?}
*/
function (options) {
this._options = _cloneDeep(options);
/** @type {?} */
var selectedItem = this.findByProperty('selected', true);
this.removeAllSelected();
if (selectedItem) {
this.selected = selectedItem;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(StSelectComponent.prototype, "selectedValue", {
get: /**
* @return {?}
*/
function () {
return this.selected && this.selected.label ? this.selected.label : '';
},
enumerable: true,
configurable: true
});
Object.defineProperty(StSelectComponent.prototype, "disableValue", {
get: /**
* @return {?}
*/
function () {
return this._isDisabled === true ? '' : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StSelectComponent.prototype, "selectId", {
get: /**
* @return {?}
*/
function () {
/** @type {?} */
var select = this._selectElement.nativeElement;
return select.getAttribute('id') !== null ? select.id : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StSelectComponent.prototype, "inputId", {
get: /**
* @return {?}
*/
function () {
return this.selectId !== null ? this.selectId + "-input" : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StSelectComponent.prototype, "labelId", {
get: /**
* @return {?}
*/
function () {
return this.selectId !== null ? this.selectId + "-label" : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StSelectComponent.prototype, "optionsId", {
get: /**
* @return {?}
*/
function () {
return this.selectId !== null ? this.selectId + "-options" : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StSelectComponent.prototype, "inputName", {
get: /**
* @return {?}
*/
function () {
return this.name && this.name.length > 0 ? this.name : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StSelectComponent.prototype, "hasLabel", {
get: /**
* @return {?}
*/
function () {
return this.label !== undefined && this.label !== null && this.label.length > 0;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
StSelectComponent.prototype.showError = /**
* @return {?}
*/
function () {
return this.errorMessage && this.errorMessage.length && (this.inputFormControl.touched || this.forceValidations) && !this._isDisabled;
};
/*
****** Control value accessor && validate methods ******
*/
/*
****** Control value accessor && validate methods ******
*/
/**
* @return {?}
*/
StSelectComponent.prototype.onSearch = /*
****** Control value accessor && validate methods ******
*/
/**
* @return {?}
*/
function () {
this.search.emit(this.searchInput.value);
this._cd.markForCheck();
};
/**
* @param {?} event
* @return {?}
*/
StSelectComponent.prototype.onSearchClick = /**
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
event.stopPropagation();
};
// Set the function to be called when the control receives a change event.
// Set the function to be called when the control receives a change event.
/**
* @param {?} fn
* @return {?}
*/
StSelectComponent.prototype.registerOnChange =
// Set the function to be called when the control receives a change event.
/**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChange = fn;
};
// Set the function to be called when the control receives a touch event.
// Set the function to be called when the control receives a touch event.
/**
* @param {?} fn
* @return {?}
*/
StSelectComponent.prototype.registerOnTouched =
// Set the function to be called when the control receives a touch event.
/**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
/**
* @param {?} disabled
* @return {?}
*/
StSelectComponent.prototype.setDisabledState = /**
* @param {?} disabled
* @return {?}
*/
function (disabled) {
this._isDisabled = disabled;
this._cd.markForCheck();
};
// Write a new value to the element.
// Write a new value to the element.
/**
* @param {?} newValue
* @return {?}
*/
StSelectComponent.prototype.writeValue =
// Write a new value to the element.
/**
* @param {?} newValue
* @return {?}
*/
function (newValue) {
if (!this.selected || this.selected.value !== newValue) {
this.selected = this.findByProperty('value', newValue);
this._cd.markForCheck();
}
};
/*
****** Component methods ******
*/
/*
****** Component methods ******
*/
/**
* @return {?}
*/
StSelectComponent.prototype.ngAfterViewInit = /*
****** Component methods ******
*/
/**
* @return {?}
*/
function () {
this._inputHTMLElement = this.inputElement.nativeElement;
/** @type {?} */
var directive = this._injector.get(StCheckValidationsDirective, null);
if (directive) {
directive.registerOnChange(this.notifyError.bind(this));
}
};
/**
* @return {?}
*/
StSelectComponent.prototype.onButtonClick = /**
* @return {?}
*/
function () {
if (!this._isDisabled) {
this.toggleButton();
this.expandedMenu ? this._inputHTMLElement.focus() : this._inputHTMLElement.blur();
}
};
/**
* @param {?} event
* @return {?}
*/
StSelectComponent.prototype.onButtonKeyPress = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (event.code === 'Enter') {
this.toggleButton();
}
};
/**
* @return {?}
*/
StSelectComponent.prototype.clearSearchInput = /**
* @return {?}
*/
function () {
this.searchInput.setValue('');
this.search.emit('');
};
/**
* @return {?}
*/
StSelectComponent.prototype.createResetButton = /**
* @return {?}
*/
function () {
return this.default !== undefined && ((!this.selected && this.inputFormControl.touched) || (this.selected && this.selected.value !== this.default));
};
/**
* @return {?}
*/
StSelectComponent.prototype.resetToDefault = /**
* @return {?}
*/
function () {
this.writeValue(this.default);
this.select.emit(this.default);
if (this.onChange) {
this.onChange(this.default);
}
this._cd.markForCheck();
};
/**
* @return {?}
*/
StSelectComponent.prototype.onClickOutside = /**
* @return {?}
*/
function () {
this.expandedMenu = false;
this.expand.emit(this.expandedMenu); // Notify expand change
};
/**
* @param {?} option
* @return {?}
*/
StSelectComponent.prototype.onChangeOption = /**
* @param {?} option
* @return {?}
*/
function (option) {
this.selected = option && option.value !== undefined ? option : undefined;
/** @type {?} */
var 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 {?}
*/
StSelectComponent.prototype.onScrollAtBottom = /**
* @return {?}
*/
function () {
this.scrollAtBottom.emit();
};
/*
****** Util component methods ******
*/
// Search element by property in option list
/*
****** Util component methods ******
*/
// Search element by property in option list
/**
* @private
* @param {?} propName
* @param {?} propValue
* @return {?}
*/
StSelectComponent.prototype.findByProperty = /*
****** Util component methods ******
*/
// Search element by property in option list
/**
* @private
* @param {?} propName
* @param {?} propValue
* @return {?}
*/
function (propName, propValue) {
if (this.isStDropdownItemList(this.options)) {
return this.options.find((/**
* @param {?} item
* @return {?}
*/
function (item) { return _has(item, propName) && item[propName] === propValue; }));
}
else if (this.isStDropdownGroupList(this.options)) {
return _flatten(this.options.map((/**
* @param {?} group
* @return {?}
*/
function (group) { return group.items; }))).find((/**
* @param {?} item
* @return {?}
*/
function (item) { return _has(item, propName) && item[propName] === propValue; }));
}
};
// Check if options are a instance of StDropDownMenuItem[]
// Check if options are a instance of StDropDownMenuItem[]
/**
* @private
* @param {?} items
* @return {?}
*/
StSelectComponent.prototype.isStDropdownItemList =
// Check if options are a instance of StDropDownMenuItem[]
/**
* @private
* @param {?} items
* @return {?}
*/
function (items) {
return this.options && this.options.length > 0 && !_has(((/** @type {?} */ (items)))[0], 'items');
};
// Check if options are a instance of StDropDownMenuGroup[]
// Check if options are a instance of StDropDownMenuGroup[]
/**
* @private
* @param {?} items
* @return {?}
*/
StSelectComponent.prototype.isStDropdownGroupList =
// Check if options are a instance of StDropDownMenuGroup[]
/**
* @private
* @param {?} items
* @return {?}
*/
function (items) {
return this.options && this.options.length > 0 && _has(((/** @type {?} */ (items)))[0], 'items');
};
/**
* @private
* @return {?}
*/
StSelectComponent.prototype.toggleButton = /**
* @private
* @return {?}
*/
function () {
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
// TODO: Remove when remove from StDropDownMenuItem model the selected property
/**
* @private
* @return {?}
*/
StSelectComponent.prototype.removeAllSelected =
// TODO: Remove when remove from StDropDownMenuItem model the selected property
/**
* @private
* @return {?}
*/
function () {
if (this.isStDropdownItemList(this.options)) {
return this.options.forEach((/**
* @param {?} item
* @return {?}
*/
function (item) {
if (item.selected) {
delete item.selected;
}
}));
}
else if (this.isStDropdownGroupList(this.options)) {
this.options.forEach((/**
* @param {?} group
* @return {?}
*/
function (group) { return group.items.forEach((/**
* @param {?} item
* @return {?}
*/
function (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 {?}
*/
function () { 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 = function () { return [
{ 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 }]
};
return StSelectComponent;
}());
export { StSelectComponent };
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":"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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   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"]}