i-tech-shared-components 1.1.26 → 1.1.28

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 (33) hide show
  1. package/esm2022/i-tech-shared-components.mjs +5 -0
  2. package/esm2022/lib/components/autocomplete-select/autocomplete-select.component.mjs +420 -0
  3. package/esm2022/lib/components/button/button.component.mjs +122 -0
  4. package/esm2022/lib/components/clear-value/clear-value.component.mjs +34 -0
  5. package/esm2022/lib/components/date-picker/date-picker.component.mjs +117 -0
  6. package/esm2022/lib/components/date-range-datepicker/date-range-datepicker.component.mjs +118 -0
  7. package/esm2022/lib/components/icon-button/icon-button.component.mjs +49 -0
  8. package/esm2022/lib/components/menu/menu.component.mjs +51 -0
  9. package/esm2022/lib/components/text/text-input.component.mjs +81 -0
  10. package/esm2022/lib/directives/date-mask.directive.mjs +92 -0
  11. package/esm2022/lib/directives/input-mask.directive.mjs +95 -0
  12. package/esm2022/lib/interfaces/app-input.interface.mjs +2 -0
  13. package/esm2022/lib/interfaces/autocomplete-configs.interface.mjs +2 -0
  14. package/esm2022/lib/interfaces/button-types.enum.mjs +17 -0
  15. package/esm2022/lib/interfaces/dropdown-selection.constants.mjs +12 -0
  16. package/esm2022/lib/pipes/array-to-string.pipe.mjs +17 -0
  17. package/esm2022/lib/pipes/generate-error-messages.pipe.mjs +29 -0
  18. package/esm2022/lib/pipes/get-value-by-key-from-object.pipe.mjs +45 -0
  19. package/esm2022/lib/services/input.service.mjs +35 -0
  20. package/esm2022/public-api.mjs +20 -0
  21. package/fesm2022/i-tech-shared-components.mjs +59 -51
  22. package/fesm2022/i-tech-shared-components.mjs.map +1 -1
  23. package/lib/components/text/text-input.component.d.ts +4 -0
  24. package/lib/interfaces/autocomplete-configs.interface.d.ts +1 -0
  25. package/package.json +14 -13
  26. package/theme/_label.scss +0 -14
  27. package/theme.scss +2 -4
  28. package/theme/_flex.scss +0 -92
  29. package/theme/_margin_padding_height_width.scss +0 -143
  30. package/theme/_material_ovveride.scss +0 -82
  31. package/theme/_modal_and_cards.scss +0 -56
  32. package/theme/_texts.scss +0 -87
  33. package/theme/variables/_desctop_sizes.scss +0 -8
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaS10ZWNoLXNoYXJlZC1jb21wb25lbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvc2hhcmVkLWNvbXBvbmVudHMvc3JjL2ktdGVjaC1zaGFyZWQtY29tcG9uZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
@@ -0,0 +1,420 @@
1
+ import { Component, ViewChild, Input, Output, EventEmitter, HostListener } from '@angular/core';
2
+ import { MatSelectModule } from "@angular/material/select";
3
+ import { ReactiveFormsModule } from "@angular/forms";
4
+ import { ButtonType } from '../../interfaces/button-types.enum';
5
+ import { NgClass, NgFor, NgIf, NgOptimizedImage } from "@angular/common";
6
+ import { MatTooltip } from "@angular/material/tooltip";
7
+ import { TranslateModule } from "@ngx-translate/core";
8
+ import { IconButtonComponent } from "../icon-button/icon-button.component";
9
+ import { ButtonComponent } from "../button/button.component";
10
+ import { GetValueByKeyFromObjectPipe } from "../../pipes/get-value-by-key-from-object.pipe";
11
+ import { ArrayToStringPipe } from "../../pipes/array-to-string.pipe";
12
+ import { MatIcon } from "@angular/material/icon";
13
+ import { GenerateErrorMessagesPipe } from "../../pipes/generate-error-messages.pipe";
14
+ import { ClearValueComponent } from "../clear-value/clear-value.component";
15
+ import { MatFormFieldModule } from "@angular/material/form-field";
16
+ import * as i0 from "@angular/core";
17
+ import * as i1 from "../../services/input.service";
18
+ import * as i2 from "@ngx-translate/core";
19
+ import * as i3 from "@angular/forms";
20
+ import * as i4 from "@angular/material/form-field";
21
+ import * as i5 from "@angular/material/select";
22
+ import * as i6 from "@angular/material/core";
23
+ export class AutocompleteSelectComponent {
24
+ /**
25
+ * See AutocompleteConfigsInterface for available configurations.
26
+ */
27
+ set configs(data) {
28
+ this.selectConfig = data;
29
+ if (!data) {
30
+ return;
31
+ }
32
+ if ((typeof this.selectConfig.paginate) === 'function') {
33
+ if (this.firstRequest) {
34
+ return;
35
+ }
36
+ this.getData();
37
+ this.firstRequest = true;
38
+ return;
39
+ }
40
+ this.data = this.selectConfig.paginate;
41
+ this.findAndSetDefaultValueFromData();
42
+ }
43
+ ;
44
+ handleVisibilityChange() {
45
+ this.tabVisibility = !document.hidden;
46
+ if (this.ngControl.control.value) {
47
+ return;
48
+ }
49
+ this.closePanelAndUnsetFocus();
50
+ if (!document.hidden) {
51
+ this.isNeededForRecall = true;
52
+ this.pending = true;
53
+ setTimeout(() => {
54
+ this.pending = false;
55
+ }, 4000);
56
+ }
57
+ }
58
+ constructor(inputService) {
59
+ this.inputService = inputService;
60
+ this.selectionChange = new EventEmitter();
61
+ this.emitAction = new EventEmitter();
62
+ this.pending = false;
63
+ this.data = [];
64
+ this.paginationData = { current: 1, last: 0 };
65
+ this.firstRequest = false;
66
+ this.showPlaceholder = true;
67
+ this.isNeededForRecall = false;
68
+ this.accessToNextRequest = true;
69
+ this.disabled = false;
70
+ this.blockRecallDefaultValueSetter = false;
71
+ this.requestLoading = false;
72
+ this.ButtonType = ButtonType;
73
+ /*
74
+ * Custom error state matcher for mat-select to properly show error state in mat-form-field
75
+ */
76
+ this.customErrorStateMatcher = {
77
+ isErrorState: (control, form) => {
78
+ return !!(control && control.invalid && this.submitValue);
79
+ }
80
+ };
81
+ this.ngControl = this.inputService.injectNgControl();
82
+ }
83
+ ngOnChanges(changes) {
84
+ if (changes['selectConfig'] && this.selectConfig) {
85
+ if ((typeof this.selectConfig.paginate) === 'function') {
86
+ this.getData();
87
+ }
88
+ }
89
+ }
90
+ ngAfterViewInit() {
91
+ this.ngControl.control.valueChanges.subscribe((res) => {
92
+ if (this.data.length && res && !this.blockRecallDefaultValueSetter) {
93
+ this.findAndSetDefaultValueFromData();
94
+ }
95
+ });
96
+ }
97
+ hardReload() {
98
+ this.getData('', true);
99
+ }
100
+ /**
101
+ * Dynamic request for select data.
102
+ * @param searchText - The input value to search options by.
103
+ * @param fromSearch - Access for search.
104
+ * @returns Select data.
105
+ */
106
+ getData(searchText, fromSearch) {
107
+ if (!fromSearch && !this.accessToNextRequest) {
108
+ return;
109
+ }
110
+ if (this.requestLoading) {
111
+ return;
112
+ }
113
+ if (fromSearch) {
114
+ this.paginationData.current = 1;
115
+ this.accessToNextRequest = true;
116
+ }
117
+ const functionToDo = this.selectConfig.paginate(this.paginationData.current, searchText);
118
+ this.requestLoading = true;
119
+ functionToDo?.subscribe((data) => {
120
+ const dataToAdd = ('content' in data) ? data.content : data;
121
+ if ('content' in data) {
122
+ this.accessToNextRequest = !data.last || (data.totalPages > this.paginationData.current);
123
+ }
124
+ this.data = (fromSearch || this.selectConfig?.blockPagination) ? dataToAdd : [...this.data, ...dataToAdd];
125
+ this.pending = false;
126
+ this.requestLoading = false;
127
+ if (!dataToAdd.length) {
128
+ this.paginationData.last = this.paginationData.current;
129
+ return;
130
+ }
131
+ this.paginationData.current += 1;
132
+ this.paginationData.last += 1;
133
+ setTimeout(() => {
134
+ this.findAndSetDefaultValueFromData();
135
+ }, 10);
136
+ }, () => {
137
+ this.pending = false;
138
+ this.requestLoading = false;
139
+ });
140
+ }
141
+ findAndSetDefaultValueFromData() {
142
+ if (this.selectConfig.multiple) {
143
+ if (this.ngControl.value && this.ngControl.value.length == 1) {
144
+ this.setShowingValue(this.data.find((item) => item.id === this.ngControl.value[0]));
145
+ }
146
+ }
147
+ else {
148
+ const isDisabled = this.ngControl.disabled;
149
+ if (isDisabled) {
150
+ // TODO Remove after migrating all selects
151
+ // this.ngControl.control.enable();
152
+ // if (!this.ngControl.value && !this.data.length) {
153
+ // this.ngControl.control.disable();
154
+ // return;
155
+ // }
156
+ // this.setDefaultValue();
157
+ // this.ngControl.control.disable();
158
+ }
159
+ else {
160
+ if (!this.ngControl.value && !this.data) {
161
+ return;
162
+ }
163
+ this.setDefaultValue();
164
+ }
165
+ }
166
+ }
167
+ setDefaultValue() {
168
+ this.defaultValue = this.data.find((item) => item.id === this.ngControl.value);
169
+ this.baseData = this.defaultValue;
170
+ if (!this.defaultValue) {
171
+ return;
172
+ }
173
+ this.selectionChange.emit();
174
+ this.setShowingValue(this.defaultValue);
175
+ }
176
+ optionClick(showingData) {
177
+ this.baseData = showingData;
178
+ if (!this.selectConfig.multiple) {
179
+ this.setShowingValue(showingData);
180
+ this.matSelect.close();
181
+ return;
182
+ }
183
+ if (this.searchInput) {
184
+ if (this.selectConfig.multiple) {
185
+ this.searchInput?.nativeElement?.focus();
186
+ }
187
+ else {
188
+ this.inputFocusOut();
189
+ }
190
+ }
191
+ this.setShowingValue(showingData);
192
+ this.showPlaceholder = false;
193
+ }
194
+ addNewItemEvent() {
195
+ this.isNeededForRecall = true;
196
+ this.emitAction.emit();
197
+ }
198
+ /**
199
+ * Filter and show.
200
+ * @param data - Existing chosen data.
201
+ */
202
+ setShowingValue(data) {
203
+ if (!data) {
204
+ return;
205
+ }
206
+ // TODO refactor this part fully
207
+ let include = data;
208
+ let includeOptional = data;
209
+ if (this.selectConfig.valueToShowByKey) {
210
+ this.selectConfig.valueToShowByKey.forEach((param) => {
211
+ if (typeof param === 'object') {
212
+ param.forEach((key) => {
213
+ include = (include) ? include[key] : null;
214
+ });
215
+ }
216
+ else {
217
+ include = include[param];
218
+ }
219
+ });
220
+ if (this.selectConfig.showFullTextWithOptionalOnSelectedValue) {
221
+ this.selectConfig.valueToShowByParam?.forEach((param) => {
222
+ if (typeof param === 'object') {
223
+ param.forEach((key) => {
224
+ includeOptional = (includeOptional) ? includeOptional[key] : null;
225
+ });
226
+ }
227
+ else {
228
+ includeOptional = includeOptional[param];
229
+ }
230
+ });
231
+ if (this.selectConfig.valueToShowByParam && typeof includeOptional === 'string') {
232
+ include += (this.selectConfig.withParamSymbol || '') + includeOptional;
233
+ }
234
+ }
235
+ }
236
+ this.showingValue = include;
237
+ this.blockRecallDefaultValueSetter = true;
238
+ }
239
+ /**
240
+ * Block another events.
241
+ * @param event - Element click event.
242
+ */
243
+ preventDefault(event) {
244
+ if (!this.selectConfig.multiple) {
245
+ return;
246
+ }
247
+ event.preventDefault();
248
+ }
249
+ registerPanelScrollEvent(element) {
250
+ if (this.selectConfig.paginateOnScroll === false) {
251
+ return;
252
+ }
253
+ const panel = element.panel.nativeElement;
254
+ panel.addEventListener('scroll', (event) => this.loadDataOnScroll(event));
255
+ }
256
+ loadDataOnScroll(event) {
257
+ const pos = (event.target.scrollTop || event.target.scrollTop) + event.target.offsetHeight;
258
+ const max = event.target.scrollHeight;
259
+ if ((pos + 1) >= max) {
260
+ if (this.paginationData.current === this.paginationData.last || this.selectConfig.blockPagination) {
261
+ return;
262
+ }
263
+ this.getData();
264
+ }
265
+ }
266
+ focusSearchInput() {
267
+ if (this.selectConfig.search && this.searchInput) {
268
+ this.searchInput.nativeElement.focus();
269
+ }
270
+ }
271
+ inputFocusOut() {
272
+ this.isNeededForRecall = !!this.searchInput.nativeElement.value;
273
+ this.searchInput.nativeElement.value = '';
274
+ this.showPlaceholder = true;
275
+ this.clearTimeoutForSearch();
276
+ }
277
+ resetValue() {
278
+ this.selectionChange.emit(null);
279
+ this.ngControl.reset(null);
280
+ this.inputFocusOut();
281
+ }
282
+ getDataWithSearch(value, event) {
283
+ this.clearTimeoutForSearch();
284
+ if (value.length >= 1) {
285
+ this.searchTimeoutId = setTimeout(() => {
286
+ this.getData(value, true);
287
+ }, 800);
288
+ }
289
+ else if (value.length <= 1 && event.keyCode === 8) {
290
+ this.getData(value, true);
291
+ }
292
+ }
293
+ clearTimeoutForSearch() {
294
+ if (this.searchTimeoutId) {
295
+ clearTimeout(this.searchTimeoutId);
296
+ this.searchTimeoutId = 0;
297
+ }
298
+ }
299
+ openSelection() {
300
+ if (this.selectConfig.disabled || this.ngControl.control.disabled) {
301
+ return;
302
+ }
303
+ if (this.showPlaceholder) {
304
+ this.matSelect.open();
305
+ }
306
+ else {
307
+ this.closePanelAndUnsetFocus();
308
+ }
309
+ this.showPlaceholder = !this.showPlaceholder;
310
+ if (!this.showPlaceholder) {
311
+ this.reCallData();
312
+ }
313
+ }
314
+ closePanelAndUnsetFocus() {
315
+ this.matSelect.close();
316
+ if (this.searchInput) {
317
+ this.searchInput.nativeElement.blur();
318
+ }
319
+ }
320
+ openedChange(event) {
321
+ if (event) {
322
+ if (this.isNeededForRecall) {
323
+ this.reCallData();
324
+ return;
325
+ }
326
+ if (!this.selectConfig.search) {
327
+ this.pending = false;
328
+ this.reCallData();
329
+ }
330
+ return;
331
+ }
332
+ this.showPlaceholder = true;
333
+ }
334
+ reCallData() {
335
+ // TODO refactor this part
336
+ if (!this.isNeededForRecall) {
337
+ return;
338
+ }
339
+ this.data = [];
340
+ this.pending = true;
341
+ this.paginationData = {
342
+ current: 1,
343
+ last: 0
344
+ };
345
+ this.accessToNextRequest = true;
346
+ if ((typeof this.selectConfig.paginate) === 'function') {
347
+ this.getData();
348
+ }
349
+ else {
350
+ this.pending = false;
351
+ this.data = this.selectConfig.paginate;
352
+ }
353
+ this.isNeededForRecall = false;
354
+ }
355
+ emitSelectionChangeAndClose(event) {
356
+ this.selectionChange.emit(event.value);
357
+ if (this.selectConfig.multiple) {
358
+ if (!event.value?.length) {
359
+ this.ngControl.control.reset();
360
+ }
361
+ return;
362
+ }
363
+ this.matSelect.close();
364
+ }
365
+ /*
366
+ * Open mat-select and focus on search on icon click
367
+ */
368
+ iconClick(matSelect, searchInput) {
369
+ matSelect.open();
370
+ searchInput?.nativeElement?.focus();
371
+ }
372
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AutocompleteSelectComponent, deps: [{ token: i1.InputService }], target: i0.ɵɵFactoryTarget.Component }); }
373
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AutocompleteSelectComponent, isStandalone: true, selector: "i-tech-autocomplete-select", inputs: { className: "className", submitValue: "submitValue", configs: "configs", detectChanges: "detectChanges" }, outputs: { selectionChange: "selectionChange", emitAction: "emitAction" }, host: { listeners: { "document:visibilitychange": "handleVisibilityChange()" } }, viewQueries: [{ propertyName: "matSelect", first: true, predicate: ["matSelect"], descendants: true }, { propertyName: "searchInput", first: true, predicate: ["searchInput"], descendants: true }, { propertyName: "allSelected", first: true, predicate: ["allSelected"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"new-mat-autocomplete\" id=\"mat_autocomplete\"\n [ngClass]=\"{\n 'mat-select-without_icon': !selectConfig.iconUrl && !selectConfig.activeStateIconUrl,\n 'mat-select-with-search': selectConfig.search,\n 'without-label': selectConfig.hideLabel,\n 'invalid_field': ngControl.control.errors && submitValue,\n 'readonly-field': selectConfig.readOnly || ngControl.control.disabled\n }\"\n [matTooltip]=\"(selectConfig.hover && !ngControl.control.disabled ? ((selectConfig.hover || '') | translate) : '')\"\n [matTooltipClass]=\"'mat-mdc-tooltip big-td-mat-tooltip'\"\n [matTooltipPosition]=\"'above'\"\n *ngIf=\"selectConfig && ngControl\">\n\n <div class=\"w-100\" *ngIf=\"!selectConfig.hideLabel\">\n <mat-label [ngClass]=\"{\n 'readonly-color' : selectConfig.readOnly || ngControl.control.disabled,\n 'invalid-label-color': !!(ngControl.control.errors && submitValue)\n }\">\n {{ selectConfig.label | translate }}\n </mat-label>\n <span *ngIf=\"selectConfig.required\" class=\"required-input\"\n [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\">*</span>\n </div>\n\n\n <!-- Search Input -->\n <div class=\"search-input w-100\"\n (click)=\"$event.stopPropagation();$event.preventDefault()\"\n [ngClass]=\"{ hide_input_placeholder: showPlaceholder || ngControl.control.disabled }\"\n *ngIf=\"selectConfig.search\"\n >\n <input autocomplete=\"off\"\n id=\"searchInput\"\n type=\"text\"\n [ngClass]=\"{'pr-25': !selectConfig.iconUrl}\"\n #searchInput\n [disabled]=\"ngControl.control.disabled || selectConfig.hover\"\n [placeholder]=\"(ngControl.control.disabled || selectConfig.hover) ? '' : 'Search'\"\n (focusout)=\"inputFocusOut()\"\n (focus)=\"openSelection()\"\n (keydown)=\"$event.stopPropagation()\"\n (keyup)=\"getDataWithSearch(searchInput.value,$event)\">\n\n <!-- Search Icon -->\n <span class=\"search-icon\">\n <i-tech-icon-button\n class=\"mr-10\"\n [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color'\n : 'default-form-icon-color'\"\n *ngIf=\"selectConfig.iconPrefix && !showPlaceholder\"\n [iconName]=\"selectConfig.iconPrefix || ''\"\n [disabled]=\"selectConfig.readOnly || false\"\n matPrefix\n >\n </i-tech-icon-button>\n </span>\n </div>\n\n <!-- Placeholder/Selected Value Display -->\n <ng-container *ngIf=\"showPlaceholder && selectConfig.search\">\n <div class=\"custom-placeholder\"\n *ngIf=\"(!ngControl?.value && !ngControl?.value?.length) ||\n (selectConfig.multiple && ngControl?.value && !ngControl?.value?.length)\"\n [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\n >\n {{ ((selectConfig.placeholder || '') | translate) }}\n </div>\n <div class=\"custom-placeholder custom-value ellipsis\"\n [ngClass]=\"{\n 'pr-42': selectConfig.iconUrl,\n 'readonly-color': selectConfig.readOnly || ngControl.control.disabled,\n 'default-form-icon-color': !(selectConfig.readOnly || ngControl.control.disabled)\n }\"\n *ngIf=\"ngControl?.value\"\n >\n {{ selectConfig?.multiple ? (ngControl.value | arrayToString) : showingValue }}\n </div>\n </ng-container>\n\n <!-- Custom Icon -->\n <img class=\"left_icon_new pointer\"\n alt=\"Toggle Selection\"\n (click)=\"iconClick(matSelect, searchInput)\"\n *ngIf=\"!selectConfig.matIconName && (selectConfig.iconUrl || selectConfig.activeStateIconUrl)\"\n [src]=\"'assets/images/icons/global/' + (ngControl.control?.value && selectConfig?.activeStateIconUrl ?\n selectConfig.activeStateIconUrl\n : selectConfig.iconUrl)\">\n\n <mat-form-field appearance=\"outline\" class=\"w-100\" (click)=\"selectConfig?.search ? focusSearchInput() : null\">\n <!-- Material Select -->\n <mat-select #matSelect=\"matSelect\"\n [panelClass]=\"'autocomplete-transform-panel-location'\"\n [attr.aria-placeholder]=\"(selectConfig.placeholder || '') | translate\"\n [aria-label]=\"selectConfig.label | translate\"\n [id]=\"selectConfig.filtrationKey || ''\"\n (opened)=\"registerPanelScrollEvent(matSelect)\"\n (openedChange)=\"openedChange($event)\"\n [formControl]=\"ngControl.control\"\n [multiple]=\"selectConfig.multiple\"\n (selectionChange)=\"emitSelectionChangeAndClose($event)\"\n [errorStateMatcher]=\"customErrorStateMatcher\"\n [placeholder]=\"(selectConfig.placeholder || '') | translate\"\n [disabled]=\"ngControl.control.disabled\"\n >\n\n <!-- Loading State -->\n <mat-option *ngIf=\"pending\" class=\"option_loading relative\">\n <div class=\"request_loading\">\n <img ngSrc=\"./loader.svg\" alt=\"\" height=\"200\" width=\"200\"/>\n </div>\n </mat-option>\n\n <!-- Options -->\n <ng-container *ngIf=\"data?.length && !pending\">\n <!-- Add New Option -->\n <mat-option *ngIf=\"selectConfig.actions\"\n class=\"pointer add_new\"\n disabled\n (click)=\"closePanelAndUnsetFocus();addNewItemEvent()\">\n <!--(click)=\"ngControl.control.reset(null);\n matSelect._onBlur();closePanelAndUnsetFocus();addNewItemEvent()\">-->\n <i-tech-button\n [type]=\"ButtonType.OUTLINE\"\n [fontIcon]=\"'add'\"\n [text]=\"('dropdown_add_item' | translate : {INPUT_NAME: (selectConfig.label | translate)}) \"\n [customClass]=\"'w-100 mat-autocomplete-select-button'\">\n </i-tech-button>\n </mat-option>\n\n <!-- Regular Options -->\n <ng-container *ngIf=\"!selectConfig?.changeText && data.length\">\n <mat-option *ngFor=\"let item of data\"\n [value]=\"selectConfig.valueByKey | getValueByKeyFromObject : item\"\n (mouseup)=\"optionClick(item)\"\n (mousedown)=\"preventDefault($event)\">\n @if (selectConfig?.needTranslateOptions) {\n {{\n ((selectConfig.valueToShowByKey | getValueByKeyFromObject\n : item : selectConfig.valueToShowByParam : selectConfig.withParamSymbol) || '') | translate\n }}\n }@else {\n {{\n ((selectConfig.valueToShowByKey | getValueByKeyFromObject\n : item : selectConfig.valueToShowByParam : selectConfig.withParamSymbol) || '')\n }}\n }\n\n </mat-option>\n </ng-container>\n\n <!-- Custom Text Options -->\n <ng-container *ngIf=\"selectConfig?.changeText && data.length\">\n <mat-option *ngFor=\"let item of data\"\n [value]=\"selectConfig.valueByKey | getValueByKeyFromObject : item\"\n (mouseup)=\"optionClick(item)\"\n (mousedown)=\"preventDefault($event)\"\n [disabled]=\"selectConfig?.changeText[item].disabled\">\n {{ selectConfig?.needTranslateOptions ? (selectConfig?.changeText[item].text | translate ) : selectConfig?.changeText[item].text}}\n </mat-option>\n </ng-container>\n </ng-container>\n\n <!-- Empty State -->\n <ng-container *ngIf=\"!pending && !data.length\">\n <mat-option disabled class=\"empty_selection_state\">\n <div class=\"actions_and_tile add_new flex_column w-100 flex_center_align_center\">\n <span>{{ 'dropdown_no_items' | translate }}</span>\n <div class=\"mt-10\">\n <i-tech-button\n *ngIf=\"selectConfig?.actions\"\n [type]=\"ButtonType.OUTLINE\"\n (buttonClick)=\"closePanelAndUnsetFocus();addNewItemEvent()\"\n [customClass]=\"'mat-autocomplete-select-button'\"\n [fontIcon]=\"'add'\"\n [text]=\"('dropdown_add_item' | translate : {INPUT_NAME: (selectConfig.label | translate)}) \">\n </i-tech-button>\n </div>\n </div>\n </mat-option>\n </ng-container>\n </mat-select>\n <mat-icon *ngIf=\"selectConfig.iconPrefix\"\n matPrefix\n [ngClass]=\"{\n 'readonly-color' : !selectConfig['iconPrefixColor']\n && (selectConfig.readOnly || ngControl.control.disabled),\n 'default-form-icon-color' : !selectConfig['iconPrefixColor']\n && !(selectConfig.readOnly || ngControl.control.disabled)\n }\"\n [matTooltip]=\"((selectConfig?.['iconPrefixTooltip'] || '') | translate)\"\n >{{ selectConfig.iconPrefix }}\n </mat-icon>\n\n <mat-icon *ngIf=\"selectConfig['iconPrefixSvg']\"\n matPrefix\n [matTooltip]=\"((selectConfig?.['iconPrefixTooltip'] || '') | translate)\"\n [svgIcon]=\"selectConfig['iconPrefixSvg'] || ''\"\n ></mat-icon>\n\n <i-tech-icon-button\n *ngIf=\"selectConfig.search && selectConfig.clearable && !ngControl.control.disabled && !!ngControl.control.value\"\n iconName=\"cancel\"\n matSuffix\n [disabled]=\"selectConfig.readOnly || false\"\n [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\n (click)=\"\n $event.stopPropagation();\n $event.preventDefault();\n ngControl.control.reset(null);\n matSelect._onBlur();\n closePanelAndUnsetFocus()\n \"\n >\n </i-tech-icon-button>\n <mat-icon\n matSuffix\n class=\"select-arrow\"\n [class.open]=\"matSelect.panelOpen\"\n [ngClass]=\"{\n 'readonly-color': selectConfig.readOnly || ngControl.control.disabled,\n 'default-form-icon-color': !(selectConfig.readOnly || ngControl.control.disabled),\n 'mt-8': !!ngControl.control.value && selectConfig.clearable\n }\"\n >\n keyboard_arrow_down\n </mat-icon>\n <!-- Error Message -->\n <mat-error *ngIf=\"!!(ngControl.control.errors && submitValue)\">\n {{ ngControl.control | generateErrorMessages : selectConfig.label : selectConfig.defaultPatternKey }}\n </mat-error>\n </mat-form-field>\n\n <!-- Reset Button -->\n <i-tech-clear-value *ngIf=\"selectConfig.reset\" (resetValue)=\"resetValue()\"></i-tech-clear-value>\n</div>\n", styles: [".left_icon_new{position:absolute;right:2px;top:1px}::ng-deep .request_loading{width:40px;height:40px;background-color:#fff!important}::ng-deep .request_loading:hover{background-color:var(--primary99)!important}::ng-deep .request_loading:focus{background-color:var(--primary99)!important}::ng-deep .request_loading img{position:absolute;left:50%;top:50%;width:100%;height:100%;transform:translate(-50%,-50%)}::ng-deep .mat-mdc-option.add_new{opacity:1!important;pointer-events:auto!important}::ng-deep .mat-mdc-option.add_new .mat-pseudo-checkbox{display:none!important}::ng-deep .mat-mdc-option.add_new .mdc-list-item__primary-text{display:inline-block!important;width:100%!important}::ng-deep .mat-mdc-option.add_new span{color:unset!important;font-size:unset!important;margin:unset!important;opacity:1!important}@media (min-width: 1920px) and (max-width: 2500px){.mat-autocomplete{height:90px!important}}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "component", type: IconButtonComponent, selector: "i-tech-icon-button", inputs: ["size", "type", "iconSvg", "iconName", "tooltip", "disabled"], outputs: ["buttonClick"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "component", type: ButtonComponent, selector: "i-tech-button", inputs: ["text", "data_cy", "fontIcon", "svgIcon", "type", "customClass", "submit", "disabled", "activated", "color"], outputs: ["buttonClick"] }, { kind: "pipe", type: GetValueByKeyFromObjectPipe, name: "getValueByKeyFromObject" }, { kind: "pipe", type: ArrayToStringPipe, name: "arrayToString" }, { kind: "directive", type: NgOptimizedImage, selector: "img[ngSrc]", inputs: ["ngSrc", "ngSrcset", "sizes", "width", "height", "loading", "priority", "loaderParams", "disableOptimizedSrcset", "fill", "placeholder", "placeholderConfig", "src", "srcset"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: GenerateErrorMessagesPipe, name: "generateErrorMessages" }, { kind: "component", type: ClearValueComponent, selector: "i-tech-clear-value", inputs: ["className", "additionalClass"], outputs: ["resetValue"] }, { kind: "ngmodule", type: MatFormFieldModule }] }); }
374
+ }
375
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AutocompleteSelectComponent, decorators: [{
376
+ type: Component,
377
+ args: [{ selector: 'i-tech-autocomplete-select', imports: [
378
+ NgClass,
379
+ MatTooltip,
380
+ NgIf,
381
+ NgFor,
382
+ TranslateModule,
383
+ IconButtonComponent,
384
+ ReactiveFormsModule,
385
+ MatSelectModule,
386
+ ButtonComponent,
387
+ GetValueByKeyFromObjectPipe,
388
+ ArrayToStringPipe,
389
+ NgOptimizedImage,
390
+ MatIcon,
391
+ GenerateErrorMessagesPipe,
392
+ ClearValueComponent,
393
+ MatFormFieldModule
394
+ ], standalone: true, template: "<div class=\"new-mat-autocomplete\" id=\"mat_autocomplete\"\n [ngClass]=\"{\n 'mat-select-without_icon': !selectConfig.iconUrl && !selectConfig.activeStateIconUrl,\n 'mat-select-with-search': selectConfig.search,\n 'without-label': selectConfig.hideLabel,\n 'invalid_field': ngControl.control.errors && submitValue,\n 'readonly-field': selectConfig.readOnly || ngControl.control.disabled\n }\"\n [matTooltip]=\"(selectConfig.hover && !ngControl.control.disabled ? ((selectConfig.hover || '') | translate) : '')\"\n [matTooltipClass]=\"'mat-mdc-tooltip big-td-mat-tooltip'\"\n [matTooltipPosition]=\"'above'\"\n *ngIf=\"selectConfig && ngControl\">\n\n <div class=\"w-100\" *ngIf=\"!selectConfig.hideLabel\">\n <mat-label [ngClass]=\"{\n 'readonly-color' : selectConfig.readOnly || ngControl.control.disabled,\n 'invalid-label-color': !!(ngControl.control.errors && submitValue)\n }\">\n {{ selectConfig.label | translate }}\n </mat-label>\n <span *ngIf=\"selectConfig.required\" class=\"required-input\"\n [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\">*</span>\n </div>\n\n\n <!-- Search Input -->\n <div class=\"search-input w-100\"\n (click)=\"$event.stopPropagation();$event.preventDefault()\"\n [ngClass]=\"{ hide_input_placeholder: showPlaceholder || ngControl.control.disabled }\"\n *ngIf=\"selectConfig.search\"\n >\n <input autocomplete=\"off\"\n id=\"searchInput\"\n type=\"text\"\n [ngClass]=\"{'pr-25': !selectConfig.iconUrl}\"\n #searchInput\n [disabled]=\"ngControl.control.disabled || selectConfig.hover\"\n [placeholder]=\"(ngControl.control.disabled || selectConfig.hover) ? '' : 'Search'\"\n (focusout)=\"inputFocusOut()\"\n (focus)=\"openSelection()\"\n (keydown)=\"$event.stopPropagation()\"\n (keyup)=\"getDataWithSearch(searchInput.value,$event)\">\n\n <!-- Search Icon -->\n <span class=\"search-icon\">\n <i-tech-icon-button\n class=\"mr-10\"\n [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color'\n : 'default-form-icon-color'\"\n *ngIf=\"selectConfig.iconPrefix && !showPlaceholder\"\n [iconName]=\"selectConfig.iconPrefix || ''\"\n [disabled]=\"selectConfig.readOnly || false\"\n matPrefix\n >\n </i-tech-icon-button>\n </span>\n </div>\n\n <!-- Placeholder/Selected Value Display -->\n <ng-container *ngIf=\"showPlaceholder && selectConfig.search\">\n <div class=\"custom-placeholder\"\n *ngIf=\"(!ngControl?.value && !ngControl?.value?.length) ||\n (selectConfig.multiple && ngControl?.value && !ngControl?.value?.length)\"\n [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\n >\n {{ ((selectConfig.placeholder || '') | translate) }}\n </div>\n <div class=\"custom-placeholder custom-value ellipsis\"\n [ngClass]=\"{\n 'pr-42': selectConfig.iconUrl,\n 'readonly-color': selectConfig.readOnly || ngControl.control.disabled,\n 'default-form-icon-color': !(selectConfig.readOnly || ngControl.control.disabled)\n }\"\n *ngIf=\"ngControl?.value\"\n >\n {{ selectConfig?.multiple ? (ngControl.value | arrayToString) : showingValue }}\n </div>\n </ng-container>\n\n <!-- Custom Icon -->\n <img class=\"left_icon_new pointer\"\n alt=\"Toggle Selection\"\n (click)=\"iconClick(matSelect, searchInput)\"\n *ngIf=\"!selectConfig.matIconName && (selectConfig.iconUrl || selectConfig.activeStateIconUrl)\"\n [src]=\"'assets/images/icons/global/' + (ngControl.control?.value && selectConfig?.activeStateIconUrl ?\n selectConfig.activeStateIconUrl\n : selectConfig.iconUrl)\">\n\n <mat-form-field appearance=\"outline\" class=\"w-100\" (click)=\"selectConfig?.search ? focusSearchInput() : null\">\n <!-- Material Select -->\n <mat-select #matSelect=\"matSelect\"\n [panelClass]=\"'autocomplete-transform-panel-location'\"\n [attr.aria-placeholder]=\"(selectConfig.placeholder || '') | translate\"\n [aria-label]=\"selectConfig.label | translate\"\n [id]=\"selectConfig.filtrationKey || ''\"\n (opened)=\"registerPanelScrollEvent(matSelect)\"\n (openedChange)=\"openedChange($event)\"\n [formControl]=\"ngControl.control\"\n [multiple]=\"selectConfig.multiple\"\n (selectionChange)=\"emitSelectionChangeAndClose($event)\"\n [errorStateMatcher]=\"customErrorStateMatcher\"\n [placeholder]=\"(selectConfig.placeholder || '') | translate\"\n [disabled]=\"ngControl.control.disabled\"\n >\n\n <!-- Loading State -->\n <mat-option *ngIf=\"pending\" class=\"option_loading relative\">\n <div class=\"request_loading\">\n <img ngSrc=\"./loader.svg\" alt=\"\" height=\"200\" width=\"200\"/>\n </div>\n </mat-option>\n\n <!-- Options -->\n <ng-container *ngIf=\"data?.length && !pending\">\n <!-- Add New Option -->\n <mat-option *ngIf=\"selectConfig.actions\"\n class=\"pointer add_new\"\n disabled\n (click)=\"closePanelAndUnsetFocus();addNewItemEvent()\">\n <!--(click)=\"ngControl.control.reset(null);\n matSelect._onBlur();closePanelAndUnsetFocus();addNewItemEvent()\">-->\n <i-tech-button\n [type]=\"ButtonType.OUTLINE\"\n [fontIcon]=\"'add'\"\n [text]=\"('dropdown_add_item' | translate : {INPUT_NAME: (selectConfig.label | translate)}) \"\n [customClass]=\"'w-100 mat-autocomplete-select-button'\">\n </i-tech-button>\n </mat-option>\n\n <!-- Regular Options -->\n <ng-container *ngIf=\"!selectConfig?.changeText && data.length\">\n <mat-option *ngFor=\"let item of data\"\n [value]=\"selectConfig.valueByKey | getValueByKeyFromObject : item\"\n (mouseup)=\"optionClick(item)\"\n (mousedown)=\"preventDefault($event)\">\n @if (selectConfig?.needTranslateOptions) {\n {{\n ((selectConfig.valueToShowByKey | getValueByKeyFromObject\n : item : selectConfig.valueToShowByParam : selectConfig.withParamSymbol) || '') | translate\n }}\n }@else {\n {{\n ((selectConfig.valueToShowByKey | getValueByKeyFromObject\n : item : selectConfig.valueToShowByParam : selectConfig.withParamSymbol) || '')\n }}\n }\n\n </mat-option>\n </ng-container>\n\n <!-- Custom Text Options -->\n <ng-container *ngIf=\"selectConfig?.changeText && data.length\">\n <mat-option *ngFor=\"let item of data\"\n [value]=\"selectConfig.valueByKey | getValueByKeyFromObject : item\"\n (mouseup)=\"optionClick(item)\"\n (mousedown)=\"preventDefault($event)\"\n [disabled]=\"selectConfig?.changeText[item].disabled\">\n {{ selectConfig?.needTranslateOptions ? (selectConfig?.changeText[item].text | translate ) : selectConfig?.changeText[item].text}}\n </mat-option>\n </ng-container>\n </ng-container>\n\n <!-- Empty State -->\n <ng-container *ngIf=\"!pending && !data.length\">\n <mat-option disabled class=\"empty_selection_state\">\n <div class=\"actions_and_tile add_new flex_column w-100 flex_center_align_center\">\n <span>{{ 'dropdown_no_items' | translate }}</span>\n <div class=\"mt-10\">\n <i-tech-button\n *ngIf=\"selectConfig?.actions\"\n [type]=\"ButtonType.OUTLINE\"\n (buttonClick)=\"closePanelAndUnsetFocus();addNewItemEvent()\"\n [customClass]=\"'mat-autocomplete-select-button'\"\n [fontIcon]=\"'add'\"\n [text]=\"('dropdown_add_item' | translate : {INPUT_NAME: (selectConfig.label | translate)}) \">\n </i-tech-button>\n </div>\n </div>\n </mat-option>\n </ng-container>\n </mat-select>\n <mat-icon *ngIf=\"selectConfig.iconPrefix\"\n matPrefix\n [ngClass]=\"{\n 'readonly-color' : !selectConfig['iconPrefixColor']\n && (selectConfig.readOnly || ngControl.control.disabled),\n 'default-form-icon-color' : !selectConfig['iconPrefixColor']\n && !(selectConfig.readOnly || ngControl.control.disabled)\n }\"\n [matTooltip]=\"((selectConfig?.['iconPrefixTooltip'] || '') | translate)\"\n >{{ selectConfig.iconPrefix }}\n </mat-icon>\n\n <mat-icon *ngIf=\"selectConfig['iconPrefixSvg']\"\n matPrefix\n [matTooltip]=\"((selectConfig?.['iconPrefixTooltip'] || '') | translate)\"\n [svgIcon]=\"selectConfig['iconPrefixSvg'] || ''\"\n ></mat-icon>\n\n <i-tech-icon-button\n *ngIf=\"selectConfig.search && selectConfig.clearable && !ngControl.control.disabled && !!ngControl.control.value\"\n iconName=\"cancel\"\n matSuffix\n [disabled]=\"selectConfig.readOnly || false\"\n [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\n (click)=\"\n $event.stopPropagation();\n $event.preventDefault();\n ngControl.control.reset(null);\n matSelect._onBlur();\n closePanelAndUnsetFocus()\n \"\n >\n </i-tech-icon-button>\n <mat-icon\n matSuffix\n class=\"select-arrow\"\n [class.open]=\"matSelect.panelOpen\"\n [ngClass]=\"{\n 'readonly-color': selectConfig.readOnly || ngControl.control.disabled,\n 'default-form-icon-color': !(selectConfig.readOnly || ngControl.control.disabled),\n 'mt-8': !!ngControl.control.value && selectConfig.clearable\n }\"\n >\n keyboard_arrow_down\n </mat-icon>\n <!-- Error Message -->\n <mat-error *ngIf=\"!!(ngControl.control.errors && submitValue)\">\n {{ ngControl.control | generateErrorMessages : selectConfig.label : selectConfig.defaultPatternKey }}\n </mat-error>\n </mat-form-field>\n\n <!-- Reset Button -->\n <i-tech-clear-value *ngIf=\"selectConfig.reset\" (resetValue)=\"resetValue()\"></i-tech-clear-value>\n</div>\n", styles: [".left_icon_new{position:absolute;right:2px;top:1px}::ng-deep .request_loading{width:40px;height:40px;background-color:#fff!important}::ng-deep .request_loading:hover{background-color:var(--primary99)!important}::ng-deep .request_loading:focus{background-color:var(--primary99)!important}::ng-deep .request_loading img{position:absolute;left:50%;top:50%;width:100%;height:100%;transform:translate(-50%,-50%)}::ng-deep .mat-mdc-option.add_new{opacity:1!important;pointer-events:auto!important}::ng-deep .mat-mdc-option.add_new .mat-pseudo-checkbox{display:none!important}::ng-deep .mat-mdc-option.add_new .mdc-list-item__primary-text{display:inline-block!important;width:100%!important}::ng-deep .mat-mdc-option.add_new span{color:unset!important;font-size:unset!important;margin:unset!important;opacity:1!important}@media (min-width: 1920px) and (max-width: 2500px){.mat-autocomplete{height:90px!important}}\n"] }]
395
+ }], ctorParameters: () => [{ type: i1.InputService }], propDecorators: { matSelect: [{
396
+ type: ViewChild,
397
+ args: ['matSelect']
398
+ }], searchInput: [{
399
+ type: ViewChild,
400
+ args: ['searchInput']
401
+ }], className: [{
402
+ type: Input
403
+ }], submitValue: [{
404
+ type: Input
405
+ }], configs: [{
406
+ type: Input
407
+ }], detectChanges: [{
408
+ type: Input
409
+ }], selectionChange: [{
410
+ type: Output
411
+ }], emitAction: [{
412
+ type: Output
413
+ }], allSelected: [{
414
+ type: ViewChild,
415
+ args: ['allSelected']
416
+ }], handleVisibilityChange: [{
417
+ type: HostListener,
418
+ args: ['document:visibilitychange']
419
+ }] } });
420
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-select.component.js","sourceRoot":"","sources":["../../../../../../projects/shared-components/src/lib/components/autocomplete-select/autocomplete-select.component.ts","../../../../../../projects/shared-components/src/lib/components/autocomplete-select/autocomplete-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewChild,\n  Input,\n  Output,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  ElementRef, HostListener, AfterViewInit\n} from '@angular/core';\nimport { MatSelect, MatSelectModule } from \"@angular/material/select\";\nimport { AutocompleteConfigsInterface } from \"../../interfaces/autocomplete-configs.interface\";\nimport { FormControlName, ReactiveFormsModule } from \"@angular/forms\";\nimport { InputService } from '../../services/input.service';\nimport { ButtonType } from '../../interfaces/button-types.enum';\nimport { NgClass, NgFor, NgIf, NgOptimizedImage } from \"@angular/common\";\nimport { MatTooltip } from \"@angular/material/tooltip\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { IconButtonComponent } from \"../icon-button/icon-button.component\";\nimport { ButtonComponent } from \"../button/button.component\";\nimport { GetValueByKeyFromObjectPipe } from \"../../pipes/get-value-by-key-from-object.pipe\";\nimport { ArrayToStringPipe } from \"../../pipes/array-to-string.pipe\";\nimport { MatIcon } from \"@angular/material/icon\";\nimport { GenerateErrorMessagesPipe } from \"../../pipes/generate-error-messages.pipe\";\nimport { ClearValueComponent } from \"../clear-value/clear-value.component\";\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\n\n@Component({\n  selector: 'i-tech-autocomplete-select',\n  templateUrl: './autocomplete-select.component.html',\n  styleUrls: ['./autocomplete-select.component.scss'],\n  imports: [\n    NgClass,\n    MatTooltip,\n    NgIf,\n    NgFor,\n    TranslateModule,\n    IconButtonComponent,\n    ReactiveFormsModule,\n    MatSelectModule,\n    ButtonComponent,\n    GetValueByKeyFromObjectPipe,\n    ArrayToStringPipe,\n    NgOptimizedImage,\n    MatIcon,\n    GenerateErrorMessagesPipe,\n    ClearValueComponent,\n    MatFormFieldModule\n  ],\n  standalone: true\n})\nexport class AutocompleteSelectComponent implements OnChanges, AfterViewInit {\n  @ViewChild('matSelect') matSelect!: MatSelect;\n  @ViewChild('searchInput') searchInput!: ElementRef;\n  @Input() className!: string;\n  @Input() submitValue!: boolean;\n\n  /**\n   * See AutocompleteConfigsInterface for available configurations.\n   */\n  @Input() set configs(data: AutocompleteConfigsInterface) {\n    this.selectConfig = data;\n    if (!data) {\n      return;\n    }\n\n    if ((typeof this.selectConfig.paginate) === 'function') {\n      if (this.firstRequest) {\n        return;\n      }\n      this.getData();\n      this.firstRequest = true\n      return;\n    }\n\n    this.data = this.selectConfig.paginate;\n    this.findAndSetDefaultValueFromData();\n  };\n\n  @Input() detectChanges!: boolean;\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() emitAction = new EventEmitter<any>();\n  @ViewChild('allSelected') allSelected!: MatSelect;\n  pending = false;\n  defaultValue!: any;\n  data: Array<any> = [];\n  paginationData: any = { current: 1, last: 0 };\n  ngControl: FormControlName;\n  selectConfig!: AutocompleteConfigsInterface;\n  firstRequest = false;\n  showPlaceholder = true;\n  isNeededForRecall = false;\n  showingValue: any;\n  searchTimeoutId: any;\n  tabVisibility!: boolean;\n  accessToNextRequest = true;\n  disabled = false;\n  blockRecallDefaultValueSetter = false;\n  baseData: any;\n  requestLoading = false;\n  protected readonly ButtonType = ButtonType;\n\n  @HostListener('document:visibilitychange')\n  handleVisibilityChange(): void {\n    this.tabVisibility = !document.hidden;\n    if (this.ngControl.control.value) {\n      return;\n    }\n    this.closePanelAndUnsetFocus();\n    if (!document.hidden) {\n      this.isNeededForRecall = true;\n      this.pending = true;\n      setTimeout(() => {\n        this.pending = false\n      }, 4000)\n    }\n  }\n\n  constructor(private inputService: InputService) {\n    this.ngControl = this.inputService.injectNgControl();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['selectConfig'] && this.selectConfig) {\n      if ((typeof this.selectConfig.paginate) === 'function') {\n        this.getData();\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    this.ngControl.control.valueChanges.subscribe((res: any) => {\n      if (this.data.length && res && !this.blockRecallDefaultValueSetter) {\n        this.findAndSetDefaultValueFromData();\n      }\n    })\n  }\n\n  hardReload(): void {\n    this.getData('', true);\n  }\n\n  /**\n   * Dynamic request for select data.\n   * @param searchText - The input value to search options by.\n   * @param fromSearch - Access for search.\n   * @returns Select data.\n   */\n  getData(searchText?: string, fromSearch?: boolean): void {\n    if (!fromSearch && !this.accessToNextRequest) {\n      return;\n    }\n\n    if (this.requestLoading) {\n      return;\n    }\n\n    if (fromSearch) {\n      this.paginationData.current = 1;\n      this.accessToNextRequest = true;\n    }\n\n    const functionToDo = this.selectConfig.paginate(this.paginationData.current, searchText);\n\n    this.requestLoading = true;\n    functionToDo?.subscribe((data: Array<any> | any) => {\n      const dataToAdd = ('content' in data) ? data.content : data;\n\n      if ('content' in data) {\n        this.accessToNextRequest = !data.last || (data.totalPages > this.paginationData.current);\n      }\n\n      this.data = (fromSearch || this.selectConfig?.blockPagination) ? dataToAdd : [...this.data, ...dataToAdd];\n      this.pending = false;\n      this.requestLoading = false;\n\n      if (!dataToAdd.length) {\n        this.paginationData.last = this.paginationData.current;\n        return;\n      }\n\n      this.paginationData.current += 1;\n      this.paginationData.last += 1;\n      setTimeout(() => {\n        this.findAndSetDefaultValueFromData();\n      }, 10)\n    }, () => {\n      this.pending = false;\n      this.requestLoading = false;\n    })\n  }\n\n  findAndSetDefaultValueFromData(): void {\n    if (this.selectConfig.multiple) {\n      if (this.ngControl.value && this.ngControl.value.length == 1) {\n        this.setShowingValue(this.data.find((item) => item.id === this.ngControl.value[0]))\n      }\n    } else {\n      const isDisabled = this.ngControl.disabled;\n      if (isDisabled) {\n        // TODO Remove after migrating all selects\n        // this.ngControl.control.enable();\n        // if (!this.ngControl.value && !this.data.length) {\n        //     this.ngControl.control.disable();\n        //     return;\n        // }\n        // this.setDefaultValue();\n        // this.ngControl.control.disable();\n      } else {\n        if (!this.ngControl.value && !this.data) {\n          return;\n        }\n        this.setDefaultValue();\n      }\n\n    }\n  }\n\n  setDefaultValue(): void {\n    this.defaultValue = this.data.find((item) => item.id === this.ngControl.value);\n    this.baseData = this.defaultValue\n    if (!this.defaultValue) {\n      return;\n    }\n    this.selectionChange.emit()\n    this.setShowingValue(this.defaultValue);\n  }\n\n  optionClick(showingData: any): void {\n    this.baseData = showingData\n    if (!this.selectConfig.multiple) {\n      this.setShowingValue(showingData);\n      this.matSelect.close();\n      return;\n    }\n    if (this.searchInput) {\n      if (this.selectConfig.multiple) {\n        this.searchInput?.nativeElement?.focus()\n      } else {\n        this.inputFocusOut();\n      }\n    }\n\n    this.setShowingValue(showingData);\n    this.showPlaceholder = false;\n  }\n\n  addNewItemEvent(): void {\n    this.isNeededForRecall = true;\n    this.emitAction.emit();\n  }\n\n  /**\n   * Filter and show.\n   * @param data - Existing chosen data.\n   */\n  setShowingValue(data: any): void {\n    if (!data) {\n      return;\n    }\n    // TODO refactor this part fully\n    let include = data;\n    let includeOptional = data;\n\n    if (this.selectConfig.valueToShowByKey) {\n      this.selectConfig.valueToShowByKey.forEach((param: Array<string | number> | string) => {\n\n        if (typeof param === 'object') {\n          param.forEach((key: string | number) => {\n            include = (include) ? include[key] : null;\n          })\n        } else {\n          include = include[param];\n        }\n      })\n      if (this.selectConfig.showFullTextWithOptionalOnSelectedValue) {\n        this.selectConfig.valueToShowByParam?.forEach((param: Array<string | number> | string) => {\n\n          if (typeof param === 'object') {\n            param.forEach((key: string | number) => {\n              includeOptional = (includeOptional) ? includeOptional[key] : null;\n            })\n          } else {\n            includeOptional = includeOptional[param];\n          }\n        })\n        if (this.selectConfig.valueToShowByParam && typeof includeOptional === 'string') {\n          include += (this.selectConfig.withParamSymbol || '') + includeOptional\n        }\n      }\n\n    }\n    this.showingValue = include;\n    this.blockRecallDefaultValueSetter = true;\n  }\n\n  /**\n   * Block another events.\n   * @param event - Element click event.\n   */\n  preventDefault(event: any) {\n    if (!this.selectConfig.multiple) {\n      return;\n    }\n    event.preventDefault()\n  }\n\n  registerPanelScrollEvent(element: MatSelect) {\n    if (this.selectConfig.paginateOnScroll === false) {\n      return;\n    }\n\n    const panel = element.panel.nativeElement;\n    panel.addEventListener('scroll', (event: any) => this.loadDataOnScroll(event));\n  }\n\n  loadDataOnScroll(event: any) {\n    const pos = (event.target.scrollTop || event.target.scrollTop) + event.target.offsetHeight;\n    const max = event.target.scrollHeight;\n    if ((pos + 1) >= max) {\n      if (this.paginationData.current === this.paginationData.last || this.selectConfig.blockPagination) {\n        return;\n      }\n      this.getData();\n    }\n  }\n\n  focusSearchInput() {\n    if (this.selectConfig.search && this.searchInput) {\n      this.searchInput.nativeElement.focus();\n    }\n  }\n\n  inputFocusOut(): void {\n    this.isNeededForRecall = !!this.searchInput.nativeElement.value;\n    this.searchInput.nativeElement.value = '';\n    this.showPlaceholder = true;\n    this.clearTimeoutForSearch();\n  }\n\n  resetValue(): void {\n    this.selectionChange.emit(null);\n    this.ngControl.reset(null);\n    this.inputFocusOut();\n  }\n\n  getDataWithSearch(value: any, event: any): void {\n    this.clearTimeoutForSearch();\n    if (value.length >= 1) {\n      this.searchTimeoutId = setTimeout(() => {\n        this.getData(value, true)\n      }, 800);\n    } else if (value.length <= 1 && event.keyCode === 8) {\n      this.getData(value, true)\n    }\n  }\n\n  clearTimeoutForSearch(): void {\n    if (this.searchTimeoutId) {\n      clearTimeout(this.searchTimeoutId);\n      this.searchTimeoutId = 0;\n    }\n  }\n\n  openSelection(): void {\n    if (this.selectConfig.disabled || this.ngControl.control.disabled) {\n      return;\n    }\n    if (this.showPlaceholder) {\n      this.matSelect.open();\n    } else {\n      this.closePanelAndUnsetFocus();\n    }\n    this.showPlaceholder = !this.showPlaceholder;\n    if (!this.showPlaceholder) {\n      this.reCallData();\n    }\n  }\n\n  closePanelAndUnsetFocus(): void {\n    this.matSelect.close();\n    if (this.searchInput) {\n      this.searchInput.nativeElement.blur()\n    }\n  }\n\n  openedChange(event: any) {\n    if (event) {\n      if (this.isNeededForRecall) {\n        this.reCallData();\n        return;\n      }\n      if (!this.selectConfig.search) {\n        this.pending = false\n        this.reCallData();\n      }\n\n      return;\n    }\n\n    this.showPlaceholder = true;\n  }\n\n  reCallData(): void {\n    // TODO refactor this part\n    if (!this.isNeededForRecall) {\n      return;\n    }\n    this.data = [];\n    this.pending = true;\n    this.paginationData = {\n      current: 1,\n      last: 0\n    };\n    this.accessToNextRequest = true;\n    if ((typeof this.selectConfig.paginate) === 'function') {\n      this.getData();\n    } else {\n      this.pending = false;\n      this.data = this.selectConfig.paginate;\n    }\n    this.isNeededForRecall = false;\n  }\n\n  emitSelectionChangeAndClose(event: any) {\n    this.selectionChange.emit(event.value);\n    if (this.selectConfig.multiple) {\n      if (!event.value?.length) {\n        this.ngControl.control.reset();\n      }\n      return;\n    }\n    this.matSelect.close();\n  }\n\n  /*\n   * Open mat-select and focus on search on icon click\n   */\n  iconClick(matSelect: MatSelect, searchInput?: ElementRef): void {\n    matSelect.open();\n    searchInput?.nativeElement?.focus();\n  }\n\n  /*\n  * Custom error state matcher for mat-select to properly show error state in mat-form-field\n   */\n  customErrorStateMatcher = {\n    isErrorState: (control: any, form: any): boolean => {\n      return !!(control && control.invalid && this.submitValue);\n    }\n  };\n}\n","<div class=\"new-mat-autocomplete\" id=\"mat_autocomplete\"\n     [ngClass]=\"{\n            'mat-select-without_icon': !selectConfig.iconUrl && !selectConfig.activeStateIconUrl,\n            'mat-select-with-search': selectConfig.search,\n            'without-label': selectConfig.hideLabel,\n            'invalid_field': ngControl.control.errors && submitValue,\n            'readonly-field': selectConfig.readOnly || ngControl.control.disabled\n         }\"\n     [matTooltip]=\"(selectConfig.hover && !ngControl.control.disabled ? ((selectConfig.hover || '') | translate) : '')\"\n     [matTooltipClass]=\"'mat-mdc-tooltip big-td-mat-tooltip'\"\n     [matTooltipPosition]=\"'above'\"\n     *ngIf=\"selectConfig && ngControl\">\n\n  <div class=\"w-100\" *ngIf=\"!selectConfig.hideLabel\">\n    <mat-label [ngClass]=\"{\n          'readonly-color' : selectConfig.readOnly || ngControl.control.disabled,\n          'invalid-label-color': !!(ngControl.control.errors && submitValue)\n        }\">\n      {{ selectConfig.label | translate }}\n    </mat-label>\n    <span *ngIf=\"selectConfig.required\" class=\"required-input\"\n          [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\">*</span>\n  </div>\n\n\n  <!-- Search Input -->\n  <div class=\"search-input w-100\"\n       (click)=\"$event.stopPropagation();$event.preventDefault()\"\n       [ngClass]=\"{ hide_input_placeholder: showPlaceholder || ngControl.control.disabled }\"\n       *ngIf=\"selectConfig.search\"\n  >\n    <input autocomplete=\"off\"\n           id=\"searchInput\"\n           type=\"text\"\n           [ngClass]=\"{'pr-25': !selectConfig.iconUrl}\"\n           #searchInput\n           [disabled]=\"ngControl.control.disabled || selectConfig.hover\"\n           [placeholder]=\"(ngControl.control.disabled || selectConfig.hover) ? '' : 'Search'\"\n           (focusout)=\"inputFocusOut()\"\n           (focus)=\"openSelection()\"\n           (keydown)=\"$event.stopPropagation()\"\n           (keyup)=\"getDataWithSearch(searchInput.value,$event)\">\n\n    <!-- Search Icon -->\n    <span class=\"search-icon\">\n            <i-tech-icon-button\n              class=\"mr-10\"\n              [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color'\n                                                                              : 'default-form-icon-color'\"\n              *ngIf=\"selectConfig.iconPrefix && !showPlaceholder\"\n              [iconName]=\"selectConfig.iconPrefix || ''\"\n              [disabled]=\"selectConfig.readOnly || false\"\n              matPrefix\n            >\n            </i-tech-icon-button>\n        </span>\n  </div>\n\n  <!-- Placeholder/Selected Value Display -->\n  <ng-container *ngIf=\"showPlaceholder && selectConfig.search\">\n    <div class=\"custom-placeholder\"\n         *ngIf=\"(!ngControl?.value && !ngControl?.value?.length) ||\n                 (selectConfig.multiple && ngControl?.value && !ngControl?.value?.length)\"\n         [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\n    >\n      {{ ((selectConfig.placeholder || '') | translate) }}\n    </div>\n    <div class=\"custom-placeholder custom-value ellipsis\"\n         [ngClass]=\"{\n                'pr-42': selectConfig.iconUrl,\n                'readonly-color': selectConfig.readOnly || ngControl.control.disabled,\n                'default-form-icon-color': !(selectConfig.readOnly || ngControl.control.disabled)\n                }\"\n         *ngIf=\"ngControl?.value\"\n    >\n      {{ selectConfig?.multiple ? (ngControl.value | arrayToString) : showingValue }}\n    </div>\n  </ng-container>\n\n  <!-- Custom Icon -->\n  <img class=\"left_icon_new pointer\"\n       alt=\"Toggle Selection\"\n       (click)=\"iconClick(matSelect, searchInput)\"\n       *ngIf=\"!selectConfig.matIconName && (selectConfig.iconUrl || selectConfig.activeStateIconUrl)\"\n       [src]=\"'assets/images/icons/global/' + (ngControl.control?.value && selectConfig?.activeStateIconUrl ?\n                                                selectConfig.activeStateIconUrl\n                                                : selectConfig.iconUrl)\">\n\n  <mat-form-field appearance=\"outline\" class=\"w-100\" (click)=\"selectConfig?.search ? focusSearchInput() : null\">\n    <!-- Material Select -->\n    <mat-select #matSelect=\"matSelect\"\n                [panelClass]=\"'autocomplete-transform-panel-location'\"\n                [attr.aria-placeholder]=\"(selectConfig.placeholder || '') | translate\"\n                [aria-label]=\"selectConfig.label | translate\"\n                [id]=\"selectConfig.filtrationKey || ''\"\n                (opened)=\"registerPanelScrollEvent(matSelect)\"\n                (openedChange)=\"openedChange($event)\"\n                [formControl]=\"ngControl.control\"\n                [multiple]=\"selectConfig.multiple\"\n                (selectionChange)=\"emitSelectionChangeAndClose($event)\"\n                [errorStateMatcher]=\"customErrorStateMatcher\"\n                [placeholder]=\"(selectConfig.placeholder || '') | translate\"\n                [disabled]=\"ngControl.control.disabled\"\n    >\n\n      <!-- Loading State -->\n      <mat-option *ngIf=\"pending\" class=\"option_loading relative\">\n        <div class=\"request_loading\">\n          <img ngSrc=\"./loader.svg\" alt=\"\" height=\"200\" width=\"200\"/>\n        </div>\n      </mat-option>\n\n      <!-- Options -->\n      <ng-container *ngIf=\"data?.length && !pending\">\n        <!-- Add New Option -->\n        <mat-option *ngIf=\"selectConfig.actions\"\n                    class=\"pointer add_new\"\n                    disabled\n                    (click)=\"closePanelAndUnsetFocus();addNewItemEvent()\">\n          <!--(click)=\"ngControl.control.reset(null);\n              matSelect._onBlur();closePanelAndUnsetFocus();addNewItemEvent()\">-->\n          <i-tech-button\n            [type]=\"ButtonType.OUTLINE\"\n            [fontIcon]=\"'add'\"\n            [text]=\"('dropdown_add_item' | translate : {INPUT_NAME: (selectConfig.label | translate)}) \"\n            [customClass]=\"'w-100 mat-autocomplete-select-button'\">\n          </i-tech-button>\n        </mat-option>\n\n        <!-- Regular Options -->\n        <ng-container *ngIf=\"!selectConfig?.changeText && data.length\">\n          <mat-option *ngFor=\"let item of data\"\n                      [value]=\"selectConfig.valueByKey | getValueByKeyFromObject : item\"\n                      (mouseup)=\"optionClick(item)\"\n                      (mousedown)=\"preventDefault($event)\">\n            @if (selectConfig?.needTranslateOptions) {\n              {{\n                ((selectConfig.valueToShowByKey | getValueByKeyFromObject\n                  : item : selectConfig.valueToShowByParam : selectConfig.withParamSymbol) || '') | translate\n              }}\n            }@else {\n              {{\n              ((selectConfig.valueToShowByKey | getValueByKeyFromObject\n                : item : selectConfig.valueToShowByParam : selectConfig.withParamSymbol) || '')\n              }}\n            }\n\n          </mat-option>\n        </ng-container>\n\n        <!-- Custom Text Options -->\n        <ng-container *ngIf=\"selectConfig?.changeText && data.length\">\n          <mat-option *ngFor=\"let item of data\"\n                      [value]=\"selectConfig.valueByKey | getValueByKeyFromObject : item\"\n                      (mouseup)=\"optionClick(item)\"\n                      (mousedown)=\"preventDefault($event)\"\n                      [disabled]=\"selectConfig?.changeText[item].disabled\">\n            {{ selectConfig?.needTranslateOptions ? (selectConfig?.changeText[item].text | translate ) : selectConfig?.changeText[item].text}}\n          </mat-option>\n        </ng-container>\n      </ng-container>\n\n      <!-- Empty State -->\n      <ng-container *ngIf=\"!pending && !data.length\">\n        <mat-option disabled class=\"empty_selection_state\">\n          <div class=\"actions_and_tile add_new flex_column w-100 flex_center_align_center\">\n            <span>{{ 'dropdown_no_items' | translate }}</span>\n            <div class=\"mt-10\">\n              <i-tech-button\n                *ngIf=\"selectConfig?.actions\"\n                [type]=\"ButtonType.OUTLINE\"\n                (buttonClick)=\"closePanelAndUnsetFocus();addNewItemEvent()\"\n                [customClass]=\"'mat-autocomplete-select-button'\"\n                [fontIcon]=\"'add'\"\n                [text]=\"('dropdown_add_item' | translate : {INPUT_NAME: (selectConfig.label | translate)}) \">\n              </i-tech-button>\n            </div>\n          </div>\n        </mat-option>\n      </ng-container>\n    </mat-select>\n    <mat-icon *ngIf=\"selectConfig.iconPrefix\"\n              matPrefix\n              [ngClass]=\"{\n                    'readonly-color' : !selectConfig['iconPrefixColor']\n                                        && (selectConfig.readOnly || ngControl.control.disabled),\n                    'default-form-icon-color' : !selectConfig['iconPrefixColor']\n                                        && !(selectConfig.readOnly || ngControl.control.disabled)\n                    }\"\n              [matTooltip]=\"((selectConfig?.['iconPrefixTooltip'] || '') | translate)\"\n    >{{ selectConfig.iconPrefix }}\n    </mat-icon>\n\n    <mat-icon *ngIf=\"selectConfig['iconPrefixSvg']\"\n              matPrefix\n              [matTooltip]=\"((selectConfig?.['iconPrefixTooltip'] || '') | translate)\"\n              [svgIcon]=\"selectConfig['iconPrefixSvg'] || ''\"\n    ></mat-icon>\n\n    <i-tech-icon-button\n      *ngIf=\"selectConfig.search && selectConfig.clearable && !ngControl.control.disabled && !!ngControl.control.value\"\n      iconName=\"cancel\"\n      matSuffix\n      [disabled]=\"selectConfig.readOnly || false\"\n      [ngClass]=\"selectConfig.readOnly || ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\n      (click)=\"\n        $event.stopPropagation();\n        $event.preventDefault();\n        ngControl.control.reset(null);\n        matSelect._onBlur();\n        closePanelAndUnsetFocus()\n      \"\n    >\n    </i-tech-icon-button>\n    <mat-icon\n      matSuffix\n      class=\"select-arrow\"\n      [class.open]=\"matSelect.panelOpen\"\n      [ngClass]=\"{\n            'readonly-color': selectConfig.readOnly || ngControl.control.disabled,\n            'default-form-icon-color': !(selectConfig.readOnly || ngControl.control.disabled),\n            'mt-8': !!ngControl.control.value && selectConfig.clearable\n         }\"\n    >\n      keyboard_arrow_down\n    </mat-icon>\n    <!-- Error Message -->\n    <mat-error *ngIf=\"!!(ngControl.control.errors && submitValue)\">\n      {{ ngControl.control | generateErrorMessages : selectConfig.label : selectConfig.defaultPatternKey }}\n    </mat-error>\n  </mat-form-field>\n\n  <!-- Reset Button -->\n  <i-tech-clear-value *ngIf=\"selectConfig.reset\" (resetValue)=\"resetValue()\"></i-tech-clear-value>\n</div>\n"]}