UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

249 lines 26.2 kB
import { __decorate, __extends, __metadata, __param, __values } from "tslib"; import { ChangeDetectorRef, Component, ElementRef, Inject, QueryList, OnDestroy, AfterViewInit, ContentChildren, Optional } from '@angular/core'; import { IGX_COMBO_COMPONENT } from './combo.common'; import { IGX_DROPDOWN_BASE } from '../drop-down/drop-down.common'; import { IgxDropDownComponent } from '../drop-down/drop-down.component'; import { DropDownActionKey } from '../drop-down/drop-down.common'; import { IgxComboAddItemComponent } from './combo-add-item.component'; import { IgxComboAPIService } from './combo.api'; import { IgxSelectionAPIService } from '../core/selection'; import { IgxComboItemComponent } from './combo-item.component'; import { DisplayDensityToken } from '../core/density'; /** @hidden */ var IgxComboDropDownComponent = /** @class */ (function (_super) { __extends(IgxComboDropDownComponent, _super); function IgxComboDropDownComponent(elementRef, cdr, selection, combo, comboAPI, _displayDensityOptions) { var _this = _super.call(this, elementRef, cdr, selection, _displayDensityOptions) || this; _this.elementRef = elementRef; _this.cdr = cdr; _this.selection = selection; _this.combo = combo; _this.comboAPI = comboAPI; _this._displayDensityOptions = _displayDensityOptions; /** * @hidden * @internal */ _this.children = null; _this.scrollHandler = function () { _this.comboAPI.disableTransitions = true; }; return _this; } IgxComboDropDownComponent_1 = IgxComboDropDownComponent; Object.defineProperty(IgxComboDropDownComponent.prototype, "scrollContainer", { /** @hidden @internal */ get: function () { return this.virtDir.dc.location.nativeElement; }, enumerable: true, configurable: true }); Object.defineProperty(IgxComboDropDownComponent.prototype, "isScrolledToLast", { get: function () { var scrollTop = this.virtDir.scrollPosition; var scrollHeight = this.virtDir.getScroll().scrollHeight; return Math.floor(scrollTop + this.virtDir.igxForContainerSize) === scrollHeight; }, enumerable: true, configurable: true }); Object.defineProperty(IgxComboDropDownComponent.prototype, "lastVisibleIndex", { get: function () { return this.combo.totalItemCount ? Math.floor(this.combo.itemsMaxHeight / this.combo.itemHeight) : this.items.length - 1; }, enumerable: true, configurable: true }); /** * @hidden @internal */ IgxComboDropDownComponent.prototype.onFocus = function () { this.focusedItem = this._focusedItem || this.items[0]; }; /** * @hidden @internal */ IgxComboDropDownComponent.prototype.onBlur = function (evt) { this.focusedItem = null; }; /** * @hidden @internal */ IgxComboDropDownComponent.prototype.onToggleOpened = function () { this.onOpened.emit(); }; /** * @hidden */ IgxComboDropDownComponent.prototype.navigateFirst = function () { this.navigateItem(this.virtDir.igxForOf.findIndex(function (e) { return !e.isHeader; })); }; /** * @hidden */ IgxComboDropDownComponent.prototype.navigatePrev = function () { if (this._focusedItem && this._focusedItem.index === 0 && this.virtDir.state.startIndex === 0) { this.combo.focusSearchInput(false); } else { _super.prototype.navigatePrev.call(this); } }; /** * @hidden */ IgxComboDropDownComponent.prototype.navigateNext = function () { var lastIndex = this.combo.totalItemCount ? this.combo.totalItemCount - 1 : this.virtDir.igxForOf.length - 1; if (this._focusedItem && this._focusedItem.index === lastIndex) { this.focusAddItemButton(); } else { _super.prototype.navigateNext.call(this); } }; /** * @hidden @internal */ IgxComboDropDownComponent.prototype.selectItem = function (item) { if (item === null || item === undefined) { return; } this.comboAPI.set_selected_item(item.itemID); this._focusedItem = item; }; IgxComboDropDownComponent.prototype.focusAddItemButton = function () { if (this.combo.isAddButtonVisible()) { this.focusedItem = this.items[this.items.length - 1]; } }; IgxComboDropDownComponent.prototype.scrollToHiddenItem = function (newItem) { }; Object.defineProperty(IgxComboDropDownComponent.prototype, "sortedChildren", { get: function () { if (this.children !== undefined) { return this.children.toArray() .sort(function (a, b) { return a.index - b.index; }); } return null; }, enumerable: true, configurable: true }); Object.defineProperty(IgxComboDropDownComponent.prototype, "items", { /** * Get all non-header items * * ```typescript * let myDropDownItems = this.dropdown.items; * ``` */ get: function () { var e_1, _a; var items = []; if (this.children !== undefined) { var sortedChildren = this.sortedChildren; try { for (var sortedChildren_1 = __values(sortedChildren), sortedChildren_1_1 = sortedChildren_1.next(); !sortedChildren_1_1.done; sortedChildren_1_1 = sortedChildren_1.next()) { var child = sortedChildren_1_1.value; if (!child.isHeader) { items.push(child); } } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (sortedChildren_1_1 && !sortedChildren_1_1.done && (_a = sortedChildren_1.return)) _a.call(sortedChildren_1); } finally { if (e_1) throw e_1.error; } } } return items; }, enumerable: true, configurable: true }); /** * @hidden @internal */ IgxComboDropDownComponent.prototype.updateScrollPosition = function () { this.virtDir.getScroll().scrollTop = this._scrollPosition; }; /** * @hidden @internal */ IgxComboDropDownComponent.prototype.onItemActionKey = function (key) { switch (key) { case DropDownActionKey.ENTER: this.handleEnter(); break; case DropDownActionKey.SPACE: this.handleSpace(); break; case DropDownActionKey.ESCAPE: this.close(); } }; IgxComboDropDownComponent.prototype.handleEnter = function () { if (this.isAddItemFocused()) { this.combo.addItemToCollection(); } else { this.close(); } }; IgxComboDropDownComponent.prototype.handleSpace = function () { if (this.isAddItemFocused()) { return; } else { this.selectItem(this.focusedItem); } }; IgxComboDropDownComponent.prototype.isAddItemFocused = function () { return this.focusedItem instanceof IgxComboAddItemComponent; }; IgxComboDropDownComponent.prototype.ngAfterViewInit = function () { this.virtDir.getScroll().addEventListener('scroll', this.scrollHandler); }; /** *@hidden @internal */ IgxComboDropDownComponent.prototype.ngOnDestroy = function () { this.virtDir.getScroll().removeEventListener('scroll', this.scrollHandler); this.destroy$.next(true); this.destroy$.complete(); }; var IgxComboDropDownComponent_1; IgxComboDropDownComponent.ctorParameters = function () { return [ { type: ElementRef }, { type: ChangeDetectorRef }, { type: IgxSelectionAPIService }, { type: undefined, decorators: [{ type: Inject, args: [IGX_COMBO_COMPONENT,] }] }, { type: IgxComboAPIService }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DisplayDensityToken,] }] } ]; }; __decorate([ ContentChildren(IgxComboItemComponent, { descendants: true }), __metadata("design:type", QueryList) ], IgxComboDropDownComponent.prototype, "children", void 0); IgxComboDropDownComponent = IgxComboDropDownComponent_1 = __decorate([ Component({ selector: 'igx-combo-drop-down', template: "<div #scrollContainer class=\"igx-drop-down__list\" igxToggle [style.width]=\"width\" [style.height]=\"height\"\n[style.maxHeight]=\"maxHeight\" [attr.id]=\"this.listId\" role=\"listbox\"\n (onOpening)=\"onToggleOpening($event)\" (onOpened)=\"onToggleOpened()\"\n (onClosing)=\"onToggleClosing($event)\" (onClosed)=\"onToggleClosed()\">\n <ng-container *ngIf=\"!collapsed\">\n <ng-content></ng-content>\n </ng-container>\n</div>\n", providers: [{ provide: IGX_DROPDOWN_BASE, useExisting: IgxComboDropDownComponent_1 }] }), __param(3, Inject(IGX_COMBO_COMPONENT)), __param(5, Optional()), __param(5, Inject(DisplayDensityToken)), __metadata("design:paramtypes", [ElementRef, ChangeDetectorRef, IgxSelectionAPIService, Object, IgxComboAPIService, Object]) ], IgxComboDropDownComponent); return IgxComboDropDownComponent; }(IgxDropDownComponent)); export { IgxComboDropDownComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combo-dropdown.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/combo/combo-dropdown.component.ts"],"names":[],"mappings":";AAAA,OAAO,EACH,iBAAiB,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,EAAE,eAAe,EAAE,QAAQ,EACnH,MAAM,eAAe,CAAC;AACvB,OAAO,EAAgB,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAiB,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AACjF,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAEjD,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,mBAAmB,EAA0B,MAAM,iBAAiB,CAAC;AAE9E,cAAc;AAMd;IAA+C,6CAAoB;IAC/D,mCACc,UAAsB,EACtB,GAAsB,EACtB,SAAiC,EACP,KAAmB,EAC7C,QAA4B,EACa,sBAA8C;QANrG,YAOI,kBAAM,UAAU,EAAE,GAAG,EAAE,SAAS,EAAE,sBAAsB,CAAC,SAC5D;QAPa,gBAAU,GAAV,UAAU,CAAY;QACtB,SAAG,GAAH,GAAG,CAAmB;QACtB,eAAS,GAAT,SAAS,CAAwB;QACP,WAAK,GAAL,KAAK,CAAc;QAC7C,cAAQ,GAAR,QAAQ,CAAoB;QACa,4BAAsB,GAAtB,sBAAsB,CAAwB;QAqBrG;;;WAGG;QAEI,cAAQ,GAA4C,IAAI,CAAC;QAyEtD,mBAAa,GAAG;YACtB,KAAI,CAAC,QAAQ,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC5C,CAAC,CAAA;;IAnGD,CAAC;kCATQ,yBAAyB;IAYnC,sBAAW,sDAAe;QADzB,wBAAwB;aACzB;YACK,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC;QAClD,CAAC;;;OAAA;IAED,sBAAc,uDAAgB;aAA9B;YACI,IAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC;YAC9C,IAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,YAAY,CAAC;YAC3D,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,KAAK,YAAY,CAAC;QACrF,CAAC;;;OAAA;IAED,sBAAc,uDAAgB;aAA9B;YACI,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;gBAC9B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC;gBAC/D,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QAC9B,CAAC;;;OAAA;IASD;;OAEG;IACI,2CAAO,GAAd;QACI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED;;OAEG;IACI,0CAAM,GAAb,UAAc,GAAI;QACd,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC5B,CAAC;IAED;;OAEG;IACI,kDAAc,GAArB;QACI,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED;;OAEG;IACI,iDAAa,GAApB;QACI,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,CAAC,QAAQ,EAAX,CAAW,CAAC,CAAC,CAAC;IACzE,CAAC;IAED;;OAEG;IACI,gDAAY,GAAnB;QACI,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,KAAK,CAAC,EAAE;YAC3F,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;SACtC;aAAM;YACH,iBAAM,YAAY,WAAE,CAAC;SACxB;IACL,CAAC;IAGD;;OAEG;IACI,gDAAY,GAAnB;QACI,IAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;QAC/G,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,KAAK,SAAS,EAAE;YAC5D,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC7B;aAAM;YACH,iBAAM,YAAY,WAAE,CAAC;SACxB;IACL,CAAC;IAED;;OAEG;IACI,8CAAU,GAAjB,UAAkB,IAAkC;QAChD,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,SAAS,EAAE;YACrC,OAAO;SACV;QACD,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC7C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC7B,CAAC;IAEO,sDAAkB,GAA1B;QACI,IAAI,IAAI,CAAC,KAAK,CAAC,kBAAkB,EAAE,EAAE;YACjC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;SACxD;IACL,CAAC;IAES,sDAAkB,GAA5B,UAA6B,OAAY,IAAU,CAAC;IAMpD,sBAAc,qDAAc;aAA5B;YACI,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;gBAC7B,OAAO,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE;qBACzB,IAAI,CAAC,UAAC,CAA+B,EAAE,CAA+B;oBACnE,OAAO,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;gBAC7B,CAAC,CAAC,CAAC;aACV;YACD,OAAO,IAAI,CAAC;QAChB,CAAC;;;OAAA;IASD,sBAAW,4CAAK;QAPhB;;;;;;WAMG;aACH;;YACI,IAAM,KAAK,GAA4B,EAAE,CAAC;YAC1C,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;gBAC7B,IAAM,cAAc,GAAG,IAAI,CAAC,cAAyC,CAAC;;oBACtE,KAAoB,IAAA,mBAAA,SAAA,cAAc,CAAA,8CAAA,0EAAE;wBAA/B,IAAM,KAAK,2BAAA;wBACZ,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;4BACjB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;yBACrB;qBACJ;;;;;;;;;aACJ;YAED,OAAO,KAAK,CAAC;QACjB,CAAC;;;OAAA;IAED;;OAEG;IACI,wDAAoB,GAA3B;QACI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC;IAC9D,CAAC;IAED;;OAEG;IACI,mDAAe,GAAtB,UAAuB,GAAsB;QACzC,QAAQ,GAAG,EAAE;YACT,KAAK,iBAAiB,CAAC,KAAK;gBACxB,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,MAAM;YACV,KAAK,iBAAiB,CAAC,KAAK;gBACxB,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,MAAM;YACV,KAAK,iBAAiB,CAAC,MAAM;gBACzB,IAAI,CAAC,KAAK,EAAE,CAAC;SACpB;IACL,CAAC;IAEO,+CAAW,GAAnB;QACI,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE;YACzB,IAAI,CAAC,KAAK,CAAC,mBAAmB,EAAE,CAAC;SACpC;aAAM;YACH,IAAI,CAAC,KAAK,EAAE,CAAC;SAChB;IACL,CAAC;IAEO,+CAAW,GAAnB;QACI,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE;YACzB,OAAO;SACV;aAAM;YACH,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACrC;IACL,CAAC;IAEO,oDAAgB,GAAxB;QACI,OAAO,IAAI,CAAC,WAAW,YAAY,wBAAwB,CAAC;IAChE,CAAC;IAEM,mDAAe,GAAtB;QACI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;IAC5E,CAAC;IAED;;OAEG;IACI,+CAAW,GAAlB;QACI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAC3E,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;;;gBAjMyB,UAAU;gBACjB,iBAAiB;gBACX,sBAAsB;gDAC1C,MAAM,SAAC,mBAAmB;gBACP,kBAAkB;gDACrC,QAAQ,YAAI,MAAM,SAAC,mBAAmB;;IA0B3C;QADC,eAAe,CAAC,qBAAqB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;kCAC7C,SAAS;+DAAsC;IAjCvD,yBAAyB;QALrC,SAAS,CAAC;YACP,QAAQ,EAAE,qBAAqB;YAC/B,6cAAoD;YACpD,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,2BAAyB,EAAE,CAAC;SACtF,CAAC;QAMO,WAAA,MAAM,CAAC,mBAAmB,CAAC,CAAA;QAE3B,WAAA,QAAQ,EAAE,CAAA,EAAE,WAAA,MAAM,CAAC,mBAAmB,CAAC,CAAA;yCALlB,UAAU;YACjB,iBAAiB;YACX,sBAAsB,UAEvB,kBAAkB;OANjC,yBAAyB,CAoMrC;IAAD,gCAAC;CAAA,AApMD,CAA+C,oBAAoB,GAoMlE;SApMY,yBAAyB","sourcesContent":["import {\n    ChangeDetectorRef, Component, ElementRef, Inject, QueryList, OnDestroy, AfterViewInit, ContentChildren, Optional\n} from '@angular/core';\nimport { IgxComboBase, IGX_COMBO_COMPONENT } from './combo.common';\nimport { IDropDownBase, IGX_DROPDOWN_BASE } from '../drop-down/drop-down.common';\nimport { IgxDropDownComponent } from '../drop-down/drop-down.component';\nimport { DropDownActionKey } from '../drop-down/drop-down.common';\nimport { IgxComboAddItemComponent } from './combo-add-item.component';\nimport { IgxComboAPIService } from './combo.api';\nimport { IgxDropDownItemBaseDirective } from '../drop-down/drop-down-item.base';\nimport { IgxSelectionAPIService } from '../core/selection';\nimport { IgxComboItemComponent } from './combo-item.component';\nimport { DisplayDensityToken, IDisplayDensityOptions } from '../core/density';\n\n/** @hidden */\n@Component({\n    selector: 'igx-combo-drop-down',\n    templateUrl: '../drop-down/drop-down.component.html',\n    providers: [{ provide: IGX_DROPDOWN_BASE, useExisting: IgxComboDropDownComponent }]\n})\nexport class IgxComboDropDownComponent extends IgxDropDownComponent implements IDropDownBase, OnDestroy, AfterViewInit {\n    constructor(\n        protected elementRef: ElementRef,\n        protected cdr: ChangeDetectorRef,\n        protected selection: IgxSelectionAPIService,\n        @Inject(IGX_COMBO_COMPONENT) public combo: IgxComboBase,\n        protected comboAPI: IgxComboAPIService,\n        @Optional() @Inject(DisplayDensityToken) protected _displayDensityOptions: IDisplayDensityOptions) {\n        super(elementRef, cdr, selection, _displayDensityOptions);\n    }\n\n    /** @hidden @internal */\n   public get scrollContainer(): HTMLElement {\n        return this.virtDir.dc.location.nativeElement;\n    }\n\n    protected get isScrolledToLast(): boolean {\n        const scrollTop = this.virtDir.scrollPosition;\n        const scrollHeight = this.virtDir.getScroll().scrollHeight;\n        return Math.floor(scrollTop + this.virtDir.igxForContainerSize) === scrollHeight;\n    }\n\n    protected get lastVisibleIndex(): number {\n        return this.combo.totalItemCount ?\n            Math.floor(this.combo.itemsMaxHeight / this.combo.itemHeight) :\n            this.items.length - 1;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @ContentChildren(IgxComboItemComponent, { descendants: true })\n    public children: QueryList<IgxDropDownItemBaseDirective> = null;\n\n    /**\n     * @hidden @internal\n     */\n    public onFocus() {\n        this.focusedItem = this._focusedItem || this.items[0];\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onBlur(evt?) {\n        this.focusedItem = null;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onToggleOpened() {\n        this.onOpened.emit();\n    }\n\n    /**\n     * @hidden\n     */\n    public navigateFirst() {\n        this.navigateItem(this.virtDir.igxForOf.findIndex(e => !e.isHeader));\n    }\n\n    /**\n     * @hidden\n     */\n    public navigatePrev() {\n        if (this._focusedItem && this._focusedItem.index === 0 && this.virtDir.state.startIndex === 0) {\n            this.combo.focusSearchInput(false);\n        } else {\n            super.navigatePrev();\n        }\n    }\n\n\n    /**\n     * @hidden\n     */\n    public navigateNext() {\n        const lastIndex = this.combo.totalItemCount ? this.combo.totalItemCount - 1 : this.virtDir.igxForOf.length - 1;\n        if (this._focusedItem && this._focusedItem.index === lastIndex) {\n            this.focusAddItemButton();\n        } else {\n            super.navigateNext();\n        }\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public selectItem(item: IgxDropDownItemBaseDirective) {\n        if (item === null || item === undefined) {\n            return;\n        }\n        this.comboAPI.set_selected_item(item.itemID);\n        this._focusedItem = item;\n    }\n\n    private focusAddItemButton() {\n        if (this.combo.isAddButtonVisible()) {\n            this.focusedItem = this.items[this.items.length - 1];\n        }\n    }\n\n    protected scrollToHiddenItem(newItem: any): void { }\n\n    protected scrollHandler = () => {\n        this.comboAPI.disableTransitions = true;\n    }\n\n    protected get sortedChildren(): IgxDropDownItemBaseDirective[] {\n        if (this.children !== undefined) {\n            return this.children.toArray()\n                .sort((a: IgxDropDownItemBaseDirective, b: IgxDropDownItemBaseDirective) => {\n                    return a.index - b.index;\n                });\n        }\n        return null;\n    }\n\n    /**\n     * Get all non-header items\n     *\n     * ```typescript\n     * let myDropDownItems = this.dropdown.items;\n     * ```\n     */\n    public get items(): IgxComboItemComponent[] {\n        const items: IgxComboItemComponent[] = [];\n        if (this.children !== undefined) {\n            const sortedChildren = this.sortedChildren as IgxComboItemComponent[];\n            for (const child of sortedChildren) {\n                if (!child.isHeader) {\n                    items.push(child);\n                }\n            }\n        }\n\n        return items;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public updateScrollPosition() {\n        this.virtDir.getScroll().scrollTop = this._scrollPosition;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onItemActionKey(key: DropDownActionKey) {\n        switch (key) {\n            case DropDownActionKey.ENTER:\n                this.handleEnter();\n                break;\n            case DropDownActionKey.SPACE:\n                this.handleSpace();\n                break;\n            case DropDownActionKey.ESCAPE:\n                this.close();\n        }\n    }\n\n    private handleEnter() {\n        if (this.isAddItemFocused()) {\n            this.combo.addItemToCollection();\n        } else {\n            this.close();\n        }\n    }\n\n    private handleSpace() {\n        if (this.isAddItemFocused()) {\n            return;\n        } else {\n            this.selectItem(this.focusedItem);\n        }\n    }\n\n    private isAddItemFocused(): boolean {\n        return this.focusedItem instanceof IgxComboAddItemComponent;\n    }\n\n    public ngAfterViewInit() {\n        this.virtDir.getScroll().addEventListener('scroll', this.scrollHandler);\n    }\n\n    /**\n     *@hidden @internal\n     */\n    public ngOnDestroy(): void {\n        this.virtDir.getScroll().removeEventListener('scroll', this.scrollHandler);\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n}\n"]}