@evotor-dev/ui-kit 6.8.0 → 6.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (19) hide show
  1. package/bundles/evotor-dev-ui-kit.umd.js +107 -28
  2. package/bundles/evotor-dev-ui-kit.umd.js.map +1 -1
  3. package/esm2015/lib/components/evo-autocomplete/components/evo-autocomplete/evo-autocomplete.component.js +393 -0
  4. package/esm2015/lib/components/evo-autocomplete/components/evo-autocomplete-default-option/evo-autocomplete-default-option.component.js +49 -0
  5. package/esm2015/lib/components/evo-autocomplete/components/evo-autocomplete-footer/evo-autocomplete-footer.component.js +16 -0
  6. package/esm2015/lib/components/evo-autocomplete/components/evo-autocomplete-header/evo-autocomplete-header.component.js +16 -0
  7. package/esm2015/lib/components/evo-autocomplete/evo-autocomplete.module.js +15 -5
  8. package/esm2015/lib/components/evo-autocomplete/public-api.js +5 -3
  9. package/fesm2015/evotor-dev-ui-kit.js +88 -24
  10. package/fesm2015/evotor-dev-ui-kit.js.map +1 -1
  11. package/lib/components/evo-autocomplete/components/{evo-autocomplete.component.d.ts → evo-autocomplete/evo-autocomplete.component.d.ts} +14 -7
  12. package/lib/components/evo-autocomplete/components/evo-autocomplete-footer/evo-autocomplete-footer.component.d.ts +5 -0
  13. package/lib/components/evo-autocomplete/components/evo-autocomplete-header/evo-autocomplete-header.component.d.ts +5 -0
  14. package/lib/components/evo-autocomplete/evo-autocomplete.module.d.ts +12 -10
  15. package/lib/components/evo-autocomplete/public-api.d.ts +4 -2
  16. package/package.json +1 -1
  17. package/esm2015/lib/components/evo-autocomplete/components/evo-autocomplete.component.js +0 -365
  18. package/esm2015/lib/components/evo-autocomplete/components/templates/evo-autocomplete-default-option.component.js +0 -49
  19. /package/lib/components/evo-autocomplete/components/{templates → evo-autocomplete-default-option}/evo-autocomplete-default-option.component.d.ts +0 -0
@@ -0,0 +1,393 @@
1
+ import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
2
+ import { merge, Subject } from 'rxjs';
3
+ import { NgSelectComponent } from '@ng-select/ng-select';
4
+ import { delay, takeUntil, tap } from 'rxjs/operators';
5
+ import { isNull } from 'lodash-es';
6
+ import { EvoInputTheme } from '../../../evo-input';
7
+ import { iconDecline } from '@evotor-dev/ui-kit/icons/system';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/forms";
10
+ import * as i2 from "@ng-select/ng-select";
11
+ import * as i3 from "../../../evo-control-error/evo-control-error.component";
12
+ import * as i4 from "../../../../directives/evo-ui-class.directive";
13
+ import * as i5 from "@angular/common";
14
+ const DEFAULT_NOT_FOUND_TEXT = 'Не найдено';
15
+ export class EvoAutocompleteComponent {
16
+ constructor(cdr, control) {
17
+ this.cdr = cdr;
18
+ this.control = control;
19
+ this.theme = EvoInputTheme.default;
20
+ this.size = 'normal';
21
+ this.isFocused = false;
22
+ this.isSelectbox = false;
23
+ this.markFirst = true;
24
+ this.addTagText = 'Добавить тэг';
25
+ this.loadingText = 'Идет поиск...';
26
+ this.dropdownPosition = 'auto';
27
+ this.closeOnSelect = true;
28
+ this.bufferAmount = 4;
29
+ this.selectableGroupAsModel = true;
30
+ this.clearOnBackspace = true;
31
+ this.clearable = true;
32
+ // Fix: https://github.com/ng-select/ng-select/pull/1257
33
+ // Don't work with custom template - labelTemp
34
+ this.editQuery = false;
35
+ // Outputs
36
+ /* eslint-disable @angular-eslint/no-output-rename */
37
+ this.blurEvent = new EventEmitter();
38
+ this.focusEvent = new EventEmitter();
39
+ this.changeEvent = new EventEmitter();
40
+ this.openEvent = new EventEmitter();
41
+ this.closeEvent = new EventEmitter();
42
+ this.searchEvent = new EventEmitter();
43
+ this.clearEvent = new EventEmitter();
44
+ this.addEvent = new EventEmitter();
45
+ this.removeEvent = new EventEmitter();
46
+ this.scrollEvent = new EventEmitter();
47
+ this.scrollToEndEvent = new EventEmitter();
48
+ this._destroy$ = new Subject();
49
+ this._onChange = (value) => { };
50
+ this._onTouched = () => { };
51
+ control.valueAccessor = this;
52
+ }
53
+ get notFoundText() {
54
+ if (this.isSelectbox) {
55
+ return this._notFoundText || '';
56
+ }
57
+ return this._notFoundText || DEFAULT_NOT_FOUND_TEXT;
58
+ }
59
+ set searchable(searchable) {
60
+ this._searchable = searchable;
61
+ }
62
+ get searchable() {
63
+ var _a;
64
+ return (_a = this._searchable) !== null && _a !== void 0 ? _a : !this.isSelectbox;
65
+ }
66
+ set setSelectbox(isSelectbox) {
67
+ this.clearable = false;
68
+ this.editQuery = false;
69
+ this.isSelectbox = isSelectbox;
70
+ }
71
+ set setTheme(theme) {
72
+ if (EvoInputTheme[theme]) {
73
+ this.theme = EvoInputTheme[theme];
74
+ }
75
+ }
76
+ get hasErrors() {
77
+ return this.control.dirty && this.control.touched && this.control.invalid;
78
+ }
79
+ get classes() {
80
+ return {
81
+ 'is-multiple-inline': this.multipleInline,
82
+ 'is-edit-query': this.editQuery,
83
+ 'is-selectbox': this.isSelectbox,
84
+ disabled: this.control.disabled,
85
+ touched: this.control.touched,
86
+ valid: this.control.valid,
87
+ invalid: this.control.invalid,
88
+ [`theme-${this.theme}`]: true,
89
+ [`size-${this.size}`]: true,
90
+ };
91
+ }
92
+ get value() {
93
+ return this._value;
94
+ }
95
+ set value(value) {
96
+ if (value !== this._value) {
97
+ this._value = value;
98
+ this._onChange(value);
99
+ }
100
+ }
101
+ getMultipleInlineItemsLabels(items) {
102
+ if (!items || !Array.isArray(items) || items.length === 0) {
103
+ return '';
104
+ }
105
+ return items
106
+ .map((item) => item[this.bindLabel] || '')
107
+ .filter((item) => item !== '')
108
+ .join(', ');
109
+ }
110
+ ngAfterViewInit() {
111
+ if (this.editQuery) {
112
+ this.editQueryMode();
113
+ }
114
+ this.patchClearButtonIcon();
115
+ // prevent option click to close evo-modal
116
+ this.ngSelectComponent.element.addEventListener('click', (e) => {
117
+ if (e.target.closest('.ng-option')) {
118
+ e.stopPropagation();
119
+ }
120
+ });
121
+ // Allows to mark view for check
122
+ // if control was validated with FormHelper.validate
123
+ // and it's touched
124
+ this.control.control.statusChanges
125
+ .pipe(takeUntil(this._destroy$), tap(() => this.cdr.markForCheck()))
126
+ .subscribe();
127
+ }
128
+ ngOnDestroy() {
129
+ this._destroy$.next();
130
+ this._destroy$.complete();
131
+ }
132
+ writeValue(value) {
133
+ this.value = value;
134
+ if (this.ngSelectComponent) {
135
+ this.ngSelectComponent.writeValue(value);
136
+ }
137
+ }
138
+ registerOnChange(fn) {
139
+ this._onChange = fn;
140
+ }
141
+ registerOnTouched(fn) {
142
+ this._onTouched = fn;
143
+ }
144
+ setDisabledState(isDisabled) {
145
+ if (this.ngSelectComponent) {
146
+ this.ngSelectComponent.setDisabledState(isDisabled);
147
+ }
148
+ }
149
+ // TODO: investigate and remove
150
+ editQueryMode() {
151
+ const ngSelectEl = this.ngSelectComponent.element;
152
+ this.inputEl = ngSelectEl.querySelector('.ng-input input');
153
+ const streams$ = [
154
+ this.changeEvent.pipe(delay(0), tap(() => {
155
+ this.resetSearchQuery();
156
+ this.inputEl.value = this.inputVal || '';
157
+ })),
158
+ this.closeEvent.pipe(delay(0), tap(() => {
159
+ this.resetSearchQuery();
160
+ if (ngSelectEl.classList.contains('ng-select-focused')) {
161
+ this.inputEl.value = this.inputVal || '';
162
+ }
163
+ })),
164
+ this.focusEvent.pipe(tap(() => {
165
+ this.resetSearchQuery();
166
+ this.inputEl.value = this.inputVal || '';
167
+ })),
168
+ this.blurEvent.pipe(tap(() => {
169
+ this.inputEl.value = '';
170
+ })),
171
+ ];
172
+ if (this.control.valueChanges) {
173
+ streams$.push(this.control.valueChanges.pipe(tap((value) => {
174
+ if (!isNull(value)) {
175
+ this.resetSearchQuery();
176
+ return;
177
+ }
178
+ this.inputVal = '';
179
+ this.inputEl.value = '';
180
+ })));
181
+ }
182
+ merge(...streams$)
183
+ .pipe(takeUntil(this._destroy$))
184
+ .subscribe();
185
+ }
186
+ resetSearchQuery() {
187
+ const currentItem = this.ngSelectComponent.selectedItems[0];
188
+ this.inputVal = (currentItem === null || currentItem === void 0 ? void 0 : currentItem.label) || '';
189
+ }
190
+ focus() {
191
+ this.ngSelectComponent.focus();
192
+ }
193
+ blur() {
194
+ this.ngSelectComponent.blur();
195
+ }
196
+ open() {
197
+ this.ngSelectComponent.open();
198
+ }
199
+ close() {
200
+ this.ngSelectComponent.close();
201
+ }
202
+ onFocus(event) {
203
+ this.isFocused = true;
204
+ this._onTouched();
205
+ if (this.control.value) {
206
+ this.focusEvent.emit(event);
207
+ }
208
+ }
209
+ onBlur(event) {
210
+ this.isFocused = false;
211
+ this.blurEvent.emit(event);
212
+ }
213
+ onClearClick() {
214
+ this.ngSelectComponent.handleClearClick();
215
+ }
216
+ /**
217
+ * Try to patch clear button icon
218
+ */
219
+ patchClearButtonIcon() {
220
+ const originalShowClearFn = this.ngSelectComponent.showClear;
221
+ const ngSelectElement = this.ngSelectComponent;
222
+ let patchTimeout = null;
223
+ this.ngSelectComponent.showClear = function () {
224
+ const isClearButtonVisible = originalShowClearFn.bind(this)();
225
+ if (isClearButtonVisible) {
226
+ if (patchTimeout) {
227
+ clearTimeout(patchTimeout);
228
+ }
229
+ patchTimeout = setTimeout(() => {
230
+ const ngClearWrapperElement = ngSelectElement.element.querySelector('.ng-clear-wrapper');
231
+ if (!ngClearWrapperElement) {
232
+ return;
233
+ }
234
+ // tslint:disable-next-line:max-line-length
235
+ ngClearWrapperElement.innerHTML = `<span class="ng-clear ng-clear_patched"><svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">${iconDecline}</svg></span>`;
236
+ });
237
+ }
238
+ return isClearButtonVisible;
239
+ };
240
+ }
241
+ }
242
+ EvoAutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EvoAutocompleteComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NgControl }], target: i0.ɵɵFactoryTarget.Component });
243
+ EvoAutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: EvoAutocompleteComponent, selector: "evo-autocomplete", inputs: { size: "size", isOpen: "isOpen", items: "items", bindLabel: "bindLabel", bindValue: "bindValue", markFirst: "markFirst", placeholder: "placeholder", typeToSearchText: "typeToSearchText", addTagText: "addTagText", loadingText: "loadingText", clearAllText: "clearAllText", dropdownPosition: "dropdownPosition", appendTo: "appendTo", loading: "loading", closeOnSelect: "closeOnSelect", hideSelected: "hideSelected", selectOnTab: "selectOnTab", openOnEnter: "openOnEnter", maxSelectedItems: "maxSelectedItems", groupBy: "groupBy", groupValue: "groupValue", bufferAmount: "bufferAmount", virtualScroll: "virtualScroll", selectableGroup: "selectableGroup", selectableGroupAsModel: "selectableGroupAsModel", searchFn: "searchFn", clearOnBackspace: "clearOnBackspace", typeahead: "typeahead", multiple: "multiple", multipleInline: "multipleInline", addTag: "addTag", clearable: "clearable", errorsMessages: "errorsMessages", compareWith: "compareWith", _notFoundText: ["notFoundText", "_notFoundText"], editQuery: "editQuery", searchable: "searchable", setSelectbox: ["isSelectbox", "setSelectbox"], setTheme: ["theme", "setTheme"] }, outputs: { blurEvent: "blur", focusEvent: "focus", changeEvent: "change", openEvent: "open", closeEvent: "close", searchEvent: "search", clearEvent: "clear", addEvent: "add", removeEvent: "remove", scrollEvent: "scroll", scrollToEndEvent: "scrollToEnd" }, queries: [{ propertyName: "labelTemp", first: true, predicate: ["labelTemp"], descendants: true, read: TemplateRef }, { propertyName: "multiLabelTemp", first: true, predicate: ["multiLabelTemp"], descendants: true, read: TemplateRef }, { propertyName: "optionTemp", first: true, predicate: ["optionTemp"], descendants: true, read: TemplateRef }, { propertyName: "optgroupTemp", first: true, predicate: ["optgroupTemp"], descendants: true, read: TemplateRef }, { propertyName: "headerTemp", first: true, predicate: ["headerTemp"], descendants: true, read: TemplateRef }, { propertyName: "footerTemp", first: true, predicate: ["footerTemp"], descendants: true, read: TemplateRef }, { propertyName: "notFoundTemp", first: true, predicate: ["notFoundTemp"], descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "ngSelectComponent", first: true, predicate: NgSelectComponent, descendants: true }], ngImport: i0, template: "<div class=\"evo-autocomplete\" [evoUiClass]=\"classes\">\n <ng-select\n [items]=\"items\"\n [bindLabel]=\"bindLabel\"\n [bindValue]=\"bindValue\"\n [markFirst]=\"markFirst\"\n [placeholder]=\"placeholder\"\n [notFoundText]=\"notFoundText\"\n [typeToSearchText]=\"typeToSearchText\"\n [addTagText]=\"addTagText\"\n [loadingText]=\"loadingText\"\n [clearAllText]=\"clearAllText\"\n [dropdownPosition]=\"dropdownPosition\"\n [appendTo]=\"appendTo\"\n [loading]=\"loading\"\n [closeOnSelect]=\"closeOnSelect\"\n [hideSelected]=\"hideSelected\"\n [selectOnTab]=\"selectOnTab\"\n [openOnEnter]=\"openOnEnter\"\n [maxSelectedItems]=\"maxSelectedItems\"\n [groupBy]=\"groupBy\"\n [groupValue]=\"groupValue\"\n [bufferAmount]=\"bufferAmount\"\n [virtualScroll]=\"virtualScroll\"\n [selectableGroup]=\"selectableGroup\"\n [selectableGroupAsModel]=\"selectableGroupAsModel\"\n [searchFn]=\"searchFn\"\n [clearOnBackspace]=\"clearOnBackspace\"\n [typeahead]=\"typeahead\"\n [multiple]=\"multiple || multipleInline\"\n [addTag]=\"addTag\"\n [searchable]=\"searchable\"\n [clearable]=\"clearable\"\n [isOpen]=\"isOpen\"\n [editableSearchTerm]=\"editQuery\"\n [disabled]=\"control.disabled\"\n [compareWith]=\"compareWith\"\n [(ngModel)]=\"value\"\n (blur)=\"onBlur($event)\"\n (focus)=\"onFocus($event)\"\n (change)=\"changeEvent.emit($event)\"\n (open)=\"openEvent.emit($event)\"\n (close)=\"closeEvent.emit($event)\"\n (search)=\"searchEvent.emit($event)\"\n (clear)=\"clearEvent.emit($event)\"\n (add)=\"addEvent.emit($event)\"\n (remove)=\"removeEvent.emit($event)\"\n (scroll)=\"scrollEvent.emit($event)\"\n (scrollToEnd)=\"scrollToEndEvent.emit($event)\"\n >\n <!-- Selected Item Template -->\n <ng-template *ngIf=\"labelTemp\" ng-label-tmp let-item=\"item\">\n <ng-template *ngTemplateOutlet=\"labelTemp; context: { item: item }\"></ng-template>\n </ng-template>\n\n <!-- Overall Label For All Selected Items Template -->\n <ng-template *ngIf=\"multiLabelTemp\" ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n <ng-template *ngTemplateOutlet=\"multiLabelTemp; context: { items: items, clear: clear }\"></ng-template>\n </ng-template>\n\n <!-- Options header template -->\n <ng-template *ngIf=\"headerTemp\" ng-header-tmp>\n <ng-template *ngTemplateOutlet=\"headerTemp; context: {items: items}\"></ng-template>\n </ng-template>\n\n <!-- Option Template -->\n <ng-template\n *ngIf=\"optionTemp\"\n ng-option-tmp\n let-item=\"item\"\n let-index=\"index\"\n let-search=\"searchTerm\"\n let-item$=\"item$\"\n >\n <ng-template\n *ngTemplateOutlet=\"optionTemp; context: { item: item, index: index, searchTerm: search, item$: item$}\"\n ></ng-template>\n </ng-template>\n\n <ng-container *ngIf=\"multipleInline && !multiLabelTemp\">\n <ng-template ng-multi-label-tmp let-items=\"items\">\n <div class=\"ng-value\">{{ getMultipleInlineItemsLabels(items) }}</div>\n </ng-template>\n </ng-container>\n\n <!-- Options group template -->\n <ng-template *ngIf=\"optgroupTemp\" ng-optgroup-tmp let-item=\"item\" let-index=\"index\">\n <ng-template *ngTemplateOutlet=\"optgroupTemp; context: { item: item, index: index }\"></ng-template>\n </ng-template>\n\n <!-- Search Text Templates -->\n <ng-template ng-typetosearch-tmp>\n <div *ngIf=\"typeToSearchText\" class=\"ng-option disabled\">{{typeToSearchText}}</div>\n </ng-template>\n <ng-template ng-loadingtext-tmp let-searchTerm=\"searchTerm\">\n <div class=\"ng-option disabled\">{{loadingText}}</div>\n </ng-template>\n\n <ng-container *ngIf=\"notFoundTemp; else defaultNotFoundTemplate\">\n <ng-template ng-notfound-tmp let-searchTerm=\"searchTerm\">\n <ng-template *ngTemplateOutlet=\"notFoundTemp; context: {searchTerm: searchTerm}\"></ng-template>\n </ng-template>\n </ng-container>\n <ng-template #defaultNotFoundTemplate>\n <ng-template ng-notfound-tmp>\n <div class=\"ng-option disabled\">{{notFoundText}}</div>\n </ng-template>\n </ng-template>\n\n <!-- Options footer template -->\n <ng-template *ngIf=\"footerTemp\" ng-footer-tmp>\n <ng-template *ngTemplateOutlet=\"footerTemp; context: {items: items}\"></ng-template>\n </ng-template>\n </ng-select>\n <evo-control-error\n *ngIf=\"hasErrors && errorsMessages\"\n [errors]=\"control.errors\"\n [errorsMessages]=\"errorsMessages\"\n ></evo-control-error>\n</div>\n", styles: ["@keyframes evo-fx-blink{50%{transform:scale(1);opacity:1}to{opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes gradient{0%{background-position:0 50%}50%{background-position:50vw 50%}to{background-position:100vw 50%}}evo-autocomplete{--evo-dropdown-max-height: 310px;--evo-autocomplete-option-overflow: hidden;--evo-autocomplete-option-text-overflow: ellipsis;--evo-autocomplete-option-white-space: nowrap;--evo-autocomplete-optgroup-overflow: hidden;--evo-autocomplete-optgroup-text-overflow: ellipsis;--evo-autocomplete-optgroup-white-space: nowrap;--evo-autocomplete-arrow-icon-color: #212121;--evo-autocomplete-option-v-padding: 12px;--evo-autocomplete-option-h-padding: 16px;--evo-autocomplete-panel-border-radius: 8px;--evo-autocomplete-panel-shadow: 0px 8px 10px rgba(0, 0, 0, .14), 0px 3px 14px rgba(0, 0, 0, .12)}evo-autocomplete .evo-autocomplete{--inner-input-padding-right: 40px;position:relative;display:block}evo-autocomplete .evo-autocomplete ng-select[ng-reflect-clearable=false]{--inner-input-padding-right: 16px}evo-autocomplete .evo-autocomplete__icon{display:block;flex:0 0 24px;width:24px;height:24px}evo-autocomplete .evo-autocomplete__icon_clear{position:absolute;top:12px;right:12px;z-index:1001;cursor:pointer;transition:fill .3s;fill:#91b1b8}evo-autocomplete .evo-autocomplete__icon_clear:hover{fill:#a7c1c6}evo-autocomplete .evo-autocomplete__icon_clear:active{fill:#829fa6}evo-autocomplete .evo-autocomplete__icon_dropdown{fill:#212121}evo-autocomplete .evo-autocomplete .ng-input{padding:0 var(--inner-input-padding-right) 0 16px}evo-autocomplete .evo-autocomplete .ng-placeholder{color:#9b9b9b}evo-autocomplete .evo-autocomplete .ng-value-container{align-items:center;min-width:0;overflow:hidden}evo-autocomplete .evo-autocomplete .ng-value{overflow:hidden;text-overflow:ellipsis}evo-autocomplete .evo-autocomplete .ng-select-container{--evo-input-height: 48px;--evo-input-border-radius: 4px;--evo-input-font-size: 16px;display:flex;height:var(--evo-input-height);color:#212121;font-weight:normal;font-size:var(--evo-input-font-size);font-family:var(--evo-font);white-space:nowrap;background-color:#fff;border:1px solid #C6C6C6;border-radius:var(--evo-input-border-radius);outline:none;transition:color .3s,box-shadow .3s,background .3s,border .3s;position:relative;align-items:center;margin:0;padding:0 12px 0 16px;line-height:var(--evo-input-height)}evo-autocomplete .evo-autocomplete .ng-select-container.ng-has-value .ng-placeholder{display:none}evo-autocomplete .evo-autocomplete .ng-select .ng-clear-wrapper{display:inline-flex;align-items:center;width:24px;height:100%;margin:0 0 0 16px;padding:0;text-align:center;color:#91b1b8;transition:color .3s}evo-autocomplete .evo-autocomplete .ng-select .ng-clear-wrapper:hover{color:#a7c1c6}evo-autocomplete .evo-autocomplete .ng-select .ng-clear-wrapper:active{color:#829fa6}evo-autocomplete .evo-autocomplete .ng-select .ng-clear-wrapper .ng-clear{display:none}evo-autocomplete .evo-autocomplete .ng-select .ng-clear-wrapper .ng-clear_patched{display:block;cursor:pointer}evo-autocomplete .evo-autocomplete .ng-select .ng-clear-wrapper .ng-clear_patched svg{display:block;fill:currentColor}evo-autocomplete .evo-autocomplete .ng-select .ng-spinner-loader{display:flex;justify-content:center;align-items:center;width:16px;height:100%;margin:0 0 0 8px;border:none;transform:none;animation:none}evo-autocomplete .evo-autocomplete .ng-select .ng-spinner-loader:before{content:\"\";display:block;flex:0 0 16px;width:16px;height:16px;border:2px solid #C6C6C6;border-top-color:#21c68b;border-radius:50%;animation:spin .8s linear infinite}evo-autocomplete .evo-autocomplete .ng-optgroup{font-weight:400;--inner-option-text-color: #212121;--inner-option-description-color: #9B9B9B;--inner-option-background: #FFFFFF;display:flex;align-items:center;min-height:48px;white-space:normal;color:var(--inner-option-text-color);background-color:var(--inner-option-background);padding:var(--evo-autocomplete-option-v-padding) var(--evo-autocomplete-option-h-padding);cursor:pointer;font-family:var(--evo-font);font-style:normal;font-size:14px;line-height:24px;font-weight:600}evo-autocomplete .evo-autocomplete .ng-optgroup evo-autocomplete-default-option{--evo-autocomplete-default-option-background: var(--inner-option-background);--evo-autocomplete-default-option-text-color: var(--inner-option-text-color);--evo-autocomplete-default-option-description-color: var(--inner-option-description-color)}evo-autocomplete .evo-autocomplete .ng-optgroup.ng-option-marked{--inner-option-text-color: #212121;--inner-option-description-color: #9B9B9B;--inner-option-background: #F4F6F8}evo-autocomplete .evo-autocomplete .ng-optgroup.ng-option-disabled{--inner-option-text-color: #C6C6C6;--inner-option-description-color: #C6C6C6;--inner-option-background: #FFFFFF;cursor:default}evo-autocomplete .evo-autocomplete .ng-optgroup.ng-option-selected{--inner-option-text-color: #212121;--inner-option-description-color: #9B9B9B;--inner-option-background: #E1ECEF}evo-autocomplete .evo-autocomplete .ng-option{font-family:var(--evo-font);font-style:normal;font-size:14px;line-height:24px;font-weight:400;--inner-option-text-color: #212121;--inner-option-description-color: #9B9B9B;--inner-option-background: #FFFFFF;display:flex;align-items:center;min-height:48px;white-space:normal;color:var(--inner-option-text-color);background-color:var(--inner-option-background);padding:var(--evo-autocomplete-option-v-padding) var(--evo-autocomplete-option-h-padding);cursor:pointer}evo-autocomplete .evo-autocomplete .ng-option evo-autocomplete-default-option{--evo-autocomplete-default-option-background: var(--inner-option-background);--evo-autocomplete-default-option-text-color: var(--inner-option-text-color);--evo-autocomplete-default-option-description-color: var(--inner-option-description-color)}evo-autocomplete .evo-autocomplete .ng-option.ng-option-marked{--inner-option-text-color: #212121;--inner-option-description-color: #9B9B9B;--inner-option-background: #F4F6F8}evo-autocomplete .evo-autocomplete .ng-option.ng-option-disabled{--inner-option-text-color: #C6C6C6;--inner-option-description-color: #C6C6C6;--inner-option-background: #FFFFFF;cursor:default}evo-autocomplete .evo-autocomplete .ng-option.ng-option-selected{--inner-option-text-color: #212121;--inner-option-description-color: #9B9B9B;--inner-option-background: #E1ECEF}evo-autocomplete .evo-autocomplete_is-edit-query .ng-select.ng-select-single:not(.ng-select-focused) .ng-select-container .ng-value-container .ng-value{visibility:visible}evo-autocomplete .evo-autocomplete_is-edit-query .ng-select.ng-select-single.ng-select-focused .ng-select-container .ng-value-container .ng-value{visibility:var(--evo-autocomplete-option-overflow)}evo-autocomplete .evo-autocomplete .ng-dropdown-panel{z-index:3001;display:block;max-height:var(--evo-dropdown-max-height, 310px);margin:4px 0;background-color:#fff;border-radius:var(--evo-autocomplete-panel-border-radius);box-shadow:var(--evo-autocomplete-panel-shadow);overflow:hidden}evo-autocomplete .evo-autocomplete .ng-dropdown-panel.ng-select-top{bottom:100%}evo-autocomplete .evo-autocomplete .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{overflow:var(--evo-autocomplete-option-overflow);white-space:var(--evo-autocomplete-option-white-space);text-overflow:var(--evo-autocomplete-option-text-overflow)}evo-autocomplete .evo-autocomplete .ng-dropdown-panel .ng-dropdown-panel-items .ng-optgroup{overflow:var(--evo-autocomplete-optgroup-overflow);white-space:var(--evo-autocomplete-optgroup-white-space);text-overflow:var(--evo-autocomplete-optgroup-text-overflow)}evo-autocomplete .evo-autocomplete .ng-dropdown-panel .ng-dropdown-panel-items::-webkit-scrollbar{width:16px;background-color:transparent}evo-autocomplete .evo-autocomplete .ng-dropdown-panel .ng-dropdown-panel-items::-webkit-scrollbar-track{background-color:transparent}evo-autocomplete .evo-autocomplete .ng-dropdown-panel .ng-dropdown-panel-items::-webkit-scrollbar-thumb{background-color:#c6c6c6;border:6px solid #FFFFFF;border-radius:16px}evo-autocomplete .evo-autocomplete .ng-dropdown-panel .ng-dropdown-panel-items::-webkit-scrollbar-button{display:none}evo-autocomplete .evo-autocomplete_is-selectbox .ng-select .ng-arrow-wrapper{display:inline-flex;align-items:center;width:24px;height:100%;margin:0 0 0 16px;padding:0;text-align:center}evo-autocomplete .evo-autocomplete_is-selectbox .ng-select .ng-arrow-wrapper .ng-arrow{display:block;width:24px;height:24px;background-color:var(--evo-autocomplete-arrow-icon-color);-webkit-mask-image:url(\"data:image/svg+xml,%3Csvg width%3D%2224%22 height%3D%2224%22 viewBox%3D%220 0 24 24%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E %3Cpath d%3D%22M8.81066 10C8.14248 10 7.80786 10.8079 8.28033 11.2803L11.4697 14.4697C11.7626 14.7626 12.2374 14.7626 12.5303 14.4697L15.7197 11.2803C16.1921 10.8079 15.8575 10 15.1893 10H8.81066Z%22 %2F%3E%3C%2Fsvg%3E\");mask-image:url(\"data:image/svg+xml,%3Csvg width%3D%2224%22 height%3D%2224%22 viewBox%3D%220 0 24 24%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E %3Cpath d%3D%22M8.81066 10C8.14248 10 7.80786 10.8079 8.28033 11.2803L11.4697 14.4697C11.7626 14.7626 12.2374 14.7626 12.5303 14.4697L15.7197 11.2803C16.1921 10.8079 15.8575 10 15.1893 10H8.81066Z%22 %2F%3E%3C%2Fsvg%3E\");background-position:center;transition:transform .25s}evo-autocomplete .evo-autocomplete_is-selectbox .ng-select.ng-select-opened .ng-arrow{transform:rotate(180deg);transform-origin:center center}evo-autocomplete .evo-autocomplete_is-selectbox .ng-select .ng-input{padding-right:32px}evo-autocomplete .evo-autocomplete_is-selectbox.ng-select-focused{z-index:11}evo-autocomplete .evo-autocomplete_is-selectbox.ng-select-focused .ng-placeholder{display:none}evo-autocomplete .evo-autocomplete_is-selectbox.ng-select-focused .ng-select-container{box-shadow:0 0 2px #91b1b8}evo-autocomplete .evo-autocomplete_is-selectbox.ng-select-clearable .ng-input{padding-right:32px}evo-autocomplete .evo-autocomplete_theme-default.evo-autocomplete_size-normal .ng-select-container{--evo-input-height: 48px;--evo-input-border-radius: 4px;--evo-input-font-size: 16px;display:flex;align-items:center;height:var(--evo-input-height);color:#212121;font-weight:normal;font-size:var(--evo-input-font-size);font-family:var(--evo-font);white-space:nowrap;background-color:#fff;border:1px solid #C6C6C6;border-radius:var(--evo-input-border-radius);outline:none;transition:color .3s,box-shadow .3s,background .3s,border .3s}evo-autocomplete .evo-autocomplete_theme-default.evo-autocomplete_size-small .ng-select-container{--evo-input-height: 48px;--evo-input-border-radius: 4px;--evo-input-font-size: 16px;--evo-input-height: 32px;display:flex;align-items:center;height:var(--evo-input-height);color:#212121;font-weight:normal;font-size:var(--evo-input-font-size);font-family:var(--evo-font);white-space:nowrap;background-color:#fff;border:1px solid #C6C6C6;border-radius:var(--evo-input-border-radius);outline:none;transition:color .3s,box-shadow .3s,background .3s,border .3s}evo-autocomplete .evo-autocomplete_theme-rounded.evo-autocomplete_size-normal .ng-select-container{--evo-input-height: 48px;--evo-input-border-radius: 4px;--evo-input-font-size: 16px;--evo-input-border-radius: 256px;display:flex;align-items:center;height:var(--evo-input-height);color:#212121;font-weight:normal;font-size:var(--evo-input-font-size);font-family:var(--evo-font);white-space:nowrap;background-color:#fff;border:1px solid #C6C6C6;border-radius:var(--evo-input-border-radius);outline:none;transition:color .3s,box-shadow .3s,background .3s,border .3s}evo-autocomplete .evo-autocomplete_theme-rounded.evo-autocomplete_size-small .ng-select-container{--evo-input-height: 48px;--evo-input-border-radius: 4px;--evo-input-font-size: 16px;--evo-input-font-size: 14px;--evo-input-height: 40px;--evo-input-border-radius: 256px;display:flex;align-items:center;height:var(--evo-input-height);color:#212121;font-weight:normal;font-size:var(--evo-input-font-size);font-family:var(--evo-font);white-space:nowrap;background-color:#fff;border:1px solid #C6C6C6;border-radius:var(--evo-input-border-radius);outline:none;transition:color .3s,box-shadow .3s,background .3s,border .3s}evo-autocomplete .evo-autocomplete_is-multiple-inline .ng-select .ng-select-container .ng-value-icon{display:none}evo-autocomplete .evo-autocomplete_is-multiple-inline .ng-select .ng-select-container .ng-input{display:none}evo-autocomplete .evo-autocomplete .ng-select.ng-select-focused .ng-select-container,evo-autocomplete .evo-autocomplete .ng-select.ng-select-opened .ng-select-container{border:solid 1px #74706F}evo-autocomplete .evo-autocomplete.evo-autocomplete_touched.evo-autocomplete_invalid .ng-select:not(.ng-select-opened) .ng-select-container{border-color:#ff1817!important}evo-autocomplete .evo-autocomplete.evo-autocomplete_disabled .ng-select-container{color:#b0b0b0!important;background-color:#f9fafb!important;border:1px solid #E3E3E3!important;cursor:default;pointer-events:none}evo-autocomplete .evo-autocomplete.evo-autocomplete_disabled .ng-select-container .ng-arrow{opacity:.3}evo-autocomplete .evo-autocomplete .ng-input>input[readonly]{-webkit-user-select:auto!important;user-select:auto!important}\n"], components: [{ type: i2.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { type: i3.EvoControlErrorComponent, selector: "evo-control-error", inputs: ["errors", "errorsMessages", "showCount"] }], directives: [{ type: i4.EvoUiClassDirective, selector: "[evoUiClass]", inputs: ["class", "evoUiClass"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.ɵh, selector: "[ng-label-tmp]" }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i2.ɵi, selector: "[ng-multi-label-tmp]" }, { type: i2.ɵj, selector: "[ng-header-tmp]" }, { type: i2.ɵf, selector: "[ng-option-tmp]" }, { type: i2.ɵg, selector: "[ng-optgroup-tmp]" }, { type: i2.ɵm, selector: "[ng-typetosearch-tmp]" }, { type: i2.ɵn, selector: "[ng-loadingtext-tmp]" }, { type: i2.ɵl, selector: "[ng-notfound-tmp]" }, { type: i2.ɵk, selector: "[ng-footer-tmp]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
244
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EvoAutocompleteComponent, decorators: [{
245
+ type: Component,
246
+ args: [{
247
+ // tslint:disable-next-line
248
+ selector: 'evo-autocomplete',
249
+ templateUrl: './evo-autocomplete.component.html',
250
+ styleUrls: ['./evo-autocomplete.component.scss'],
251
+ changeDetection: ChangeDetectionStrategy.OnPush,
252
+ encapsulation: ViewEncapsulation.None,
253
+ }]
254
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.NgControl }]; }, propDecorators: { size: [{
255
+ type: Input
256
+ }], isOpen: [{
257
+ type: Input
258
+ }], items: [{
259
+ type: Input
260
+ }], bindLabel: [{
261
+ type: Input
262
+ }], bindValue: [{
263
+ type: Input
264
+ }], markFirst: [{
265
+ type: Input
266
+ }], placeholder: [{
267
+ type: Input
268
+ }], typeToSearchText: [{
269
+ type: Input
270
+ }], addTagText: [{
271
+ type: Input
272
+ }], loadingText: [{
273
+ type: Input
274
+ }], clearAllText: [{
275
+ type: Input
276
+ }], dropdownPosition: [{
277
+ type: Input
278
+ }], appendTo: [{
279
+ type: Input
280
+ }], loading: [{
281
+ type: Input
282
+ }], closeOnSelect: [{
283
+ type: Input
284
+ }], hideSelected: [{
285
+ type: Input
286
+ }], selectOnTab: [{
287
+ type: Input
288
+ }], openOnEnter: [{
289
+ type: Input
290
+ }], maxSelectedItems: [{
291
+ type: Input
292
+ }], groupBy: [{
293
+ type: Input
294
+ }], groupValue: [{
295
+ type: Input
296
+ }], bufferAmount: [{
297
+ type: Input
298
+ }], virtualScroll: [{
299
+ type: Input
300
+ }], selectableGroup: [{
301
+ type: Input
302
+ }], selectableGroupAsModel: [{
303
+ type: Input
304
+ }], searchFn: [{
305
+ type: Input
306
+ }], clearOnBackspace: [{
307
+ type: Input
308
+ }], typeahead: [{
309
+ type: Input
310
+ }], multiple: [{
311
+ type: Input
312
+ }], multipleInline: [{
313
+ type: Input
314
+ }], addTag: [{
315
+ type: Input
316
+ }], clearable: [{
317
+ type: Input
318
+ }], errorsMessages: [{
319
+ type: Input
320
+ }], compareWith: [{
321
+ type: Input
322
+ }], _notFoundText: [{
323
+ type: Input,
324
+ args: ['notFoundText']
325
+ }], editQuery: [{
326
+ type: Input
327
+ }], blurEvent: [{
328
+ type: Output,
329
+ args: ['blur']
330
+ }], focusEvent: [{
331
+ type: Output,
332
+ args: ['focus']
333
+ }], changeEvent: [{
334
+ type: Output,
335
+ args: ['change']
336
+ }], openEvent: [{
337
+ type: Output,
338
+ args: ['open']
339
+ }], closeEvent: [{
340
+ type: Output,
341
+ args: ['close']
342
+ }], searchEvent: [{
343
+ type: Output,
344
+ args: ['search']
345
+ }], clearEvent: [{
346
+ type: Output,
347
+ args: ['clear']
348
+ }], addEvent: [{
349
+ type: Output,
350
+ args: ['add']
351
+ }], removeEvent: [{
352
+ type: Output,
353
+ args: ['remove']
354
+ }], scrollEvent: [{
355
+ type: Output,
356
+ args: ['scroll']
357
+ }], scrollToEndEvent: [{
358
+ type: Output,
359
+ args: ['scrollToEnd']
360
+ }], ngSelectComponent: [{
361
+ type: ViewChild,
362
+ args: [NgSelectComponent]
363
+ }], labelTemp: [{
364
+ type: ContentChild,
365
+ args: ['labelTemp', { read: TemplateRef }]
366
+ }], multiLabelTemp: [{
367
+ type: ContentChild,
368
+ args: ['multiLabelTemp', { read: TemplateRef }]
369
+ }], optionTemp: [{
370
+ type: ContentChild,
371
+ args: ['optionTemp', { read: TemplateRef }]
372
+ }], optgroupTemp: [{
373
+ type: ContentChild,
374
+ args: ['optgroupTemp', { read: TemplateRef }]
375
+ }], headerTemp: [{
376
+ type: ContentChild,
377
+ args: ['headerTemp', { read: TemplateRef }]
378
+ }], footerTemp: [{
379
+ type: ContentChild,
380
+ args: ['footerTemp', { read: TemplateRef }]
381
+ }], notFoundTemp: [{
382
+ type: ContentChild,
383
+ args: ['notFoundTemp', { read: TemplateRef }]
384
+ }], searchable: [{
385
+ type: Input
386
+ }], setSelectbox: [{
387
+ type: Input,
388
+ args: ['isSelectbox']
389
+ }], setTheme: [{
390
+ type: Input,
391
+ args: ['theme']
392
+ }] } });
393
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../../projects/evo-ui-kit/src/lib/components/evo-autocomplete/components/evo-autocomplete/evo-autocomplete.component.ts","../../../../../../../../projects/evo-ui-kit/src/lib/components/evo-autocomplete/components/evo-autocomplete/evo-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    Output,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {ControlValueAccessor, NgControl} from '@angular/forms';\nimport {merge, Subject} from 'rxjs';\nimport {NgSelectComponent} from '@ng-select/ng-select';\nimport {delay, takeUntil, tap} from 'rxjs/operators';\nimport {isNull} from 'lodash-es';\nimport {EvoInputTheme} from '../../../evo-input';\nimport {iconDecline} from '@evotor-dev/ui-kit/icons/system';\nimport {EvoAutocompleteSize} from '../../types/evo-autocomplete-size';\n\nexport type DropdownPosition = 'bottom' | 'top' | 'auto';\nexport type AddTagFn = (term: string) => any | Promise<any>;\nexport type SearchFn = (term: string, item: any) => boolean;\nexport type CompareWithFn = (a: any, b: any) => boolean;\nexport type GroupValueFn = (key: string | object, children: any[]) => string | object;\n\nconst DEFAULT_NOT_FOUND_TEXT = 'Не найдено';\n\n@Component({\n    // tslint:disable-next-line\n    selector: 'evo-autocomplete',\n    templateUrl: './evo-autocomplete.component.html',\n    styleUrls: ['./evo-autocomplete.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EvoAutocompleteComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\n    theme: EvoInputTheme = EvoInputTheme.default;\n\n    @Input() size: EvoAutocompleteSize = 'normal';\n\n    isFocused = false;\n    isSelectbox = false;\n\n    // Inputs\n    @Input() isOpen;\n    @Input() items: any[];\n    @Input() bindLabel: string;\n    @Input() bindValue: string;\n    @Input() markFirst = true;\n    @Input() placeholder: string;\n    @Input() typeToSearchText: string;\n    @Input() addTagText = 'Добавить тэг';\n    @Input() loadingText = 'Идет поиск...';\n    @Input() clearAllText: string;\n    @Input() dropdownPosition: DropdownPosition = 'auto';\n    @Input() appendTo: string;\n    @Input() loading: boolean;\n    @Input() closeOnSelect = true;\n    @Input() hideSelected: boolean;\n    @Input() selectOnTab: boolean;\n    @Input() openOnEnter: boolean;\n    @Input() maxSelectedItems: number;\n    // tslint:disable-next-line\n    @Input() groupBy: string | Function;\n    @Input() groupValue: GroupValueFn;\n    @Input() bufferAmount = 4;\n    @Input() virtualScroll: boolean;\n    @Input() selectableGroup: boolean;\n    @Input() selectableGroupAsModel = true;\n    @Input() searchFn: SearchFn;\n    @Input() clearOnBackspace = true;\n    @Input() typeahead: Subject<string>;\n    @Input() multiple: boolean;\n    @Input() multipleInline: boolean;\n    @Input() addTag: boolean | AddTagFn;\n    @Input() clearable = true;\n    @Input() errorsMessages: {[key: string]: string};\n    @Input() compareWith: CompareWithFn;\n    @Input('notFoundText') _notFoundText: string;\n\n    // Fix: https://github.com/ng-select/ng-select/pull/1257\n    // Don't work with custom template - labelTemp\n    @Input() editQuery = false;\n\n    // Outputs\n    /* eslint-disable @angular-eslint/no-output-rename */\n    @Output('blur') blurEvent = new EventEmitter();\n    @Output('focus') focusEvent = new EventEmitter();\n    @Output('change') changeEvent = new EventEmitter();\n    @Output('open') openEvent = new EventEmitter();\n    @Output('close') closeEvent = new EventEmitter();\n    @Output('search') searchEvent = new EventEmitter<{term: string; items: any[]}>();\n    @Output('clear') clearEvent = new EventEmitter();\n    @Output('add') addEvent = new EventEmitter();\n    @Output('remove') removeEvent = new EventEmitter();\n    @Output('scroll') scrollEvent = new EventEmitter<{start: number; end: number}>();\n    @Output('scrollToEnd') scrollToEndEvent = new EventEmitter();\n    /* eslint-enable @angular-eslint/no-output-rename */\n\n    @ViewChild(NgSelectComponent)\n    ngSelectComponent: NgSelectComponent;\n\n    @ContentChild('labelTemp', {read: TemplateRef}) labelTemp: TemplateRef<any>;\n    @ContentChild('multiLabelTemp', {read: TemplateRef}) multiLabelTemp: TemplateRef<any>;\n    @ContentChild('optionTemp', {read: TemplateRef}) optionTemp: TemplateRef<any>;\n    @ContentChild('optgroupTemp', {read: TemplateRef}) optgroupTemp: TemplateRef<any>;\n    @ContentChild('headerTemp', {read: TemplateRef}) headerTemp: TemplateRef<any>;\n    @ContentChild('footerTemp', {read: TemplateRef}) footerTemp: TemplateRef<any>;\n    @ContentChild('notFoundTemp', {read: TemplateRef}) notFoundTemp: TemplateRef<any>;\n\n    protected inputVal: string;\n\n    protected readonly _destroy$ = new Subject<void>();\n\n    protected _value: any;\n\n    protected inputEl: HTMLInputElement;\n\n    protected _searchable;\n\n    get notFoundText(): string {\n        if (this.isSelectbox) {\n            return this._notFoundText || '';\n        }\n        return this._notFoundText || DEFAULT_NOT_FOUND_TEXT;\n    }\n\n    constructor(private readonly cdr: ChangeDetectorRef, public control: NgControl) {\n        control.valueAccessor = this;\n    }\n\n    @Input() set searchable(searchable: boolean) {\n        this._searchable = searchable;\n    }\n\n    get searchable(): boolean {\n        return this._searchable ?? !this.isSelectbox;\n    }\n\n    @Input('isSelectbox') set setSelectbox(isSelectbox: boolean) {\n        this.clearable = false;\n        this.editQuery = false;\n        this.isSelectbox = isSelectbox;\n    }\n\n    @Input('theme') set setTheme(theme: string | EvoInputTheme) {\n        if (EvoInputTheme[theme]) {\n            this.theme = EvoInputTheme[theme];\n        }\n    }\n\n    get hasErrors(): boolean {\n        return this.control.dirty && this.control.touched && this.control.invalid;\n    }\n\n    get classes(): {[key: string]: boolean} {\n        return {\n            'is-multiple-inline': this.multipleInline,\n            'is-edit-query': this.editQuery,\n            'is-selectbox': this.isSelectbox,\n            disabled: this.control.disabled,\n            touched: this.control.touched,\n            valid: this.control.valid,\n            invalid: this.control.invalid,\n            [`theme-${this.theme}`]: true,\n            [`size-${this.size}`]: true,\n        };\n    }\n\n    get value(): any {\n        return this._value;\n    }\n\n    set value(value: any) {\n        if (value !== this._value) {\n            this._value = value;\n            this._onChange(value);\n        }\n    }\n\n    getMultipleInlineItemsLabels(items: any[]): string {\n        if (!items || !Array.isArray(items) || items.length === 0) {\n            return '';\n        }\n        return items\n            .map((item) => item[this.bindLabel] || '')\n            .filter((item) => item !== '')\n            .join(', ');\n    }\n\n    ngAfterViewInit(): void {\n        if (this.editQuery) {\n            this.editQueryMode();\n        }\n\n        this.patchClearButtonIcon();\n\n        // prevent option click to close evo-modal\n        this.ngSelectComponent.element.addEventListener('click', (e) => {\n            if ((e.target as HTMLElement).closest('.ng-option')) {\n                e.stopPropagation();\n            }\n        });\n\n        // Allows to mark view for check\n        // if control was validated with FormHelper.validate\n        // and it's touched\n        this.control.control.statusChanges\n            .pipe(\n                takeUntil(this._destroy$),\n                tap(() => this.cdr.markForCheck()),\n            )\n            .subscribe();\n    }\n\n    ngOnDestroy(): void {\n        this._destroy$.next();\n        this._destroy$.complete();\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n        if (this.ngSelectComponent) {\n            this.ngSelectComponent.writeValue(value);\n        }\n    }\n\n    registerOnChange(fn: any): void {\n        this._onChange = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this._onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (this.ngSelectComponent) {\n            this.ngSelectComponent.setDisabledState(isDisabled);\n        }\n    }\n\n    // TODO: investigate and remove\n    editQueryMode(): void {\n        const ngSelectEl: HTMLElement = this.ngSelectComponent.element;\n        this.inputEl = ngSelectEl.querySelector('.ng-input input');\n        const streams$ = [\n            this.changeEvent.pipe(\n                delay(0),\n                tap(() => {\n                    this.resetSearchQuery();\n                    this.inputEl.value = this.inputVal || '';\n                }),\n            ),\n            this.closeEvent.pipe(\n                delay(0),\n                tap(() => {\n                    this.resetSearchQuery();\n                    if (ngSelectEl.classList.contains('ng-select-focused')) {\n                        this.inputEl.value = this.inputVal || '';\n                    }\n                }),\n            ),\n            this.focusEvent.pipe(\n                tap(() => {\n                    this.resetSearchQuery();\n                    this.inputEl.value = this.inputVal || '';\n                }),\n            ),\n            this.blurEvent.pipe(\n                tap(() => {\n                    this.inputEl.value = '';\n                }),\n            ),\n        ];\n\n        if (this.control.valueChanges) {\n            streams$.push(\n                this.control.valueChanges.pipe(\n                    tap((value) => {\n                        if (!isNull(value)) {\n                            this.resetSearchQuery();\n                            return;\n                        }\n                        this.inputVal = '';\n                        this.inputEl.value = '';\n                    }),\n                ),\n            );\n        }\n\n        merge(...streams$)\n            .pipe(takeUntil(this._destroy$))\n            .subscribe();\n    }\n\n    resetSearchQuery(): void {\n        const currentItem = this.ngSelectComponent.selectedItems[0];\n        this.inputVal = currentItem?.label || '';\n    }\n\n    focus(): void {\n        this.ngSelectComponent.focus();\n    }\n\n    blur(): void {\n        this.ngSelectComponent.blur();\n    }\n\n    open(): void {\n        this.ngSelectComponent.open();\n    }\n\n    close(): void {\n        this.ngSelectComponent.close();\n    }\n\n    onFocus(event: FocusEvent): void {\n        this.isFocused = true;\n        this._onTouched();\n        if (this.control.value) {\n            this.focusEvent.emit(event);\n        }\n    }\n\n    onBlur(event: FocusEvent): void {\n        this.isFocused = false;\n        this.blurEvent.emit(event);\n    }\n\n    onClearClick(): void {\n        this.ngSelectComponent.handleClearClick();\n    }\n\n    protected _onChange = (value) => {};\n\n    protected _onTouched = () => {};\n\n    /**\n     * Try to patch clear button icon\n     */\n    protected patchClearButtonIcon(): void {\n        const originalShowClearFn = this.ngSelectComponent.showClear;\n        const ngSelectElement = this.ngSelectComponent;\n        let patchTimeout = null;\n        this.ngSelectComponent.showClear = function () {\n            const isClearButtonVisible = originalShowClearFn.bind(this)();\n            if (isClearButtonVisible) {\n                if (patchTimeout) {\n                    clearTimeout(patchTimeout);\n                }\n                patchTimeout = setTimeout(() => {\n                    const ngClearWrapperElement = ngSelectElement.element.querySelector('.ng-clear-wrapper');\n                    if (!ngClearWrapperElement) {\n                        return;\n                    }\n                    // tslint:disable-next-line:max-line-length\n                    ngClearWrapperElement.innerHTML = `<span class=\"ng-clear ng-clear_patched\"><svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">${iconDecline}</svg></span>`;\n                });\n            }\n            return isClearButtonVisible;\n        };\n    }\n}\n","<div class=\"evo-autocomplete\" [evoUiClass]=\"classes\">\n    <ng-select\n        [items]=\"items\"\n        [bindLabel]=\"bindLabel\"\n        [bindValue]=\"bindValue\"\n        [markFirst]=\"markFirst\"\n        [placeholder]=\"placeholder\"\n        [notFoundText]=\"notFoundText\"\n        [typeToSearchText]=\"typeToSearchText\"\n        [addTagText]=\"addTagText\"\n        [loadingText]=\"loadingText\"\n        [clearAllText]=\"clearAllText\"\n        [dropdownPosition]=\"dropdownPosition\"\n        [appendTo]=\"appendTo\"\n        [loading]=\"loading\"\n        [closeOnSelect]=\"closeOnSelect\"\n        [hideSelected]=\"hideSelected\"\n        [selectOnTab]=\"selectOnTab\"\n        [openOnEnter]=\"openOnEnter\"\n        [maxSelectedItems]=\"maxSelectedItems\"\n        [groupBy]=\"groupBy\"\n        [groupValue]=\"groupValue\"\n        [bufferAmount]=\"bufferAmount\"\n        [virtualScroll]=\"virtualScroll\"\n        [selectableGroup]=\"selectableGroup\"\n        [selectableGroupAsModel]=\"selectableGroupAsModel\"\n        [searchFn]=\"searchFn\"\n        [clearOnBackspace]=\"clearOnBackspace\"\n        [typeahead]=\"typeahead\"\n        [multiple]=\"multiple || multipleInline\"\n        [addTag]=\"addTag\"\n        [searchable]=\"searchable\"\n        [clearable]=\"clearable\"\n        [isOpen]=\"isOpen\"\n        [editableSearchTerm]=\"editQuery\"\n        [disabled]=\"control.disabled\"\n        [compareWith]=\"compareWith\"\n        [(ngModel)]=\"value\"\n        (blur)=\"onBlur($event)\"\n        (focus)=\"onFocus($event)\"\n        (change)=\"changeEvent.emit($event)\"\n        (open)=\"openEvent.emit($event)\"\n        (close)=\"closeEvent.emit($event)\"\n        (search)=\"searchEvent.emit($event)\"\n        (clear)=\"clearEvent.emit($event)\"\n        (add)=\"addEvent.emit($event)\"\n        (remove)=\"removeEvent.emit($event)\"\n        (scroll)=\"scrollEvent.emit($event)\"\n        (scrollToEnd)=\"scrollToEndEvent.emit($event)\"\n    >\n        <!-- Selected Item Template -->\n        <ng-template *ngIf=\"labelTemp\" ng-label-tmp let-item=\"item\">\n            <ng-template *ngTemplateOutlet=\"labelTemp; context: { item: item }\"></ng-template>\n        </ng-template>\n\n        <!-- Overall Label For All Selected Items Template -->\n        <ng-template *ngIf=\"multiLabelTemp\" ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n            <ng-template *ngTemplateOutlet=\"multiLabelTemp; context: { items: items, clear: clear }\"></ng-template>\n        </ng-template>\n\n        <!-- Options header template -->\n        <ng-template *ngIf=\"headerTemp\" ng-header-tmp>\n            <ng-template *ngTemplateOutlet=\"headerTemp; context: {items: items}\"></ng-template>\n        </ng-template>\n\n        <!-- Option Template -->\n        <ng-template\n            *ngIf=\"optionTemp\"\n            ng-option-tmp\n            let-item=\"item\"\n            let-index=\"index\"\n            let-search=\"searchTerm\"\n            let-item$=\"item$\"\n        >\n            <ng-template\n                *ngTemplateOutlet=\"optionTemp; context: { item: item, index: index, searchTerm: search, item$: item$}\"\n            ></ng-template>\n        </ng-template>\n\n        <ng-container *ngIf=\"multipleInline && !multiLabelTemp\">\n            <ng-template ng-multi-label-tmp let-items=\"items\">\n                <div class=\"ng-value\">{{ getMultipleInlineItemsLabels(items) }}</div>\n            </ng-template>\n        </ng-container>\n\n        <!-- Options group template -->\n        <ng-template *ngIf=\"optgroupTemp\" ng-optgroup-tmp let-item=\"item\" let-index=\"index\">\n            <ng-template *ngTemplateOutlet=\"optgroupTemp; context: { item: item, index: index }\"></ng-template>\n        </ng-template>\n\n        <!-- Search Text Templates -->\n        <ng-template ng-typetosearch-tmp>\n            <div *ngIf=\"typeToSearchText\" class=\"ng-option disabled\">{{typeToSearchText}}</div>\n        </ng-template>\n        <ng-template ng-loadingtext-tmp let-searchTerm=\"searchTerm\">\n            <div class=\"ng-option disabled\">{{loadingText}}</div>\n        </ng-template>\n\n        <ng-container *ngIf=\"notFoundTemp; else defaultNotFoundTemplate\">\n            <ng-template ng-notfound-tmp let-searchTerm=\"searchTerm\">\n                <ng-template *ngTemplateOutlet=\"notFoundTemp; context: {searchTerm: searchTerm}\"></ng-template>\n            </ng-template>\n        </ng-container>\n        <ng-template #defaultNotFoundTemplate>\n            <ng-template ng-notfound-tmp>\n                <div class=\"ng-option disabled\">{{notFoundText}}</div>\n            </ng-template>\n        </ng-template>\n\n        <!-- Options footer template -->\n        <ng-template *ngIf=\"footerTemp\" ng-footer-tmp>\n            <ng-template *ngTemplateOutlet=\"footerTemp; context: {items: items}\"></ng-template>\n        </ng-template>\n    </ng-select>\n    <evo-control-error\n        *ngIf=\"hasErrors && errorsMessages\"\n        [errors]=\"control.errors\"\n        [errorsMessages]=\"errorsMessages\"\n    ></evo-control-error>\n</div>\n"]}
@@ -0,0 +1,49 @@
1
+ import { ChangeDetectionStrategy, Component, HostBinding, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../../../evo-checkbox/evo-checkbox.component";
4
+ import * as i2 from "@angular/common";
5
+ import * as i3 from "@angular/forms";
6
+ export class EvoAutocompleteDefaultOptionComponent {
7
+ constructor(cdr) {
8
+ this.cdr = cdr;
9
+ }
10
+ get hasCheckboxClass() {
11
+ return this.hasCheckbox;
12
+ }
13
+ onSelectedChange(e) {
14
+ this.cdr.markForCheck();
15
+ }
16
+ onCheckboxClick(e) {
17
+ var _a;
18
+ e.preventDefault();
19
+ e.stopImmediatePropagation();
20
+ if (e.target) {
21
+ (_a = e.target.closest('.ng-option')) === null || _a === void 0 ? void 0 : _a.dispatchEvent(new Event('click'));
22
+ }
23
+ }
24
+ }
25
+ EvoAutocompleteDefaultOptionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EvoAutocompleteDefaultOptionComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
26
+ EvoAutocompleteDefaultOptionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: EvoAutocompleteDefaultOptionComponent, selector: "evo-autocomplete-default-option", inputs: { hasCheckbox: "hasCheckbox", label: "label", description: "description", isDisabled: "isDisabled", isSelected: "isSelected" }, host: { properties: { "class.has-checkbox": "this.hasCheckboxClass" } }, ngImport: i0, template: "<div class=\"option option_has-checkbox\" *ngIf=\"hasCheckbox\">\n <evo-checkbox\n [ngModel]=\"isSelected\"\n [ngModelOptions]=\"{standalone: true}\"\n [disabled]=\"isDisabled\"\n (click)=\"onCheckboxClick($event)\"\n (change)=\"onCheckboxClick($event)\"\n (ngModelChange)=\"onSelectedChange($event)\"\n >{{ label }}</evo-checkbox>\n <ng-container *ngIf=\"description\">\n <div class=\"option__description\">{{ description }}</div>\n </ng-container>\n</div>\n<div class=\"option\" *ngIf=\"!hasCheckbox\">\n <div class=\"option__label\">{{ label }}</div>\n <ng-container *ngIf=\"description\">\n <div class=\"option__description\">{{ description }}</div>\n </ng-container>\n</div>\n", styles: [":host{display:block;color:inherit;white-space:var(--evo-autocomplete-option-white-space, nowrap);--evo-autocomplete-default-option-text-color: #212121;--evo-autocomplete-default-option-description-color: #9B9B9B;--evo-autocomplete-default-option-background: #FFFFFF}.option{position:relative;z-index:1;color:var(--evo-autocomplete-default-option-text-color);background:var(--evo-autocomplete-default-option-background)}.option__label{font-family:var(--evo-font);font-style:normal;font-size:14px;line-height:24px;font-weight:400;display:block;margin-bottom:0;overflow:var(--evo-autocomplete-option-overflow, hidden);color:var(--evo-autocomplete-default-option-text-color);text-overflow:var(--evo-autocomplete-option-text-overflow, ellipsis)}.option__description{font-family:var(--evo-font);font-style:normal;font-size:12px;line-height:18px;font-weight:400;display:block;overflow:var(--evo-autocomplete-option-overflow, hidden);color:var(--evo-autocomplete-default-option-description-color);text-overflow:var(--evo-autocomplete-option-text-overflow, ellipsis)}.option evo-checkbox{color:var(--evo-autocomplete-default-option-text-color)}.option evo-checkbox+.option evo-checkbox__description{padding-left:32px}\n"], components: [{ type: i1.EvoCheckboxComponent, selector: "evo-checkbox", inputs: ["indeterminate"], outputs: ["indeterminateChange"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EvoAutocompleteDefaultOptionComponent, decorators: [{
28
+ type: Component,
29
+ args: [{
30
+ selector: 'evo-autocomplete-default-option',
31
+ templateUrl: './evo-autocomplete-default-option.component.html',
32
+ styleUrls: ['./evo-autocomplete-default-option.component.scss'],
33
+ changeDetection: ChangeDetectionStrategy.OnPush,
34
+ }]
35
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { hasCheckbox: [{
36
+ type: Input
37
+ }], label: [{
38
+ type: Input
39
+ }], description: [{
40
+ type: Input
41
+ }], isDisabled: [{
42
+ type: Input
43
+ }], isSelected: [{
44
+ type: Input
45
+ }], hasCheckboxClass: [{
46
+ type: HostBinding,
47
+ args: ['class.has-checkbox']
48
+ }] } });
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLWF1dG9jb21wbGV0ZS1kZWZhdWx0LW9wdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldm8tdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9ldm8tYXV0b2NvbXBsZXRlL2NvbXBvbmVudHMvZXZvLWF1dG9jb21wbGV0ZS1kZWZhdWx0LW9wdGlvbi9ldm8tYXV0b2NvbXBsZXRlLWRlZmF1bHQtb3B0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1hdXRvY29tcGxldGUvY29tcG9uZW50cy9ldm8tYXV0b2NvbXBsZXRlLWRlZmF1bHQtb3B0aW9uL2V2by1hdXRvY29tcGxldGUtZGVmYXVsdC1vcHRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFxQixTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFRMUcsTUFBTSxPQUFPLHFDQUFxQztJQVk5QyxZQUFvQixHQUFzQjtRQUF0QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtJQUMxQyxDQUFDO0lBTEQsSUFBdUMsZ0JBQWdCO1FBQ25ELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUM1QixDQUFDO0lBS0QsZ0JBQWdCLENBQUMsQ0FBQztRQUNkLElBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDNUIsQ0FBQztJQUVELGVBQWUsQ0FBQyxDQUFROztRQUNwQixDQUFDLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDbkIsQ0FBQyxDQUFDLHdCQUF3QixFQUFFLENBQUM7UUFDN0IsSUFBSSxDQUFDLENBQUMsTUFBTSxFQUFFO1lBQ1YsTUFBQyxDQUFDLENBQUMsTUFBc0IsQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLDBDQUFFLGFBQWEsQ0FBQyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1NBQ3RGO0lBQ0wsQ0FBQzs7bUlBekJRLHFDQUFxQzt1SEFBckMscUNBQXFDLHdSQ1JsRCx3dkJBbUJBOzRGRFhhLHFDQUFxQztrQkFOakQsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsaUNBQWlDO29CQUMzQyxXQUFXLEVBQUUsa0RBQWtEO29CQUMvRCxTQUFTLEVBQUUsQ0FBQyxrREFBa0QsQ0FBQztvQkFDL0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEO3dHQUVZLFdBQVc7c0JBQW5CLEtBQUs7Z0JBRUcsS0FBSztzQkFBYixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUVpQyxnQkFBZ0I7c0JBQXRELFdBQVc7dUJBQUMsb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2V2by1hdXRvY29tcGxldGUtZGVmYXVsdC1vcHRpb24nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9ldm8tYXV0b2NvbXBsZXRlLWRlZmF1bHQtb3B0aW9uLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ldm8tYXV0b2NvbXBsZXRlLWRlZmF1bHQtb3B0aW9uLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIEV2b0F1dG9jb21wbGV0ZURlZmF1bHRPcHRpb25Db21wb25lbnQge1xuICAgIEBJbnB1dCgpIGhhc0NoZWNrYm94OiBib29sZWFuO1xuXG4gICAgQElucHV0KCkgbGFiZWw6IHN0cmluZztcbiAgICBASW5wdXQoKSBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICAgIEBJbnB1dCgpIGlzRGlzYWJsZWQ6IGJvb2xlYW47XG4gICAgQElucHV0KCkgaXNTZWxlY3RlZDogYm9vbGVhbjtcblxuICAgIEBIb3N0QmluZGluZygnY2xhc3MuaGFzLWNoZWNrYm94JykgZ2V0IGhhc0NoZWNrYm94Q2xhc3MoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmhhc0NoZWNrYm94O1xuICAgIH1cblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xuICAgIH1cblxuICAgIG9uU2VsZWN0ZWRDaGFuZ2UoZSk6IHZvaWQge1xuICAgICAgICB0aGlzLmNkci5tYXJrRm9yQ2hlY2soKTtcbiAgICB9XG5cbiAgICBvbkNoZWNrYm94Q2xpY2soZTogRXZlbnQpOiB2b2lkIHtcbiAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICBlLnN0b3BJbW1lZGlhdGVQcm9wYWdhdGlvbigpO1xuICAgICAgICBpZiAoZS50YXJnZXQpIHtcbiAgICAgICAgICAgIChlLnRhcmdldCBhcyBIVE1MRWxlbWVudCkuY2xvc2VzdCgnLm5nLW9wdGlvbicpPy5kaXNwYXRjaEV2ZW50KG5ldyBFdmVudCgnY2xpY2snKSk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwib3B0aW9uIG9wdGlvbl9oYXMtY2hlY2tib3hcIiAqbmdJZj1cImhhc0NoZWNrYm94XCI+XG4gICAgPGV2by1jaGVja2JveFxuICAgICAgICBbbmdNb2RlbF09XCJpc1NlbGVjdGVkXCJcbiAgICAgICAgW25nTW9kZWxPcHRpb25zXT1cIntzdGFuZGFsb25lOiB0cnVlfVwiXG4gICAgICAgIFtkaXNhYmxlZF09XCJpc0Rpc2FibGVkXCJcbiAgICAgICAgKGNsaWNrKT1cIm9uQ2hlY2tib3hDbGljaygkZXZlbnQpXCJcbiAgICAgICAgKGNoYW5nZSk9XCJvbkNoZWNrYm94Q2xpY2soJGV2ZW50KVwiXG4gICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cIm9uU2VsZWN0ZWRDaGFuZ2UoJGV2ZW50KVwiXG4gICAgPnt7IGxhYmVsIH19PC9ldm8tY2hlY2tib3g+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImRlc2NyaXB0aW9uXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJvcHRpb25fX2Rlc2NyaXB0aW9uXCI+e3sgZGVzY3JpcHRpb24gfX08L2Rpdj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbjwvZGl2PlxuPGRpdiBjbGFzcz1cIm9wdGlvblwiICpuZ0lmPVwiIWhhc0NoZWNrYm94XCI+XG4gICAgPGRpdiBjbGFzcz1cIm9wdGlvbl9fbGFiZWxcIj57eyBsYWJlbCB9fTwvZGl2PlxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJkZXNjcmlwdGlvblwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwib3B0aW9uX19kZXNjcmlwdGlvblwiPnt7IGRlc2NyaXB0aW9uIH19PC9kaXY+XG4gICAgPC9uZy1jb250YWluZXI+XG48L2Rpdj5cbiJdfQ==
@@ -0,0 +1,16 @@
1
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class EvoAutocompleteFooterComponent {
4
+ }
5
+ EvoAutocompleteFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EvoAutocompleteFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
6
+ EvoAutocompleteFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: EvoAutocompleteFooterComponent, selector: "evo-autocomplete-footer", ngImport: i0, template: "<div class=\"evo-autocomplete-footer\">\n <ng-content></ng-content>\n</div>\n", styles: [":host{--evo-autocomplete-footer-border: solid 1px #C6C6C6;--evo-autocomplete-footer-v-padding: var(--evo-autocomplete-option-h-padding);--evo-autocomplete-footer-h-padding: var(--evo-autocomplete-option-h-padding)}.evo-autocomplete-footer{display:flex;flex-direction:column;padding:var(--evo-autocomplete-footer-v-padding) var(--evo-autocomplete-footer-h-padding);border-top:var(--evo-autocomplete-footer-border);border-radius:0 0 var(--evo-autocomplete-panel-border-radius) var(--evo-autocomplete-panel-border-radius)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
7
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EvoAutocompleteFooterComponent, decorators: [{
8
+ type: Component,
9
+ args: [{
10
+ selector: 'evo-autocomplete-footer',
11
+ templateUrl: './evo-autocomplete-footer.component.html',
12
+ styleUrls: ['./evo-autocomplete-footer.component.scss'],
13
+ changeDetection: ChangeDetectionStrategy.OnPush,
14
+ }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLWF1dG9jb21wbGV0ZS1mb290ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLWF1dG9jb21wbGV0ZS9jb21wb25lbnRzL2V2by1hdXRvY29tcGxldGUtZm9vdGVyL2V2by1hdXRvY29tcGxldGUtZm9vdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1hdXRvY29tcGxldGUvY29tcG9uZW50cy9ldm8tYXV0b2NvbXBsZXRlLWZvb3Rlci9ldm8tYXV0b2NvbXBsZXRlLWZvb3Rlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFDLE1BQU0sZUFBZSxDQUFDOztBQVFqRSxNQUFNLE9BQU8sOEJBQThCOzs0SEFBOUIsOEJBQThCO2dIQUE5Qiw4QkFBOEIsK0RDUjNDLGtGQUdBOzRGREthLDhCQUE4QjtrQkFOMUMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUseUJBQXlCO29CQUNuQyxXQUFXLEVBQUUsMENBQTBDO29CQUN2RCxTQUFTLEVBQUUsQ0FBQywwQ0FBMEMsQ0FBQztvQkFDdkQsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldm8tYXV0b2NvbXBsZXRlLWZvb3RlcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2V2by1hdXRvY29tcGxldGUtZm9vdGVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ldm8tYXV0b2NvbXBsZXRlLWZvb3Rlci5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBFdm9BdXRvY29tcGxldGVGb290ZXJDb21wb25lbnQge31cbiIsIjxkaXYgY2xhc3M9XCJldm8tYXV0b2NvbXBsZXRlLWZvb3RlclwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PlxuIl19
@@ -0,0 +1,16 @@
1
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class EvoAutocompleteHeaderComponent {
4
+ }
5
+ EvoAutocompleteHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EvoAutocompleteHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
6
+ EvoAutocompleteHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: EvoAutocompleteHeaderComponent, selector: "evo-autocomplete-header", ngImport: i0, template: "<div class=\"evo-autocomplete-header\">\n <ng-content></ng-content>\n</div>\n", styles: [":host{--evo-autocomplete-header-border: solid 1px #C6C6C6;--evo-autocomplete-header-v-padding: var(--evo-autocomplete-option-h-padding);--evo-autocomplete-header-h-padding: var(--evo-autocomplete-option-h-padding)}.evo-autocomplete-header{display:flex;flex-direction:column;padding:var(--evo-autocomplete-header-v-padding) var(--evo-autocomplete-header-h-padding);border-bottom:var(--evo-autocomplete-header-border);border-radius:var(--evo-autocomplete-panel-border-radius) var(--evo-autocomplete-panel-border-radius) 0 0}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
7
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: EvoAutocompleteHeaderComponent, decorators: [{
8
+ type: Component,
9
+ args: [{
10
+ selector: 'evo-autocomplete-header',
11
+ templateUrl: './evo-autocomplete-header.component.html',
12
+ styleUrls: ['./evo-autocomplete-header.component.scss'],
13
+ changeDetection: ChangeDetectionStrategy.OnPush,
14
+ }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLWF1dG9jb21wbGV0ZS1oZWFkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLWF1dG9jb21wbGV0ZS9jb21wb25lbnRzL2V2by1hdXRvY29tcGxldGUtaGVhZGVyL2V2by1hdXRvY29tcGxldGUtaGVhZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1hdXRvY29tcGxldGUvY29tcG9uZW50cy9ldm8tYXV0b2NvbXBsZXRlLWhlYWRlci9ldm8tYXV0b2NvbXBsZXRlLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFDLE1BQU0sZUFBZSxDQUFDOztBQVFqRSxNQUFNLE9BQU8sOEJBQThCOzs0SEFBOUIsOEJBQThCO2dIQUE5Qiw4QkFBOEIsK0RDUjNDLGtGQUdBOzRGREthLDhCQUE4QjtrQkFOMUMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUseUJBQXlCO29CQUNuQyxXQUFXLEVBQUUsMENBQTBDO29CQUN2RCxTQUFTLEVBQUUsQ0FBQywwQ0FBMEMsQ0FBQztvQkFDdkQsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldm8tYXV0b2NvbXBsZXRlLWhlYWRlcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2V2by1hdXRvY29tcGxldGUtaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ldm8tYXV0b2NvbXBsZXRlLWhlYWRlci5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBFdm9BdXRvY29tcGxldGVIZWFkZXJDb21wb25lbnQge31cbiIsIjxkaXYgY2xhc3M9XCJldm8tYXV0b2NvbXBsZXRlLWhlYWRlclwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PlxuIl19