UNPKG

ngx-slice-kit

Version:

[![npm version](https://badge.fury.io/js/ngx-slice-kit.svg)](https://badge.fury.io/js/ngx-slice-kit)

254 lines 40.4 kB
import { Component, EventEmitter, forwardRef, HostBinding, Inject, Input, Output, PLATFORM_ID, ViewChild } from '@angular/core'; import { DOCUMENT, isPlatformServer } from '@angular/common'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { BehaviorSubject, fromEvent } from 'rxjs'; import { debounceTime } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "../dropdown.service"; import * as i2 from "../options.service"; import * as i3 from "../../core/layout-control/layout-control.service"; import * as i4 from "@angular/common"; import * as i5 from "../../buttons/icon/icon.component"; export class AutocompleteComponent { constructor(document, platformId, dropdownService, optionsService, renderer, layoutControlService) { this.document = document; this.platformId = platformId; this.dropdownService = dropdownService; this.optionsService = optionsService; this.renderer = renderer; this.layoutControlService = layoutControlService; this.$options = new BehaviorSubject(null); this.label = ''; this.placeholder = ''; this.small = false; this.caption = ''; this.focusEvent = new EventEmitter(); this.blurEvent = new EventEmitter(); this.resultEvent = new EventEmitter(); this.valueChanges = new EventEmitter(); this.error = undefined; this.value = ''; this.uid = layoutControlService.generateLayoutElementHash(); } set options(o) { this.$options.next(o); if (this.isOpen) { this.optionsService.options = this.getOptions(); } } get options() { return this.$options.getValue(); } set required(val) { this.req = val === '' || val === true; } get required() { return this.req; } get isDisabled() { return this.disabled; } getOptions() { return [...this.options].map(o => { o.selected = this.currentValue === o; return o; }); } isInactive() { return !this.currentValue; } hasValuesToDrop() { return !this.isInactive(); } onOpen() { this.isOpen = true; this.emitFocus(); } onClose() { this.isOpen = false; this.emitBlur(); } emitBlur() { if (this.focused) { this.focused = false; this.blurEvent.emit(); } } emitFocus() { if (!this.focused) { this.focused = true; this.focusEvent.emit(); } } selected() { return this.currentValue?.label ?? ''; } onResult(option) { this.onTouched(); this.writeValue(option); } writeValue(val) { if (val?.size > 0) { this.currentValues = val; const multipleResult = this.options.filter(o => this.currentValues.has(o)); this.onChange(multipleResult); this.resultEvent.emit(multipleResult); } else { this.currentValue = val; this.onChange(val); this.resultEvent.emit(this.currentValue); } } addValue(o) { const alreadySelected = this.currentValues.has(o); o.selected = !alreadySelected; alreadySelected ? this.currentValues.delete(o) : this.currentValues.add(o); this.writeValue(this.currentValues); } clearValue(e) { e.stopPropagation(); this.valueChanges.emit(null); this.currentValue = undefined; this.writeValue(undefined); } onChange(value) { } onTouched() { } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } setInputSubscription() { this.sub = fromEvent(this.inputElementRef.nativeElement, `keyup`).pipe(debounceTime(500)).subscribe((e) => { if (e.code === 'ArrowUp' || e.code === 'ArrowDown' || e.code === 'Escape' || e.code === 'Enter') { e.preventDefault(); e.stopPropagation(); return; } const value = e?.target?.value; this.valueChanges.emit(value); }); } onInput(ev) { if (ev.code === 'ArrowUp' || ev.code === 'ArrowDown' || ev.code === 'Escape' || ev.code === 'Enter') { ev.preventDefault(); ev.stopPropagation(); return; } const value = ev?.target?.value; this.valueChanges.emit(value); } showDropdown() { if (isPlatformServer(this.platformId)) { return; } if (this.isOpen) { return; } this.onOpen(); this.optionsService.options = this.getOptions(); const opts = { triggerRect: this.autocomplete.nativeElement.getBoundingClientRect(), fitWidth: true, multi: false, hideBackdrop: true, parentElem: this.autocomplete.nativeElement, }; this.dropdownService.showDropdown(opts).subscribe(res => { this.onClose(); // this.optionsService.options = null; if (res) { this.inputElementRef.nativeElement.blur(); this.onResult(res); } }); } // public ngOnInit(): void { // // this.setInputSubscription(); // } ngOnDestroy() { this.sub?.unsubscribe(); this.blurEvent.complete(); this.focusEvent.complete(); this.resultEvent.complete(); this.valueChanges.complete(); } } AutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: AutocompleteComponent, deps: [{ token: DOCUMENT }, { token: PLATFORM_ID }, { token: i1.DropdownService }, { token: i2.OptionsService }, { token: i0.Renderer2 }, { token: i3.LayoutControlService }], target: i0.ɵɵFactoryTarget.Component }); AutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: AutocompleteComponent, selector: "sdk-autocomplete", inputs: { options: "options", required: "required", label: "label", placeholder: "placeholder", disabled: "disabled", small: "small", icon: "icon", caption: "caption", error: "error", isDisabled: "isDisabled" }, outputs: { focusEvent: "focusEvent", blurEvent: "blurEvent", resultEvent: "resultEvent", valueChanges: "valueChanges" }, host: { properties: { "class.invalid": "this.error", "class.disabled": "this.isDisabled" } }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => AutocompleteComponent), multi: true } ], viewQueries: [{ propertyName: "autocomplete", first: true, predicate: ["autocomplete"], descendants: true, static: true }, { propertyName: "inputElementRef", first: true, predicate: ["input"], descendants: true, static: true }], ngImport: i0, template: "<label for=\"{{uid}}\" class=\"sdk-autocomplete-label\"\n [class.active]=\"value !== undefined\"\n [class.small]=\"small\">\n {{label}}\n <span *ngIf=\"required\" class=\"sdk-autocomplete-label-required-mark\">&nbsp;*</span>\n</label>\n\n<div class=\"sdk-autocomplete-wrap\" #autocomplete>\n <div class=\"sdk-autocomplete\" (click)=\"showDropdown()\"\n [ngClass]=\"{\n active: isOpen,\n small: small,\n invalid: error\n }\">\n <span class=\"sdk-autocomplete-icon\" *ngIf=\"icon\">\n <sdk-icon [icon]=\"icon\" [size]=\"small ? 16 : 24\"></sdk-icon>\n </span>\n <input class=\"sdk-autocomplete-input\" type=\"text\"\n value=\"{{selected()}}\"\n id=\"{{uid}}\"\n [placeholder]=\"placeholder\"\n (keyup)=\"onInput($event)\"\n (focus)=\"emitFocus()\"\n (blur)=\"emitBlur()\"\n #input>\n <span class=\"sdk-autocomplete-actions\">\n <ng-container *ngIf=\"!hasValuesToDrop()\">\n <div class=\"interface-icon-wrap icon-chevron\" [class.active]=\"isOpen\">\n <sdk-icon icon=\"chevron_down\" [size]=\"24\"></sdk-icon>\n </div>\n </ng-container>\n <ng-container *ngIf=\"hasValuesToDrop()\">\n <div class=\"interface-icon-wrap icon-clear\">\n <sdk-icon icon=\"close\" [size]=\"16\" [inline]=\"true\" (click)=\"clearValue($event)\"></sdk-icon>\n </div>\n </ng-container>\n </span>\n </div>\n</div>\n\n<div class=\"sdk-caption\" *ngIf=\"caption\">\n {{caption}}\n</div>\n<div class=\"sdk-error\" *ngIf=\"error\">\n <sdk-icon icon=\"alert\" size=\"12\"></sdk-icon>\n {{error ? error : ''}}\n</div>\n", styles: [":host{display:flex;width:100%;flex-direction:column;margin-bottom:10px;position:relative}:host.sdk-autocomplete--invalid{animation:shake .4s}:host.disabled{opacity:.6;pointer-events:none;cursor:default}.sdk-autocomplete-label-required-mark{color:var(--warn)}.sdk-autocomplete-label{color:var(--base-a50);transition:all .2s;font-size:17px;margin-bottom:2px}.sdk-autocomplete-label.small{font-size:15px}.sdk-autocomplete-label.active{color:var(--base-a90)}.sdk-autocomplete-wrap{position:relative;background-color:var(--background-a90);border-radius:8px;overflow:hidden}.sdk-autocomplete{display:flex;align-items:center;align-content:center;flex-wrap:nowrap;white-space:nowrap;padding:10px 16px;border-radius:8px;height:44px;min-width:256px;cursor:pointer;position:relative;z-index:3;border-color:var(--regular-a50);border-width:1px;border-style:solid;transition:.4s}.sdk-autocomplete.invalid{transition:all .2s ease;border-color:var(--warn);background-color:var(--warn-a20-rgb)}.sdk-autocomplete.full-width{width:100%}.sdk-autocomplete.small{padding:5px 12px;height:32px}.sdk-autocomplete.small .sdk-autocomplete-input{font-size:15px}.sdk-autocomplete.small .sdk-autocomplete-icon{margin-right:4px}.sdk-autocomplete.active{z-index:23;border-color:var(--regular-a100)}.sdk-autocomplete .sdk-autocomplete-icon{margin-right:8px}.sdk-autocomplete .sdk-autocomplete-input,.sdk-autocomplete .sdk-autocomplete-value{flex-basis:100%;color:var(--base-a90);background-color:transparent;max-width:100%;font-size:17px;font-weight:400;line-height:24px;outline:none;border:none;transition:all .4s;font-family:Inter,sans-serif;overflow:hidden;white-space:nowrap;-ms-text-overflow:ellipsis;text-overflow:ellipsis}.sdk-menu-more__item-icon{height:16px;width:20px;position:relative;top:2px}.sdk-autocomplete__arrow-button{outline:none;display:flex;margin:auto auto auto -32px;cursor:pointer;transition:transform .2s,opacity .2s}.sdk-autocomplete__arrow-button:hover{opacity:.8}.sdk-autocomplete__overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:20}.select__arrow-button--open img{transform:rotate(180deg)}.inactive{color:var(--base-a50)}.sdk-autocomplete__interface-icon{transition:all .4s}.sdk-autocomplete__interface-icon:hover{opacity:.6}.sdk-autocomplete__interface-icon .interface-icon__wrapper--open{height:24px;width:24px}.sdk-autocomplete__interface-icon .interface-icon__wrapper--clear{height:16px;width:16px}.interface-icon-wrap{display:flex;align-items:center;justify-content:center;width:24px;height:24px;transition:all .2s}.interface-icon-wrap.active{transform:scaleY(-1)}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.IconComponent, selector: "sdk-icon", inputs: ["icon", "image", "inline", "size", "color"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: AutocompleteComponent, decorators: [{ type: Component, args: [{ selector: 'sdk-autocomplete', providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => AutocompleteComponent), multi: true } ], template: "<label for=\"{{uid}}\" class=\"sdk-autocomplete-label\"\n [class.active]=\"value !== undefined\"\n [class.small]=\"small\">\n {{label}}\n <span *ngIf=\"required\" class=\"sdk-autocomplete-label-required-mark\">&nbsp;*</span>\n</label>\n\n<div class=\"sdk-autocomplete-wrap\" #autocomplete>\n <div class=\"sdk-autocomplete\" (click)=\"showDropdown()\"\n [ngClass]=\"{\n active: isOpen,\n small: small,\n invalid: error\n }\">\n <span class=\"sdk-autocomplete-icon\" *ngIf=\"icon\">\n <sdk-icon [icon]=\"icon\" [size]=\"small ? 16 : 24\"></sdk-icon>\n </span>\n <input class=\"sdk-autocomplete-input\" type=\"text\"\n value=\"{{selected()}}\"\n id=\"{{uid}}\"\n [placeholder]=\"placeholder\"\n (keyup)=\"onInput($event)\"\n (focus)=\"emitFocus()\"\n (blur)=\"emitBlur()\"\n #input>\n <span class=\"sdk-autocomplete-actions\">\n <ng-container *ngIf=\"!hasValuesToDrop()\">\n <div class=\"interface-icon-wrap icon-chevron\" [class.active]=\"isOpen\">\n <sdk-icon icon=\"chevron_down\" [size]=\"24\"></sdk-icon>\n </div>\n </ng-container>\n <ng-container *ngIf=\"hasValuesToDrop()\">\n <div class=\"interface-icon-wrap icon-clear\">\n <sdk-icon icon=\"close\" [size]=\"16\" [inline]=\"true\" (click)=\"clearValue($event)\"></sdk-icon>\n </div>\n </ng-container>\n </span>\n </div>\n</div>\n\n<div class=\"sdk-caption\" *ngIf=\"caption\">\n {{caption}}\n</div>\n<div class=\"sdk-error\" *ngIf=\"error\">\n <sdk-icon icon=\"alert\" size=\"12\"></sdk-icon>\n {{error ? error : ''}}\n</div>\n", styles: [":host{display:flex;width:100%;flex-direction:column;margin-bottom:10px;position:relative}:host.sdk-autocomplete--invalid{animation:shake .4s}:host.disabled{opacity:.6;pointer-events:none;cursor:default}.sdk-autocomplete-label-required-mark{color:var(--warn)}.sdk-autocomplete-label{color:var(--base-a50);transition:all .2s;font-size:17px;margin-bottom:2px}.sdk-autocomplete-label.small{font-size:15px}.sdk-autocomplete-label.active{color:var(--base-a90)}.sdk-autocomplete-wrap{position:relative;background-color:var(--background-a90);border-radius:8px;overflow:hidden}.sdk-autocomplete{display:flex;align-items:center;align-content:center;flex-wrap:nowrap;white-space:nowrap;padding:10px 16px;border-radius:8px;height:44px;min-width:256px;cursor:pointer;position:relative;z-index:3;border-color:var(--regular-a50);border-width:1px;border-style:solid;transition:.4s}.sdk-autocomplete.invalid{transition:all .2s ease;border-color:var(--warn);background-color:var(--warn-a20-rgb)}.sdk-autocomplete.full-width{width:100%}.sdk-autocomplete.small{padding:5px 12px;height:32px}.sdk-autocomplete.small .sdk-autocomplete-input{font-size:15px}.sdk-autocomplete.small .sdk-autocomplete-icon{margin-right:4px}.sdk-autocomplete.active{z-index:23;border-color:var(--regular-a100)}.sdk-autocomplete .sdk-autocomplete-icon{margin-right:8px}.sdk-autocomplete .sdk-autocomplete-input,.sdk-autocomplete .sdk-autocomplete-value{flex-basis:100%;color:var(--base-a90);background-color:transparent;max-width:100%;font-size:17px;font-weight:400;line-height:24px;outline:none;border:none;transition:all .4s;font-family:Inter,sans-serif;overflow:hidden;white-space:nowrap;-ms-text-overflow:ellipsis;text-overflow:ellipsis}.sdk-menu-more__item-icon{height:16px;width:20px;position:relative;top:2px}.sdk-autocomplete__arrow-button{outline:none;display:flex;margin:auto auto auto -32px;cursor:pointer;transition:transform .2s,opacity .2s}.sdk-autocomplete__arrow-button:hover{opacity:.8}.sdk-autocomplete__overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:20}.select__arrow-button--open img{transform:rotate(180deg)}.inactive{color:var(--base-a50)}.sdk-autocomplete__interface-icon{transition:all .4s}.sdk-autocomplete__interface-icon:hover{opacity:.6}.sdk-autocomplete__interface-icon .interface-icon__wrapper--open{height:24px;width:24px}.sdk-autocomplete__interface-icon .interface-icon__wrapper--clear{height:16px;width:16px}.interface-icon-wrap{display:flex;align-items:center;justify-content:center;width:24px;height:24px;transition:all .2s}.interface-icon-wrap.active{transform:scaleY(-1)}\n"] }] }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID] }] }, { type: i1.DropdownService }, { type: i2.OptionsService }, { type: i0.Renderer2 }, { type: i3.LayoutControlService }]; }, propDecorators: { options: [{ type: Input }], required: [{ type: Input }], autocomplete: [{ type: ViewChild, args: ['autocomplete', { static: true }] }], inputElementRef: [{ type: ViewChild, args: ['input', { static: true }] }], label: [{ type: Input }], placeholder: [{ type: Input }], disabled: [{ type: Input }], small: [{ type: Input }], icon: [{ type: Input }], caption: [{ type: Input }], focusEvent: [{ type: Output }], blurEvent: [{ type: Output }], resultEvent: [{ type: Output }], valueChanges: [{ type: Output }], error: [{ type: Input }, { type: HostBinding, args: ['class.invalid'] }], isDisabled: [{ type: Input }, { type: HostBinding, args: ['class.disabled'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../libs/ngx-slice-kit/src/lib/dropdowns/autocomplete/autocomplete.component.ts","../../../../../../libs/ngx-slice-kit/src/lib/dropdowns/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Inject,\n    Input,\n    OnDestroy,\n    Output,\n    PLATFORM_ID,\n    Renderer2,\n    ViewChild\n} from '@angular/core';\nimport { DOCUMENT, isPlatformServer } from '@angular/common';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { BehaviorSubject, fromEvent, Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport { OptionModel } from '../dropdown-option.model';\nimport { DropdownOptions } from '../dropdown.model';\nimport { DropdownService } from '../dropdown.service';\nimport { OptionsService } from '../options.service';\nimport { LayoutControlService } from '../../core/layout-control/layout-control.service';\n\n@Component({\n    selector: 'sdk-autocomplete',\n    templateUrl: './autocomplete.component.html',\n    styleUrls: ['./autocomplete.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => AutocompleteComponent),\n            multi: true\n        }\n    ]\n})\nexport class AutocompleteComponent implements ControlValueAccessor, OnDestroy {\n\n    private $options: BehaviorSubject<OptionModel[]> = new BehaviorSubject<OptionModel[]>(null);\n    private req: boolean;\n\n    @Input() public set options(o: OptionModel[]) {\n        this.$options.next(o);\n        if (this.isOpen) {\n            this.optionsService.options = this.getOptions();\n        }\n    }\n\n    public get options(): OptionModel[] {\n        return this.$options.getValue();\n    }\n\n    @Input() public set required(val: any) {\n        this.req = val === '' || val === true;\n    }\n\n    public get required(): any {\n        return this.req;\n    }\n\n    public sub: Subscription;\n    @ViewChild('autocomplete', {static: true}) public autocomplete: ElementRef;\n    @ViewChild('input', {static: true}) public inputElementRef: ElementRef;\n    @Input() public label = '';\n    @Input() public placeholder = '';\n    @Input() public disabled: boolean;\n    @Input() public small: boolean = false;\n    @Input() public icon: string;\n    @Input() public caption: string = '';\n\n    @Output() public focusEvent: EventEmitter<any> = new EventEmitter();\n    @Output() public blurEvent: EventEmitter<any> = new EventEmitter();\n    @Output() public resultEvent: EventEmitter<any> = new EventEmitter();\n    @Output() public valueChanges: EventEmitter<any> = new EventEmitter();\n\n    @Input() @HostBinding('class.invalid')\n    public error: string = undefined;\n\n    @Input() @HostBinding('class.disabled')\n    public get isDisabled(): boolean {\n        return this.disabled;\n    }\n\n    public isOpen: boolean;\n    public focused: boolean;\n    public currentValue: OptionModel;\n    public currentValues: Set<OptionModel>;\n    public uid: string;\n\n    public value: string = '';\n\n    constructor(\n        @Inject(DOCUMENT) private document: any,\n        @Inject(PLATFORM_ID) private platformId: any,\n        private dropdownService: DropdownService,\n        private optionsService: OptionsService,\n        private renderer: Renderer2,\n        private layoutControlService: LayoutControlService\n    ) {\n        this.uid = layoutControlService.generateLayoutElementHash();\n    }\n\n    public getOptions(): OptionModel[] {\n        return [...this.options].map(o => {\n            o.selected = this.currentValue === o;\n            return o;\n        });\n    }\n\n    public isInactive(): boolean {\n        return !this.currentValue;\n    }\n\n    public hasValuesToDrop(): boolean {\n        return !this.isInactive();\n    }\n\n    public onOpen(): void {\n        this.isOpen = true;\n        this.emitFocus();\n    }\n\n    public onClose(): void {\n        this.isOpen = false;\n        this.emitBlur();\n    }\n\n    public emitBlur(): void {\n        if (this.focused) {\n            this.focused = false;\n            this.blurEvent.emit();\n        }\n    }\n\n    public emitFocus(): void {\n        if (!this.focused) {\n            this.focused = true;\n            this.focusEvent.emit();\n        }\n    }\n\n    public selected(): string {\n        return this.currentValue?.label ?? '';\n    }\n\n    public onResult(option: OptionModel): void {\n        this.onTouched();\n        this.writeValue(option);\n    }\n\n    public writeValue(val): void {\n        if (val?.size > 0) {\n            this.currentValues = val;\n            const multipleResult = this.options.filter(o => this.currentValues.has(o));\n            this.onChange(multipleResult);\n            this.resultEvent.emit(multipleResult);\n        } else {\n            this.currentValue = val;\n            this.onChange(val);\n            this.resultEvent.emit(this.currentValue);\n        }\n    }\n\n    public addValue(o: OptionModel): void {\n        const alreadySelected = this.currentValues.has(o);\n        o.selected = !alreadySelected;\n        alreadySelected ? this.currentValues.delete(o) : this.currentValues.add(o);\n        this.writeValue(this.currentValues);\n    }\n\n    public clearValue(e): void {\n        e.stopPropagation();\n        this.valueChanges.emit(null);\n        this.currentValue = undefined;\n        this.writeValue(undefined);\n    }\n\n    public onChange(value): void {\n    }\n\n    public onTouched(): void {\n    }\n\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    public registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    public setDisabledState?(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    public setInputSubscription(): void {\n        this.sub = fromEvent(this.inputElementRef.nativeElement, `keyup`).pipe(\n            debounceTime(500)\n        ).subscribe((e: any) => {\n            if (e.code === 'ArrowUp' ||\n                e.code === 'ArrowDown' ||\n                e.code === 'Escape' ||\n                e.code === 'Enter') {\n                e.preventDefault();\n                e.stopPropagation();\n                return;\n            }\n\n            const value = e?.target?.value;\n            this.valueChanges.emit(value);\n        });\n    }\n\n    public onInput(ev: any): void {\n        if (ev.code === 'ArrowUp' ||\n            ev.code === 'ArrowDown' ||\n            ev.code === 'Escape' ||\n            ev.code === 'Enter') {\n            ev.preventDefault();\n            ev.stopPropagation();\n            return;\n        }\n        const value = ev?.target?.value;\n        this.valueChanges.emit(value);\n    }\n\n    public showDropdown(): void {\n        if (isPlatformServer(this.platformId)) {\n            return;\n        }\n\n        if (this.isOpen) {\n            return;\n        }\n        this.onOpen();\n        this.optionsService.options = this.getOptions();\n\n        const opts: DropdownOptions = {\n            triggerRect: this.autocomplete.nativeElement.getBoundingClientRect(),\n            fitWidth: true,\n            multi: false,\n            hideBackdrop: true,\n            parentElem: this.autocomplete.nativeElement,\n        };\n\n        this.dropdownService.showDropdown(opts).subscribe(res => {\n            this.onClose();\n            // this.optionsService.options = null;\n            if (res) {\n                this.inputElementRef.nativeElement.blur();\n                this.onResult(res);\n            }\n        });\n    }\n\n    // public ngOnInit(): void {\n    //     // this.setInputSubscription();\n    // }\n\n    public ngOnDestroy(): void {\n        this.sub?.unsubscribe();\n        this.blurEvent.complete();\n        this.focusEvent.complete();\n        this.resultEvent.complete();\n        this.valueChanges.complete();\n    }\n}\n","<label for=\"{{uid}}\" class=\"sdk-autocomplete-label\"\n       [class.active]=\"value !== undefined\"\n       [class.small]=\"small\">\n    {{label}}\n    <span *ngIf=\"required\" class=\"sdk-autocomplete-label-required-mark\">&nbsp;*</span>\n</label>\n\n<div class=\"sdk-autocomplete-wrap\" #autocomplete>\n    <div class=\"sdk-autocomplete\" (click)=\"showDropdown()\"\n         [ngClass]=\"{\n            active: isOpen,\n            small: small,\n            invalid: error\n         }\">\n        <span class=\"sdk-autocomplete-icon\" *ngIf=\"icon\">\n            <sdk-icon [icon]=\"icon\" [size]=\"small ? 16 : 24\"></sdk-icon>\n        </span>\n        <input class=\"sdk-autocomplete-input\" type=\"text\"\n               value=\"{{selected()}}\"\n               id=\"{{uid}}\"\n               [placeholder]=\"placeholder\"\n               (keyup)=\"onInput($event)\"\n               (focus)=\"emitFocus()\"\n               (blur)=\"emitBlur()\"\n               #input>\n        <span class=\"sdk-autocomplete-actions\">\n            <ng-container *ngIf=\"!hasValuesToDrop()\">\n                <div class=\"interface-icon-wrap icon-chevron\" [class.active]=\"isOpen\">\n                    <sdk-icon icon=\"chevron_down\" [size]=\"24\"></sdk-icon>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"hasValuesToDrop()\">\n                <div class=\"interface-icon-wrap icon-clear\">\n                    <sdk-icon icon=\"close\" [size]=\"16\" [inline]=\"true\" (click)=\"clearValue($event)\"></sdk-icon>\n                </div>\n            </ng-container>\n        </span>\n    </div>\n</div>\n\n<div class=\"sdk-caption\" *ngIf=\"caption\">\n    {{caption}}\n</div>\n<div class=\"sdk-error\" *ngIf=\"error\">\n    <sdk-icon icon=\"alert\" size=\"12\"></sdk-icon>\n    {{error ? error : ''}}\n</div>\n"]}