@testgorilla/tgo-ui 1.2.1 → 1.3.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.
- package/components/autocomplete/autocomplete.component.d.ts +107 -0
- package/components/autocomplete/autocomplete.component.module.d.ts +19 -0
- package/components/autocomplete/autocomplete.model.d.ts +13 -0
- package/components/autocomplete/includes.pipe.d.ts +12 -0
- package/components/autocomplete/transform-Item.pipe.d.ts +11 -0
- package/components/badge/badge.component.d.ts +40 -0
- package/components/badge/badge.component.module.d.ts +9 -0
- package/components/badge/badge.model.d.ts +18 -0
- package/components/button/button.component.d.ts +11 -3
- package/components/button/button.component.module.d.ts +2 -1
- package/components/button/button.model.d.ts +1 -1
- package/components/step/step.component.d.ts +93 -0
- package/components/step/step.component.module.d.ts +9 -0
- package/components/stepper/providers/is-mobile.d.ts +2 -0
- package/components/stepper/stepper.component.d.ts +47 -0
- package/components/stepper/stepper.component.module.d.ts +13 -0
- package/components/stepper/stepper.model.d.ts +12 -0
- package/directives/select-text.directive.d.ts +19 -0
- package/directives/step-line-width.directive.d.ts +15 -0
- package/esm2022/components/alert-banner/alert-banner.component.mjs +2 -2
- package/esm2022/components/autocomplete/autocomplete.component.mjs +302 -0
- package/esm2022/components/autocomplete/autocomplete.component.module.mjs +81 -0
- package/esm2022/components/autocomplete/autocomplete.model.mjs +16 -0
- package/esm2022/components/autocomplete/includes.pipe.mjs +21 -0
- package/esm2022/components/autocomplete/transform-Item.pipe.mjs +29 -0
- package/esm2022/components/badge/badge.component.mjs +66 -0
- package/esm2022/components/badge/badge.component.module.mjs +19 -0
- package/esm2022/components/badge/badge.model.mjs +19 -0
- package/esm2022/components/banner-action/banner-action.component.mjs +1 -1
- package/esm2022/components/button/button.component.mjs +19 -4
- package/esm2022/components/button/button.component.module.mjs +5 -4
- package/esm2022/components/button/button.model.mjs +1 -1
- package/esm2022/components/create-account/create-account.component.mjs +1 -1
- package/esm2022/components/create-password/create-password.component.mjs +1 -1
- package/esm2022/components/dialog/dialog.component.mjs +1 -1
- package/esm2022/components/dropdown/dropdown.component.mjs +1 -1
- package/esm2022/components/field/field.component.mjs +1 -1
- package/esm2022/components/forgot-password/forgot-password.component.mjs +1 -1
- package/esm2022/components/login/login.component.mjs +1 -1
- package/esm2022/components/snackbar/snackbar.component.mjs +2 -2
- package/esm2022/components/step/step.component.mjs +91 -0
- package/esm2022/components/step/step.component.module.mjs +19 -0
- package/esm2022/components/stepper/providers/is-mobile.mjs +11 -0
- package/esm2022/components/stepper/stepper.component.mjs +91 -0
- package/esm2022/components/stepper/stepper.component.module.mjs +43 -0
- package/esm2022/components/stepper/stepper.model.mjs +5 -0
- package/esm2022/directives/select-text.directive.mjs +41 -0
- package/esm2022/directives/step-line-width.directive.mjs +38 -0
- package/esm2022/public-api.mjs +12 -1
- package/esm2022/utils/autocomplete-utils.mjs +61 -0
- package/fesm2022/testgorilla-tgo-ui.mjs +920 -34
- package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
- package/package.json +5 -2
- package/public-api.d.ts +8 -0
- package/src/assets/i18n/en.json +12 -1
- package/src/assets/images/step-finish.svg +6 -0
- package/utils/autocomplete-utils.d.ts +11 -0
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, forwardRef, inject, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { map, ReplaySubject, startWith } from 'rxjs';
|
|
4
|
+
import { AutocompleteUtils } from '../../utils/autocomplete-utils';
|
|
5
|
+
import { Autocomplete, Padding, Timeout } from './autocomplete.model';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "@angular/material/form-field";
|
|
9
|
+
import * as i3 from "@angular/material/autocomplete";
|
|
10
|
+
import * as i4 from "@angular/material/core";
|
|
11
|
+
import * as i5 from "@angular/material/input";
|
|
12
|
+
import * as i6 from "@angular/forms";
|
|
13
|
+
import * as i7 from "../tag/tag.component";
|
|
14
|
+
import * as i8 from "../icon/icon.component";
|
|
15
|
+
import * as i9 from "@ngneat/transloco";
|
|
16
|
+
import * as i10 from "../../directives/select-text.directive";
|
|
17
|
+
import * as i11 from "./transform-Item.pipe";
|
|
18
|
+
import * as i12 from "./includes.pipe";
|
|
19
|
+
export class AutocompleteComponent {
|
|
20
|
+
constructor() {
|
|
21
|
+
/**
|
|
22
|
+
* @property itemsList
|
|
23
|
+
* @description The list of items to display in the autocomplete.
|
|
24
|
+
* @memberof AutocompleteComponent
|
|
25
|
+
*/
|
|
26
|
+
this.itemsList = [];
|
|
27
|
+
/**
|
|
28
|
+
* @property suggestionsList
|
|
29
|
+
* @description The list of suggestions to display in the autocomplete.
|
|
30
|
+
* @memberof AutocompleteComponent
|
|
31
|
+
*/
|
|
32
|
+
this.suggestionsList = [];
|
|
33
|
+
/**
|
|
34
|
+
* @property disabled
|
|
35
|
+
* @description If `true`, the autocomplete is disabled.
|
|
36
|
+
* @memberof AutocompleteComponent
|
|
37
|
+
*/
|
|
38
|
+
this.disabled = false;
|
|
39
|
+
/**
|
|
40
|
+
* @property allowAdd
|
|
41
|
+
* @description If `true`, allows adding new values to the autocomplete.
|
|
42
|
+
* @memberof AutocompleteComponent
|
|
43
|
+
*/
|
|
44
|
+
this.allowAdd = true;
|
|
45
|
+
/**
|
|
46
|
+
* @property textField
|
|
47
|
+
* @description The field to be used as the display text in the autocomplete.
|
|
48
|
+
* @memberof AutocompleteComponent
|
|
49
|
+
*/
|
|
50
|
+
this.textField = '';
|
|
51
|
+
/**
|
|
52
|
+
* @property valueField
|
|
53
|
+
* @description The field to be used as the value in the autocomplete.
|
|
54
|
+
* @memberof AutocompleteComponent
|
|
55
|
+
*/
|
|
56
|
+
this.valueField = '';
|
|
57
|
+
/**
|
|
58
|
+
* @property label
|
|
59
|
+
* @description The label for the autocomplete input.
|
|
60
|
+
* @memberof AutocompleteComponent
|
|
61
|
+
*/
|
|
62
|
+
this.label = '';
|
|
63
|
+
/**
|
|
64
|
+
* @property type
|
|
65
|
+
* @description The type of the autocomplete ('single', 'multi', etc.).
|
|
66
|
+
* @memberof AutocompleteComponent
|
|
67
|
+
*/
|
|
68
|
+
this.type = 'multi';
|
|
69
|
+
/**
|
|
70
|
+
* @property minCharactersSearch
|
|
71
|
+
* @description The minimum characters to trigger search.
|
|
72
|
+
* @memberof AutocompleteComponent
|
|
73
|
+
*/
|
|
74
|
+
this.minCharactersSearch = 3;
|
|
75
|
+
this.selectionChange = new EventEmitter();
|
|
76
|
+
this.searchTextChange = new EventEmitter();
|
|
77
|
+
this.cdr = inject(ChangeDetectorRef);
|
|
78
|
+
this.inputValue = '';
|
|
79
|
+
this.isInputFocus = false;
|
|
80
|
+
this.autocompleteType = Autocomplete;
|
|
81
|
+
this.isOverLapping = false;
|
|
82
|
+
this.isOverlapChecking = true;
|
|
83
|
+
this.overlapIndex = 0;
|
|
84
|
+
this.inputValueSearch$ = new ReplaySubject(1);
|
|
85
|
+
this.userInput$ = new ReplaySubject(1);
|
|
86
|
+
this.filteredItemsList$ = this.inputValueSearch$.pipe(startWith(''), map(inputValue => inputValue.length ? AutocompleteUtils.filterItems(this.itemsList, inputValue, this.textField) : null));
|
|
87
|
+
this.filteredSuggestionList$ = this.inputValueSearch$.pipe(map(inputValue => inputValue.length ? AutocompleteUtils.filterItems(this.suggestionsList, inputValue, this.textField) : null));
|
|
88
|
+
this.searchResult$ = this.inputValueSearch$.pipe(map(inputValue => !!inputValue.trim()));
|
|
89
|
+
this.translationContext = 'AUTOCOMPLETE.';
|
|
90
|
+
this.onChange = (_) => { };
|
|
91
|
+
this.onTouch = () => { };
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* @property value
|
|
95
|
+
* @description The selected value(s) in the autocomplete.
|
|
96
|
+
* @memberof AutocompleteComponent
|
|
97
|
+
*/
|
|
98
|
+
set itemValue(v) {
|
|
99
|
+
this.value = AutocompleteUtils.isArray(v) ? v : [v];
|
|
100
|
+
}
|
|
101
|
+
ngOnChanges() {
|
|
102
|
+
this.itemsList = AutocompleteUtils.excludeSuggestions(this.itemsList, this.suggestionsList, this.valueField);
|
|
103
|
+
this.initValue();
|
|
104
|
+
}
|
|
105
|
+
ngAfterViewInit() {
|
|
106
|
+
if (this.type !== Autocomplete.LARGE) {
|
|
107
|
+
this.checkOverlap(Timeout.VIEW_INITIALIZED_COMPONENT_LOAD, true);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
registerOnChange(fn) {
|
|
111
|
+
this.onChange = fn;
|
|
112
|
+
}
|
|
113
|
+
registerOnTouched(fn) {
|
|
114
|
+
this.onTouch = fn;
|
|
115
|
+
}
|
|
116
|
+
setDisabledState(isDisabled) {
|
|
117
|
+
this.disabled = isDisabled;
|
|
118
|
+
}
|
|
119
|
+
writeValue(value) {
|
|
120
|
+
this.value = value;
|
|
121
|
+
}
|
|
122
|
+
onOptionSelected(event) {
|
|
123
|
+
const inputValue = event.option.value;
|
|
124
|
+
const itemValue = AutocompleteUtils.createValueItem(inputValue, this.textField, this.valueField);
|
|
125
|
+
this.addNewValue(itemValue);
|
|
126
|
+
if (this.type === this.autocompleteType.MULTI) {
|
|
127
|
+
this.checkOverlap();
|
|
128
|
+
}
|
|
129
|
+
queueMicrotask(() => {
|
|
130
|
+
if (this.type !== this.autocompleteType.SINGLE) {
|
|
131
|
+
this.inputValue = '';
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);
|
|
135
|
+
}
|
|
136
|
+
this.cdr.markForCheck();
|
|
137
|
+
});
|
|
138
|
+
this.onUpdate();
|
|
139
|
+
}
|
|
140
|
+
onOptionRemoved(input, option) {
|
|
141
|
+
setTimeout(() => (input.showPanel = false), 0);
|
|
142
|
+
const foundValue = this.value.find((v) => v === option);
|
|
143
|
+
if (foundValue) {
|
|
144
|
+
this.value = this.value.filter((v) => v !== option);
|
|
145
|
+
}
|
|
146
|
+
if (this.type === this.autocompleteType.MULTI) {
|
|
147
|
+
this.checkOverlap();
|
|
148
|
+
}
|
|
149
|
+
if (!this.value.length) {
|
|
150
|
+
this.inputValue = '';
|
|
151
|
+
}
|
|
152
|
+
this.onUpdate();
|
|
153
|
+
}
|
|
154
|
+
onInputChange(event) {
|
|
155
|
+
const inputValue = event.target.value;
|
|
156
|
+
this.userInput$.next(inputValue);
|
|
157
|
+
if (inputValue.length >= this.minCharactersSearch) {
|
|
158
|
+
this.inputValueSearch$.next(inputValue);
|
|
159
|
+
this.searchTextChange.emit(inputValue);
|
|
160
|
+
}
|
|
161
|
+
else {
|
|
162
|
+
this.inputValueSearch$.next('');
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
onClear() {
|
|
166
|
+
this.inputValue = '';
|
|
167
|
+
this.value = AutocompleteUtils.isArray(this.value) ? [] : '';
|
|
168
|
+
this.isOverLapping = false;
|
|
169
|
+
this.overlapIndex = 0;
|
|
170
|
+
this.onUpdate();
|
|
171
|
+
}
|
|
172
|
+
refillInput() {
|
|
173
|
+
if (this.value && this.type === this.autocompleteType.SINGLE && !this.inputValue) {
|
|
174
|
+
this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);
|
|
175
|
+
this.inputValueSearch$.next('');
|
|
176
|
+
}
|
|
177
|
+
if (!this.inputValue && this.value?.length) {
|
|
178
|
+
this.inputValue = ' ';
|
|
179
|
+
}
|
|
180
|
+
this.isInputFocus = false;
|
|
181
|
+
}
|
|
182
|
+
onFocus() {
|
|
183
|
+
this.isInputFocus = true;
|
|
184
|
+
const inputValue = AutocompleteUtils.isArray(this.inputValue) ? this.inputValue[0] : this.inputValue;
|
|
185
|
+
if (AutocompleteUtils.isPrimitive(inputValue)) {
|
|
186
|
+
if (inputValue?.match(/^\s+/gm)) {
|
|
187
|
+
this.inputValue = inputValue.trimStart();
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
if (inputValue[this.textField]?.match(/^\s+/gm)) {
|
|
192
|
+
this.inputValue = inputValue[this.textField].trimStart();
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
checkOverlap(delay = Timeout.VIEW_INITIALIZED_AFTER_ACTION, init = false) {
|
|
197
|
+
this.isOverLapping = false;
|
|
198
|
+
this.isOverlapChecking = true;
|
|
199
|
+
setTimeout(() => {
|
|
200
|
+
const inputWidth = this.matFormFieldElement?._textField.nativeElement.clientWidth - Padding.AUTOCOMPLETE_CONTAINER;
|
|
201
|
+
const tags = this.tagContainer?.nativeElement.querySelectorAll('.value-tag');
|
|
202
|
+
if (tags) {
|
|
203
|
+
let width = 0;
|
|
204
|
+
tags.forEach((tag, index) => {
|
|
205
|
+
width += tag.getBoundingClientRect().width;
|
|
206
|
+
if (!this.isOverLapping && width > inputWidth) {
|
|
207
|
+
this.isOverLapping = true;
|
|
208
|
+
this.overlapIndex = index;
|
|
209
|
+
}
|
|
210
|
+
});
|
|
211
|
+
this.isOverlapChecking = false;
|
|
212
|
+
if (init) {
|
|
213
|
+
if (this.type === this.autocompleteType.SINGLE) {
|
|
214
|
+
this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);
|
|
215
|
+
}
|
|
216
|
+
else {
|
|
217
|
+
this.inputValue = ' ';
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
this.cdr.markForCheck();
|
|
221
|
+
}
|
|
222
|
+
}, delay);
|
|
223
|
+
}
|
|
224
|
+
onUpdate() {
|
|
225
|
+
this.inputValueSearch$.next('');
|
|
226
|
+
this.userInput$.next('');
|
|
227
|
+
this.selectionChange.emit(this.value);
|
|
228
|
+
this.onChange(this.value);
|
|
229
|
+
}
|
|
230
|
+
initValue() {
|
|
231
|
+
if (this.type === this.autocompleteType.SINGLE) {
|
|
232
|
+
this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);
|
|
233
|
+
}
|
|
234
|
+
else {
|
|
235
|
+
this.inputValue = ' ';
|
|
236
|
+
}
|
|
237
|
+
if (this.type === this.autocompleteType.MULTI) {
|
|
238
|
+
this.checkOverlap();
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
addNewValue(newValue) {
|
|
242
|
+
if (this.type !== this.autocompleteType.SINGLE && !this.value) {
|
|
243
|
+
this.value = [];
|
|
244
|
+
}
|
|
245
|
+
const foundDuplicate = AutocompleteUtils.findDuplicate(this.value, newValue, this.textField);
|
|
246
|
+
if (this.type !== this.autocompleteType.SINGLE) {
|
|
247
|
+
this.value = foundDuplicate ? this.value.filter((v) => v !== foundDuplicate) : [...this.value, newValue];
|
|
248
|
+
}
|
|
249
|
+
else {
|
|
250
|
+
this.value = newValue;
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AutocompleteComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
254
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AutocompleteComponent, selector: "ui-autocomplete", inputs: { itemsList: "itemsList", suggestionsList: "suggestionsList", disabled: "disabled", allowAdd: "allowAdd", textField: "textField", valueField: "valueField", label: "label", itemValue: "itemValue", type: "type", minCharactersSearch: "minCharactersSearch" }, outputs: { selectionChange: "selectionChange", searchTextChange: "searchTextChange" }, providers: [
|
|
255
|
+
{
|
|
256
|
+
provide: NG_VALUE_ACCESSOR,
|
|
257
|
+
useExisting: forwardRef(() => AutocompleteComponent),
|
|
258
|
+
multi: true,
|
|
259
|
+
},
|
|
260
|
+
], viewQueries: [{ propertyName: "matFormFieldElement", first: true, predicate: ["matFormField"], descendants: true }, { propertyName: "tagContainer", first: true, predicate: ["tagContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *transloco=\"let t\">\n <div class=\"autocomplete-wrapper\">\n <mat-form-field\n [appearance]=\"'outline'\"\n #matFormField\n [ngClass]=\"{ 'large-size': type === autocompleteType.LARGE, disabled: disabled }\"\n >\n <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n <div class=\"input-container\">\n <div\n class=\"selected-items\"\n #tagContainer\n *ngIf=\"\n (type === autocompleteType.LARGE && this.value) ||\n (!(inputValue && this.isInputFocus) && this.value && type !== autocompleteType.SINGLE)\n \"\n >\n <ui-tag\n class=\"value-tag\"\n [id]=\"'ui-tag-' + i\"\n *ngFor=\"let valueItem of value; let i = index\"\n [label]=\"valueItem | transformItem: textField\"\n [allowClose]=\"true\"\n [style.display]=\"isOverLapping && i >= overlapIndex ? 'none' : 'block'\"\n [ngClass]=\"{\n 'overlap-tag': isOverlapChecking && overlapIndex && i >= overlapIndex && type === autocompleteType.MULTI\n }\"\n (close)=\"onOptionRemoved(autocomplete, valueItem)\"\n ></ui-tag>\n <ng-container *ngIf=\"isOverLapping\">\n <div *ngIf=\"!overlapIndex; else overlapTag\" class=\"overlap-count\">\n {{ t(translationContext + 'SELECTED_AMOUNT', { numberSelected: (value | slice: overlapIndex).length }) }}\n </div>\n <ng-template #overlapTag>\n <ui-tag [readOnly]=\"true\" [label]=\"'+' + (value | slice: overlapIndex).length\"></ui-tag>\n </ng-template>\n </ng-container>\n </div>\n <input\n [disabled]=\"disabled\"\n [ngClass]=\"{ 'unset-margin': this.value && type === autocompleteType.LARGE }\"\n (blur)=\"refillInput()\"\n (focusin)=\"onFocus()\"\n matInput\n [type]=\"'text'\"\n [matAutocomplete]=\"autocomplete\"\n (input)=\"onInputChange($event)\"\n [(ngModel)]=\"inputValue\"\n />\n </div>\n\n <ui-icon\n class=\"remove-selected\"\n [ngClass]=\"{ 'large-input-icon': type === autocompleteType.LARGE }\"\n (click)=\"onClear()\"\n *ngIf=\"inputValue || value?.length\"\n [size]=\"'24'\"\n [name]=\"'Close'\"\n ></ui-icon>\n\n <mat-autocomplete\n #autocomplete\n (optionSelected)=\"onOptionSelected($event)\"\n [hideSingleSelectionIndicator]=\"false\"\n >\n <ng-container *ngIf=\"!(searchResult$ | async)\">\n <mat-optgroup [label]=\"t(translationContext + 'SUGGESTED') | uppercase\" *ngIf=\"suggestionsList.length\">\n <mat-option\n [ngClass]=\"{ 'selected-option': suggested | includes: value }\"\n *ngFor=\"let suggested of suggestionsList\"\n [value]=\"suggested\"\n >\n <span [selectText]=\"userInput$ | async\">{{ suggested | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <mat-optgroup [label]=\"t(translationContext + 'SELECTED') | uppercase\" *ngIf=\"value?.length && type !== autocompleteType.SINGLE\">\n <mat-option\n [ngClass]=\"{ 'selected-option': item | includes: value }\"\n *ngFor=\"let item of value\"\n [value]=\"item\"\n >\n <span>{{ item | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <mat-optgroup [label]=\"t(translationContext + 'SELECTED') | uppercase\" *ngIf=\"value?.length && type === autocompleteType.SINGLE\">\n <mat-option\n [class]=\"'selected-option'\"\n [value]=\"value\"\n >\n <span [selectText]=\"userInput$ | async\">{{ value | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </mat-optgroup>\n </ng-container>\n\n <ng-container *ngIf=\"filteredSuggestionList$ | async as filteredSuggestionList\">\n <ng-container *ngIf=\"filteredItemsList$ | async as filteredItemsList\">\n <mat-optgroup [label]=\"t(translationContext + 'SUGGESTED') | uppercase\" *ngIf=\"filteredSuggestionList.length\">\n <mat-option\n [ngClass]=\"{ 'selected-option': item | includes: value }\"\n *ngFor=\"let item of filteredSuggestionList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <ng-container *ngIf=\"!filteredSuggestionList.length; else showItemListWithGroup\">\n <mat-option\n [ngClass]=\"{ 'selected-option': item | includes: value }\"\n *ngFor=\"let item of filteredItemsList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </ng-container>\n\n <ng-template #showItemListWithGroup>\n <mat-optgroup [label]=\"t(translationContext + 'ALL_ITEMS') | uppercase\" *ngIf=\"filteredItemsList.length\">\n <mat-option\n [ngClass]=\"{ 'selected-option': item | includes: value }\"\n *ngFor=\"let item of filteredItemsList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </mat-optgroup>\n </ng-template>\n\n <ng-container *ngIf=\"!filteredItemsList.length && !filteredSuggestionList.length && inputValue\">\n <ng-container *ngIf=\"allowAdd; else notFound\">\n <mat-option [value]=\"inputValue\">\n <span>{{ t('COMMON.ADD') }}</span>\n <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n </mat-option>\n </ng-container>\n\n <ng-template #notFound>\n <mat-option [style.pointer-events]=\"'none'\">\n <span>{{ t(translationContext + 'NO_RESULTS_FOUND') }}</span>\n </mat-option>\n </ng-template>\n </ng-container>\n </ng-container>\n </ng-container>\n </mat-autocomplete>\n </mat-form-field>\n </div>\n</ng-container>\n", styles: [".large-size input{margin:10px 0}.large-size .selected-items{margin:5px 0;flex-wrap:wrap}.large-size .input-container{display:block}.large-size ::ng-deep .mat-mdc-form-field-infix,.large-size .mat-mdc-form-field-flex{align-items:unset!important}.disabled ui-icon{opacity:.5}.input-container{width:100%;margin:auto;display:flex}.input-container .selected-items{display:flex}.input-container .selected-items .overlap-count{font-size:14px;line-height:20px;width:80px}.input-container .selected-items .overlap-tag{position:absolute;opacity:0}.input-container input{margin-left:4px}.input-container input.unset-margin{margin-top:unset}.add-suggestion{margin:0 5px;color:#000;font-weight:700}.remove-selected{cursor:pointer}.remove-selected.large-input-icon{margin-top:10px}::ng-deep .mdc-menu-surface.mat-mdc-autocomplete-panel{box-shadow:0 8px 24px 4px #00000014;max-height:312px!important}::ng-deep .mat-mdc-form-field{min-width:330px!important}::ng-deep .mat-mdc-option:hover:not(.mdc-list-item--disabled),::ng-deep .mat-mdc-option:focus:not(.mdc-list-item--disabled),::ng-deep .mat-mdc-option.mat-mdc-option-active,::ng-deep .mat-mdc-option.mdc-list-item--selected:not(.mat-mdc-option-multiple):not(.mdc-list-item--disabled){background:#E9F0F1!important}::ng-deep .mat-mdc-text-field-wrapper.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above{top:28px!important}::ng-deep .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-floating-label{top:50%!important}::ng-deep .mat-mdc-text-field-wrapper{padding-left:12px!important}::ng-deep .mat-focused .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-floating-label{color:#276678!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch{border-bottom:2px solid #276678!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading{border-left:2px solid #276678!important;border-bottom:2px solid #276678!important;border-top:2px solid #276678!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing{border:2px solid #276678!important;border-left:unset!important}::ng-deep .mat-mdc-form-field-infix,::ng-deep .mat-mdc-form-field-flex{min-height:48px!important;max-height:184px!important;overflow-y:auto;overflow-x:hidden;padding:0!important;display:flex;justify-content:center;text-align:center;align-items:center;flex-direction:row;width:100%}::ng-deep .mdc-line-ripple{display:none!important}::ng-deep .mat-mdc-option{padding-right:32px;padding-left:12px!important}::ng-deep .mat-mdc-option ui-icon{display:none;position:absolute;right:0;bottom:calc(50% - 8px);margin:0 10px}::ng-deep .mat-mdc-option.selected-option{background:#E9F0F1}::ng-deep .mat-mdc-option.selected-option ui-icon{display:block}::ng-deep .mat-mdc-option.mdc-list-item--selected .mdc-list-item__primary-text,::ng-deep .mat-mdc-option .mdc-list-item--activated .mdc-list-item__primary-text{color:#000!important}::ng-deep .mat-mdc-option .mat-pseudo-checkbox{display:none}::ng-deep .mat-mdc-optgroup .mat-mdc-optgroup-label{font-weight:700!important}::ng-deep .mat-mdc-optgroup .mdc-list-item__primary-text{color:#000;font-size:12px;line-height:16px;font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "component", type: i3.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple", "hideSingleSelectionIndicator"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i4.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i4.MatOptgroup, selector: "mat-optgroup", inputs: ["disabled"], exportAs: ["matOptgroup"] }, { kind: "directive", type: i3.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.TagComponent, selector: "ui-tag", inputs: ["label", "icon", "allowClose", "readOnly", "isSelected", "showIconWhenSelected", "isDisabled"], outputs: ["close", "press"] }, { kind: "component", type: i8.IconComponent, selector: "ui-icon", inputs: ["size", "cssClass", "name", "color"] }, { kind: "directive", type: i9.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoLang", "translocoLoadingTpl"] }, { kind: "directive", type: i10.SelectTextDirective, selector: "[selectText]", inputs: ["selectText"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }, { kind: "pipe", type: i11.TransformItemPipe, name: "transformItem" }, { kind: "pipe", type: i12.IncludesPipe, name: "includes" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
261
|
+
}
|
|
262
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AutocompleteComponent, decorators: [{
|
|
263
|
+
type: Component,
|
|
264
|
+
args: [{ selector: 'ui-autocomplete', providers: [
|
|
265
|
+
{
|
|
266
|
+
provide: NG_VALUE_ACCESSOR,
|
|
267
|
+
useExisting: forwardRef(() => AutocompleteComponent),
|
|
268
|
+
multi: true,
|
|
269
|
+
},
|
|
270
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\n <div class=\"autocomplete-wrapper\">\n <mat-form-field\n [appearance]=\"'outline'\"\n #matFormField\n [ngClass]=\"{ 'large-size': type === autocompleteType.LARGE, disabled: disabled }\"\n >\n <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n <div class=\"input-container\">\n <div\n class=\"selected-items\"\n #tagContainer\n *ngIf=\"\n (type === autocompleteType.LARGE && this.value) ||\n (!(inputValue && this.isInputFocus) && this.value && type !== autocompleteType.SINGLE)\n \"\n >\n <ui-tag\n class=\"value-tag\"\n [id]=\"'ui-tag-' + i\"\n *ngFor=\"let valueItem of value; let i = index\"\n [label]=\"valueItem | transformItem: textField\"\n [allowClose]=\"true\"\n [style.display]=\"isOverLapping && i >= overlapIndex ? 'none' : 'block'\"\n [ngClass]=\"{\n 'overlap-tag': isOverlapChecking && overlapIndex && i >= overlapIndex && type === autocompleteType.MULTI\n }\"\n (close)=\"onOptionRemoved(autocomplete, valueItem)\"\n ></ui-tag>\n <ng-container *ngIf=\"isOverLapping\">\n <div *ngIf=\"!overlapIndex; else overlapTag\" class=\"overlap-count\">\n {{ t(translationContext + 'SELECTED_AMOUNT', { numberSelected: (value | slice: overlapIndex).length }) }}\n </div>\n <ng-template #overlapTag>\n <ui-tag [readOnly]=\"true\" [label]=\"'+' + (value | slice: overlapIndex).length\"></ui-tag>\n </ng-template>\n </ng-container>\n </div>\n <input\n [disabled]=\"disabled\"\n [ngClass]=\"{ 'unset-margin': this.value && type === autocompleteType.LARGE }\"\n (blur)=\"refillInput()\"\n (focusin)=\"onFocus()\"\n matInput\n [type]=\"'text'\"\n [matAutocomplete]=\"autocomplete\"\n (input)=\"onInputChange($event)\"\n [(ngModel)]=\"inputValue\"\n />\n </div>\n\n <ui-icon\n class=\"remove-selected\"\n [ngClass]=\"{ 'large-input-icon': type === autocompleteType.LARGE }\"\n (click)=\"onClear()\"\n *ngIf=\"inputValue || value?.length\"\n [size]=\"'24'\"\n [name]=\"'Close'\"\n ></ui-icon>\n\n <mat-autocomplete\n #autocomplete\n (optionSelected)=\"onOptionSelected($event)\"\n [hideSingleSelectionIndicator]=\"false\"\n >\n <ng-container *ngIf=\"!(searchResult$ | async)\">\n <mat-optgroup [label]=\"t(translationContext + 'SUGGESTED') | uppercase\" *ngIf=\"suggestionsList.length\">\n <mat-option\n [ngClass]=\"{ 'selected-option': suggested | includes: value }\"\n *ngFor=\"let suggested of suggestionsList\"\n [value]=\"suggested\"\n >\n <span [selectText]=\"userInput$ | async\">{{ suggested | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <mat-optgroup [label]=\"t(translationContext + 'SELECTED') | uppercase\" *ngIf=\"value?.length && type !== autocompleteType.SINGLE\">\n <mat-option\n [ngClass]=\"{ 'selected-option': item | includes: value }\"\n *ngFor=\"let item of value\"\n [value]=\"item\"\n >\n <span>{{ item | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <mat-optgroup [label]=\"t(translationContext + 'SELECTED') | uppercase\" *ngIf=\"value?.length && type === autocompleteType.SINGLE\">\n <mat-option\n [class]=\"'selected-option'\"\n [value]=\"value\"\n >\n <span [selectText]=\"userInput$ | async\">{{ value | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </mat-optgroup>\n </ng-container>\n\n <ng-container *ngIf=\"filteredSuggestionList$ | async as filteredSuggestionList\">\n <ng-container *ngIf=\"filteredItemsList$ | async as filteredItemsList\">\n <mat-optgroup [label]=\"t(translationContext + 'SUGGESTED') | uppercase\" *ngIf=\"filteredSuggestionList.length\">\n <mat-option\n [ngClass]=\"{ 'selected-option': item | includes: value }\"\n *ngFor=\"let item of filteredSuggestionList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </mat-optgroup>\n\n <ng-container *ngIf=\"!filteredSuggestionList.length; else showItemListWithGroup\">\n <mat-option\n [ngClass]=\"{ 'selected-option': item | includes: value }\"\n *ngFor=\"let item of filteredItemsList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </ng-container>\n\n <ng-template #showItemListWithGroup>\n <mat-optgroup [label]=\"t(translationContext + 'ALL_ITEMS') | uppercase\" *ngIf=\"filteredItemsList.length\">\n <mat-option\n [ngClass]=\"{ 'selected-option': item | includes: value }\"\n *ngFor=\"let item of filteredItemsList\"\n [value]=\"item\"\n >\n <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n <ui-icon [name]=\"'Check'\"></ui-icon>\n </mat-option>\n </mat-optgroup>\n </ng-template>\n\n <ng-container *ngIf=\"!filteredItemsList.length && !filteredSuggestionList.length && inputValue\">\n <ng-container *ngIf=\"allowAdd; else notFound\">\n <mat-option [value]=\"inputValue\">\n <span>{{ t('COMMON.ADD') }}</span>\n <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n </mat-option>\n </ng-container>\n\n <ng-template #notFound>\n <mat-option [style.pointer-events]=\"'none'\">\n <span>{{ t(translationContext + 'NO_RESULTS_FOUND') }}</span>\n </mat-option>\n </ng-template>\n </ng-container>\n </ng-container>\n </ng-container>\n </mat-autocomplete>\n </mat-form-field>\n </div>\n</ng-container>\n", styles: [".large-size input{margin:10px 0}.large-size .selected-items{margin:5px 0;flex-wrap:wrap}.large-size .input-container{display:block}.large-size ::ng-deep .mat-mdc-form-field-infix,.large-size .mat-mdc-form-field-flex{align-items:unset!important}.disabled ui-icon{opacity:.5}.input-container{width:100%;margin:auto;display:flex}.input-container .selected-items{display:flex}.input-container .selected-items .overlap-count{font-size:14px;line-height:20px;width:80px}.input-container .selected-items .overlap-tag{position:absolute;opacity:0}.input-container input{margin-left:4px}.input-container input.unset-margin{margin-top:unset}.add-suggestion{margin:0 5px;color:#000;font-weight:700}.remove-selected{cursor:pointer}.remove-selected.large-input-icon{margin-top:10px}::ng-deep .mdc-menu-surface.mat-mdc-autocomplete-panel{box-shadow:0 8px 24px 4px #00000014;max-height:312px!important}::ng-deep .mat-mdc-form-field{min-width:330px!important}::ng-deep .mat-mdc-option:hover:not(.mdc-list-item--disabled),::ng-deep .mat-mdc-option:focus:not(.mdc-list-item--disabled),::ng-deep .mat-mdc-option.mat-mdc-option-active,::ng-deep .mat-mdc-option.mdc-list-item--selected:not(.mat-mdc-option-multiple):not(.mdc-list-item--disabled){background:#E9F0F1!important}::ng-deep .mat-mdc-text-field-wrapper.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above{top:28px!important}::ng-deep .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-floating-label{top:50%!important}::ng-deep .mat-mdc-text-field-wrapper{padding-left:12px!important}::ng-deep .mat-focused .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-floating-label{color:#276678!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch{border-bottom:2px solid #276678!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading{border-left:2px solid #276678!important;border-bottom:2px solid #276678!important;border-top:2px solid #276678!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing{border:2px solid #276678!important;border-left:unset!important}::ng-deep .mat-mdc-form-field-infix,::ng-deep .mat-mdc-form-field-flex{min-height:48px!important;max-height:184px!important;overflow-y:auto;overflow-x:hidden;padding:0!important;display:flex;justify-content:center;text-align:center;align-items:center;flex-direction:row;width:100%}::ng-deep .mdc-line-ripple{display:none!important}::ng-deep .mat-mdc-option{padding-right:32px;padding-left:12px!important}::ng-deep .mat-mdc-option ui-icon{display:none;position:absolute;right:0;bottom:calc(50% - 8px);margin:0 10px}::ng-deep .mat-mdc-option.selected-option{background:#E9F0F1}::ng-deep .mat-mdc-option.selected-option ui-icon{display:block}::ng-deep .mat-mdc-option.mdc-list-item--selected .mdc-list-item__primary-text,::ng-deep .mat-mdc-option .mdc-list-item--activated .mdc-list-item__primary-text{color:#000!important}::ng-deep .mat-mdc-option .mat-pseudo-checkbox{display:none}::ng-deep .mat-mdc-optgroup .mat-mdc-optgroup-label{font-weight:700!important}::ng-deep .mat-mdc-optgroup .mdc-list-item__primary-text{color:#000;font-size:12px;line-height:16px;font-weight:700}\n"] }]
|
|
271
|
+
}], propDecorators: { itemsList: [{
|
|
272
|
+
type: Input
|
|
273
|
+
}], suggestionsList: [{
|
|
274
|
+
type: Input
|
|
275
|
+
}], disabled: [{
|
|
276
|
+
type: Input
|
|
277
|
+
}], allowAdd: [{
|
|
278
|
+
type: Input
|
|
279
|
+
}], textField: [{
|
|
280
|
+
type: Input
|
|
281
|
+
}], valueField: [{
|
|
282
|
+
type: Input
|
|
283
|
+
}], label: [{
|
|
284
|
+
type: Input
|
|
285
|
+
}], itemValue: [{
|
|
286
|
+
type: Input
|
|
287
|
+
}], type: [{
|
|
288
|
+
type: Input
|
|
289
|
+
}], minCharactersSearch: [{
|
|
290
|
+
type: Input
|
|
291
|
+
}], selectionChange: [{
|
|
292
|
+
type: Output
|
|
293
|
+
}], searchTextChange: [{
|
|
294
|
+
type: Output
|
|
295
|
+
}], matFormFieldElement: [{
|
|
296
|
+
type: ViewChild,
|
|
297
|
+
args: ['matFormField']
|
|
298
|
+
}], tagContainer: [{
|
|
299
|
+
type: ViewChild,
|
|
300
|
+
args: ['tagContainer']
|
|
301
|
+
}] } });
|
|
302
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../src/components/autocomplete/autocomplete.component.ts","../../../../../src/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EAET,YAAY,EACZ,UAAU,EACV,MAAM,EACN,KAAK,EAEL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAGzE,OAAO,EAAE,GAAG,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAoB,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;;;;;;;;;;;;;;AAexF,MAAM,OAAO,qBAAqB;IAblC;QAcE;;;;WAIG;QACM,cAAS,GAAU,EAAE,CAAC;QAE/B;;;;WAIG;QACM,oBAAe,GAAU,EAAE,CAAC;QAErC;;;;WAIG;QACM,aAAQ,GAAG,KAAK,CAAC;QAE1B;;;;WAIG;QACM,aAAQ,GAAG,IAAI,CAAC;QAEzB;;;;WAIG;QACM,cAAS,GAAG,EAAE,CAAC;QAExB;;;;WAIG;QACM,eAAU,GAAG,EAAE,CAAC;QAEzB;;;;WAIG;QACM,UAAK,GAAG,EAAE,CAAC;QAWpB;;;;WAIG;QACM,SAAI,GAAqB,OAAO,CAAC;QAE1C;;;;WAIG;QACM,wBAAmB,GAAG,CAAC,CAAC;QAEvB,oBAAe,GAAG,IAAI,YAAY,EAAO,CAAC;QAC1C,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;QAKvC,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAEvC,eAAU,GAAQ,EAAE,CAAC;QACrB,iBAAY,GAAG,KAAK,CAAC;QACrB,qBAAgB,GAAG,YAAY,CAAC;QAChC,kBAAa,GAAG,KAAK,CAAC;QACtB,sBAAiB,GAAG,IAAI,CAAC;QACzB,iBAAY,GAAG,CAAC,CAAC;QACjB,sBAAiB,GAAG,IAAI,aAAa,CAAS,CAAC,CAAC,CAAC;QACjD,eAAU,GAAG,IAAI,aAAa,CAAS,CAAC,CAAC,CAAC;QAC1C,uBAAkB,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CACxD,SAAS,CAAC,EAAE,CAAC,EACb,GAAG,CAAC,UAAU,CAAC,EAAE,CACf,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,EAAE,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CACrG,CACF,CAAC;QACQ,4BAAuB,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAC7D,GAAG,CAAC,UAAU,CAAC,EAAE,CACf,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,CAAC,eAAe,EAAE,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAC3G,CACF,CAAC;QACQ,kBAAa,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QAEpF,uBAAkB,GAAG,eAAe,CAAC;QAa/C,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAC1B,YAAO,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;KA2KpB;IA7OC;;;;OAIG;IACH,IAAa,SAAS,CAAC,CAAM;QAC3B,IAAI,CAAC,KAAK,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACtD,CAAC;IA+CD,WAAW;QACT,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAC7G,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,KAAK,EAAE;YACpC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,+BAA+B,EAAE,IAAI,CAAC,CAAC;SAClE;IACH,CAAC;IAKD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAES,gBAAgB,CAAC,KAAmC;QAC5D,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QACtC,MAAM,SAAS,GAAG,iBAAiB,CAAC,eAAe,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QACjG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QAE5B,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE;YAC7C,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;QAED,cAAc,CAAC,GAAG,EAAE;YAClB,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE;gBAC9C,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;aACtB;iBAAM;gBACL,IAAI,CAAC,UAAU,GAAG,iBAAiB,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;aACvF;YACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAES,eAAe,CAAC,KAAU,EAAE,MAAW;QAC/C,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;QAE/C,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC;QAE7D,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC;SAC1D;QAED,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE;YAC7C,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;QAED,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YACtB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;SACtB;QAED,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAES,aAAa,CAAC,KAAY;QAClC,MAAM,UAAU,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QAC5D,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjC,IAAI,UAAU,CAAC,MAAM,IAAI,IAAI,CAAC,mBAAmB,EAAE;YACjD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACxC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACxC;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SACjC;IACH,CAAC;IAES,OAAO;QACf,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,KAAK,GAAG,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7D,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAES,WAAW;QACnB,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAChF,IAAI,CAAC,UAAU,GAAG,iBAAiB,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YACtF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SACjC;QAED,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE;YAC1C,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;SACvB;QAED,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IAES,OAAO;QACf,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAEzB,MAAM,UAAU,GAAG,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;QAErG,IAAI,iBAAiB,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE;YAC7C,IAAI,UAAU,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE;gBAC/B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,SAAS,EAAE,CAAC;aAC1C;SACF;aAAM;YACL,IAAI,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE;gBAC/C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,CAAC;aAC1D;SACF;IACH,CAAC;IAEO,YAAY,CAAC,KAAK,GAAG,OAAO,CAAC,6BAA6B,EAAE,IAAI,GAAG,KAAK;QAC9E,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAE9B,UAAU,CAAC,GAAG,EAAE;YACd,MAAM,UAAU,GACd,IAAI,CAAC,mBAAmB,EAAE,UAAU,CAAC,aAAa,CAAC,WAAW,GAAG,OAAO,CAAC,sBAAsB,CAAC;YAClG,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,EAAE,aAAa,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;YAE7E,IAAI,IAAI,EAAE;gBACR,IAAI,KAAK,GAAG,CAAC,CAAC;gBAEd,IAAI,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,KAAa,EAAE,EAAE;oBACvC,KAAK,IAAI,GAAG,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;oBAE3C,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,KAAK,GAAG,UAAU,EAAE;wBAC7C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;wBAC1B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;qBAC3B;gBACH,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC/B,IAAI,IAAI,EAAE;oBACR,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE;wBAC9C,IAAI,CAAC,UAAU,GAAG,iBAAiB,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;qBAC1F;yBAAM;wBACL,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;qBACvB;iBACF;gBACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;QACH,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAEO,QAAQ;QACd,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAChC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACzB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAEO,SAAS;QACf,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE;YAC9C,IAAI,CAAC,UAAU,GAAG,iBAAiB,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;SAC1F;aAAM;YACL,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;SACvB;QACD,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE;YAC7C,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;IAEO,WAAW,CAAC,QAAa;QAC/B,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YAC7D,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;SACjB;QAED,MAAM,cAAc,GAAG,iBAAiB,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAE7F,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE;YAC9C,IAAI,CAAC,KAAK,GAAG,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,KAAK,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;SAC/G;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;SACvB;IACH,CAAC;+GA9RU,qBAAqB;mGAArB,qBAAqB,yYATrB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;gBACpD,KAAK,EAAE,IAAI;aACZ;SACF,mQC/BH,0yNA4JA;;4FD1Ha,qBAAqB;kBAbjC,SAAS;+BACE,iBAAiB,aAGhB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC;4BACpD,KAAK,EAAE,IAAI;yBACZ;qBACF,mBACgB,uBAAuB,CAAC,MAAM;8BAQtC,SAAS;sBAAjB,KAAK;gBAOG,eAAe;sBAAvB,KAAK;gBAOG,QAAQ;sBAAhB,KAAK;gBAOG,QAAQ;sBAAhB,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAOG,UAAU;sBAAlB,KAAK;gBAOG,KAAK;sBAAb,KAAK;gBAOO,SAAS;sBAArB,KAAK;gBASG,IAAI;sBAAZ,KAAK;gBAOG,mBAAmB;sBAA3B,KAAK;gBAEI,eAAe;sBAAxB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBAEoB,mBAAmB;sBAA7C,SAAS;uBAAC,cAAc;gBACE,YAAY;sBAAtC,SAAS;uBAAC,cAAc","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  inject,\n  Input,\n  OnChanges,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatFormField } from '@angular/material/form-field';\nimport { map, ReplaySubject, startWith } from 'rxjs';\nimport { AutocompleteUtils } from '../../utils/autocomplete-utils';\nimport { Autocomplete, AutocompleteType, Padding, Timeout } from './autocomplete.model';\n\n@Component({\n  selector: 'ui-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  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AutocompleteComponent implements ControlValueAccessor, OnChanges, AfterViewInit {\n  /**\n   * @property itemsList\n   * @description The list of items to display in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() itemsList: any[] = [];\n\n  /**\n   * @property suggestionsList\n   * @description The list of suggestions to display in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() suggestionsList: any[] = [];\n\n  /**\n   * @property disabled\n   * @description If `true`, the autocomplete is disabled.\n   * @memberof AutocompleteComponent\n   */\n  @Input() disabled = false;\n\n  /**\n   * @property allowAdd\n   * @description If `true`, allows adding new values to the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() allowAdd = true;\n\n  /**\n   * @property textField\n   * @description The field to be used as the display text in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() textField = '';\n\n  /**\n   * @property valueField\n   * @description The field to be used as the value in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() valueField = '';\n\n  /**\n   * @property label\n   * @description The label for the autocomplete input.\n   * @memberof AutocompleteComponent\n   */\n  @Input() label = '';\n\n  /**\n   * @property value\n   * @description The selected value(s) in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() set itemValue(v: any) {\n    this.value = AutocompleteUtils.isArray(v) ? v : [v];\n  }\n\n  /**\n   * @property type\n   * @description The type of the autocomplete ('single', 'multi', etc.).\n   * @memberof AutocompleteComponent\n   */\n  @Input() type: AutocompleteType = 'multi';\n\n  /**\n   * @property minCharactersSearch\n   * @description The minimum characters to trigger search.\n   * @memberof AutocompleteComponent\n   */\n  @Input() minCharactersSearch = 3;\n\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() searchTextChange = new EventEmitter<string>();\n\n  @ViewChild('matFormField') matFormFieldElement: MatFormField;\n  @ViewChild('tagContainer') tagContainer: ElementRef<HTMLElement>;\n\n  private readonly cdr = inject(ChangeDetectorRef);\n  protected value: any;\n  protected inputValue: any = '';\n  protected isInputFocus = false;\n  protected autocompleteType = Autocomplete;\n  protected isOverLapping = false;\n  protected isOverlapChecking = true;\n  protected overlapIndex = 0;\n  protected inputValueSearch$ = new ReplaySubject<string>(1);\n  protected userInput$ = new ReplaySubject<string>(1);\n  protected filteredItemsList$ = this.inputValueSearch$.pipe(\n    startWith(''),\n    map(inputValue =>\n      inputValue.length ? AutocompleteUtils.filterItems(this.itemsList, inputValue, this.textField) : null\n    )\n  );\n  protected filteredSuggestionList$ = this.inputValueSearch$.pipe(\n    map(inputValue =>\n      inputValue.length ? AutocompleteUtils.filterItems(this.suggestionsList, inputValue, this.textField) : null\n    )\n  );\n  protected searchResult$ = this.inputValueSearch$.pipe(map(inputValue => !!inputValue.trim()));\n\n  protected translationContext = 'AUTOCOMPLETE.';\n\n  ngOnChanges(): void {\n    this.itemsList = AutocompleteUtils.excludeSuggestions(this.itemsList, this.suggestionsList, this.valueField);\n    this.initValue();\n  }\n\n  ngAfterViewInit(): void {\n    if (this.type !== Autocomplete.LARGE) {\n      this.checkOverlap(Timeout.VIEW_INITIALIZED_COMPONENT_LOAD, true);\n    }\n  }\n\n  onChange = (_: any) => {};\n  onTouch = () => {};\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  protected onOptionSelected(event: MatAutocompleteSelectedEvent): void {\n    const inputValue = event.option.value;\n    const itemValue = AutocompleteUtils.createValueItem(inputValue, this.textField, this.valueField);\n    this.addNewValue(itemValue);\n\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n\n    queueMicrotask(() => {\n      if (this.type !== this.autocompleteType.SINGLE) {\n        this.inputValue = '';\n      } else {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);\n      }\n      this.cdr.markForCheck();\n    });\n\n    this.onUpdate();\n  }\n\n  protected onOptionRemoved(input: any, option: any): void {\n    setTimeout(() => (input.showPanel = false), 0);\n\n    const foundValue = this.value.find((v: any) => v === option);\n\n    if (foundValue) {\n      this.value = this.value.filter((v: any) => v !== option);\n    }\n\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n\n    if (!this.value.length) {\n      this.inputValue = '';\n    }\n\n    this.onUpdate();\n  }\n\n  protected onInputChange(event: Event): void {\n    const inputValue = (event.target as HTMLInputElement).value;\n    this.userInput$.next(inputValue);\n    if (inputValue.length >= this.minCharactersSearch) {\n      this.inputValueSearch$.next(inputValue);\n      this.searchTextChange.emit(inputValue);\n    } else {\n      this.inputValueSearch$.next('');\n    }\n  }\n\n  protected onClear(): void {\n    this.inputValue = '';\n    this.value = AutocompleteUtils.isArray(this.value) ? [] : '';\n    this.isOverLapping = false;\n    this.overlapIndex = 0;\n    this.onUpdate();\n  }\n\n  protected refillInput(): void {\n    if (this.value && this.type === this.autocompleteType.SINGLE && !this.inputValue) {\n      this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);\n      this.inputValueSearch$.next('');\n    }\n\n    if (!this.inputValue && this.value?.length) {\n      this.inputValue = ' ';\n    }\n\n    this.isInputFocus = false;\n  }\n\n  protected onFocus(): void {\n    this.isInputFocus = true;\n\n    const inputValue = AutocompleteUtils.isArray(this.inputValue) ? this.inputValue[0] : this.inputValue;\n\n    if (AutocompleteUtils.isPrimitive(inputValue)) {\n      if (inputValue?.match(/^\\s+/gm)) {\n        this.inputValue = inputValue.trimStart();\n      }\n    } else {\n      if (inputValue[this.textField]?.match(/^\\s+/gm)) {\n        this.inputValue = inputValue[this.textField].trimStart();\n      }\n    }\n  }\n\n  private checkOverlap(delay = Timeout.VIEW_INITIALIZED_AFTER_ACTION, init = false): void {\n    this.isOverLapping = false;\n    this.isOverlapChecking = true;\n\n    setTimeout(() => {\n      const inputWidth =\n        this.matFormFieldElement?._textField.nativeElement.clientWidth - Padding.AUTOCOMPLETE_CONTAINER;\n      const tags = this.tagContainer?.nativeElement.querySelectorAll('.value-tag');\n\n      if (tags) {\n        let width = 0;\n\n        tags.forEach((tag: any, index: number) => {\n          width += tag.getBoundingClientRect().width;\n\n          if (!this.isOverLapping && width > inputWidth) {\n            this.isOverLapping = true;\n            this.overlapIndex = index;\n          }\n        });\n        this.isOverlapChecking = false;\n        if (init) {\n          if (this.type === this.autocompleteType.SINGLE) {\n            this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);\n          } else {\n            this.inputValue = ' ';\n          }\n        }\n        this.cdr.markForCheck();\n      }\n    }, delay);\n  }\n\n  private onUpdate(): void {\n    this.inputValueSearch$.next('');\n    this.userInput$.next('');\n    this.selectionChange.emit(this.value);\n    this.onChange(this.value);\n  }\n\n  private initValue(): void {\n    if (this.type === this.autocompleteType.SINGLE) {\n      this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);\n    } else {\n      this.inputValue = ' ';\n    }\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n  }\n\n  private addNewValue(newValue: any): void {\n    if (this.type !== this.autocompleteType.SINGLE && !this.value) {\n      this.value = [];\n    }\n\n    const foundDuplicate = AutocompleteUtils.findDuplicate(this.value, newValue, this.textField);\n\n    if (this.type !== this.autocompleteType.SINGLE) {\n      this.value = foundDuplicate ? this.value.filter((v: any) => v !== foundDuplicate) : [...this.value, newValue];\n    } else {\n      this.value = newValue;\n    }\n  }\n}\n","<ng-container *transloco=\"let t\">\n  <div class=\"autocomplete-wrapper\">\n    <mat-form-field\n      [appearance]=\"'outline'\"\n      #matFormField\n      [ngClass]=\"{ 'large-size': type === autocompleteType.LARGE, disabled: disabled }\"\n    >\n      <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n      <div class=\"input-container\">\n        <div\n          class=\"selected-items\"\n          #tagContainer\n          *ngIf=\"\n            (type === autocompleteType.LARGE && this.value) ||\n            (!(inputValue && this.isInputFocus) && this.value && type !== autocompleteType.SINGLE)\n          \"\n        >\n          <ui-tag\n            class=\"value-tag\"\n            [id]=\"'ui-tag-' + i\"\n            *ngFor=\"let valueItem of value; let i = index\"\n            [label]=\"valueItem | transformItem: textField\"\n            [allowClose]=\"true\"\n            [style.display]=\"isOverLapping && i >= overlapIndex ? 'none' : 'block'\"\n            [ngClass]=\"{\n              'overlap-tag': isOverlapChecking && overlapIndex && i >= overlapIndex && type === autocompleteType.MULTI\n            }\"\n            (close)=\"onOptionRemoved(autocomplete, valueItem)\"\n          ></ui-tag>\n          <ng-container *ngIf=\"isOverLapping\">\n            <div *ngIf=\"!overlapIndex; else overlapTag\" class=\"overlap-count\">\n              {{ t(translationContext + 'SELECTED_AMOUNT', { numberSelected: (value | slice: overlapIndex).length }) }}\n            </div>\n            <ng-template #overlapTag>\n              <ui-tag [readOnly]=\"true\" [label]=\"'+' + (value | slice: overlapIndex).length\"></ui-tag>\n            </ng-template>\n          </ng-container>\n        </div>\n        <input\n          [disabled]=\"disabled\"\n          [ngClass]=\"{ 'unset-margin': this.value && type === autocompleteType.LARGE }\"\n          (blur)=\"refillInput()\"\n          (focusin)=\"onFocus()\"\n          matInput\n          [type]=\"'text'\"\n          [matAutocomplete]=\"autocomplete\"\n          (input)=\"onInputChange($event)\"\n          [(ngModel)]=\"inputValue\"\n        />\n      </div>\n\n      <ui-icon\n        class=\"remove-selected\"\n        [ngClass]=\"{ 'large-input-icon': type === autocompleteType.LARGE }\"\n        (click)=\"onClear()\"\n        *ngIf=\"inputValue || value?.length\"\n        [size]=\"'24'\"\n        [name]=\"'Close'\"\n      ></ui-icon>\n\n      <mat-autocomplete\n        #autocomplete\n        (optionSelected)=\"onOptionSelected($event)\"\n        [hideSingleSelectionIndicator]=\"false\"\n      >\n        <ng-container *ngIf=\"!(searchResult$ | async)\">\n          <mat-optgroup [label]=\"t(translationContext + 'SUGGESTED') | uppercase\" *ngIf=\"suggestionsList.length\">\n            <mat-option\n              [ngClass]=\"{ 'selected-option': suggested | includes: value }\"\n              *ngFor=\"let suggested of suggestionsList\"\n              [value]=\"suggested\"\n            >\n              <span [selectText]=\"userInput$ | async\">{{ suggested | transformItem: textField }}</span>\n              <ui-icon [name]=\"'Check'\"></ui-icon>\n            </mat-option>\n          </mat-optgroup>\n\n          <mat-optgroup [label]=\"t(translationContext + 'SELECTED') | uppercase\" *ngIf=\"value?.length && type !== autocompleteType.SINGLE\">\n            <mat-option\n              [ngClass]=\"{ 'selected-option': item | includes: value }\"\n              *ngFor=\"let item of value\"\n              [value]=\"item\"\n            >\n              <span>{{ item | transformItem: textField }}</span>\n              <ui-icon [name]=\"'Check'\"></ui-icon>\n            </mat-option>\n          </mat-optgroup>\n\n          <mat-optgroup [label]=\"t(translationContext + 'SELECTED') | uppercase\" *ngIf=\"value?.length && type === autocompleteType.SINGLE\">\n            <mat-option\n              [class]=\"'selected-option'\"\n              [value]=\"value\"\n            >\n              <span [selectText]=\"userInput$ | async\">{{ value | transformItem: textField }}</span>\n              <ui-icon [name]=\"'Check'\"></ui-icon>\n            </mat-option>\n          </mat-optgroup>\n        </ng-container>\n\n        <ng-container *ngIf=\"filteredSuggestionList$ | async as filteredSuggestionList\">\n          <ng-container *ngIf=\"filteredItemsList$ | async as filteredItemsList\">\n            <mat-optgroup [label]=\"t(translationContext + 'SUGGESTED') | uppercase\" *ngIf=\"filteredSuggestionList.length\">\n              <mat-option\n                [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                *ngFor=\"let item of filteredSuggestionList\"\n                [value]=\"item\"\n              >\n                <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                <ui-icon [name]=\"'Check'\"></ui-icon>\n              </mat-option>\n            </mat-optgroup>\n\n            <ng-container *ngIf=\"!filteredSuggestionList.length; else showItemListWithGroup\">\n              <mat-option\n                [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                *ngFor=\"let item of filteredItemsList\"\n                [value]=\"item\"\n              >\n                <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                <ui-icon [name]=\"'Check'\"></ui-icon>\n              </mat-option>\n            </ng-container>\n\n            <ng-template #showItemListWithGroup>\n              <mat-optgroup [label]=\"t(translationContext + 'ALL_ITEMS') | uppercase\" *ngIf=\"filteredItemsList.length\">\n                <mat-option\n                  [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                  *ngFor=\"let item of filteredItemsList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [name]=\"'Check'\"></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n            </ng-template>\n\n            <ng-container *ngIf=\"!filteredItemsList.length && !filteredSuggestionList.length && inputValue\">\n              <ng-container *ngIf=\"allowAdd; else notFound\">\n                <mat-option [value]=\"inputValue\">\n                  <span>{{ t('COMMON.ADD') }}</span>\n                  <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n                </mat-option>\n              </ng-container>\n\n              <ng-template #notFound>\n                <mat-option [style.pointer-events]=\"'none'\">\n                  <span>{{ t(translationContext + 'NO_RESULTS_FOUND') }}</span>\n                </mat-option>\n              </ng-template>\n            </ng-container>\n          </ng-container>\n        </ng-container>\n      </mat-autocomplete>\n    </mat-form-field>\n  </div>\n</ng-container>\n"]}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { APP_INITIALIZER, NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { AutocompleteComponent } from './autocomplete.component';
|
|
4
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
5
|
+
import { MatAutocompleteModule } from '@angular/material/autocomplete';
|
|
6
|
+
import { MatInputModule } from '@angular/material/input';
|
|
7
|
+
import { FormsModule } from '@angular/forms';
|
|
8
|
+
import { TagComponentModule } from '../tag/tag.component.module';
|
|
9
|
+
import { MatChipsModule } from '@angular/material/chips';
|
|
10
|
+
import { IconComponentModule } from '../icon/icon.component.module';
|
|
11
|
+
import { TransformItemPipe } from './transform-Item.pipe';
|
|
12
|
+
import { IncludesPipe } from './includes.pipe';
|
|
13
|
+
import { SelectTextDirective } from '../../directives/select-text.directive';
|
|
14
|
+
import { TranslocoModule, TranslocoService } from '@ngneat/transloco';
|
|
15
|
+
import { lastValueFrom } from 'rxjs';
|
|
16
|
+
import * as i0 from "@angular/core";
|
|
17
|
+
const preloadLang = (transloco) => () => {
|
|
18
|
+
transloco.setActiveLang('en');
|
|
19
|
+
return lastValueFrom(transloco.load('en'));
|
|
20
|
+
};
|
|
21
|
+
export class AutocompleteComponentModule {
|
|
22
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AutocompleteComponentModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
23
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: AutocompleteComponentModule, declarations: [AutocompleteComponent, TransformItemPipe, IncludesPipe, SelectTextDirective], imports: [CommonModule,
|
|
24
|
+
MatFormFieldModule,
|
|
25
|
+
MatAutocompleteModule,
|
|
26
|
+
MatInputModule,
|
|
27
|
+
FormsModule,
|
|
28
|
+
TagComponentModule,
|
|
29
|
+
MatChipsModule,
|
|
30
|
+
IconComponentModule,
|
|
31
|
+
TranslocoModule], exports: [AutocompleteComponent] }); }
|
|
32
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AutocompleteComponentModule, providers: [
|
|
33
|
+
TransformItemPipe,
|
|
34
|
+
IncludesPipe,
|
|
35
|
+
SelectTextDirective,
|
|
36
|
+
{
|
|
37
|
+
provide: APP_INITIALIZER,
|
|
38
|
+
useFactory: preloadLang,
|
|
39
|
+
deps: [TranslocoService],
|
|
40
|
+
multi: true,
|
|
41
|
+
},
|
|
42
|
+
], imports: [CommonModule,
|
|
43
|
+
MatFormFieldModule,
|
|
44
|
+
MatAutocompleteModule,
|
|
45
|
+
MatInputModule,
|
|
46
|
+
FormsModule,
|
|
47
|
+
TagComponentModule,
|
|
48
|
+
MatChipsModule,
|
|
49
|
+
IconComponentModule,
|
|
50
|
+
TranslocoModule] }); }
|
|
51
|
+
}
|
|
52
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AutocompleteComponentModule, decorators: [{
|
|
53
|
+
type: NgModule,
|
|
54
|
+
args: [{
|
|
55
|
+
declarations: [AutocompleteComponent, TransformItemPipe, IncludesPipe, SelectTextDirective],
|
|
56
|
+
imports: [
|
|
57
|
+
CommonModule,
|
|
58
|
+
MatFormFieldModule,
|
|
59
|
+
MatAutocompleteModule,
|
|
60
|
+
MatInputModule,
|
|
61
|
+
FormsModule,
|
|
62
|
+
TagComponentModule,
|
|
63
|
+
MatChipsModule,
|
|
64
|
+
IconComponentModule,
|
|
65
|
+
TranslocoModule,
|
|
66
|
+
],
|
|
67
|
+
exports: [AutocompleteComponent],
|
|
68
|
+
providers: [
|
|
69
|
+
TransformItemPipe,
|
|
70
|
+
IncludesPipe,
|
|
71
|
+
SelectTextDirective,
|
|
72
|
+
{
|
|
73
|
+
provide: APP_INITIALIZER,
|
|
74
|
+
useFactory: preloadLang,
|
|
75
|
+
deps: [TranslocoService],
|
|
76
|
+
multi: true,
|
|
77
|
+
},
|
|
78
|
+
],
|
|
79
|
+
}]
|
|
80
|
+
}] });
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9hdXRvY29tcGxldGUvYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDakUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzFELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUM3RSxPQUFPLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDdEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFFckMsTUFBTSxXQUFXLEdBQUcsQ0FBQyxTQUEyQixFQUFFLEVBQUUsQ0FBQyxHQUFHLEVBQUU7SUFDeEQsU0FBUyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM5QixPQUFPLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDN0MsQ0FBQyxDQUFDO0FBNEJGLE1BQU0sT0FBTywyQkFBMkI7K0dBQTNCLDJCQUEyQjtnSEFBM0IsMkJBQTJCLGlCQXpCdkIscUJBQXFCLEVBQUUsaUJBQWlCLEVBQUUsWUFBWSxFQUFFLG1CQUFtQixhQUV4RixZQUFZO1lBQ1osa0JBQWtCO1lBQ2xCLHFCQUFxQjtZQUNyQixjQUFjO1lBQ2QsV0FBVztZQUNYLGtCQUFrQjtZQUNsQixjQUFjO1lBQ2QsbUJBQW1CO1lBQ25CLGVBQWUsYUFFUCxxQkFBcUI7Z0hBYXBCLDJCQUEyQixhQVozQjtZQUNULGlCQUFpQjtZQUNqQixZQUFZO1lBQ1osbUJBQW1CO1lBQ25CO2dCQUNFLE9BQU8sRUFBRSxlQUFlO2dCQUN4QixVQUFVLEVBQUUsV0FBVztnQkFDdkIsSUFBSSxFQUFFLENBQUMsZ0JBQWdCLENBQUM7Z0JBQ3hCLEtBQUssRUFBRSxJQUFJO2FBQ1o7U0FDRixZQXJCQyxZQUFZO1lBQ1osa0JBQWtCO1lBQ2xCLHFCQUFxQjtZQUNyQixjQUFjO1lBQ2QsV0FBVztZQUNYLGtCQUFrQjtZQUNsQixjQUFjO1lBQ2QsbUJBQW1CO1lBQ25CLGVBQWU7OzRGQWVOLDJCQUEyQjtrQkExQnZDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMscUJBQXFCLEVBQUUsaUJBQWlCLEVBQUUsWUFBWSxFQUFFLG1CQUFtQixDQUFDO29CQUMzRixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixrQkFBa0I7d0JBQ2xCLHFCQUFxQjt3QkFDckIsY0FBYzt3QkFDZCxXQUFXO3dCQUNYLGtCQUFrQjt3QkFDbEIsY0FBYzt3QkFDZCxtQkFBbUI7d0JBQ25CLGVBQWU7cUJBQ2hCO29CQUNELE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO29CQUNoQyxTQUFTLEVBQUU7d0JBQ1QsaUJBQWlCO3dCQUNqQixZQUFZO3dCQUNaLG1CQUFtQjt3QkFDbkI7NEJBQ0UsT0FBTyxFQUFFLGVBQWU7NEJBQ3hCLFVBQVUsRUFBRSxXQUFXOzRCQUN2QixJQUFJLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQzs0QkFDeEIsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0Y7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUFBfSU5JVElBTElaRVIsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQXV0b2NvbXBsZXRlQ29tcG9uZW50IH0gZnJvbSAnLi9hdXRvY29tcGxldGUuY29tcG9uZW50JztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuaW1wb3J0IHsgTWF0QXV0b2NvbXBsZXRlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYXV0b2NvbXBsZXRlJztcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBUYWdDb21wb25lbnRNb2R1bGUgfSBmcm9tICcuLi90YWcvdGFnLmNvbXBvbmVudC5tb2R1bGUnO1xuaW1wb3J0IHsgTWF0Q2hpcHNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jaGlwcyc7XG5pbXBvcnQgeyBJY29uQ29tcG9uZW50TW9kdWxlIH0gZnJvbSAnLi4vaWNvbi9pY29uLmNvbXBvbmVudC5tb2R1bGUnO1xuaW1wb3J0IHsgVHJhbnNmb3JtSXRlbVBpcGUgfSBmcm9tICcuL3RyYW5zZm9ybS1JdGVtLnBpcGUnO1xuaW1wb3J0IHsgSW5jbHVkZXNQaXBlIH0gZnJvbSAnLi9pbmNsdWRlcy5waXBlJztcbmltcG9ydCB7IFNlbGVjdFRleHREaXJlY3RpdmUgfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzL3NlbGVjdC10ZXh0LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBUcmFuc2xvY29Nb2R1bGUsIFRyYW5zbG9jb1NlcnZpY2UgfSBmcm9tICdAbmduZWF0L3RyYW5zbG9jbyc7XG5pbXBvcnQgeyBsYXN0VmFsdWVGcm9tIH0gZnJvbSAncnhqcyc7XG5cbmNvbnN0IHByZWxvYWRMYW5nID0gKHRyYW5zbG9jbzogVHJhbnNsb2NvU2VydmljZSkgPT4gKCkgPT4ge1xuICB0cmFuc2xvY28uc2V0QWN0aXZlTGFuZygnZW4nKTtcbiAgcmV0dXJuIGxhc3RWYWx1ZUZyb20odHJhbnNsb2NvLmxvYWQoJ2VuJykpO1xufTtcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbQXV0b2NvbXBsZXRlQ29tcG9uZW50LCBUcmFuc2Zvcm1JdGVtUGlwZSwgSW5jbHVkZXNQaXBlLCBTZWxlY3RUZXh0RGlyZWN0aXZlXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBNYXRGb3JtRmllbGRNb2R1bGUsXG4gICAgTWF0QXV0b2NvbXBsZXRlTW9kdWxlLFxuICAgIE1hdElucHV0TW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIFRhZ0NvbXBvbmVudE1vZHVsZSxcbiAgICBNYXRDaGlwc01vZHVsZSxcbiAgICBJY29uQ29tcG9uZW50TW9kdWxlLFxuICAgIFRyYW5zbG9jb01vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW0F1dG9jb21wbGV0ZUNvbXBvbmVudF0sXG4gIHByb3ZpZGVyczogW1xuICAgIFRyYW5zZm9ybUl0ZW1QaXBlLFxuICAgIEluY2x1ZGVzUGlwZSxcbiAgICBTZWxlY3RUZXh0RGlyZWN0aXZlLFxuICAgIHtcbiAgICAgIHByb3ZpZGU6IEFQUF9JTklUSUFMSVpFUixcbiAgICAgIHVzZUZhY3Rvcnk6IHByZWxvYWRMYW5nLFxuICAgICAgZGVwczogW1RyYW5zbG9jb1NlcnZpY2VdLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgQXV0b2NvbXBsZXRlQ29tcG9uZW50TW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export var Autocomplete;
|
|
2
|
+
(function (Autocomplete) {
|
|
3
|
+
Autocomplete["SINGLE"] = "single";
|
|
4
|
+
Autocomplete["MULTI"] = "multi";
|
|
5
|
+
Autocomplete["LARGE"] = "large";
|
|
6
|
+
})(Autocomplete || (Autocomplete = {}));
|
|
7
|
+
export var Padding;
|
|
8
|
+
(function (Padding) {
|
|
9
|
+
Padding[Padding["AUTOCOMPLETE_CONTAINER"] = 80] = "AUTOCOMPLETE_CONTAINER";
|
|
10
|
+
})(Padding || (Padding = {}));
|
|
11
|
+
export var Timeout;
|
|
12
|
+
(function (Timeout) {
|
|
13
|
+
Timeout[Timeout["VIEW_INITIALIZED_AFTER_ACTION"] = 20] = "VIEW_INITIALIZED_AFTER_ACTION";
|
|
14
|
+
Timeout[Timeout["VIEW_INITIALIZED_COMPONENT_LOAD"] = 600] = "VIEW_INITIALIZED_COMPONENT_LOAD";
|
|
15
|
+
})(Timeout || (Timeout = {}));
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYXV0b2NvbXBsZXRlL2F1dG9jb21wbGV0ZS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQU4sSUFBWSxZQUlYO0FBSkQsV0FBWSxZQUFZO0lBQ3RCLGlDQUFpQixDQUFBO0lBQ2pCLCtCQUFlLENBQUE7SUFDZiwrQkFBZSxDQUFBO0FBQ2pCLENBQUMsRUFKVyxZQUFZLEtBQVosWUFBWSxRQUl2QjtBQUVELE1BQU0sQ0FBTixJQUFZLE9BRVg7QUFGRCxXQUFZLE9BQU87SUFDakIsMEVBQTJCLENBQUE7QUFDN0IsQ0FBQyxFQUZXLE9BQU8sS0FBUCxPQUFPLFFBRWxCO0FBRUQsTUFBTSxDQUFOLElBQVksT0FHWDtBQUhELFdBQVksT0FBTztJQUNqQix3RkFBa0MsQ0FBQTtJQUNsQyw2RkFBcUMsQ0FBQTtBQUN2QyxDQUFDLEVBSFcsT0FBTyxLQUFQLE9BQU8sUUFHbEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBBdXRvY29tcGxldGVUeXBlID0gJ3NpbmdsZScgfCAnbXVsdGknIHwgJ2xhcmdlJztcblxuZXhwb3J0IGVudW0gQXV0b2NvbXBsZXRlIHtcbiAgU0lOR0xFID0gJ3NpbmdsZScsXG4gIE1VTFRJID0gJ211bHRpJyxcbiAgTEFSR0UgPSAnbGFyZ2UnLFxufVxuXG5leHBvcnQgZW51bSBQYWRkaW5nIHtcbiAgQVVUT0NPTVBMRVRFX0NPTlRBSU5FUiA9IDgwLFxufVxuXG5leHBvcnQgZW51bSBUaW1lb3V0IHtcbiAgVklFV19JTklUSUFMSVpFRF9BRlRFUl9BQ1RJT04gPSAyMCxcbiAgVklFV19JTklUSUFMSVpFRF9DT01QT05FTlRfTE9BRCA9IDYwMCxcbn1cbiJdfQ==
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* The purpose of this pipe is to determine if the value is present in the values array.
|
|
5
|
+
* If values is an array, the method uses the includes method to check for inclusion.
|
|
6
|
+
* If values is not an array, it checks for strict equality between value and values.
|
|
7
|
+
*/
|
|
8
|
+
export class IncludesPipe {
|
|
9
|
+
transform(value, values) {
|
|
10
|
+
return Array.isArray(values) ? values.includes(value) : value === values;
|
|
11
|
+
}
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IncludesPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
13
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: IncludesPipe, name: "includes" }); }
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IncludesPipe, decorators: [{
|
|
16
|
+
type: Pipe,
|
|
17
|
+
args: [{
|
|
18
|
+
name: 'includes',
|
|
19
|
+
}]
|
|
20
|
+
}] });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5jbHVkZXMucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2F1dG9jb21wbGV0ZS9pbmNsdWRlcy5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQUVwRDs7OztHQUlHO0FBSUgsTUFBTSxPQUFPLFlBQVk7SUFDdkIsU0FBUyxDQUFDLEtBQVUsRUFBRSxNQUFXO1FBQy9CLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxLQUFLLE1BQU0sQ0FBQztJQUMzRSxDQUFDOytHQUhVLFlBQVk7NkdBQVosWUFBWTs7NEZBQVosWUFBWTtrQkFIeEIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsVUFBVTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogVGhlIHB1cnBvc2Ugb2YgdGhpcyBwaXBlIGlzIHRvIGRldGVybWluZSBpZiB0aGUgdmFsdWUgaXMgcHJlc2VudCBpbiB0aGUgdmFsdWVzIGFycmF5LlxuICogSWYgdmFsdWVzIGlzIGFuIGFycmF5LCB0aGUgbWV0aG9kIHVzZXMgdGhlIGluY2x1ZGVzIG1ldGhvZCB0byBjaGVjayBmb3IgaW5jbHVzaW9uLlxuICogSWYgdmFsdWVzIGlzIG5vdCBhbiBhcnJheSwgaXQgY2hlY2tzIGZvciBzdHJpY3QgZXF1YWxpdHkgYmV0d2VlbiB2YWx1ZSBhbmQgdmFsdWVzLlxuICovXG5AUGlwZSh7XG4gIG5hbWU6ICdpbmNsdWRlcycsXG59KVxuZXhwb3J0IGNsYXNzIEluY2x1ZGVzUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0odmFsdWU6IGFueSwgdmFsdWVzOiBhbnkpOiBib29sZWFuIHtcbiAgICByZXR1cm4gQXJyYXkuaXNBcnJheSh2YWx1ZXMpID8gdmFsdWVzLmluY2x1ZGVzKHZhbHVlKSA6IHZhbHVlID09PSB2YWx1ZXM7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { AutocompleteUtils } from '../../utils/autocomplete-utils';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* the TransformItemPipe is designed to selectively extract and return values from objects based on a specified field,
|
|
6
|
+
* providing a way to transform and display data a template.
|
|
7
|
+
*/
|
|
8
|
+
export class TransformItemPipe {
|
|
9
|
+
transform(value, field) {
|
|
10
|
+
if (AutocompleteUtils.isPrimitive(value)) {
|
|
11
|
+
return value;
|
|
12
|
+
}
|
|
13
|
+
else if (!AutocompleteUtils.isPrimitive(value) && field && (value[field] || value[0][field])) {
|
|
14
|
+
return value[field] || value[0][field];
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
AutocompleteUtils.throwInvalidSetupError();
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TransformItemPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
21
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: TransformItemPipe, name: "transformItem" }); }
|
|
22
|
+
}
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TransformItemPipe, decorators: [{
|
|
24
|
+
type: Pipe,
|
|
25
|
+
args: [{
|
|
26
|
+
name: 'transformItem',
|
|
27
|
+
}]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNmb3JtLUl0ZW0ucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2F1dG9jb21wbGV0ZS90cmFuc2Zvcm0tSXRlbS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDOztBQUVuRTs7O0dBR0c7QUFJSCxNQUFNLE9BQU8saUJBQWlCO0lBQzVCLFNBQVMsQ0FBQyxLQUFVLEVBQUUsS0FBYTtRQUNqQyxJQUFJLGlCQUFpQixDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUN4QyxPQUFPLEtBQUssQ0FBQztTQUNkO2FBQU0sSUFBSSxDQUFDLGlCQUFpQixDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUU7WUFDOUYsT0FBTyxLQUFLLENBQUMsS0FBSyxDQUFDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3hDO2FBQU07WUFDTCxpQkFBaUIsQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO1NBQzVDO0lBQ0gsQ0FBQzsrR0FUVSxpQkFBaUI7NkdBQWpCLGlCQUFpQjs7NEZBQWpCLGlCQUFpQjtrQkFIN0IsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsZUFBZTtpQkFDdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBdXRvY29tcGxldGVVdGlscyB9IGZyb20gJy4uLy4uL3V0aWxzL2F1dG9jb21wbGV0ZS11dGlscyc7XG5cbi8qKlxuICogdGhlIFRyYW5zZm9ybUl0ZW1QaXBlIGlzIGRlc2lnbmVkIHRvIHNlbGVjdGl2ZWx5IGV4dHJhY3QgYW5kIHJldHVybiB2YWx1ZXMgZnJvbSBvYmplY3RzIGJhc2VkIG9uIGEgc3BlY2lmaWVkIGZpZWxkLFxuICogcHJvdmlkaW5nIGEgd2F5IHRvIHRyYW5zZm9ybSBhbmQgZGlzcGxheSBkYXRhIGEgdGVtcGxhdGUuXG4gKi9cbkBQaXBlKHtcbiAgbmFtZTogJ3RyYW5zZm9ybUl0ZW0nLFxufSlcbmV4cG9ydCBjbGFzcyBUcmFuc2Zvcm1JdGVtUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0odmFsdWU6IGFueSwgZmllbGQ6IHN0cmluZyk6IGFueSB7XG4gICAgaWYgKEF1dG9jb21wbGV0ZVV0aWxzLmlzUHJpbWl0aXZlKHZhbHVlKSkge1xuICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0gZWxzZSBpZiAoIUF1dG9jb21wbGV0ZVV0aWxzLmlzUHJpbWl0aXZlKHZhbHVlKSAmJiBmaWVsZCAmJiAodmFsdWVbZmllbGRdIHx8IHZhbHVlWzBdW2ZpZWxkXSkpIHtcbiAgICAgIHJldHVybiB2YWx1ZVtmaWVsZF0gfHwgdmFsdWVbMF1bZmllbGRdO1xuICAgIH0gZWxzZSB7XG4gICAgICBBdXRvY29tcGxldGVVdGlscy50aHJvd0ludmFsaWRTZXR1cEVycm9yKCk7XG4gICAgfVxuICB9XG59XG4iXX0=
|