ngx-slice-kit
Version:
[](https://badge.fury.io/js/ngx-slice-kit)
254 lines • 40.4 kB
JavaScript
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\"> *</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\"> *</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"]}