UNPKG

@catull/igniteui-angular

Version:

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

315 lines 34.2 kB
import { __decorate, __metadata, __param } from "tslib"; import { Directive, Input, Self, Optional, Inject, HostBinding, Output, EventEmitter, NgModule, ElementRef, HostListener, ChangeDetectorRef, OnDestroy } 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'; /** * **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> * ``` */ let IgxAutocompleteDirective = class IgxAutocompleteDirective extends IgxDropDownItemNavigationDirective { constructor(ngModel, formControl, group, elementRef, cdr) { super(null); 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 = (value) => { if (!value.newSelection) { return; } value.cancel = true; // Disable selection in the drop down, because in autocomplete we do not save selection. const newValue = value.newSelection.value; const 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 = () => { if (this.target.focusedItem) { this.target.focusedItem.focused = false; this.target.focusedItem = null; } this.target.navigateFirst(); this.cdr.detectChanges(); }; } get model() { return this.ngModel || this.formControl; } /** @hidden @internal */ get nativeElement() { return this.elementRef.nativeElement; } /** @hidden @internal */ get parentElement() { return this.group ? this.group.element.nativeElement : this.nativeElement; } get settings() { const settings = Object.assign({}, this.defaultSettings, this.autocompleteSettings); if (!settings.positionStrategy.settings.target) { const positionStrategyClone = settings.positionStrategy.clone(); positionStrategyClone.settings.target = this.parentElement; settings.positionStrategy = positionStrategyClone; } return settings; } /** @hidden @internal */ get ariaExpanded() { return !this.collapsed; } /** @hidden @internal */ get hasPopUp() { return 'listbox'; } /** @hidden @internal */ get ariaOwns() { return this.target.listId; } /** @hidden @internal */ get ariaActiveDescendant() { return !this.target.collapsed && this.target.focusedItem ? this.target.focusedItem.id : null; } /** @hidden @internal */ get ariaAutocomplete() { return 'list'; } /** @hidden @internal */ onInput() { this.open(); } /** @hidden @internal */ onArrowDown(event) { event.preventDefault(); this.open(); } /** @hidden @internal */ onTab() { this.close(); } /** @hidden @internal */ handleKeyDown(event) { if (!this.collapsed) { switch (event.key.toLowerCase()) { case 'space': case 'spacebar': case ' ': case 'home': case 'end': return; default: super.handleKeyDown(event); } } } /** @hidden @internal */ onArrowDownKeyDown() { super.onArrowDownKeyDown(); } /** @hidden @internal */ onArrowUpKeyDown() { super.onArrowUpKeyDown(); } /** @hidden @internal */ onEndKeyDown() { super.onEndKeyDown(); } /** @hidden @internal */ onHomeKeyDown() { super.onHomeKeyDown(); } /** * Closes autocomplete drop down */ close() { if (this.collapsed) { return; } this.target.close(); this.dropDownOpened$.next(); } /** * Opens autocomplete drop down */ open() { 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); } get collapsed() { return this.target ? this.target.collapsed : true; } /** @hidden */ ngOnDestroy() { this.dropDownOpened$.complete(); } }; IgxAutocompleteDirective.ctorParameters = () => [ { 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 } ]; __decorate([ Input('igxAutocomplete'), __metadata("design:type", IgxDropDownComponent) ], IgxAutocompleteDirective.prototype, "target", void 0); __decorate([ Input('igxAutocompleteDisabled'), __metadata("design:type", Object) ], IgxAutocompleteDirective.prototype, "disabled", void 0); __decorate([ Input('igxAutocompleteSettings'), __metadata("design:type", Object) ], IgxAutocompleteDirective.prototype, "autocompleteSettings", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxAutocompleteDirective.prototype, "onItemSelected", void 0); __decorate([ HostBinding('attr.autocomplete'), __metadata("design:type", Object) ], IgxAutocompleteDirective.prototype, "autofill", void 0); __decorate([ HostBinding('attr.role'), __metadata("design:type", Object) ], IgxAutocompleteDirective.prototype, "role", void 0); __decorate([ HostBinding('attr.aria-expanded'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxAutocompleteDirective.prototype, "ariaExpanded", null); __decorate([ HostBinding('attr.aria-haspopup'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxAutocompleteDirective.prototype, "hasPopUp", null); __decorate([ HostBinding('attr.aria-owns'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxAutocompleteDirective.prototype, "ariaOwns", null); __decorate([ HostBinding('attr.aria-activedescendant'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxAutocompleteDirective.prototype, "ariaActiveDescendant", null); __decorate([ HostBinding('attr.aria-autocomplete'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxAutocompleteDirective.prototype, "ariaAutocomplete", null); __decorate([ HostListener('input'), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], IgxAutocompleteDirective.prototype, "onInput", null); __decorate([ HostListener('keydown.ArrowDown', ['$event']), HostListener('keydown.Alt.ArrowDown', ['$event']), HostListener('keydown.ArrowUp', ['$event']), HostListener('keydown.Alt.ArrowUp', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Event]), __metadata("design:returntype", void 0) ], IgxAutocompleteDirective.prototype, "onArrowDown", null); __decorate([ HostListener('keydown.Tab'), HostListener('keydown.Shift.Tab'), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], IgxAutocompleteDirective.prototype, "onTab", null); IgxAutocompleteDirective = __decorate([ Directive({ selector: '[igxAutocomplete]' }), __param(0, Self()), __param(0, Optional()), __param(0, Inject(NgModel)), __param(1, Self()), __param(1, Optional()), __param(1, Inject(FormControlName)), __param(2, Optional()), __metadata("design:paramtypes", [NgModel, FormControlName, IgxInputGroupComponent, ElementRef, ChangeDetectorRef]) ], IgxAutocompleteDirective); export { IgxAutocompleteDirective }; /** @hidden */ let IgxAutocompleteModule = class IgxAutocompleteModule { }; IgxAutocompleteModule = __decorate([ NgModule({ imports: [IgxDropDownModule, CommonModule], declarations: [IgxAutocompleteDirective], exports: [IgxAutocompleteDirective] }) ], 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, IBaseEventArgs } 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, IBaseEventArgs {\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')\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')\n    @HostListener('keydown.Shift.Tab')\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"]}