igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
606 lines • 41.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Directive, Input, Self, Optional, Inject, HostBinding, Output, EventEmitter, NgModule, ElementRef, HostListener, ChangeDetectorRef } from '@angular/core';
import { NgModel, FormControlName } from '@angular/forms';
import { CommonModule } from '@angular/common';
import { Subject } from 'rxjs';
import { first, takeUntil } from 'rxjs/operators';
import { AbsoluteScrollStrategy, AutoPositionStrategy } from '../../services/index';
import { IgxDropDownModule, IgxDropDownComponent, IgxDropDownItemNavigationDirective } from '../../drop-down/index';
import { IgxInputGroupComponent } from '../../input-group/index';
/**
* Interface that encapsulates onItemSelection event arguments - new value and cancel selection.
* @export
* @record
*/
export function AutocompleteItemSelectionEventArgs() { }
if (false) {
/**
* New value selected from the drop down
* @type {?}
*/
AutocompleteItemSelectionEventArgs.prototype.value;
}
/**
* @record
*/
export function AutocompleteOverlaySettings() { }
if (false) {
/**
* Position strategy to use with this settings
* @type {?|undefined}
*/
AutocompleteOverlaySettings.prototype.positionStrategy;
/**
* Scroll strategy to use with this settings
* @type {?|undefined}
*/
AutocompleteOverlaySettings.prototype.scrollStrategy;
/**
* Set the outlet container to attach the overlay to
* @type {?|undefined}
*/
AutocompleteOverlaySettings.prototype.outlet;
}
/**
* **Ignite UI for Angular Autocomplete** -
* [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/autocomplete.html)
*
* The igxAutocomplete directive provides a way to enhance a text input
* by showing a drop down of suggested options, provided by the developer.
*
* Example:
* ```html
* <input type="text" [igxAutocomplete]="townsPanel" />
* <igx-drop-down #townsPanel>
* <igx-drop-down-item *ngFor="let town of towns | startsWith:townSelected" [value]="town">
* {{town}}
* </igx-drop-down-item>
* </igx-drop-down>
* ```
*/
var IgxAutocompleteDirective = /** @class */ (function (_super) {
tslib_1.__extends(IgxAutocompleteDirective, _super);
function IgxAutocompleteDirective(ngModel, formControl, group, elementRef, cdr) {
var _this = _super.call(this, null) || this;
_this.ngModel = ngModel;
_this.formControl = formControl;
_this.group = group;
_this.elementRef = elementRef;
_this.cdr = cdr;
_this.defaultSettings = {
modal: false,
scrollStrategy: new AbsoluteScrollStrategy(),
positionStrategy: new AutoPositionStrategy({ target: _this.parentElement }),
excludePositionTarget: true
};
_this.dropDownOpened$ = new Subject();
/**
* Enables/disables autocomplete component
*
* ```typescript
* // get
* let disabled = this.autocomplete.disabled;
* ```
* ```html
* <!--set-->
* <input type="text" [igxAutocomplete]="townsPanel" [igxAutocompleteDisabled]="disabled"/>
* ```
* ```typescript
* // set
* public disabled = true;
* ```
*/
_this.disabled = false;
/**
* Emitted after item from the drop down is selected
*
* ```html
* <input igxInput [igxAutocomplete]="townsPanel" (onItemSelected)='itemSelected($event)' />
* ```
*/
_this.onItemSelected = new EventEmitter();
/**
* @hidden \@internal
*/
_this.autofill = 'off';
/**
* @hidden \@internal
*/
_this.role = 'combobox';
_this.select = function (value) {
if (!value.newSelection) {
return;
}
value.cancel = true; // Disable selection in the drop down, because in autocomplete we do not save selection.
// Disable selection in the drop down, because in autocomplete we do not save selection.
/** @type {?} */
var newValue = value.newSelection.value;
/** @type {?} */
var args = { value: newValue, cancel: false };
_this.onItemSelected.emit(args);
if (args.cancel) {
return;
}
_this.close();
_this.nativeElement.focus();
// Update model after the input is re-focused, in order to have proper valid styling.
// Otherwise when item is selected using mouse (and input is blurred), then valid style will be removed.
_this.model ? _this.model.control.setValue(newValue) : _this.nativeElement.value = newValue;
};
_this.highlightFirstItem = function () {
if (_this.target.focusedItem) {
_this.target.focusedItem.focused = false;
_this.target.focusedItem = null;
}
_this.target.navigateFirst();
_this.cdr.detectChanges();
};
return _this;
}
Object.defineProperty(IgxAutocompleteDirective.prototype, "model", {
get: /**
* @protected
* @return {?}
*/
function () {
return this.ngModel || this.formControl;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAutocompleteDirective.prototype, "nativeElement", {
/** @hidden @internal */
get: /**
* @hidden \@internal
* @return {?}
*/
function () {
return this.elementRef.nativeElement;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAutocompleteDirective.prototype, "parentElement", {
/** @hidden @internal */
get: /**
* @hidden \@internal
* @return {?}
*/
function () {
return this.group ? this.group.element.nativeElement : this.nativeElement;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAutocompleteDirective.prototype, "settings", {
get: /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var settings = Object.assign({}, this.defaultSettings, this.autocompleteSettings);
if (!settings.positionStrategy.settings.target) {
/** @type {?} */
var positionStrategyClone = settings.positionStrategy.clone();
positionStrategyClone.settings.target = this.parentElement;
settings.positionStrategy = positionStrategyClone;
}
return settings;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAutocompleteDirective.prototype, "ariaExpanded", {
/** @hidden @internal */
get: /**
* @hidden \@internal
* @return {?}
*/
function () {
return !this.collapsed;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAutocompleteDirective.prototype, "hasPopUp", {
/** @hidden @internal */
get: /**
* @hidden \@internal
* @return {?}
*/
function () {
return 'listbox';
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAutocompleteDirective.prototype, "ariaOwns", {
/** @hidden @internal */
get: /**
* @hidden \@internal
* @return {?}
*/
function () {
return this.target.listId;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAutocompleteDirective.prototype, "ariaActiveDescendant", {
/** @hidden @internal */
get: /**
* @hidden \@internal
* @return {?}
*/
function () {
return !this.target.collapsed && this.target.focusedItem ? this.target.focusedItem.id : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAutocompleteDirective.prototype, "ariaAutocomplete", {
/** @hidden @internal */
get: /**
* @hidden \@internal
* @return {?}
*/
function () {
return 'list';
},
enumerable: true,
configurable: true
});
/** @hidden @internal */
/**
* @hidden \@internal
* @return {?}
*/
IgxAutocompleteDirective.prototype.onInput = /**
* @hidden \@internal
* @return {?}
*/
function () {
this.open();
};
/** @hidden @internal */
/**
* @hidden \@internal
* @param {?} event
* @return {?}
*/
IgxAutocompleteDirective.prototype.onArrowDown = /**
* @hidden \@internal
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
this.open();
};
/** @hidden @internal */
/**
* @hidden \@internal
* @return {?}
*/
IgxAutocompleteDirective.prototype.onTab = /**
* @hidden \@internal
* @return {?}
*/
function () {
this.close();
};
/** @hidden @internal */
/**
* @hidden \@internal
* @param {?} event
* @return {?}
*/
IgxAutocompleteDirective.prototype.handleKeyDown = /**
* @hidden \@internal
* @param {?} event
* @return {?}
*/
function (event) {
if (!this.collapsed) {
switch (event.key.toLowerCase()) {
case 'space':
case 'spacebar':
case ' ':
case 'home':
case 'end':
return;
default:
_super.prototype.handleKeyDown.call(this, event);
}
}
};
/** @hidden @internal */
/**
* @hidden \@internal
* @return {?}
*/
IgxAutocompleteDirective.prototype.onArrowDownKeyDown = /**
* @hidden \@internal
* @return {?}
*/
function () {
_super.prototype.onArrowDownKeyDown.call(this);
};
/** @hidden @internal */
/**
* @hidden \@internal
* @return {?}
*/
IgxAutocompleteDirective.prototype.onArrowUpKeyDown = /**
* @hidden \@internal
* @return {?}
*/
function () {
_super.prototype.onArrowUpKeyDown.call(this);
};
/** @hidden @internal */
/**
* @hidden \@internal
* @return {?}
*/
IgxAutocompleteDirective.prototype.onEndKeyDown = /**
* @hidden \@internal
* @return {?}
*/
function () {
_super.prototype.onEndKeyDown.call(this);
};
/** @hidden @internal */
/**
* @hidden \@internal
* @return {?}
*/
IgxAutocompleteDirective.prototype.onHomeKeyDown = /**
* @hidden \@internal
* @return {?}
*/
function () {
_super.prototype.onHomeKeyDown.call(this);
};
/**
* Closes autocomplete drop down
*/
/**
* Closes autocomplete drop down
* @return {?}
*/
IgxAutocompleteDirective.prototype.close = /**
* Closes autocomplete drop down
* @return {?}
*/
function () {
if (this.collapsed) {
return;
}
this.target.close();
this.dropDownOpened$.next();
};
/**
* Opens autocomplete drop down
*/
/**
* Opens autocomplete drop down
* @return {?}
*/
IgxAutocompleteDirective.prototype.open = /**
* Opens autocomplete drop down
* @return {?}
*/
function () {
if (this.disabled || !this.collapsed) {
return;
}
this.target.width = this.parentElement.clientWidth + 'px';
this.target.open(this.settings);
this.target.onSelection.pipe(takeUntil(this.dropDownOpened$)).subscribe(this.select);
this.target.onOpened.pipe(first()).subscribe(this.highlightFirstItem);
this.target.children.changes.pipe(takeUntil(this.dropDownOpened$)).subscribe(this.highlightFirstItem);
};
Object.defineProperty(IgxAutocompleteDirective.prototype, "collapsed", {
get: /**
* @private
* @return {?}
*/
function () {
return this.target ? this.target.collapsed : true;
},
enumerable: true,
configurable: true
});
/** @hidden */
/**
* @hidden
* @return {?}
*/
IgxAutocompleteDirective.prototype.ngOnDestroy = /**
* @hidden
* @return {?}
*/
function () {
this.dropDownOpened$.complete();
};
IgxAutocompleteDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxAutocomplete]'
},] }
];
/** @nocollapse */
IgxAutocompleteDirective.ctorParameters = function () { return [
{ type: NgModel, decorators: [{ type: Self }, { type: Optional }, { type: Inject, args: [NgModel,] }] },
{ type: FormControlName, decorators: [{ type: Self }, { type: Optional }, { type: Inject, args: [FormControlName,] }] },
{ type: IgxInputGroupComponent, decorators: [{ type: Optional }] },
{ type: ElementRef },
{ type: ChangeDetectorRef }
]; };
IgxAutocompleteDirective.propDecorators = {
target: [{ type: Input, args: ['igxAutocomplete',] }],
disabled: [{ type: Input, args: ['igxAutocompleteDisabled',] }],
autocompleteSettings: [{ type: Input, args: ['igxAutocompleteSettings',] }],
onItemSelected: [{ type: Output }],
autofill: [{ type: HostBinding, args: ['attr.autocomplete',] }],
role: [{ type: HostBinding, args: ['attr.role',] }],
ariaExpanded: [{ type: HostBinding, args: ['attr.aria-expanded',] }],
hasPopUp: [{ type: HostBinding, args: ['attr.aria-haspopup',] }],
ariaOwns: [{ type: HostBinding, args: ['attr.aria-owns',] }],
ariaActiveDescendant: [{ type: HostBinding, args: ['attr.aria-activedescendant',] }],
ariaAutocomplete: [{ type: HostBinding, args: ['attr.aria-autocomplete',] }],
onInput: [{ type: HostListener, args: ['input', ['$event'],] }],
onArrowDown: [{ type: HostListener, args: ['keydown.ArrowDown', ['$event'],] }, { type: HostListener, args: ['keydown.Alt.ArrowDown', ['$event'],] }, { type: HostListener, args: ['keydown.ArrowUp', ['$event'],] }, { type: HostListener, args: ['keydown.Alt.ArrowUp', ['$event'],] }],
onTab: [{ type: HostListener, args: ['keydown.Tab', ['$event'],] }, { type: HostListener, args: ['keydown.Shift.Tab', ["$event"],] }]
};
return IgxAutocompleteDirective;
}(IgxDropDownItemNavigationDirective));
export { IgxAutocompleteDirective };
if (false) {
/**
* @type {?}
* @private
*/
IgxAutocompleteDirective.prototype.defaultSettings;
/**
* @type {?}
* @protected
*/
IgxAutocompleteDirective.prototype.id;
/**
* @type {?}
* @protected
*/
IgxAutocompleteDirective.prototype.dropDownOpened$;
/**
* Sets the target of the autocomplete directive
*
* ```html
* <!-- Set -->
* <input [igxAutocomplete]="dropdown" />
* ...
* <igx-drop-down #dropdown>
* ...
* </igx-drop-down>
* ```
* @type {?}
*/
IgxAutocompleteDirective.prototype.target;
/**
* Enables/disables autocomplete component
*
* ```typescript
* // get
* let disabled = this.autocomplete.disabled;
* ```
* ```html
* <!--set-->
* <input type="text" [igxAutocomplete]="townsPanel" [igxAutocompleteDisabled]="disabled"/>
* ```
* ```typescript
* // set
* public disabled = true;
* ```
* @type {?}
*/
IgxAutocompleteDirective.prototype.disabled;
/**
* Provide overlay settings for the autocomplete drop down
*
* ```typescript
* // get
* let settings = this.autocomplete.autocompleteSettings;
* ```
* ```html
* <!--set-->
* <input type="text" [igxAutocomplete]="townsPanel" [igxAutocompleteSettings]="settings"/>
* ```
* ```typescript
* // set
* this.settings = {
* positionStrategy: new ConnectedPositioningStrategy({
* closeAnimation: null,
* openAnimation: null
* })
* };
* ```
* @type {?}
*/
IgxAutocompleteDirective.prototype.autocompleteSettings;
/**
* Emitted after item from the drop down is selected
*
* ```html
* <input igxInput [igxAutocomplete]="townsPanel" (onItemSelected)='itemSelected($event)' />
* ```
* @type {?}
*/
IgxAutocompleteDirective.prototype.onItemSelected;
/**
* @hidden \@internal
* @type {?}
*/
IgxAutocompleteDirective.prototype.autofill;
/**
* @hidden \@internal
* @type {?}
*/
IgxAutocompleteDirective.prototype.role;
/**
* @type {?}
* @private
*/
IgxAutocompleteDirective.prototype.select;
/**
* @type {?}
* @private
*/
IgxAutocompleteDirective.prototype.highlightFirstItem;
/**
* @type {?}
* @protected
*/
IgxAutocompleteDirective.prototype.ngModel;
/**
* @type {?}
* @protected
*/
IgxAutocompleteDirective.prototype.formControl;
/**
* @type {?}
* @protected
*/
IgxAutocompleteDirective.prototype.group;
/**
* @type {?}
* @protected
*/
IgxAutocompleteDirective.prototype.elementRef;
/**
* @type {?}
* @protected
*/
IgxAutocompleteDirective.prototype.cdr;
}
/**
* @hidden
*/
var IgxAutocompleteModule = /** @class */ (function () {
function IgxAutocompleteModule() {
}
IgxAutocompleteModule.decorators = [
{ type: NgModule, args: [{
imports: [IgxDropDownModule, CommonModule],
declarations: [IgxAutocompleteDirective],
exports: [IgxAutocompleteDirective]
},] }
];
return IgxAutocompleteModule;
}());
export { IgxAutocompleteModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/directives/autocomplete/autocomplete.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive, Input, Self, Optional, Inject, HostBinding, Output, EventEmitter,\n    NgModule, ElementRef, HostListener, ChangeDetectorRef, OnDestroy } from '@angular/core';\nimport { NgModel, FormControlName } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { Subject } from 'rxjs';\nimport { first, takeUntil } from 'rxjs/operators';\nimport { CancelableEventArgs } from '../../core/utils';\nimport { OverlaySettings, AbsoluteScrollStrategy, IScrollStrategy, IPositionStrategy, AutoPositionStrategy } from '../../services/index';\nimport { IgxDropDownModule, IgxDropDownComponent, ISelectionEventArgs, IgxDropDownItemNavigationDirective } from '../../drop-down/index';\nimport { IgxInputGroupComponent } from '../../input-group/index';\nimport { IgxOverlayOutletDirective } from '../toggle/toggle.directive';\n\n/**\n * Interface that encapsulates onItemSelection event arguments - new value and cancel selection.\n * @export\n */\nexport interface AutocompleteItemSelectionEventArgs extends CancelableEventArgs {\n    /**\n     * New value selected from the drop down\n     */\n    value: string;\n}\n\nexport interface AutocompleteOverlaySettings {\n    /** Position strategy to use with this settings */\n    positionStrategy?: IPositionStrategy;\n    /** Scroll strategy to use with this settings */\n    scrollStrategy?: IScrollStrategy;\n    /** Set the outlet container to attach the overlay to */\n    outlet?: IgxOverlayOutletDirective | ElementRef;\n}\n\n/**\n * **Ignite UI for Angular Autocomplete** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/autocomplete.html)\n *\n * The igxAutocomplete directive provides a way to enhance a text input\n * by showing a drop down of suggested options, provided by the developer.\n *\n * Example:\n * ```html\n * <input type=\"text\" [igxAutocomplete]=\"townsPanel\" />\n * <igx-drop-down #townsPanel>\n *     <igx-drop-down-item *ngFor=\"let town of towns | startsWith:townSelected\" [value]=\"town\">\n *         {{town}}\n *     </igx-drop-down-item>\n * </igx-drop-down>\n * ```\n */\n@Directive({\n    selector: '[igxAutocomplete]'\n})\nexport class IgxAutocompleteDirective extends IgxDropDownItemNavigationDirective implements OnDestroy {\n\n    constructor(@Self() @Optional() @Inject(NgModel) protected ngModel: NgModel,\n                @Self() @Optional() @Inject(FormControlName) protected formControl: FormControlName,\n                @Optional() protected group: IgxInputGroupComponent,\n                protected elementRef: ElementRef,\n                protected cdr: ChangeDetectorRef) {\n        super(null);\n    }\n\n    private defaultSettings: OverlaySettings = {\n        modal: false,\n        scrollStrategy: new AbsoluteScrollStrategy(),\n        positionStrategy: new AutoPositionStrategy({ target: this.parentElement }),\n        excludePositionTarget: true\n    };\n\n    protected id: string;\n    protected dropDownOpened$ = new Subject<boolean>();\n    protected get model() {\n        return this.ngModel || this.formControl;\n    }\n\n    /** @hidden @internal */\n    get nativeElement(): HTMLInputElement {\n        return this.elementRef.nativeElement;\n    }\n\n    /** @hidden @internal */\n    get parentElement(): HTMLElement {\n        return this.group ? this.group.element.nativeElement : this.nativeElement;\n    }\n\n    private get settings(): OverlaySettings {\n        const settings = Object.assign({}, this.defaultSettings, this.autocompleteSettings);\n        if (!settings.positionStrategy.settings.target) {\n            const positionStrategyClone: IPositionStrategy = settings.positionStrategy.clone();\n            positionStrategyClone.settings.target = this.parentElement;\n            settings.positionStrategy = positionStrategyClone;\n        }\n        return settings;\n    }\n\n    /**\n     * Sets the target of the autocomplete directive\n     *\n     * ```html\n     * <!-- Set -->\n     * <input [igxAutocomplete]=\"dropdown\" />\n     * ...\n     * <igx-drop-down #dropdown>\n     * ...\n     * </igx-drop-down>\n     * ```\n     */\n    @Input('igxAutocomplete')\n    public target: IgxDropDownComponent;\n\n    /**\n     * Enables/disables autocomplete component\n     *\n     * ```typescript\n     * // get\n     * let disabled = this.autocomplete.disabled;\n     * ```\n     * ```html\n     * <!--set-->\n     * <input type=\"text\" [igxAutocomplete]=\"townsPanel\" [igxAutocompleteDisabled]=\"disabled\"/>\n     * ```\n     * ```typescript\n     * // set\n     * public disabled = true;\n     * ```\n     */\n    @Input('igxAutocompleteDisabled')\n    public disabled = false;\n\n    /**\n     * Provide overlay settings for the autocomplete drop down\n     *\n     * ```typescript\n     * // get\n     * let settings = this.autocomplete.autocompleteSettings;\n     * ```\n     * ```html\n     * <!--set-->\n     * <input type=\"text\" [igxAutocomplete]=\"townsPanel\" [igxAutocompleteSettings]=\"settings\"/>\n     * ```\n     * ```typescript\n     * // set\n     * this.settings = {\n     *  positionStrategy: new ConnectedPositioningStrategy({\n     *      closeAnimation: null,\n     *      openAnimation: null\n     *  })\n     * };\n     * ```\n     */\n    @Input('igxAutocompleteSettings')\n    autocompleteSettings: AutocompleteOverlaySettings;\n\n    /**\n     * Emitted after item from the drop down is selected\n     *\n     * ```html\n     * <input igxInput [igxAutocomplete]=\"townsPanel\" (onItemSelected)='itemSelected($event)' />\n     * ```\n     */\n    @Output()\n    onItemSelected = new EventEmitter<AutocompleteItemSelectionEventArgs>();\n\n    /** @hidden @internal */\n    @HostBinding('attr.autocomplete')\n    public autofill = 'off';\n\n    /** @hidden  @internal */\n    @HostBinding('attr.role')\n    public role = 'combobox';\n\n    /** @hidden  @internal */\n    @HostBinding('attr.aria-expanded')\n    public get ariaExpanded() {\n        return !this.collapsed;\n    }\n\n    /** @hidden  @internal */\n    @HostBinding('attr.aria-haspopup')\n    public get hasPopUp() {\n        return 'listbox';\n    }\n\n    /** @hidden  @internal */\n    @HostBinding('attr.aria-owns')\n    public get ariaOwns() {\n        return this.target.listId;\n    }\n\n    /** @hidden  @internal */\n    @HostBinding('attr.aria-activedescendant')\n    public get ariaActiveDescendant() {\n        return !this.target.collapsed && this.target.focusedItem ? this.target.focusedItem.id : null;\n    }\n\n    /** @hidden  @internal */\n    @HostBinding('attr.aria-autocomplete')\n    public get ariaAutocomplete() {\n        return 'list';\n    }\n\n    /** @hidden  @internal */\n    @HostListener('input', ['$event'])\n    onInput() {\n        this.open();\n    }\n\n    /** @hidden  @internal */\n    @HostListener('keydown.ArrowDown', ['$event'])\n    @HostListener('keydown.Alt.ArrowDown', ['$event'])\n    @HostListener('keydown.ArrowUp', ['$event'])\n    @HostListener('keydown.Alt.ArrowUp', ['$event'])\n    onArrowDown(event: Event) {\n        event.preventDefault();\n        this.open();\n    }\n\n    /** @hidden  @internal */\n    @HostListener('keydown.Tab', ['$event'])\n    @HostListener('keydown.Shift.Tab', [`$event`])\n    onTab() {\n        this.close();\n    }\n\n    /** @hidden  @internal */\n    handleKeyDown(event) {\n        if (!this.collapsed) {\n            switch (event.key.toLowerCase()) {\n                case 'space':\n                case 'spacebar':\n                case ' ':\n                case 'home':\n                case 'end':\n                    return;\n                default:\n                    super.handleKeyDown(event);\n            }\n        }\n    }\n\n    /** @hidden  @internal */\n    onArrowDownKeyDown() {\n        super.onArrowDownKeyDown();\n    }\n\n    /** @hidden  @internal */\n    onArrowUpKeyDown() {\n        super.onArrowUpKeyDown();\n    }\n\n    /** @hidden  @internal */\n    onEndKeyDown() {\n        super.onEndKeyDown();\n    }\n\n    /** @hidden  @internal */\n    onHomeKeyDown() {\n        super.onHomeKeyDown();\n    }\n\n    /**\n     * Closes autocomplete drop down\n     */\n    public close() {\n        if (this.collapsed) {\n            return;\n        }\n        this.target.close();\n        this.dropDownOpened$.next();\n    }\n\n    /**\n     * Opens autocomplete drop down\n     */\n    public open() {\n        if (this.disabled || !this.collapsed) {\n            return;\n        }\n        this.target.width = this.parentElement.clientWidth + 'px';\n        this.target.open(this.settings);\n        this.target.onSelection.pipe(takeUntil(this.dropDownOpened$)).subscribe(this.select);\n        this.target.onOpened.pipe(first()).subscribe(this.highlightFirstItem);\n        this.target.children.changes.pipe(takeUntil(this.dropDownOpened$)).subscribe(this.highlightFirstItem);\n    }\n\n    private get collapsed(): boolean {\n        return this.target ? this.target.collapsed : true;\n    }\n\n    private select = (value: ISelectionEventArgs) => {\n        if (!value.newSelection) {\n            return;\n        }\n        value.cancel = true; // Disable selection in the drop down, because in autocomplete we do not save selection.\n        const newValue = value.newSelection.value;\n        const args: AutocompleteItemSelectionEventArgs = { value: newValue, cancel: false };\n        this.onItemSelected.emit(args);\n        if (args.cancel) {\n            return;\n        }\n        this.close();\n        this.nativeElement.focus();\n\n        // Update model after the input is re-focused, in order to have proper valid styling.\n        // Otherwise when item is selected using mouse (and input is blurred), then valid style will be removed.\n        this.model ? this.model.control.setValue(newValue) : this.nativeElement.value = newValue;\n    }\n\n    private highlightFirstItem = () => {\n        if (this.target.focusedItem) {\n            this.target.focusedItem.focused = false;\n            this.target.focusedItem = null;\n        }\n        this.target.navigateFirst();\n        this.cdr.detectChanges();\n    }\n\n    /** @hidden */\n    public ngOnDestroy() {\n        this.dropDownOpened$.complete();\n    }\n}\n\n/** @hidden */\n@NgModule({\n    imports: [IgxDropDownModule, CommonModule],\n    declarations: [IgxAutocompleteDirective],\n    exports: [IgxAutocompleteDirective]\n})\nexport class IgxAutocompleteModule { }\n"]}