ngx-selectbox-may
Version:
Angular selectbox with autocomplete
447 lines • 39.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, ElementRef, ViewChild, ViewChildren, QueryList, forwardRef, Output, EventEmitter, ContentChild, TemplateRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { NgxSelectboxMayService } from './ngx-selectbox-may.service';
import { NGXSelectMayConfigs } from './ngx-selectbox-may-configs';
export class NgxSelectboxMayComponent {
/**
* @param {?} _selectboxref
* @param {?} selectboxService
*/
constructor(_selectboxref, selectboxService) {
this._selectboxref = _selectboxref;
this.selectboxService = selectboxService;
this.dropdownRows = [];
this.configs = new NGXSelectMayConfigs();
this.selectedRows = [];
this.show_items = false;
this.searchText = "";
this.isEnable = true;
this.propagateChange = (_) => { };
this.propagateOnTouch = (_) => { };
this.onKeyUp = new EventEmitter();
this.onSelect = new EventEmitter();
this.onBlur = new EventEmitter();
}
/**
* @param {?} items
* @return {?}
*/
set items(items) {
this.createDropdownRows(items);
}
/**
* @param {?} cssClass
* @return {?}
*/
set cssClass(cssClass) {
this.configs.cssClass = cssClass;
}
/**
* @param {?} valueField
* @return {?}
*/
set valueField(valueField) {
this.configs.valueField = valueField;
}
/**
* @param {?} labelField
* @return {?}
*/
set labelField(labelField) {
this.configs.labelField = labelField;
this.reconfigureLabelsAndValues();
}
/**
* @param {?} placeholder
* @return {?}
*/
set placeholder(placeholder) {
this.configs.placeholderText = placeholder;
}
/**
* @param {?} emptyText
* @return {?}
*/
set emptyText(emptyText) {
this.configs.emptyText = emptyText;
}
/**
* @param {?} showEmptyText
* @return {?}
*/
set showEmptyResultText(showEmptyText) {
this.configs.showEmptyResultsLabel = showEmptyText;
}
/**
* @param {?} isMulti
* @return {?}
*/
set isMulti(isMulti) {
this.configs.isMultiSelect = isMulti;
}
/**
* @param {?} isLoading
* @return {?}
*/
set isLoading(isLoading) {
this._isLoading = isLoading;
}
/**
* @param {?} loadingText
* @return {?}
*/
set loadingText(loadingText) {
this._loadingText = loadingText;
}
/**
* @return {?}
*/
ngOnInit() {
}
/**
* @param {?} items
* @return {?}
*/
createDropdownRows(items) {
this.dropdownRows = this.selectboxService.createDropdownRows(items, this.configs);
this.setValuesPassedExternal(this.ngModelValue);
}
/**
* @return {?}
*/
reconfigureLabelsAndValues() {
this.selectboxService.reconfigureDropdownRowLabelsAndValues(this.dropdownRows, this.configs);
}
/**
* @return {?}
*/
getSelectboxLabel() {
/** @type {?} */
let label = this.selectboxService.createDropdownLabel(this.configs, this.selectedRows);
return label ? label : this.configs.placeholderText;
}
/**
* @return {?}
*/
getEmptyTextLabel() {
return this.configs.emptyText ? this.configs.emptyText : NGXSelectMayConfigs.EMPTY_TEXT;
}
/**
* @return {?}
*/
getLoadingText() {
return this._loadingText ? this._loadingText : NGXSelectMayConfigs.LOADING_TEXT;
}
/**
* @return {?}
*/
onClickSelectBox() {
this.showItemsWindow();
}
/**
* @return {?}
*/
getActiveClass() {
return NGXSelectMayConfigs.ROW_ACTIVE_CLASS;
}
/**
* @return {?}
*/
showItemsWindow() {
this.show_items = true;
}
/**
* @return {?}
*/
hideItemsWindow() {
this.onBlur.emit(this.searchText);
this.resetFilters();
this.show_items = false;
}
/**
* @return {?}
*/
onRemoveClick() {
this.selectboxService.unselectAllSelectedRows(this.dropdownRows);
this.selectedRows = [];
this.publishValue();
}
/**
* @param {?} e
* @return {?}
*/
onSearchKeydown(e) {
if (e.key == "Escape") {
this.hideItemsWindow();
}
//Up and Down arrow events
if (e.keyCode == 38 || e.keyCode == 40) {
e.preventDefault();
}
}
/**
* @param {?} e
* @return {?}
*/
onSearchKeyup(e) {
if (e.keyCode == 38 || e.keyCode == 40 || e.key == "Escape") {
e.preventDefault();
}
else {
this.onKeyUp.emit(this.searchText);
}
}
/**
* @return {?}
*/
resetFilters() {
this.searchText = "";
}
/**
* @param {?} row
* @param {?} index
* @return {?}
*/
onClickItem(row, index) {
if (this.configs.isMultiSelect) {
}
else {
this.selectedRows = this.selectboxService.setSelectedItems(this.configs, this.selectedRows, this.dropdownRows, row);
this.onSelect.emit(row.data);
this.hideItemsWindow();
}
this.publishValue();
}
/**
* @return {?}
*/
publishValue() {
/** @type {?} */
let values = this.selectedRows.map(r => r.value);
if (this.configs.isMultiSelect) {
this.propagateChange(values);
}
else {
this.propagateChange(values.length > 0 ? values[0] : "");
}
}
/**
* @param {?} obj
* @return {?}
*/
setValuesPassedExternal(obj) {
if (this.configs.isMultiSelect) {
this.selectedRows = this.selectboxService.selectItemsByValue(this.dropdownRows, obj);
}
else {
this.selectedRows = this.selectboxService.selectItemByValue(this.dropdownRows, obj);
}
}
/*
*
* On Item browse open window begin & document outside click event Begins
*
*/
/**
* @param {?} content
* @return {?}
*/
set content(content) {
this.itemWindow = content;
// this.positionWindow();
this.focusToSearchField();
this.scrollToSelectedItem();
}
/**
* @return {?}
*/
positionWindow() {
if (this.searchField) {
/** @type {?} */
const selectBoxRef = this._selectboxref.nativeElement;
/** @type {?} */
var viewportOffset = selectBoxRef.getBoundingClientRect();
console.log(viewportOffset);
this.itemWindow.nativeElement.setAttribute('style', 'width: ' + (selectBoxRef.firstChild.offsetWidth + 3) + 'px; top: ' + (viewportOffset.top - 5) + 'px; margin-left: -12px;');
}
}
/**
* @return {?}
*/
focusToSearchField() {
if (this.searchField) {
this.searchField.nativeElement.focus();
}
}
/**
* @return {?}
*/
scrollToSelectedItem() {
this.listItems.forEach(li => {
if (li.nativeElement.classList.contains(NGXSelectMayConfigs.ROW_ACTIVE_CLASS)) {
/** @type {?} */
const scrollLi = li.nativeElement;
this.itemWindow.nativeElement.getElementsByTagName("ul")[0].scrollTop = scrollLi.offsetTop - (scrollLi.offsetHeight + 20);
}
});
}
/**
* @param {?} e
* @return {?}
*/
onClickOutside(e) {
if (!this._selectboxref.nativeElement.contains(event.target) && this.show_items) {
this.hideItemsWindow();
}
}
/**
* @param {?} e
* @return {?}
*/
onWindowResize(e) {
// this.positionWindow();
}
/**
* @return {?}
*/
setDisable() {
this.hideItemsWindow();
this.isEnable = false;
}
/**
* @return {?}
*/
setEnable() {
this.isEnable = true;
}
/**
* @param {?} obj
* @return {?}
*/
writeValue(obj) {
this.ngModelValue = obj;
this.setValuesPassedExternal(obj);
}
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.propagateChange = fn;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this.propagateOnTouch = fn;
}
/**
* @param {?} isDisabled
* @return {?}
*/
setDisabledState(isDisabled) {
console.log(isDisabled, "set disable");
if (isDisabled) {
this.setDisable();
}
else {
this.setEnable();
}
}
}
NgxSelectboxMayComponent.decorators = [
{ type: Component, args: [{
selector: 'ngx-selectbox-may',
host: {
'(document:click)': 'onClickOutside($event)',
'(window:resize)': 'onWindowResize($event)'
},
template: "<div [ngClass]=\"configs.cssClass\" class=\"__ngx-selectbox-may\">\n <span class=\"__selected-label\">\n <span>{{getSelectboxLabel()}}</span>\n </span>\n <div *ngIf=\"_isLoading\" class=\"__loading-text\">{{getLoadingText()}}</div>\n <div class=\"__clickable-area\" (click)=\"onClickSelectBox()\"></div>\n <button *ngIf=\"selectedRows.length>0 && isEnable\" type=\"button\" class=\"__remove-selected-btn\" (click)=\"onRemoveClick()\">\n <i></i>\n </button>\n <div *ngIf=\"show_items\" class=\"__item-list-browser\" #item_window>\n <div class=\"__item-search\">\n <input #search_field type=\"text\" max-length=\"15\" (keydown)=\"onSearchKeydown($event)\"\n (keyup)=\"onSearchKeyup($event)\" placeholder=\"search\" [(ngModel)]=\"searchText\" />\n </div>\n <ng-container *ngTemplateOutlet=\"actionTemplate\"></ng-container>\n <ul class=\"__ngx-selectbox-ul\">\n <ng-container *ngFor=\"let item of dropdownRows | ngx_item_filter:searchText; let i = index; let l = count\">\n <li #li_item *ngIf=\"l>0\" (click)=\"onClickItem(item, i)\" [ngClass]=\"item.isSelected ? getActiveClass() : ''\">\n {{item.label}}\n </li>\n </ng-container>\n <li class=\"__empty-items\"\n *ngIf=\"(dropdownRows | ngx_item_filter:searchText).length === 0 && configs.showEmptyResultsLabel\">\n {{getEmptyTextLabel()}}\n </li>\n </ul>\n </div>\n <div *ngIf=\"!isEnable\" class=\"__disabled-mask\"></div>\n</div>",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => NgxSelectboxMayComponent),
multi: true,
}
],
styles: [".__ngx-selectbox-may{position:relative;min-width:200px;padding:3px 40px 3px 10px;display:flex;align-items:center;cursor:pointer;background-color:#fff}.__ngx-selectbox-may .__disabled-mask{position:absolute;background-color:rgba(0,0,0,.15);top:0;left:0;right:0;bottom:0}.__ngx-selectbox-may::before{content:\"\\f107\";position:absolute;font-family:FontAwesome;color:#3f495b;right:10px;top:0;bottom:0;display:flex;align-items:center;font-size:14px}.__ngx-selectbox-may .__selected-label{position:relative;display:block;width:100%;text-align:left;height:19px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.__ngx-selectbox-may .__remove-selected-btn{background-color:transparent;border:0;outline:0;cursor:pointer;position:absolute;right:20px;top:0;bottom:0;display:flex;align-items:center}.__ngx-selectbox-may .__clickable-area{position:absolute;top:0;left:0;right:0;bottom:0}.__ngx-selectbox-may .__remove-selected-btn i::before{content:\"\\f00d\";font-family:FontAwesome;font-style:normal!important;-webkit-text-stroke:.5px #f1f4f8}.__ngx-selectbox-may .__selected-label .__remove-selected-btn::before{content:\"\\f00c\";position:absolute;font-family:FontAwesome;right:12px;font-size:12px;top:0;bottom:0;display:flex;align-items:center;-webkit-text-stroke:.5px #f1f4f8}.__ngx-selectbox-may .__item-list-browser{position:absolute;background-color:#fff;border-radius:4px;border:1px solid #dfe3e9;box-shadow:0 3px 18px -6px rgba(0,0,0,.5);z-index:1;top:-2px;left:-2px;right:-2px}.__ngx-selectbox-may .__item-list-browser ul{max-height:200px;overflow-y:auto;padding:0;margin:0;border-top:1px solid #dfe3e9}.__ngx-selectbox-may .__item-list-browser ul li{color:#777;font-size:13px;text-align:left;padding:9px 24px 9px 12px;border-bottom:1px solid #dfe3e9;cursor:pointer;line-height:17px}.__ngx-selectbox-may .__item-list-browser ul li.selected,.__ngx-selectbox-may .__item-list-browser ul li:hover{background-color:#f1f4f8;color:#2ea2f8}.__ngx-selectbox-may .__item-list-browser ul li.active{background-color:#f1f4f8;color:#2ea2f8;position:relative}.__ngx-selectbox-may .__item-list-browser ul li.active::before{content:\"\\f00c\";position:absolute;font-family:FontAwesome;right:12px;font-size:12px;-webkit-text-stroke:.5px #f1f4f8;top:0;bottom:0;display:flex;align-items:center}.__ngx-selectbox-may .__item-list-browser ul li.__empty-items{color:#ff7f74;background-color:#fff4f4;cursor:auto}.__ngx-selectbox-may .__item-list-browser ul li:last-child{border-bottom:none}.__ngx-selectbox-may .__item-list-browser .__item-search{padding:5px;display:flex;position:relative}.__ngx-selectbox-may .__item-list-browser .__item-search::before{content:\"\\f002\";position:absolute;font-family:FontAwesome;right:16px;-webkit-text-stroke:.5px #fff;color:#ced0da;top:0;bottom:0;display:flex;align-items:center}.__ngx-selectbox-may .__item-list-browser .__item-search input[type=text]{width:100%;border:1px solid #dfe3e9;border-radius:4px;padding:8px 30px 8px 10px;outline:0}.__ngx-selectbox-may .__item-list-browser .__item-search input[type=text]:focus{border:1px solid #2ea2f8;box-shadow:0 0 0 3px #2ea2f84d}.__ngx-selectbox-may .__item-list-browser ul::-webkit-scrollbar{width:11px;height:18px}.__ngx-selectbox-may .__item-list-browser ul::-webkit-scrollbar-thumb{height:6px;border:3px solid transparent;background-clip:padding-box;-webkit-border-radius:7px;background-color:rgba(0,0,0,.15);-webkit-box-shadow:inset -1px -1px 0 rgba(0,0,0,.05) inset 1px 1px 0 rgba(0,0,0,.05)}.__ngx-selectbox-may .__item-list-browser ul::-webkit-scrollbar-button{width:0;height:0;display:none}.__ngx-selectbox-may .__item-list-browser ul::-webkit-scrollbar-corner{background-color:transparent}.__ngx-selectbox-may .__loading-text{position:absolute;background-color:#e5e5e5;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;padding-left:10px;border-radius:4px;z-index:2}"]
}] }
];
/** @nocollapse */
NgxSelectboxMayComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: NgxSelectboxMayService }
];
NgxSelectboxMayComponent.propDecorators = {
items: [{ type: Input, args: ["items",] }],
cssClass: [{ type: Input, args: ["css-class",] }],
valueField: [{ type: Input, args: ["value-field",] }],
labelField: [{ type: Input, args: ["label-field",] }],
placeholder: [{ type: Input, args: ["placeholder",] }],
emptyText: [{ type: Input, args: ["empty-text",] }],
showEmptyResultText: [{ type: Input, args: ["show-empty-text",] }],
isMulti: [{ type: Input, args: ["is-multi",] }],
isLoading: [{ type: Input, args: ["is-loading",] }],
loadingText: [{ type: Input, args: ["loading-text",] }],
onKeyUp: [{ type: Output, args: ["search-keyup",] }],
onSelect: [{ type: Output, args: ["on-select-item",] }],
onBlur: [{ type: Output, args: ["on-blur",] }],
searchField: [{ type: ViewChild, args: ['search_field',] }],
listItems: [{ type: ViewChildren, args: ["li_item",] }],
actionTemplate: [{ type: ContentChild, args: ['actionTemplate',] }],
content: [{ type: ViewChild, args: ['item_window',] }]
};
if (false) {
/** @type {?} */
NgxSelectboxMayComponent.prototype.dropdownRows;
/** @type {?} */
NgxSelectboxMayComponent.prototype.configs;
/** @type {?} */
NgxSelectboxMayComponent.prototype.selectedRows;
/** @type {?} */
NgxSelectboxMayComponent.prototype.show_items;
/** @type {?} */
NgxSelectboxMayComponent.prototype.searchText;
/** @type {?} */
NgxSelectboxMayComponent.prototype.isEnable;
/** @type {?} */
NgxSelectboxMayComponent.prototype.propagateChange;
/** @type {?} */
NgxSelectboxMayComponent.prototype.propagateOnTouch;
/** @type {?} */
NgxSelectboxMayComponent.prototype._isLoading;
/** @type {?} */
NgxSelectboxMayComponent.prototype._loadingText;
/** @type {?} */
NgxSelectboxMayComponent.prototype.onKeyUp;
/** @type {?} */
NgxSelectboxMayComponent.prototype.onSelect;
/** @type {?} */
NgxSelectboxMayComponent.prototype.onBlur;
/** @type {?} */
NgxSelectboxMayComponent.prototype.searchField;
/** @type {?} */
NgxSelectboxMayComponent.prototype.listItems;
/** @type {?} */
NgxSelectboxMayComponent.prototype.itemWindow;
/** @type {?} */
NgxSelectboxMayComponent.prototype.actionTemplate;
/** @type {?} */
NgxSelectboxMayComponent.prototype.ngModelValue;
/**
* @type {?}
* @private
*/
NgxSelectboxMayComponent.prototype._selectboxref;
/**
* @type {?}
* @private
*/
NgxSelectboxMayComponent.prototype.selectboxService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-selectbox-may.component.js","sourceRoot":"ng://ngx-selectbox-may/","sources":["lib/ngx-selectbox-may.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ElementRef, ViewChild, ViewChildren, QueryList, forwardRef, HostListener, Output, EventEmitter, ContentChild, TemplateRef, OnDestroy, NgZone } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NgxSelectboxMayService } from './ngx-selectbox-may.service';\nimport { NGXSelectMayConfigs, NGXSelectMayRow } from './ngx-selectbox-may-configs';\n\n@Component({\n  selector: 'ngx-selectbox-may',\n  host: {\n    '(document:click)': 'onClickOutside($event)',\n    '(window:resize)': 'onWindowResize($event)'\n  },\n  templateUrl: './ngx-selectbox-may.component.html',\n  styleUrls: ['./ngx-selectbox-may.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NgxSelectboxMayComponent),\n      multi: true,\n    }\n  ]\n})\nexport class NgxSelectboxMayComponent implements OnInit, ControlValueAccessor {\n\n  dropdownRows: Array<NGXSelectMayRow> = [];\n  configs: NGXSelectMayConfigs = new NGXSelectMayConfigs();\n  selectedRows: Array<NGXSelectMayRow> = [];\n  show_items: boolean = false;\n  searchText: string = \"\";\n  isEnable:boolean = true;\n  propagateChange = (_: any) => { };\n  propagateOnTouch = (_: any) => { };\n\n  @Input(\"items\")\n  set items(items: any[]) {\n    this.createDropdownRows(items);\n  }\n\n  @Input(\"css-class\")\n  set cssClass(cssClass: string) {\n    this.configs.cssClass = cssClass;\n  }\n\n  @Input(\"value-field\")\n  set valueField(valueField: string) {\n    this.configs.valueField = valueField;\n  }\n\n  @Input(\"label-field\")\n  set labelField(labelField: string) {\n    this.configs.labelField = labelField;\n    this.reconfigureLabelsAndValues();\n  }\n\n  @Input(\"placeholder\")\n  set placeholder(placeholder: string) {\n    this.configs.placeholderText = placeholder;\n  }\n\n  @Input(\"empty-text\")\n  set emptyText(emptyText: string) {\n    this.configs.emptyText = emptyText;\n  }\n\n  @Input(\"show-empty-text\")\n  set showEmptyResultText(showEmptyText: boolean) {\n    this.configs.showEmptyResultsLabel = showEmptyText;\n  }\n\n  @Input(\"is-multi\")\n  set isMulti(isMulti: boolean) {\n    this.configs.isMultiSelect = isMulti;\n  }\n\n  _isLoading: boolean;\n  @Input(\"is-loading\")\n  set isLoading(isLoading: boolean) {\n    this._isLoading = isLoading;\n  }\n\n  _loadingText: string;\n  @Input(\"loading-text\")\n  set loadingText(loadingText: string) {\n    this._loadingText = loadingText;\n  }\n\n  @Output(\"search-keyup\") onKeyUp = new EventEmitter();\n  @Output(\"on-select-item\") onSelect = new EventEmitter();\n  @Output(\"on-blur\") onBlur = new EventEmitter();\n\n  @ViewChild('search_field') searchField: ElementRef;\n  @ViewChildren(\"li_item\") listItems: QueryList<ElementRef>;\n  itemWindow: ElementRef;\n\n  @ContentChild('actionTemplate') actionTemplate: TemplateRef<ElementRef>;\n  constructor(private _selectboxref: ElementRef, private selectboxService: NgxSelectboxMayService) {\n\n  }\n\n  ngOnInit() {\n  }\n\n\n  createDropdownRows(items: any[]) {\n    this.dropdownRows = this.selectboxService.createDropdownRows(items, this.configs);\n    this.setValuesPassedExternal(this.ngModelValue);\n  }\n\n  reconfigureLabelsAndValues() {\n    this.selectboxService.reconfigureDropdownRowLabelsAndValues(this.dropdownRows, this.configs);\n  }\n\n  getSelectboxLabel() {\n    let label = this.selectboxService.createDropdownLabel(this.configs, this.selectedRows);\n    return label ? label : this.configs.placeholderText;\n  }\n\n  getEmptyTextLabel() {\n    return this.configs.emptyText ? this.configs.emptyText : NGXSelectMayConfigs.EMPTY_TEXT;\n  }\n\n  getLoadingText() {\n    return this._loadingText ? this._loadingText : NGXSelectMayConfigs.LOADING_TEXT;\n  }\n\n  onClickSelectBox() {\n    this.showItemsWindow();\n  }\n\n  getActiveClass() {\n    return NGXSelectMayConfigs.ROW_ACTIVE_CLASS;\n  }\n\n  showItemsWindow() {\n    this.show_items = true;\n  }\n\n  hideItemsWindow() {\n    this.onBlur.emit(this.searchText);\n    this.resetFilters();\n    this.show_items = false;\n  }\n\n  onRemoveClick() {\n    this.selectboxService.unselectAllSelectedRows(this.dropdownRows);\n    this.selectedRows = [];\n    this.publishValue();\n  }\n\n  onSearchKeydown(e) {\n    if (e.key == \"Escape\") {\n      this.hideItemsWindow();\n    }\n    //Up and Down arrow events\n    if (e.keyCode == 38 || e.keyCode == 40) {\n      e.preventDefault();\n    }\n  }\n\n  onSearchKeyup(e) {\n    if (e.keyCode == 38 || e.keyCode == 40 || e.key == \"Escape\") {\n      e.preventDefault();\n    }\n    else {\n      this.onKeyUp.emit(this.searchText);\n    }\n  }\n\n  resetFilters() {\n    this.searchText = \"\";\n  }\n\n  onClickItem(row: NGXSelectMayRow, index: number) {\n    if (this.configs.isMultiSelect) {\n\n    } else {\n      this.selectedRows = this.selectboxService.setSelectedItems(this.configs, this.selectedRows, this.dropdownRows, row);\n      this.onSelect.emit(row.data);\n      this.hideItemsWindow();\n    }\n    this.publishValue();\n  }\n\n  publishValue() {\n    let values = this.selectedRows.map(r => r.value);\n    if (this.configs.isMultiSelect) {\n      this.propagateChange(values);\n    } else {\n      this.propagateChange(values.length > 0 ? values[0] : \"\");\n    }\n  }\n\n  setValuesPassedExternal(obj: any) {\n    if (this.configs.isMultiSelect) {\n      this.selectedRows = this.selectboxService.selectItemsByValue(this.dropdownRows, obj);\n    } else {\n      this.selectedRows = this.selectboxService.selectItemByValue(this.dropdownRows, obj);\n    }\n  }\n\n  /*\n  *\n  * On Item browse open window begin & document outside click event Begins\n  * \n  */\n\n  @ViewChild('item_window') set content(content: ElementRef) {\n    this.itemWindow = content;\n    // this.positionWindow();\n    this.focusToSearchField();\n    this.scrollToSelectedItem();\n  }\n\n  positionWindow() {\n    if (this.searchField) {\n      const selectBoxRef = this._selectboxref.nativeElement;\n      var viewportOffset = selectBoxRef.getBoundingClientRect();\n      console.log(viewportOffset);\n      this.itemWindow.nativeElement.setAttribute('style', 'width: ' + (selectBoxRef.firstChild.offsetWidth + 3) + 'px; top: ' + (viewportOffset.top - 5) + 'px; margin-left: -12px;');\n    }\n  }\n\n  focusToSearchField() {\n    if (this.searchField) {\n      this.searchField.nativeElement.focus();\n    }\n  }\n\n  scrollToSelectedItem() {\n    this.listItems.forEach(li => {\n      if (li.nativeElement.classList.contains(NGXSelectMayConfigs.ROW_ACTIVE_CLASS)) {\n        const scrollLi = li.nativeElement;\n        this.itemWindow.nativeElement.getElementsByTagName(\"ul\")[0].scrollTop = scrollLi.offsetTop - (scrollLi.offsetHeight + 20);\n      }\n    });\n  }\n\n  onClickOutside(e) {\n    if (!this._selectboxref.nativeElement.contains(event.target) && this.show_items) {\n      this.hideItemsWindow();\n    }\n  }\n\n  onWindowResize(e) {\n    // this.positionWindow();\n  }\n\n  setDisable(){\n    this.hideItemsWindow();\n    this.isEnable = false;\n  }\n\n  setEnable(){\n    this.isEnable = true;\n  }\n\n  /*\n  *\n  * On Item browse open window begin & document outside click event Ends\n  * \n  */\n\n\n\n  /*\n  //on document key up and down\n\n  @HostListener('document:keydown', ['$event']) onKeydownHandler(event: KeyboardEvent) {\n    if((event.keyCode == 38 || event.keyCode == 40) && this.itemWindow && this.clonedItems.length > 0){\n        var index = -1;\n        var ul = this.itemWindow.nativeElement.getElementsByTagName(\"ul\")[0]\n        var selectedLi = ul.getElementsByClassName('selected')[0];\n        if(selectedLi){\n          index = Array.prototype.indexOf.call(ul.children, selectedLi);\n          selectedLi.classList.remove(\"selected\");\n        }\n        //up arrow\n        if(event.keyCode == 38){\n          index = ((index - 1) < 0) ? 0 : (index - 1);\n        }\n        //down arrow\n        else{\n          index = ((index + 1) > (ul.children.length -1)) ? (ul.children.length -1) :  (index + 1);\n        }\n        ul.children[index].classList.add(\"selected\");\n        ul.scrollTop = ul.children[index].offsetTop - (ul.children[index].offsetHeight + 20);\n    }\n  }\n*/\n  //Control value accessor begins\n  //Store external value once items got loaded in to dropdown\n  ngModelValue: any;\n  writeValue(obj: any): void {\n    this.ngModelValue = obj;\n    this.setValuesPassedExternal(obj);\n  }\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n  registerOnTouched(fn: any): void {\n    this.propagateOnTouch = fn;\n  }\n  setDisabledState?(isDisabled: boolean): void {\n    console.log(isDisabled, \"set disable\");\n    if(isDisabled){\n      this.setDisable();\n    }else{\n      this.setEnable();\n    }\n  }\n  //Control value accessor ends\n}"]}